123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353 |
- <?php namespace System\DB;
- abstract class Eloquent {
- /**
- * Indicates if the model exists in the database.
- *
- * @var bool
- */
- public $exists = false;
- /**
- * The model attributes.
- *
- * @var array
- */
- public $attributes = array();
- /**
- * The model's dirty attributes.
- *
- * @var array
- */
- public $dirty = array();
- /**
- * The model's ignored attributes.
- *
- * Ignored attributes will not be saved to the database, and
- * are primarily used to hold relationships.
- *
- * @var array
- */
- public $ignore = array();
- /**
- * The relationships that should be eagerly loaded.
- *
- * @var array
- */
- public $includes = array();
- /**
- * The relationship type the model is currently resolving.
- *
- * @var string
- */
- public $relating;
- /**
- * The foreign key of the "relating" relationship.
- *
- * @var string
- */
- public $relating_key;
- /**
- * The table name of the model being resolved. Used during many-to-many eager loading.
- *
- * @var string
- */
- public $relating_table;
- /**
- * The model query instance.
- *
- * @var Query
- */
- public $query;
- /**
- * Create a new model instance and set the relationships
- * that should be eagerly loaded.
- *
- * @return mixed
- */
- public static function with()
- {
- // -----------------------------------------------------
- // Create a new model instance.
- // -----------------------------------------------------
- $model = Eloquent\Factory::make(get_called_class());
- // -----------------------------------------------------
- // Set the eager relationships.
- // -----------------------------------------------------
- $model->includes = func_get_args();
- return $model;
- }
- /**
- * Get a model by the primary key.
- *
- * @param int $id
- * @return mixed
- */
- public static function find($id)
- {
- return Eloquent\Factory::make(get_called_class())->where('id', '=', $id)->first();
- }
- /**
- * Get an array of models from the database.
- *
- * @return array
- */
- private function _get()
- {
- return Eloquent\Hydrate::from($this);
- }
- /**
- * Get the first model result
- *
- * @return mixed
- */
- private function _first()
- {
- // -----------------------------------------------------
- // Load the hydrated models.
- // -----------------------------------------------------
- $results = Eloquent\Hydrate::from($this->take(1));
- // -----------------------------------------------------
- // Return the first result.
- // -----------------------------------------------------
- if (count($results) > 0)
- {
- reset($results);
- return current($results);
- }
- }
- /**
- * Retrieve the query for a 1:1 relationship.
- *
- * @param string $model
- * @return mixed
- */
- public function has_one($model)
- {
- return Eloquent\Relate::has_one($model, $this);
- }
- /**
- * Retrieve the query for a 1:* relationship.
- *
- * @param string $model
- * @return mixed
- */
- public function has_many($model)
- {
- return Eloquent\Relate::has_many($model, $this);
- }
- /**
- * Retrieve the query for a 1:1 belonging relationship.
- *
- * @param string $model
- * @return mixed
- */
- public function belongs_to($model)
- {
- // -----------------------------------------------------
- // Get the calling function name.
- // -----------------------------------------------------
- list(, $caller) = debug_backtrace(false);
- return Eloquent\Relate::belongs_to($caller, $model, $this);
- }
- /**
- * Retrieve the query for a *:* relationship.
- *
- * @param string $model
- * @return mixed
- */
- public function has_many_and_belongs_to($model)
- {
- return Eloquent\Relate::has_many_and_belongs_to($model, $this);
- }
- /**
- * Save the model to the database.
- *
- * @return void
- */
- public function save()
- {
- Eloquent\Warehouse::store($this);
- }
- /**
- * Magic method for retrieving model attributes.
- */
- public function __get($key)
- {
- // -----------------------------------------------------
- // Check the ignored attributes first.
- // -----------------------------------------------------
- if (array_key_exists($key, $this->ignore))
- {
- return $this->ignore[$key];
- }
- // -----------------------------------------------------
- // Is the attribute actually a relationship?
- // -----------------------------------------------------
- if (method_exists($this, $key))
- {
- // -----------------------------------------------------
- // Get the query / model for the relationship.
- // -----------------------------------------------------
- $model = $this->$key();
- // -----------------------------------------------------
- // Return the relationship results.
- // -----------------------------------------------------
- return ($this->relating == 'has_one' or $this->relating == 'belongs_to')
- ? $this->ignore[$key] = $model->first()
- : $this->ignore[$key] = $model->get();
- }
- // -----------------------------------------------------
- // Check the "regular" attributes.
- // -----------------------------------------------------
- return (array_key_exists($key, $this->attributes)) ? $this->attributes[$key] : null;
- }
- /**
- * Magic Method for setting model attributes.
- */
- public function __set($key, $value)
- {
- // -----------------------------------------------------
- // Is the key actually a relationship?
- // -----------------------------------------------------
- if (method_exists($this, $key))
- {
- $this->ignore[$key] = $value;
- }
- else
- {
- // -----------------------------------------------------
- // Add the value to the attributes.
- // -----------------------------------------------------
- $this->attributes[$key] = $value;
- $this->dirty[$key] = $value;
- }
- }
- /**
- * Magic Method for determining if a model attribute is set.
- */
- public function __isset($key)
- {
- return (array_key_exists($key, $this->attributes) or array_key_exists($key, $this->ignore));
- }
- /**
- * Magic Method for unsetting model attributes.
- */
- public function __unset($key)
- {
- unset($this->attributes[$key]);
- unset($this->ignore[$key]);
- unset($this->dirty[$key]);
- }
- /**
- * Magic Method for handling dynamic method calls.
- */
- public function __call($method, $parameters)
- {
- // -----------------------------------------------------
- // Is the "get" method being called?
- // -----------------------------------------------------
- if ($method == 'get')
- {
- return $this->_get();
- }
- // -----------------------------------------------------
- // Is the "first" method being called?
- // -----------------------------------------------------
- if ($method == 'first')
- {
- return $this->_first();
- }
- // -----------------------------------------------------
- // If the method is an aggregate function, just return
- // the aggregate value from the query.
- // -----------------------------------------------------
- if (in_array($method, array('count', 'sum', 'min', 'max', 'avg')))
- {
- return call_user_func_array(array($this->query, $method), $parameters);
- }
- // -----------------------------------------------------
- // Pass the method call to the query instance.
- // -----------------------------------------------------
- call_user_func_array(array($this->query, $method), $parameters);
- return $this;
- }
- /**
- * Magic Method for handling dynamic static method calls.
- */
- public static function __callStatic($method, $parameters)
- {
- // -----------------------------------------------------
- // Create a new model instance.
- // -----------------------------------------------------
- $model = Eloquent\Factory::make(get_called_class());
- // -----------------------------------------------------
- // Do we need to return the entire table?
- // -----------------------------------------------------
- if ($method == 'get')
- {
- return $model->_get();
- }
- // -----------------------------------------------------
- // Do we need to return the first model from the table?
- // -----------------------------------------------------
- if ($method == 'first')
- {
- return $model->_first();
- }
- // -----------------------------------------------------
- // If the method is an aggregate function, just return
- // the aggregate value from the query.
- // -----------------------------------------------------
- if (in_array($method, array('count', 'sum', 'min', 'max', 'avg')))
- {
- return call_user_func_array(array($model->query, $method), $parameters);
- }
- // -----------------------------------------------------
- // Pass the method call to the query instance.
- // -----------------------------------------------------
- call_user_func_array(array($model->query, $method), $parameters);
- return $model;
- }
- }
|