Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F17826727
ManiphestTaskProject.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
1 KB
Referenced Files
None
Subscribers
None
ManiphestTaskProject.php
View Options
<?php
/**
* This is a DAO for the Task -> Project table, which denormalizes the
* relationship between tasks and projects into a link table so it can be
* efficiently queried. This table is not authoritative; the projectPHIDs field
* of ManiphestTask is. The rows in this table are regenerated when transactions
* are applied to tasks which affected their associated projects.
*
* @group maniphest
*/
final
class
ManiphestTaskProject
extends
ManiphestDAO
{
protected
$taskPHID
;
protected
$projectPHID
;
public
function
getConfiguration
()
{
return
array
(
self
::
CONFIG_IDS
=>
self
::
IDS_MANUAL
,
self
::
CONFIG_TIMESTAMPS
=>
false
,
);
}
public
static
function
updateTaskProjects
(
ManiphestTask
$task
)
{
$dao
=
new
ManiphestTaskProject
();
$conn
=
$dao
->
establishConnection
(
'w'
);
$sql
=
array
();
foreach
(
$task
->
getProjectPHIDs
()
as
$project_phid
)
{
$sql
[]
=
qsprintf
(
$conn
,
'(%s, %s)'
,
$task
->
getPHID
(),
$project_phid
);
}
queryfx
(
$conn
,
'DELETE FROM %T WHERE taskPHID = %s'
,
$dao
->
getTableName
(),
$task
->
getPHID
());
if
(
$sql
)
{
queryfx
(
$conn
,
'INSERT INTO %T (taskPHID, projectPHID) VALUES %Q'
,
$dao
->
getTableName
(),
implode
(
', '
,
$sql
));
}
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Mon, Jul 28, 7:35 AM (1 d, 6 h ago)
Storage Engine
blob
Storage Format
Encrypted (AES-256-CBC)
Storage Handle
8240510
Default Alt Text
ManiphestTaskProject.php (1 KB)
Attached To
Mode
rP Phabricator
Attached
Detach File
Event Timeline
Log In to Comment