IServiceableModel extends IModel
A model that has service providers attached.
Table of Contents
| getPropertyProviders() | Retrieve a list of property service providers | \buffalokiwi\magicgraph\IPropertyServiceProvider[] | 
|---|---|---|
| createCopy() | Create a copy/clone of the model and all properties. | IModel | 
| clearEditFlags() | Clears the internal edited flags for each property | void | 
| instanceOf() | A way to determine if this model OR if a property set is an instance of some interface. | bool | 
| hasEdits() | Detect if any properties have been edited in this model | bool | 
| getPropertySet() | Retrieve the property set used for this model. | IPropertySet | 
| getPropertyNameSetByFlags() | Retrieve a set with the property name bits toggled on for properties with the supplied flags. | IBigSet | 
| getPropertyConfig() | Retrieve a property config instance attached to this model. | IPropertyConfig | 
| getPropertyNameSet() | Retrieve property names as an IBigSet instance. | IBigSet | 
| toObject() | Convert the model to a json representation. | string | 
| toArray() | Convert this model to an array. | array | 
| fromArray() | void | |
| equals() | Test if this model is equal to some other model | bool | 
| getValue() | Retrieve the value of some property | mixed | 
| setValue() | Sets the value of some property | void | 
| getModifiedProperties() | Retrieve a list of modified properties | ISet | 
| getInsertProperties() | Gets A propertyset containing properties for insert | IBigSet | 
| validate() | Test to see if this model is valid prior to save() | void | 
| validateAll() | If you want to validate each property and return a list of errors indexed by property name, this is the method to call. | array | 
| hash() | Retrieve a unique hash for this object | string | 
| hasPrimaryKeyValues() | Test that the model has all primary key values | bool | 
Methods
getPropertyProviders()
Retrieve a list of property service providers
        public
                                getPropertyProviders(
                )
        : \buffalokiwi\magicgraph\IPropertyServiceProvider[]
    
    
    
        
            Return values
\buffalokiwi\magicgraph\IPropertyServiceProvider[]createCopy()
Create a copy/clone of the model and all properties.
        public
                                createCopy(
                    
            [                $copyIsSaveable :
                bool
                 = true ]            
                )
        : IModel
    
    
            Parameters
- $copyIsSaveable : bool = true
- If this is false, then the primary key flags are removed from the copied model. This will cause the repository save method to fail when a save is attempted. 
Return values
IModel —Copied model
clearEditFlags()
Clears the internal edited flags for each property
        public
                                clearEditFlags(
                )
        : void
    
    
    
        
    
instanceOf()
A way to determine if this model OR if a property set is an instance of some interface.
        public
                                instanceOf(
                    
                            $interface :
                string
                            
                )
        : bool
    
        This is used due to decorators.
Parameters
- $interface : string
- Interface name 
Return values
bool —if this implements it
hasEdits()
Detect if any properties have been edited in this model
        public
                                hasEdits(
                    
            [                $prop :
                string
                 = '' ]            
                )
        : bool
    
    
            Parameters
- $prop : string = ''
- Property name. If $prop is not empty then this would test that the supplied property name is not empty. Otherwise, this tests if any property was edited. 
Return values
bool —has edits
getPropertySet()
Retrieve the property set used for this model.
        public
                                getPropertySet(
                )
        : IPropertySet
    
        This method FORMERLY returned a clone of the internal property set. Currently, this returns the internal PropertySet.
Tags
Return values
IPropertySetgetPropertyNameSetByFlags()
Retrieve a set with the property name bits toggled on for properties with the supplied flags.
        public
                                getPropertyNameSetByFlags(
                    
                            ...$flags :
                string
                            
                )
        : IBigSet
    
    
            Parameters
- $flags : string
- Flags 
Return values
IBigSet —names
getPropertyConfig()
Retrieve a property config instance attached to this model.
        public
                                getPropertyConfig(
                    
                            $intf :
                string
                            
                )
        : IPropertyConfig
    
    
            Parameters
- $intf : string
- Interface of the config instance 
Tags
Return values
IPropertyConfig —The config instance
getPropertyNameSet()
Retrieve property names as an IBigSet instance.
        public
                                getPropertyNameSet(
                )
        : IBigSet
    
        This will return a set containing all of the property names, and have zero members active. This is available due to how expensive cloning the backing IPropertySet instance can be. Use this for simple operations such as determining if a property name is valid.
Return values
IBigSet —property names
toObject()
Convert the model to a json representation.
        public
                                toObject(
                    
            [                $properties :
                IBigSet|null
                 = null ]            
                    
            [,                 $includeArrays :
                bool
                 = false ]            
                    
            [,                 $includeModels :
                bool
                 = false ]            
                )
        : string
    
    
            Parameters
- $properties : IBigSet|null = null
- $includeArrays : bool = false
- $includeModels : bool = false
Return values
string —JSON object
toArray()
Convert this model to an array.
        public
                                toArray(
                    
            [                $properties :
                IPropertySet
                 = null ]            
                    
            [,                 $includeArrays :
                bool
                 = false ]            
                    
            [,                 $includeModels :
                bool
                 = false ]            
                )
        : array
    
    
            Parameters
- $properties : IPropertySet = null
- Properties to include 
- $includeArrays : bool = false
- $includeModels : bool = false
Return values
arrayfromArray()
        public
                                fromArray(
                    
                            $data :
                array
                            
                )
        : void
    
    
            Parameters
- $data : array
equals()
Test if this model is equal to some other model
        public
                                equals(
                    
                            $that :
                IModel
                            
                )
        : bool
    
    
            Parameters
- $that : IModel
- model to compare 
Return values
bool —is equals
getValue()
Retrieve the value of some property
        public
                                getValue(
                    
                            $property :
                string
                            
                    
            [,                 $context :
                array
                 = [] ]            
                )
        : mixed
    
    
            Parameters
- $property : string
- Property 
- $context : array = []
Tags
Return values
mixed —value
setValue()
Sets the value of some property
        public
                                setValue(
                    
                            $property :
                string
                            
                    
            ,                 $value :
                mixed
                            
                )
        : void
    
    
            Parameters
- $property : string
- Property to set 
- $value : mixed
- property value 
Tags
getModifiedProperties()
Retrieve a list of modified properties
        public
                                getModifiedProperties(
                )
        : ISet
    
    
    
        
            Return values
ISet —modified properties
getInsertProperties()
Gets A propertyset containing properties for insert
        public
                                getInsertProperties(
                )
        : IBigSet
    
    
    
        
            Return values
IBigSet —insert properties
validate()
Test to see if this model is valid prior to save()
        public
                                validate(
                )
        : void
    
    
    
            Tags
validateAll()
If you want to validate each property and return a list of errors indexed by property name, this is the method to call.
        public
                                validateAll(
                    
            [                $debugErrors :
                bool
                 = false ]            
                )
        : array
    
        Note: This simply calls validate() in a loop, catches exceptions and tosses some errors in a list.
Parameters
- $debugErrors : bool = false
Return values
array —[property name => message]
hash()
Retrieve a unique hash for this object
        public
                                hash(
                )
        : string
    
    
    
        
            Return values
string —hash
hasPrimaryKeyValues()
Test that the model has all primary key values
        public
                                hasPrimaryKeyValues(
                )
        : bool
    
    
    
        
            Return values
bool —has values