SQLServiceableRepository extends SQLRepositoryProxy
A proxy/decorator base class for the ISaveableObjectFactory interface
Table of Contents
| $tfact | Transaction factory | ITransactionFactory | 
|---|---|---|
| $providers | Property providers | \buffalokiwi\magicgraph\IModelPropertyProvider[] | 
| $repo | Repo | IRepository | 
| $repo | Repo | IRepository | 
| $factory | Factory | IObjectFactory | 
| __construct() | Create a new proxy instance | mixed | 
| getSaveFunction() | Retrieve an IRunnable instance to be used with some ITransaction instance. | IRunnable | 
| save() | Save some record. | void | 
| saveAll() | Saves a batch of records. | void | 
| __construct() | mixed | |
| query() | Query the data source. | \buffalokiwi\magicgraph\IModel[] | 
| getTable() | Retrieve the database table name backing this repository. | string | 
| getDatabaseConnection() | Retrieve the database connection | IDBConnection | 
| lockTable() | Lock the table via "lock tables". | void | 
| unlockTable() | Unlock the tables obtained by lockTable() This also commits. | void | 
| getLock() | Attempts to obtain a lock for this table via GET_LOCK(). | void | 
| releaseLock() | Release the lock obtained by getLock() | void | 
| isTableLocked() | If the table is locked via lock tables. | bool | 
| isLocked() | If there is a lock in effect via GET_LOCK() | bool | 
| getPage() | Retrieve user records by page. | array | 
| getRepo() | Get the stored repo | ISQLRepository | 
| __call() | mixed | |
| getSaveFunction() | Retrieve an IRunnable instance to be used with some ITransaction instance. | IRunnable | 
| createUnitOfWork() | Create a unit of work against the repo. | IRunnable | 
| stream() | Stream the data one record at a time from the data source. This may not always be implemented. | Generator | 
| get() | Load some record by primary key | IModel | 
| getAll() | Retrieve a list of models by a list of primary key values. | \buffalokiwi\magicgraph\IModel[] | 
| getIdsForProperty() | Retrieve a list of id's for some property. | array | 
| getForProperty() | Retrieve a list of models where some property name matches some value. | array | 
| findByProperty() | Perform a simple search by property name. | array | 
| count() | Retrieve the estimated record count. | int | 
| exists() | Tests to see if some value exists by primary key | bool | 
| save() | Save some record. | void | 
| saveAll() | Saves a batch of records. | void | 
| remove() | Removes a model. | void | 
| removeById() | Remove an entry by id. This does not work for compound keys. | void | 
| create() | Create a new Model instance using the internal data mapper. | IModel | 
| createPropertyNameSet() | Retrieves a set containing the property names. | IBigSet | 
| createPropertySet() | Clones and returns the internal property set used to construct objects. | IPropertySet | 
| addPropertyConfig() | Adds an additional property config to this repo. | mixed | 
Properties
$tfact
Transaction factory
        private
                ITransactionFactory
        $tfact
            
            
$providers
Property providers
        private
                \buffalokiwi\magicgraph\IModelPropertyProvider[]
        $providers
            
            
$repo
Repo
        private
                IRepository
        $repo
            
            
$repo
Repo
        private
                IRepository
        $repo
            
            
$factory
Factory
        private
                IObjectFactory
        $factory
            
            
Methods
__construct()
Create a new proxy instance
        public
                                __construct(
                    
                            $repo :
                IRepository
                            
                    
            ,                 $tfact :
                ITransactionFactory
                            
                    
            ,                 ...$providers :
                IModelPropertyProvider
                            
                )
        : mixed
    
    
            Parameters
- $repo : IRepository
- $tfact : ITransactionFactory
- $providers : IModelPropertyProvider
Return values
mixedgetSaveFunction()
Retrieve an IRunnable instance to be used with some ITransaction instance.
        public
                                getSaveFunction(
                    
                            $beforeSave :
                Closure
                            
                    
            ,                 $afterSave :
                Closure
                            
                    
            ,                 ...$models :
                IModel
                            
                )
        : IRunnable
    
        This runnable will execute the supplied function prior to saving the model.
Parameters
- $beforeSave : Closure
- What to run prior to saving f( IRepository, ...IModel ) 
- $afterSave : Closure
- What to run after saving f( IRepository, ...IModel ) 
- $models : IModel
- One or more models to save 
Return values
IRunnablesave()
Save some record.
        public
                                save(
                    
                            $model :
                IModel
                            
                    
            [,                 $validate :
                bool
                 = true ]            
                )
        : void
    
        If the primary key value is specified, this is considered to be an update. Otherwise, this is considered to be an insert.
Parameters
- $model : IModel
- Model to save 
- $validate : bool = true
- Validate the model prior to save 
Tags
saveAll()
Saves a batch of records.
        public
                                saveAll(
                    
                            ...$model :
                IModel
                            
                )
        : void
    
        All records are first validated, then saved sequentially. Validation exceptions will be thrown prior to any saves happening.
If the primary key value is specified, this is considered to be an update. Otherwise, this is considered to be an insert.
Parameters
- $model : IModel
- Model to save 
Tags
__construct()
        public
                                __construct(
                    
                            $factory :
                IObjectFactory
                            
                )
        : mixed
    
    
            Parameters
- $factory : IObjectFactory
Return values
mixedquery()
Query the data source.
        public
                                query(
                    
                            $properties :
                IBigSet
                            
                    
            ,                 $filter :
                IFilter
                            
                    
            [,                 $rows :
                IRows
                 = null ]            
                )
        : \buffalokiwi\magicgraph\IModel[]
    
    
            Parameters
- $properties : IBigSet
- Properties to return 
- $filter : IFilter
- Filters to use 
- $rows : IRows = null
- Sort order and limit 
Tags
Return values
\buffalokiwi\magicgraph\IModel[] —model instances
getTable()
Retrieve the database table name backing this repository.
        public
                                getTable(
                )
        : string
    
    
    
        
            Return values
string —database table name
getDatabaseConnection()
Retrieve the database connection
        public
                                getDatabaseConnection(
                )
        : IDBConnection
    
    
    
        
            Return values
IDBConnection —database connection
lockTable()
Lock the table via "lock tables".
        public
                                lockTable(
                )
        : void
    
        Disables autocommit.
unlockTable()
Unlock the tables obtained by lockTable() This also commits.
        public
                                unlockTable(
                )
        : void
    
    
    
        
    
getLock()
Attempts to obtain a lock for this table via GET_LOCK().
        public
                                getLock(
                )
        : void
    
        This blocks until one can be obtained.
releaseLock()
Release the lock obtained by getLock()
        public
                                releaseLock(
                )
        : void
    
    
    
        
    
isTableLocked()
If the table is locked via lock tables.
        public
                                isTableLocked(
                )
        : bool
    
    
    
        
            Return values
bool —locked
isLocked()
If there is a lock in effect via GET_LOCK()
        public
                                isLocked(
                )
        : bool
    
    
    
        
            Return values
bool —is locked
getPage()
Retrieve user records by page.
        public
                                getPage(
                    
                            $page :
                int
                            
                    
            [,                 $size :
                int
                 = 25 ]            
                    
            [,                 $orderBy :
                string
                 = '' ]            
                )
        : array
    
    
            Parameters
- $page : int
- Page number 
- $size : int = 25
- page size 
- $orderBy : string = ''
Return values
array —IModel[] Model
getRepo()
Get the stored repo
        protected
                final                getRepo(
                )
        : ISQLRepository
    
    
    
            Tags
Return values
ISQLRepository__call()
        public
                                __call(
                    
                            $name :
                mixed
                            
                    
            ,                 $arguments :
                mixed
                            
                )
        : mixed
    
    
            Parameters
- $name : mixed
- $arguments : mixed
Return values
mixedgetSaveFunction()
Retrieve an IRunnable instance to be used with some ITransaction instance.
        public
                                getSaveFunction(
                    
                            $beforeSave :
                Closure
                            
                    
            ,                 $afterSave :
                Closure
                            
                    
            ,                 ...$models :
                IModel
                            
                )
        : IRunnable
    
        This runnable will execute the supplied function prior to saving the model.
Parameters
- $beforeSave : Closure
- What to run prior to saving f( IRepository, ...IModel ) 
- $afterSave : Closure
- What to run after saving f( IRepository, ...IModel ) 
- $models : IModel
- One or more models to save 
Return values
IRunnablecreateUnitOfWork()
Create a unit of work against the repo.
        public
                                createUnitOfWork(
                    
                            $action :
                Closure
                            
                )
        : IRunnable
    
    
            Parameters
- $action : Closure
- f( IRepository $repo ) : void - What to do 
Return values
IRunnable —Runnable
stream()
Stream the data one record at a time from the data source. This may not always be implemented.
        public
                                stream(
                    
                            $properties :
                IBigSet
                            
                    
            ,                 $filter :
                IFilter
                            
                    
            [,                 $rows :
                IRows
                 = null ]            
                )
        : Generator
    
    
            Parameters
Tags
Return values
Generator —yielded results
get()
Load some record by primary key
        public
                                get(
                    
                            ...$id :
                string
                            
                )
        : IModel
    
    
            Parameters
- $id : string
- id 
Tags
Return values
IModel —model instance
getAll()
Retrieve a list of models by a list of primary key values.
        public
                                getAll(
                    
                            $idList :
                array
                            
                )
        : \buffalokiwi\magicgraph\IModel[]
    
    
            Parameters
- $idList : array
- id list 
Tags
Return values
\buffalokiwi\magicgraph\IModel[] —found models
getIdsForProperty()
Retrieve a list of id's for some property.
        public
                                getIdsForProperty(
                    
                            $propertyName :
                string
                            
                    
            ,                 $value :
                string
                            
                )
        : array
    
        If primary key is compound, then each returned element will be an array (map) listing each key.
Parameters
- $propertyName : string
- Property Name 
- $value : string
- value 
Return values
array —ids
getForProperty()
Retrieve a list of models where some property name matches some value.
        public
                                getForProperty(
                    
                            $propertyName :
                string
                            
                    
            ,                 $value :
                mixed
                            
                )
        : array
    
    
            Parameters
- $propertyName : string
- Property name 
- $value : mixed
- value 
Tags
Return values
arrayfindByProperty()
Perform a simple search by property name.
        public
                                findByProperty(
                    
                            $propertyName :
                string
                            
                    
            ,                 $value :
                string
                            
                    
            [,                 $limit :
                int
                 = 100 ]            
                )
        : array
    
        If the engine supports simple searching, this can be used for that. For example: With SQL databases, this can simply be a wildcard search. Also possible to use full text indexes or whatever else the engine supports.
Depending on the repo, this could connect to any number of things for searching.
Parameters
- $propertyName : string
- Property name 
- $value : string
- Search value. What this is depends on the engine. 
- $limit : int = 100
Tags
Return values
arraycount()
Retrieve the estimated record count.
        public
                                count(
                    
            [                $full :
                bool
                 = false ]            
                )
        : int
    
    
            Parameters
- $full : bool = false
- Set to true to retrieve count(*), set to false for max(primary key) 
Return values
int —estimated number of records
exists()
Tests to see if some value exists by primary key
        public
                                exists(
                    
                            ...$id :
                string
                            
                )
        : bool
    
    
            Parameters
- $id : string
Return values
boolsave()
Save some record.
        public
                                save(
                    
                            $model :
                IModel
                            
                    
            [,                 $validate :
                bool
                 = true ]            
                )
        : void
    
        If the primary key value is specified, this is considered to be an update. Otherwise, this is considered to be an insert.
Parameters
- $model : IModel
- Model to save 
- $validate : bool = true
- Validate the model prior to save 
Tags
saveAll()
Saves a batch of records.
        public
                                saveAll(
                    
                            ...$model :
                IModel
                            
                )
        : void
    
        All records are first validated, then saved sequentially. Validation exceptions will be thrown prior to any saves happening.
If the primary key value is specified, this is considered to be an update. Otherwise, this is considered to be an insert.
Parameters
- $model : IModel
- Model to save 
Tags
remove()
Removes a model.
        public
                                remove(
                    
                            $model :
                IModel
                            
                )
        : void
    
    
            Parameters
- $model : IModel
- Model to remove 
Tags
removeById()
Remove an entry by id. This does not work for compound keys.
        public
                                removeById(
                    
                            $id :
                string
                            
                )
        : void
    
    
            Parameters
- $id : string
- id 
Tags
create()
Create a new Model instance using the internal data mapper.
        public
                                create(
                    
                            $data :
                array
                            
                    
            [,                 $readOnly :
                bool
                 = false ]            
                )
        : IModel
    
    
            Parameters
- $data : array
- Raw data to use 
- $readOnly : bool = false
- Set the produced model to read only 
Tags
Return values
IModel —model instance
createPropertyNameSet()
Retrieves a set containing the property names.
        public
                                createPropertyNameSet(
                )
        : IBigSet
    
    
    
        
            Return values
IBigSet —set
createPropertySet()
Clones and returns the internal property set used to construct objects.
        public
                                createPropertySet(
                )
        : IPropertySet
    
    
    
        
            Return values
IPropertySet —property set
addPropertyConfig()
Adds an additional property config to this repo.
        public
                                addPropertyConfig(
                    
                            ...$config :
                type
                            
                )
        : mixed
    
        When models reference themselves, sometimes it's necessary for a property config to reference the repository (circular).
Feels a bit like cheating to me...
Parameters
- $config : type