Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F105842231
PhabricatorFactCountEngine.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Thu, Mar 20, 04:38
Size
2 KB
Mime Type
text/x-php
Expires
Sat, Mar 22, 04:38 (2 d)
Engine
blob
Format
Raw Data
Handle
25041237
Attached To
rPH Phabricator
PhabricatorFactCountEngine.php
View Options
<?php
/**
* Simple fact engine which counts objects.
*/
final
class
PhabricatorFactCountEngine
extends
PhabricatorFactEngine
{
public
function
getFactSpecs
(
array
$fact_types
)
{
$results
=
array
();
foreach
(
$fact_types
as
$type
)
{
if
(!
strncmp
(
$type
,
'+N:'
,
3
))
{
if
(
$type
==
'+N:*'
)
{
$name
=
pht
(
'Total Objects'
);
}
else
{
$name
=
pht
(
'Total Objects of type %s'
,
substr
(
$type
,
3
));
}
$results
[]
=
id
(
new
PhabricatorFactSimpleSpec
(
$type
))
->
setName
(
$name
)
->
setUnit
(
PhabricatorFactSimpleSpec
::
UNIT_COUNT
);
}
if
(!
strncmp
(
$type
,
'N:'
,
2
))
{
if
(
$type
==
'N:*'
)
{
$name
=
pht
(
'Objects'
);
}
else
{
$name
=
pht
(
'Objects of type %s'
,
substr
(
$type
,
2
));
}
$results
[]
=
id
(
new
PhabricatorFactSimpleSpec
(
$type
))
->
setName
(
$name
)
->
setUnit
(
PhabricatorFactSimpleSpec
::
UNIT_COUNT
);
}
}
return
$results
;
}
public
function
shouldComputeRawFactsForObject
(
PhabricatorLiskDAO
$object
)
{
return
true
;
}
public
function
computeRawFactsForObject
(
PhabricatorLiskDAO
$object
)
{
$facts
=
array
();
$phid
=
$object
->
getPHID
();
$type
=
phid_get_type
(
$phid
);
foreach
(
array
(
'N:*'
,
'N:'
.
$type
)
as
$fact_type
)
{
$facts
[]
=
id
(
new
PhabricatorFactRaw
())
->
setFactType
(
$fact_type
)
->
setObjectPHID
(
$phid
)
->
setValueX
(
1
)
->
setEpoch
(
$object
->
getDateCreated
());
}
return
$facts
;
}
public
function
shouldComputeAggregateFacts
()
{
return
true
;
}
public
function
computeAggregateFacts
()
{
$table
=
new
PhabricatorFactRaw
();
$table_name
=
$table
->
getTableName
();
$conn
=
$table
->
establishConnection
(
'r'
);
$counts
=
queryfx_all
(
$conn
,
'SELECT factType, SUM(valueX) N FROM %T WHERE factType LIKE %>
GROUP BY factType'
,
$table_name
,
'N:'
);
$facts
=
array
();
foreach
(
$counts
as
$count
)
{
$facts
[]
=
id
(
new
PhabricatorFactAggregate
())
->
setFactType
(
'+'
.
$count
[
'factType'
])
->
setValueX
(
$count
[
'N'
]);
}
return
$facts
;
}
}
Event Timeline
Log In to Comment