Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
D
doctrine-dbal
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Tomáš Trávníček
doctrine-dbal
Commits
6ef0cc99
Commit
6ef0cc99
authored
Jun 05, 2007
by
zYne
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
--no commit message
--no commit message
parent
c697f09f
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
95 additions
and
13 deletions
+95
-13
AuditLog.php
lib/Doctrine/AuditLog.php
+87
-12
Record.php
lib/Doctrine/Record.php
+8
-1
No files found.
lib/Doctrine/AuditLog.php
View file @
6ef0cc99
...
...
@@ -31,20 +31,90 @@
*/
class
Doctrine_AuditLog
{
protected
$_options
=
array
(
'className'
=>
'%CLASS%Version'
,
'deleteTrigger'
=>
'%TABLE%_ddt'
,
'updateTrigger'
=>
'%TABLE%_dut'
,
'versionTable'
=>
'%TABLE%_dvt'
,
'identifier'
=>
'__version'
,
);
protected
$_table
;
public
function
__construct
(
Doctrine_Table
$table
)
{
$this
->
_table
=
$table
;
}
public
function
audit
()
{
$conn
=
$this
->
_table
->
getConnection
();
// begin new transaction
$conn
->
beginTransaction
();
try
{
// create the version table and the triggers
$this
->
createVersionTable
();
$conn
->
execute
(
$this
->
deleteTriggerSql
());
$conn
->
execute
(
$this
->
updateTriggerSql
());
// commit structure changes
$conn
->
commit
();
}
catch
(
Doctrine_Connection_Exception
$e
)
{
$conn
->
rollback
();
}
}
public
function
createVersionTable
()
{
$data
=
$this
->
_table
->
getExportableFormat
(
false
);
$conn
=
$this
->
_table
->
getConnection
();
$data
[
'tableName'
]
=
str_replace
(
'%TABLE%'
,
$data
[
'tableName'
],
$this
->
_options
[
'versionTable'
]);
foreach
(
$data
[
'columns'
]
as
$name
=>
$def
)
{
unset
(
$data
[
'columns'
][
$name
][
'autoinc'
]);
unset
(
$data
[
'columns'
][
$name
][
'autoincrement'
]);
unset
(
$data
[
'columns'
][
$name
][
'sequence'
]);
unset
(
$data
[
'columns'
][
$name
][
'seq'
]);
}
$data
[
'columns'
]
=
array_merge
(
array
(
$this
->
_options
[
'identifier'
]
=>
array
(
'type'
=>
'integer'
,
'primary'
=>
true
,
'autoinc'
=>
true
)),
$data
[
'columns'
]);
$definition
=
'class '
.
str_replace
(
'%CLASS%'
,
$this
->
_table
->
getComponentName
(),
$this
->
_options
[
'className'
])
.
' extends Doctrine_Record { '
.
'public function setTableDefinition() { '
.
'$this->hasColumns('
.
var_export
(
$data
[
'columns'
],
true
)
.
');'
.
'$this->option(\'tableName\', \''
.
$data
[
'tableName'
]
.
'\'); } }'
;
print
$definition
;
eval
(
$definition
);
$data
[
'options'
][
'primary'
]
=
array
(
$this
->
_options
[
'identifier'
]);
$conn
->
export
->
createTable
(
$data
[
'tableName'
],
$data
[
'columns'
],
$data
[
'options'
]);
}
public
function
deleteTriggerSql
(
Doctrine_Table
$table
)
/**
* deleteTriggerSql
*
* returns the sql needed for the delete trigger creation
*/
public
function
deleteTriggerSql
()
{
$conn
=
$table
->
getConnection
();
$columnNames
=
$table
->
getColumnNames
();
$conn
=
$t
his
->
_t
able
->
getConnection
();
$columnNames
=
$t
his
->
_t
able
->
getColumnNames
();
$oldColumns
=
array_map
(
array
(
$this
,
'formatOld'
),
$columnNames
);
$sql
=
'CREATE TRIGGER '
.
$conn
->
quoteIdentifier
(
$table
->
getTableName
())
.
'_ddt'
.
' DELETE ON '
.
$conn
->
quoteIdentifier
(
$table
->
getTableName
())
.
$conn
->
quoteIdentifier
(
$t
his
->
_t
able
->
getTableName
())
.
'_ddt'
.
' DELETE ON '
.
$conn
->
quoteIdentifier
(
$t
his
->
_t
able
->
getTableName
())
.
' BEGIN'
.
' INSERT INTO '
.
$table
->
getTableName
()
.
'_dvt ('
.
' INSERT INTO '
.
$t
his
->
_t
able
->
getTableName
()
.
'_dvt ('
.
implode
(
', '
,
array_map
(
array
(
$conn
,
'quoteIdentifier'
),
$columnNames
))
.
') VALUES ('
.
implode
(
', '
,
array_map
(
array
(
$conn
,
'quoteIdentifier'
),
$oldColumns
))
...
...
@@ -52,16 +122,21 @@ class Doctrine_AuditLog
.
' END;'
;
return
$sql
;
}
public
function
updateTriggerSql
(
Doctrine_Table
$table
)
/**
* updateTriggerSql
*
* returns the sql needed for the update trigger creation
*/
public
function
updateTriggerSql
()
{
$conn
=
$table
->
getConnection
();
$columnNames
=
$table
->
getColumnNames
();
$conn
=
$t
his
->
_t
able
->
getConnection
();
$columnNames
=
$t
his
->
_t
able
->
getColumnNames
();
$oldColumns
=
array_map
(
array
(
$this
,
'formatOld'
),
$columnNames
);
$sql
=
'CREATE TRIGGER '
.
$conn
->
quoteIdentifier
(
$table
->
getTableName
())
.
'_dut'
.
' UPDATE ON '
.
$conn
->
quoteIdentifier
(
$table
->
getTableName
())
.
$conn
->
quoteIdentifier
(
$t
his
->
_t
able
->
getTableName
())
.
'_dut'
.
' UPDATE ON '
.
$conn
->
quoteIdentifier
(
$t
his
->
_t
able
->
getTableName
())
.
' BEGIN'
.
' INSERT INTO '
.
$table
->
getTableName
()
.
'_dvt ('
.
' INSERT INTO '
.
$t
his
->
_t
able
->
getTableName
()
.
'_dvt ('
.
implode
(
', '
,
array_map
(
array
(
$conn
,
'quoteIdentifier'
),
$columnNames
))
.
') VALUES ('
.
implode
(
', '
,
array_map
(
array
(
$conn
,
'quoteIdentifier'
),
$oldColumns
))
...
...
lib/Doctrine/Record.php
View file @
6ef0cc99
...
...
@@ -1339,10 +1339,17 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
* @param mixed $options
* @return void
*/
final
public
function
hasColumn
(
$name
,
$type
,
$length
=
2147483647
,
$options
=
""
)
public
function
hasColumn
(
$name
,
$type
,
$length
=
2147483647
,
$options
=
""
)
{
$this
->
_table
->
setColumn
(
$name
,
$type
,
$length
,
$options
);
}
public
function
hasColumns
(
array
$definitions
)
{
foreach
(
$definitions
as
$name
=>
$options
)
{
$this
->
hasColumn
(
$name
,
$options
[
'type'
],
$options
[
'length'
],
$options
);
}
}
/**
* countRelated
*
...
...
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