Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
U
UserAdminV2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
庄欣
UserAdminV2
Commits
718d51e0
Commit
718d51e0
authored
Aug 02, 2011
by
Taylor Otwell
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactoring eloquent model.
parent
277be848
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
22 deletions
+27
-22
system/db/eloquent/model.php
+27
-22
No files found.
system/db/eloquent/model.php
View file @
718d51e0
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
use
System\Str
;
use
System\Str
;
use
System\Config
;
use
System\Config
;
use
System\Inflector
;
use
System\Inflector
;
use
System\Paginator
;
use
System\DB\Manager
;
use
System\DB\Manager
;
abstract
class
Model
{
abstract
class
Model
{
...
@@ -206,12 +207,10 @@ abstract class Model {
...
@@ -206,12 +207,10 @@ abstract class Model {
if
(
is_null
(
$per_page
))
if
(
is_null
(
$per_page
))
{
{
$per_page
=
(
property_exists
(
get_class
(
$this
),
'per_page'
))
?
static
::
$per_page
:
15
;
$per_page
=
(
property_exists
(
get_class
(
$this
),
'per_page'
))
?
static
::
$per_page
:
20
;
}
}
$current_page
=
\System\Paginator
::
page
(
$total
,
$per_page
);
return
Paginator
::
make
(
$this
->
for_page
(
Paginator
::
page
(
$total
,
$per_page
),
$per_page
)
->
get
(),
$total
,
$per_page
);
return
\System\Paginator
::
make
(
$this
->
for_page
(
$current_page
,
$per_page
)
->
get
(),
$total
,
$per_page
);
}
}
/**
/**
...
@@ -292,9 +291,6 @@ abstract class Model {
...
@@ -292,9 +291,6 @@ abstract class Model {
/**
/**
* Retrieve the query for a *:* relationship.
* Retrieve the query for a *:* relationship.
*
*
* By default, the intermediate table name is the plural names of the models
* arranged alphabetically and concatenated with an underscore.
*
* The default foreign key for many-to-many relations is the name of the model
* The default foreign key for many-to-many relations is the name of the model
* with an appended _id. This is the same convention as has_one and has_many.
* with an appended _id. This is the same convention as has_one and has_many.
*
*
...
@@ -308,23 +304,14 @@ abstract class Model {
...
@@ -308,23 +304,14 @@ abstract class Model {
{
{
$this
->
relating
=
__FUNCTION__
;
$this
->
relating
=
__FUNCTION__
;
if
(
is_null
(
$table
))
$this
->
relating_table
=
(
is_null
(
$table
))
?
$this
->
intermediate_table
(
$model
)
:
$table
;
{
$models
=
array
(
Inflector
::
plural
(
$model
),
Inflector
::
plural
(
get_class
(
$this
)));
sort
(
$models
);
$this
->
relating_table
=
strtolower
(
$models
[
0
]
.
'_'
.
$models
[
1
]);
}
else
{
$this
->
relating_table
=
$table
;
}
// Allowing the overriding of the foreign and associated keys provides the flexibility for
// Allowing the overriding of the foreign and associated keys provides the flexibility for
// self-referential many-to-many relationships, such as a "buddy list".
// self-referential many-to-many relationships, such as a "buddy list".
$this
->
relating_key
=
(
is_null
(
$foreign_key
))
?
strtolower
(
get_class
(
$this
))
.
'_id'
:
$foreign_key
;
$this
->
relating_key
=
(
is_null
(
$foreign_key
))
?
strtolower
(
get_class
(
$this
))
.
'_id'
:
$foreign_key
;
// The associated key is the foreign key name of the related model. So, if the related model
// is "Role", the associated key on the intermediate table would be "role_id".
$associated_key
=
(
is_null
(
$associated_key
))
?
strtolower
(
$model
)
.
'_id'
:
$associated_key
;
$associated_key
=
(
is_null
(
$associated_key
))
?
strtolower
(
$model
)
.
'_id'
:
$associated_key
;
return
static
::
query
(
$model
)
return
static
::
query
(
$model
)
...
@@ -334,6 +321,24 @@ abstract class Model {
...
@@ -334,6 +321,24 @@ abstract class Model {
}
}
/**
/**
* Determine the intermediate table name for a given model.
*
* By default, the intermediate table name is the plural names of the models
* arranged alphabetically and concatenated with an underscore.
*
* @param string $model
* @return string
*/
private
function
intermediate_table
(
$model
)
{
$models
=
array
(
Inflector
::
plural
(
$model
),
Inflector
::
plural
(
get_class
(
$this
)));
sort
(
$models
);
return
strtolower
(
$models
[
0
]
.
'_'
.
$models
[
1
]);
}
/**
* Save the model to the database.
* Save the model to the database.
*
*
* @return void
* @return void
...
@@ -359,7 +364,7 @@ abstract class Model {
...
@@ -359,7 +364,7 @@ abstract class Model {
// Otherwise, we will insert the model and set the ID attribute.
// Otherwise, we will insert the model and set the ID attribute.
if
(
$this
->
exists
)
if
(
$this
->
exists
)
{
{
$this
->
query
->
where
(
'id'
,
'='
,
$this
->
attributes
[
'id'
])
->
update
(
$this
->
dirty
);
$this
->
query
->
where
_id
(
$this
->
attributes
[
'id'
])
->
update
(
$this
->
dirty
);
}
}
else
else
{
{
...
@@ -421,9 +426,9 @@ abstract class Model {
...
@@ -421,9 +426,9 @@ abstract class Model {
// load it and return the results of the relationship query.
// load it and return the results of the relationship query.
elseif
(
method_exists
(
$this
,
$key
))
elseif
(
method_exists
(
$this
,
$key
))
{
{
$
model
=
$this
->
$key
();
$
query
=
$this
->
$key
();
return
$this
->
ignore
[
$key
]
=
(
in_array
(
$this
->
relating
,
array
(
'has_one'
,
'belongs_to'
)))
?
$
model
->
first
()
:
$model
->
get
();
return
$this
->
ignore
[
$key
]
=
(
in_array
(
$this
->
relating
,
array
(
'has_one'
,
'belongs_to'
)))
?
$
query
->
first
()
:
$query
->
get
();
}
}
elseif
(
array_key_exists
(
$key
,
$this
->
attributes
))
elseif
(
array_key_exists
(
$key
,
$this
->
attributes
))
{
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment