All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.com.ibm.as400.resource.ResourceMetaData Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: ResourceMetaData.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.resource;

import com.ibm.as400.access.AS400;
import com.ibm.as400.access.ExtendedIllegalArgumentException;
import java.io.Serializable;
import java.lang.reflect.Array;
import java.util.Enumeration;
import java.util.Hashtable;
import java.util.Vector;



/**
The ResourceMetaData class represents information about a
{@link com.ibm.as400.resource.Resource Resource}
or {@link com.ibm.as400.resource.ResourceList ResourceList}.
@deprecated Use packages com.ibm.as400.access and com.ibm.as400.access.list instead. 
**/
//
// Design notes:
//
// 1. I used the term "type" instead of "class" because Java won't let
//    me call a variable "class" and it won't let me call a method
//    getClass().
//
// 3. The design of this class is meant to leave the semantics of
//    the possible values to the resource implementation.  For example,
//    if there are different possible values depending on the
//    system level or languages installed, the resource is responsible
//    for generating that list on the fly and plugging it into the
//    ResourceMetaData object.
//
// 4. By default, the ResourceMetaData and possible values are always considered
//    to be applicable.  It is possible to define the entire ResourceMetaData or
//    possible values to be applicable only for certain levels.  The notion
//    of level is intentionally vague, and can be used to represent a release,
//    a set of features, etc.
//
public class ResourceMetaData
implements Serializable
{
  private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";




    static final long serialVersionUID = 4L;



    // Private data.
    private static ResourceLevel    defaultLevel_               = new ResourceLevel();

    private Object          id_;
    private Object          defaultValue_                       = null;
    private ResourceLevel   level_                              = null;
    private boolean         multipleAllowed_                    = false;
    private Hashtable       possibleValues_                     = new Hashtable();
    private Hashtable       possibleValuePresentations_         = new Hashtable();
    private Presentation    presentation_;
    private boolean         readOnly_;
    private Class           type_;
    private boolean         valueLimited_;



/**
Constructs a ResourceMetaData object for a read-only value with no
possible values.

@param id                               The ID.
@param type                             The type of value.
@param presentation                     The presentation information.
**/
    public ResourceMetaData(Object id,
                            Class type,
                            Presentation presentation)
    {
        this(id, type, true, null, null, false, false, presentation, null);
    }



/**
Constructs a ResourceMetaData object.

@param id                               The ID.
@param type                             The type of value.
@param readOnly                         true if the value is read-only,
                                        false if the value is writable.
@param possibleValues                   The possible values, or null if
                                        there are none.  All possible values must be
                                        of the correct type.
@param defaultValue                     The default value, or null if there is no
                                        default.
@param valueLimited                     true if the value is limited to
                                        the possible values, false if other values are
                                        allowed.
@param multipleAllowed                  true if multiple values are allowed.
@param presentation                     The presentation information.
@param possibleValuePresentations       The possible value presentations, or null
                                        if none.
**/
    public ResourceMetaData(Object id,
                            Class type,
                            boolean readOnly,
                            Object[] possibleValues,
                            Object defaultValue,
                            boolean valueLimited,
                            boolean multipleAllowed,
                            Presentation presentation,
                            Presentation[] possibleValuePresentations)
    {
        if (id == null)
            throw new NullPointerException("id");
        if (type == null)
            throw new NullPointerException("type");
        if (presentation == null)
            throw new NullPointerException("presentation");

        id_                 = id;
        defaultValue_       = defaultValue;
        level_              = defaultLevel_;
        type_               = type;
        readOnly_           = readOnly;
        valueLimited_       = valueLimited;
        multipleAllowed_    = multipleAllowed;
        presentation_       = presentation;

        if (possibleValues != null)
            setPossibleValues(possibleValues, null);

        if (defaultValue != null)
            validateValue(defaultValue);

        if (possibleValuePresentations != null) {
            if (possibleValues == null)
                throw new NullPointerException("possibleValues");
            if (possibleValuePresentations.length > possibleValues.length)
                throw new ExtendedIllegalArgumentException("possibleValuePresentations", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);

            for(int i = 0; i < possibleValuePresentations.length; ++i)
                possibleValuePresentations_.put(possibleValues[i], possibleValuePresentations[i]);
        }
    }



    private static boolean arrayCompare(byte[] a, byte[] b)
    {
        if (a.length != b.length)
            return false;
        for(int i = 0; i < a.length; ++i) {
            if (a[i] != b[i])
                return false;
        }
        return true;
    }


/**
Indicates if multiple values are allowed.  If this is
true, then values are expressed as arrays.

@return true if multiple values are allowed, false otherwise.
**/
    public boolean areMultipleAllowed()
    {
        return multipleAllowed_;
    }



/**
Returns the ID.

@return The ID.
**/
    public Object getID()
    {
        return id_;
    }



/**
Returns the default value.

@return The default value, or null if there is no default value.
**/
     public Object getDefaultValue()
    {
        return defaultValue_;
    }



/**
Returns the level for which this is supported.

@return The level for which this is supported.
**/
    public ResourceLevel getLevel()
    {
        return level_;
    }



/**
Returns the presentation information.

@return The presentation.
**/
     public Presentation getPresentation()
    {
        return presentation_;
    }



/**
Returns the possible values.  If the value is limited to the
possible values, then the value will always be
one of these values.

@return The possible values.  The array has zero elements if
        there are no possible values.
**/
    public Object[] getPossibleValues()
    {
        Object[] possibleValues = new Object[possibleValues_.size()];
        Enumeration values = possibleValues_.keys();
        int i = 0;
        while(values.hasMoreElements())
            possibleValues[i++] = values.nextElement();
        return possibleValues;
    }



/**
Returns the possible values that are valid for the specified
level.  If this value is limited to the possible values,
then the value will always be one of these values.

@param level    The level.
@return The possible values.  The array has zero elements if
        there are no possible values.
**/
    Object[] getPossibleValues(String level)
    {
        if (level == null)
            throw new NullPointerException("level");

        Vector possibleValuesV = new Vector(possibleValues_.size());
        Enumeration values = possibleValues_.keys();
        while(values.hasMoreElements()) {
            Object possibleValue = values.nextElement();
            ResourceLevel possibleValueLevel = (ResourceLevel)possibleValues_.get(possibleValue);
            if (possibleValueLevel.checkLevel(level))
                possibleValuesV.addElement(possibleValue);
        }

        Object[] possibleValues = new Object[possibleValuesV.size()];
        possibleValuesV.copyInto(possibleValues);
        return possibleValues;
    }



/**
Returns the presentation for a possible value.

@param possibleValue    The possible value.
@return The presentation for the possible value, or null if there
        is no presentation available for the possible value.
**/
    public Presentation getPossibleValuePresentation(Object possibleValue)
    {
        if (possibleValue == null)
            throw new NullPointerException("possibleValue");
        validateValue(possibleValue);

        if (possibleValuePresentations_.containsKey(possibleValue))
            return (Presentation)possibleValuePresentations_.get(possibleValue);
        else
            return null;
    }



/**
Returns the presentations for the possible values.

@return The presentations for the possible values.
        The array has zero elements if
        there are no possible values.
**/
    public Presentation[] getPossibleValuePresentations()
    {
        Object[] possibleValues = getPossibleValues();
        Presentation[] possibleValuePresentations = new Presentation[possibleValues.length];
        for(int i = 0; i < possibleValues.length; ++i)
            possibleValuePresentations[i] = getPossibleValuePresentation(possibleValues[i]);
        return possibleValuePresentations;
    }


/**
Returns the presentations for the possible values that
are valid for the specified level.

@param  level    The level.
@return The presentations for the possible values.
        The array has zero elements if
        there are no possible values.
**/
    Presentation[] getPossibleValuePresentations(String level)
    {
        if (level == null)
            throw new NullPointerException("level");

        Object[] possibleValues = getPossibleValues(level);
        Presentation[] possibleValuePresentations = new Presentation[possibleValues.length];
        for(int i = 0; i < possibleValues.length; ++i)
            possibleValuePresentations[i] = getPossibleValuePresentation(possibleValues[i]);
        return possibleValuePresentations;
    }




/**
Returns the type of value.
**/
    public Class getType()
    {
        return type_;
    }



/**
Indicates if the value is read-only.

@return true if the value is read-only,  false if
        the value is writable.
**/
    public boolean isReadOnly()
    {
        return readOnly_;
    }



/**
Indicates if the value is limited to the possible values.

@return          true if the value is limited to
                            the possible values, false if other values
                            are allowed.
**/
    public boolean isValueLimited()
    {
        return valueLimited_;
    }



/**
Sets the level for which this is valid.

@param level        The level for which this is valid, or null if this is
                    valid for all levels.
**/
    public void setLevel(ResourceLevel level)
    {
        if (level == null)
            level_ = defaultLevel_;
        else
            level_ = level;
    }



/**
Sets the possible values for a level.  If this value
is limited, then the value will always be one of these values.

@param possibleValues       The possible values, or an empty
                            array if there are none.  All possible values
                            must be of the correct type.
@param level                The level for which the possible values are valid,
                            or null if the possible values are valid for all levels.
**/
    public void setPossibleValues(Object[] possibleValues, ResourceLevel level)
    {
        if (possibleValues == null)
            throw new NullPointerException("possibleValues");

        Class possibleValuesType = ((multipleAllowed_) && (type_.isArray())) ? type_.getComponentType() : type_;

        for (int i = 0; i < possibleValues.length; ++i) {
            if (! (possibleValuesType.isAssignableFrom(possibleValues[i].getClass())))
                throw new ExtendedIllegalArgumentException("possibleValues[" + i + "]", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
        }

        for (int i = 0; i < possibleValues.length; ++i) {
            if (level == null)
                possibleValues_.put(possibleValues[i], defaultLevel_);
            else
                possibleValues_.put(possibleValues[i], level);
        }
    }




/**
Returns the String representation of the ID.

@return The String representation of the ID.
**/
    public String toString()
    {
        return id_.toString();
    }



/**
Validates a value.

@param value            The value.
@param possibleValues   The possible values.
@return                 The index in the possible values to which
                        this value is equal, or -1 if it
                        does not equal any of the possible values.

@exception ExtendedIllegalArgumentException If the value is not the
                                    correct type or the value does
                                    not equal any of the possible values and
                                    the value is limited.
**/
    private int validateValue(Object value, Object[] possibleValues)
    {
        int index = -1;
        for (int i = 0; i < possibleValues.length; ++i) {
            if (value.getClass().equals(byte[].class)) {
                if (arrayCompare((byte[])value, (byte[])possibleValues[i])) {
                    index = i;
                    break;
                }
            }
            else if (value.equals(possibleValues[i])) {
                index = i;
                break;
            }
        }

        if ((valueLimited_) && (index < 0)) {
            throw new ExtendedIllegalArgumentException("value(" + value + ") for id(" + id_ + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
        }

        return index;
    }



/**
Validates an value.

@param value   The value.
@return        The value.  If the value should be an array and it was passed as a 
               single value, then this will return a 1-element array.

@exception ExtendedIllegalArgumentException If the value is not the
                                    correct type or the value does
                                    not equal any of the possible values and
                                    the value is limited.
**/
    Object validateValue(Object value)
    {
        if (value == null)
            throw new NullPointerException("value");

        // Validate the type.
        Class valueClass = value.getClass();
        if (multipleAllowed_) {
            if (valueClass.isArray()) {
                if (! (type_.isAssignableFrom(valueClass.getComponentType())))
                    throw new ExtendedIllegalArgumentException("value(" + value + ") type(" + valueClass + ") for id(" + id_ + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
                Object[] asArray = (Object[])value;
                for(int i = 0; i < asArray.length; ++i) {
                    if (validateValue(asArray[i], getPossibleValues()) < 0)
                        return value;
                }
                return value;
            }
            else {
                if (! (type_.isAssignableFrom(valueClass)))
                    throw new ExtendedIllegalArgumentException("value(" + value + ") type(" + valueClass + ") for id(" + id_ + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
                validateValue(value, getPossibleValues());
                // They passed a single value, but the processing code is expecting
                // an array, so create a single element array.
                Object[] asArray = (Object[])Array.newInstance(type_, 1);
                asArray[0] = value;
                return asArray;
            }
        }
        else {
            if (! (type_.isAssignableFrom(valueClass)))
                throw new ExtendedIllegalArgumentException("value(" + value + ") type(" + valueClass + ") for id(" + id_ + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
            validateValue(value, getPossibleValues());
            return value;
        }
    }



/**
Validates an value for the specified level.

@param value   The value.
@param level            The level.
@return                 The index in the possible values to which
                        this value is equal, or -1 if it
                        does not equal any of the possible values.

@exception ExtendedIllegalArgumentException If the value is not the
                                    correct type or the value does
                                    not equal any of the possible values and
                                    the value is limited.
**/
    int validateValue(Object value, String level)
    {
        if (value == null)
            throw new NullPointerException("value");
        if (level == null)
            throw new NullPointerException("level");

        if (! (type_.isAssignableFrom(value.getClass())))
            throw new ExtendedIllegalArgumentException("value(" + value + ") type(" + value.getClass() + ") for id(" + id_ + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);

        return validateValue(value, getPossibleValues(level));
    }



}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy