hackedteam/rcs-console-library

View on GitHub
src/it/ht/rcs/console/build/model/_ExploitParamEntityMetadata.as

Summary

Maintainability
Test Coverage

/**
 * This is a generated class and is not intended for modification.  
 */
package it.ht.rcs.console.build.model
{
import com.adobe.fiber.styles.IStyle;
import com.adobe.fiber.styles.Style;
import com.adobe.fiber.styles.StyleValidator;
import com.adobe.fiber.valueobjects.AbstractEntityMetadata;
import com.adobe.fiber.valueobjects.AvailablePropertyIterator;
import com.adobe.fiber.valueobjects.IPropertyIterator;
import mx.collections.ArrayCollection;
import mx.events.ValidationResultEvent;
import com.adobe.fiber.core.model_internal;
import com.adobe.fiber.valueobjects.IModelType;
import mx.events.PropertyChangeEvent;

use namespace model_internal;

[ExcludeClass]
internal class _ExploitParamEntityMetadata extends com.adobe.fiber.valueobjects.AbstractEntityMetadata
{
    private static var emptyArray:Array = new Array();

    model_internal static var allProperties:Array = new Array("string", "file", "combo");
    model_internal static var allAssociationProperties:Array = new Array();
    model_internal static var allRequiredProperties:Array = new Array("string", "file", "combo");
    model_internal static var allAlwaysAvailableProperties:Array = new Array("string", "file", "combo");
    model_internal static var guardedProperties:Array = new Array();
    model_internal static var dataProperties:Array = new Array("string", "file", "combo");
    model_internal static var sourceProperties:Array = emptyArray
    model_internal static var nonDerivedProperties:Array = new Array("string", "file", "combo");
    model_internal static var derivedProperties:Array = new Array();
    model_internal static var collectionProperties:Array = new Array("combo");
    model_internal static var collectionBaseMap:Object;
    model_internal static var entityName:String = "ExploitParam";
    model_internal static var dependentsOnMap:Object;
    model_internal static var dependedOnServices:Array = new Array();
    model_internal static var propertyTypeMap:Object;

    
    model_internal var _stringIsValid:Boolean;
    model_internal var _stringValidator:com.adobe.fiber.styles.StyleValidator;
    model_internal var _stringIsValidCacheInitialized:Boolean = false;
    model_internal var _stringValidationFailureMessages:Array;
    
    model_internal var _fileIsValid:Boolean;
    model_internal var _fileValidator:com.adobe.fiber.styles.StyleValidator;
    model_internal var _fileIsValidCacheInitialized:Boolean = false;
    model_internal var _fileValidationFailureMessages:Array;
    
    model_internal var _comboIsValid:Boolean;
    model_internal var _comboValidator:com.adobe.fiber.styles.StyleValidator;
    model_internal var _comboIsValidCacheInitialized:Boolean = false;
    model_internal var _comboValidationFailureMessages:Array;

    model_internal var _instance:_Super_ExploitParam;
    model_internal static var _nullStyle:com.adobe.fiber.styles.Style = new com.adobe.fiber.styles.Style();

    public function _ExploitParamEntityMetadata(value : _Super_ExploitParam)
    {
        // initialize property maps
        if (model_internal::dependentsOnMap == null)
        {
            // dependents map
            model_internal::dependentsOnMap = new Object();
            model_internal::dependentsOnMap["string"] = new Array();
            model_internal::dependentsOnMap["file"] = new Array();
            model_internal::dependentsOnMap["combo"] = new Array();

            // collection base map
            model_internal::collectionBaseMap = new Object();
            model_internal::collectionBaseMap["combo"] = "String";
        }

        // Property type Map
        model_internal::propertyTypeMap = new Object();
        model_internal::propertyTypeMap["string"] = "String";
        model_internal::propertyTypeMap["file"] = "String";
        model_internal::propertyTypeMap["combo"] = "ArrayCollection";

        model_internal::_instance = value;
        model_internal::_stringValidator = new StyleValidator(model_internal::_instance.model_internal::_doValidationForString);
        model_internal::_stringValidator.required = true;
        model_internal::_stringValidator.requiredFieldError = "string is required";
        //model_internal::_stringValidator.source = model_internal::_instance;
        //model_internal::_stringValidator.property = "string";
        model_internal::_fileValidator = new StyleValidator(model_internal::_instance.model_internal::_doValidationForFile);
        model_internal::_fileValidator.required = true;
        model_internal::_fileValidator.requiredFieldError = "file is required";
        //model_internal::_fileValidator.source = model_internal::_instance;
        //model_internal::_fileValidator.property = "file";
        model_internal::_comboValidator = new StyleValidator(model_internal::_instance.model_internal::_doValidationForCombo);
        model_internal::_comboValidator.required = true;
        model_internal::_comboValidator.requiredFieldError = "combo is required";
        //model_internal::_comboValidator.source = model_internal::_instance;
        //model_internal::_comboValidator.property = "combo";
    }

    override public function getEntityName():String
    {
        return model_internal::entityName;
    }

    override public function getProperties():Array
    {
        return model_internal::allProperties;
    }

    override public function getAssociationProperties():Array
    {
        return model_internal::allAssociationProperties;
    }

    override public function getRequiredProperties():Array
    {
         return model_internal::allRequiredProperties;   
    }

    override public function getDataProperties():Array
    {
        return model_internal::dataProperties;
    }

    public function getSourceProperties():Array
    {
        return model_internal::sourceProperties;
    }

    public function getNonDerivedProperties():Array
    {
        return model_internal::nonDerivedProperties;
    }

    override public function getGuardedProperties():Array
    {
        return model_internal::guardedProperties;
    }

    override public function getUnguardedProperties():Array
    {
        return model_internal::allAlwaysAvailableProperties;
    }

    override public function getDependants(propertyName:String):Array
    {
       if (model_internal::nonDerivedProperties.indexOf(propertyName) == -1)
            throw new Error(propertyName + " is not a data property of entity ExploitParam");
            
       return model_internal::dependentsOnMap[propertyName] as Array;  
    }

    override public function getDependedOnServices():Array
    {
        return model_internal::dependedOnServices;
    }

    override public function getCollectionProperties():Array
    {
        return model_internal::collectionProperties;
    }

    override public function getCollectionBase(propertyName:String):String
    {
        if (model_internal::collectionProperties.indexOf(propertyName) == -1)
            throw new Error(propertyName + " is not a collection property of entity ExploitParam");

        return model_internal::collectionBaseMap[propertyName];
    }
    
    override public function getPropertyType(propertyName:String):String
    {
        if (model_internal::allProperties.indexOf(propertyName) == -1)
            throw new Error(propertyName + " is not a property of ExploitParam");

        return model_internal::propertyTypeMap[propertyName];
    }

    override public function getAvailableProperties():com.adobe.fiber.valueobjects.IPropertyIterator
    {
        return new com.adobe.fiber.valueobjects.AvailablePropertyIterator(this);
    }

    override public function getValue(propertyName:String):*
    {
        if (model_internal::allProperties.indexOf(propertyName) == -1)
        {
            throw new Error(propertyName + " does not exist for entity ExploitParam");
        }

        return model_internal::_instance[propertyName];
    }

    override public function setValue(propertyName:String, value:*):void
    {
        if (model_internal::nonDerivedProperties.indexOf(propertyName) == -1)
        {
            throw new Error(propertyName + " is not a modifiable property of entity ExploitParam");
        }

        model_internal::_instance[propertyName] = value;
    }

    override public function getMappedByProperty(associationProperty:String):String
    {
        switch(associationProperty)
        {
            default:
            {
                return null;
            }
        }
    }

    override public function getPropertyLength(propertyName:String):int
    {
        switch(propertyName)
        {
            default:
            {
                return 0;
            }
        }
    }

    override public function isAvailable(propertyName:String):Boolean
    {
        if (model_internal::allProperties.indexOf(propertyName) == -1)
        {
            throw new Error(propertyName + " does not exist for entity ExploitParam");
        }

        if (model_internal::allAlwaysAvailableProperties.indexOf(propertyName) != -1)
        {
            return true;
        }

        switch(propertyName)
        {
            default:
            {
                return true;
            }
        }
    }

    override public function getIdentityMap():Object
    {
        var returnMap:Object = new Object();

        return returnMap;
    }

    [Bindable(event="propertyChange")]
    override public function get invalidConstraints():Array
    {
        if (model_internal::_instance.model_internal::_cacheInitialized_isValid)
        {
            return model_internal::_instance.model_internal::_invalidConstraints;
        }
        else
        {
            // recalculate isValid
            model_internal::_instance.model_internal::_isValid = model_internal::_instance.model_internal::calculateIsValid();
            return model_internal::_instance.model_internal::_invalidConstraints;        
        }
    }

    [Bindable(event="propertyChange")]
    override public function get validationFailureMessages():Array
    {
        if (model_internal::_instance.model_internal::_cacheInitialized_isValid)
        {
            return model_internal::_instance.model_internal::_validationFailureMessages;
        }
        else
        {
            // recalculate isValid
            model_internal::_instance.model_internal::_isValid = model_internal::_instance.model_internal::calculateIsValid();
            return model_internal::_instance.model_internal::_validationFailureMessages;
        }
    }

    override public function getDependantInvalidConstraints(propertyName:String):Array
    {
        var dependants:Array = getDependants(propertyName);
        if (dependants.length == 0)
        {
            return emptyArray;
        }

        var currentlyInvalid:Array = invalidConstraints;
        if (currentlyInvalid.length == 0)
        {
            return emptyArray;
        }

        var filterFunc:Function = function(element:*, index:int, arr:Array):Boolean
        {
            return dependants.indexOf(element) > -1;
        }

        return currentlyInvalid.filter(filterFunc);
    }

    /**
     * isValid
     */
    [Bindable(event="propertyChange")] 
    public function get isValid() : Boolean
    {
        if (model_internal::_instance.model_internal::_cacheInitialized_isValid)
        {
            return model_internal::_instance.model_internal::_isValid;
        }
        else
        {
            // recalculate isValid
            model_internal::_instance.model_internal::_isValid = model_internal::_instance.model_internal::calculateIsValid();
            return model_internal::_instance.model_internal::_isValid;
        }
    }

    [Bindable(event="propertyChange")]
    public function get isStringAvailable():Boolean
    {
        return true;
    }

    [Bindable(event="propertyChange")]
    public function get isFileAvailable():Boolean
    {
        return true;
    }

    [Bindable(event="propertyChange")]
    public function get isComboAvailable():Boolean
    {
        return true;
    }


    /**
     * derived property recalculation
     */
    public function invalidateDependentOnString():void
    {
        if (model_internal::_stringIsValidCacheInitialized )
        {
            model_internal::_instance.model_internal::_doValidationCacheOfString = null;
            model_internal::calculateStringIsValid();
        }
    }
    public function invalidateDependentOnFile():void
    {
        if (model_internal::_fileIsValidCacheInitialized )
        {
            model_internal::_instance.model_internal::_doValidationCacheOfFile = null;
            model_internal::calculateFileIsValid();
        }
    }
    public function invalidateDependentOnCombo():void
    {
        if (model_internal::_comboIsValidCacheInitialized )
        {
            model_internal::_instance.model_internal::_doValidationCacheOfCombo = null;
            model_internal::calculateComboIsValid();
        }
    }

    model_internal function fireChangeEvent(propertyName:String, oldValue:Object, newValue:Object):void
    {
        this.dispatchEvent(mx.events.PropertyChangeEvent.createUpdateEvent(this, propertyName, oldValue, newValue));
    }

    [Bindable(event="propertyChange")]   
    public function get stringStyle():com.adobe.fiber.styles.Style
    {
        return model_internal::_nullStyle;
    }

    public function get stringValidator() : StyleValidator
    {
        return model_internal::_stringValidator;
    }

    model_internal function set _stringIsValid_der(value:Boolean):void 
    {
        var oldValue:Boolean = model_internal::_stringIsValid;         
        if (oldValue !== value)
        {
            model_internal::_stringIsValid = value;
            this.dispatchEvent(mx.events.PropertyChangeEvent.createUpdateEvent(this, "stringIsValid", oldValue, value));
        }                             
    }

    [Bindable(event="propertyChange")]
    public function get stringIsValid():Boolean
    {
        if (!model_internal::_stringIsValidCacheInitialized)
        {
            model_internal::calculateStringIsValid();
        }

        return model_internal::_stringIsValid;
    }

    model_internal function calculateStringIsValid():void
    {
        var valRes:ValidationResultEvent = model_internal::_stringValidator.validate(model_internal::_instance.string)
        model_internal::_stringIsValid_der = (valRes.results == null);
        model_internal::_stringIsValidCacheInitialized = true;
        if (valRes.results == null)
             model_internal::stringValidationFailureMessages_der = emptyArray;
        else
        {
            var _valFailures:Array = new Array();
            for (var a:int = 0 ; a<valRes.results.length ; a++)
            {
                _valFailures.push(valRes.results[a].errorMessage);
            }
            model_internal::stringValidationFailureMessages_der = _valFailures;
        }
    }

    [Bindable(event="propertyChange")]
    public function get stringValidationFailureMessages():Array
    {
        if (model_internal::_stringValidationFailureMessages == null)
            model_internal::calculateStringIsValid();

        return _stringValidationFailureMessages;
    }

    model_internal function set stringValidationFailureMessages_der(value:Array) : void
    {
        var oldValue:Array = model_internal::_stringValidationFailureMessages;

        var needUpdate : Boolean = false;
        if (oldValue == null)
            needUpdate = true;
    
        // avoid firing the event when old and new value are different empty arrays
        if (!needUpdate && (oldValue !== value && (oldValue.length > 0 || value.length > 0)))
        {
            if (oldValue.length == value.length)
            {
                for (var a:int=0; a < oldValue.length; a++)
                {
                    if (oldValue[a] !== value[a])
                    {
                        needUpdate = true;
                        break;
                    }
                }
            }
            else
            {
                needUpdate = true;
            }
        }

        if (needUpdate)
        {
            model_internal::_stringValidationFailureMessages = value;   
            this.dispatchEvent(mx.events.PropertyChangeEvent.createUpdateEvent(this, "stringValidationFailureMessages", oldValue, value));
            // Only execute calculateIsValid if it has been called before, to update the validationFailureMessages for
            // the entire entity.
            if (model_internal::_instance.model_internal::_cacheInitialized_isValid)
            {
                model_internal::_instance.model_internal::isValid_der = model_internal::_instance.model_internal::calculateIsValid();
            }
        }
    }

    [Bindable(event="propertyChange")]   
    public function get fileStyle():com.adobe.fiber.styles.Style
    {
        return model_internal::_nullStyle;
    }

    public function get fileValidator() : StyleValidator
    {
        return model_internal::_fileValidator;
    }

    model_internal function set _fileIsValid_der(value:Boolean):void 
    {
        var oldValue:Boolean = model_internal::_fileIsValid;         
        if (oldValue !== value)
        {
            model_internal::_fileIsValid = value;
            this.dispatchEvent(mx.events.PropertyChangeEvent.createUpdateEvent(this, "fileIsValid", oldValue, value));
        }                             
    }

    [Bindable(event="propertyChange")]
    public function get fileIsValid():Boolean
    {
        if (!model_internal::_fileIsValidCacheInitialized)
        {
            model_internal::calculateFileIsValid();
        }

        return model_internal::_fileIsValid;
    }

    model_internal function calculateFileIsValid():void
    {
        var valRes:ValidationResultEvent = model_internal::_fileValidator.validate(model_internal::_instance.file)
        model_internal::_fileIsValid_der = (valRes.results == null);
        model_internal::_fileIsValidCacheInitialized = true;
        if (valRes.results == null)
             model_internal::fileValidationFailureMessages_der = emptyArray;
        else
        {
            var _valFailures:Array = new Array();
            for (var a:int = 0 ; a<valRes.results.length ; a++)
            {
                _valFailures.push(valRes.results[a].errorMessage);
            }
            model_internal::fileValidationFailureMessages_der = _valFailures;
        }
    }

    [Bindable(event="propertyChange")]
    public function get fileValidationFailureMessages():Array
    {
        if (model_internal::_fileValidationFailureMessages == null)
            model_internal::calculateFileIsValid();

        return _fileValidationFailureMessages;
    }

    model_internal function set fileValidationFailureMessages_der(value:Array) : void
    {
        var oldValue:Array = model_internal::_fileValidationFailureMessages;

        var needUpdate : Boolean = false;
        if (oldValue == null)
            needUpdate = true;
    
        // avoid firing the event when old and new value are different empty arrays
        if (!needUpdate && (oldValue !== value && (oldValue.length > 0 || value.length > 0)))
        {
            if (oldValue.length == value.length)
            {
                for (var a:int=0; a < oldValue.length; a++)
                {
                    if (oldValue[a] !== value[a])
                    {
                        needUpdate = true;
                        break;
                    }
                }
            }
            else
            {
                needUpdate = true;
            }
        }

        if (needUpdate)
        {
            model_internal::_fileValidationFailureMessages = value;   
            this.dispatchEvent(mx.events.PropertyChangeEvent.createUpdateEvent(this, "fileValidationFailureMessages", oldValue, value));
            // Only execute calculateIsValid if it has been called before, to update the validationFailureMessages for
            // the entire entity.
            if (model_internal::_instance.model_internal::_cacheInitialized_isValid)
            {
                model_internal::_instance.model_internal::isValid_der = model_internal::_instance.model_internal::calculateIsValid();
            }
        }
    }

    [Bindable(event="propertyChange")]   
    public function get comboStyle():com.adobe.fiber.styles.Style
    {
        return model_internal::_nullStyle;
    }

    public function get comboValidator() : StyleValidator
    {
        return model_internal::_comboValidator;
    }

    model_internal function set _comboIsValid_der(value:Boolean):void 
    {
        var oldValue:Boolean = model_internal::_comboIsValid;         
        if (oldValue !== value)
        {
            model_internal::_comboIsValid = value;
            this.dispatchEvent(mx.events.PropertyChangeEvent.createUpdateEvent(this, "comboIsValid", oldValue, value));
        }                             
    }

    [Bindable(event="propertyChange")]
    public function get comboIsValid():Boolean
    {
        if (!model_internal::_comboIsValidCacheInitialized)
        {
            model_internal::calculateComboIsValid();
        }

        return model_internal::_comboIsValid;
    }

    model_internal function calculateComboIsValid():void
    {
        var valRes:ValidationResultEvent = model_internal::_comboValidator.validate(model_internal::_instance.combo)
        model_internal::_comboIsValid_der = (valRes.results == null);
        model_internal::_comboIsValidCacheInitialized = true;
        if (valRes.results == null)
             model_internal::comboValidationFailureMessages_der = emptyArray;
        else
        {
            var _valFailures:Array = new Array();
            for (var a:int = 0 ; a<valRes.results.length ; a++)
            {
                _valFailures.push(valRes.results[a].errorMessage);
            }
            model_internal::comboValidationFailureMessages_der = _valFailures;
        }
    }

    [Bindable(event="propertyChange")]
    public function get comboValidationFailureMessages():Array
    {
        if (model_internal::_comboValidationFailureMessages == null)
            model_internal::calculateComboIsValid();

        return _comboValidationFailureMessages;
    }

    model_internal function set comboValidationFailureMessages_der(value:Array) : void
    {
        var oldValue:Array = model_internal::_comboValidationFailureMessages;

        var needUpdate : Boolean = false;
        if (oldValue == null)
            needUpdate = true;
    
        // avoid firing the event when old and new value are different empty arrays
        if (!needUpdate && (oldValue !== value && (oldValue.length > 0 || value.length > 0)))
        {
            if (oldValue.length == value.length)
            {
                for (var a:int=0; a < oldValue.length; a++)
                {
                    if (oldValue[a] !== value[a])
                    {
                        needUpdate = true;
                        break;
                    }
                }
            }
            else
            {
                needUpdate = true;
            }
        }

        if (needUpdate)
        {
            model_internal::_comboValidationFailureMessages = value;   
            this.dispatchEvent(mx.events.PropertyChangeEvent.createUpdateEvent(this, "comboValidationFailureMessages", oldValue, value));
            // Only execute calculateIsValid if it has been called before, to update the validationFailureMessages for
            // the entire entity.
            if (model_internal::_instance.model_internal::_cacheInitialized_isValid)
            {
                model_internal::_instance.model_internal::isValid_der = model_internal::_instance.model_internal::calculateIsValid();
            }
        }
    }


     /**
     * 
     * @inheritDoc 
     */ 
     override public function getStyle(propertyName:String):com.adobe.fiber.styles.IStyle
     {
         switch(propertyName)
         {
            default:
            {
                return null;
            }
         }
     }
     
     /**
     * 
     * @inheritDoc 
     *  
     */  
     override public function getPropertyValidationFailureMessages(propertyName:String):Array
     {
         switch(propertyName)
         {
            case("string"):
            {
                return stringValidationFailureMessages;
            }
            case("file"):
            {
                return fileValidationFailureMessages;
            }
            case("combo"):
            {
                return comboValidationFailureMessages;
            }
            default:
            {
                return emptyArray;
            }
         }
     }

}

}