Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F568013
PhabricatorUserCache.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Size
3 KB
Referenced Files
None
Subscribers
None
PhabricatorUserCache.php
View Options
<?php
final
class
PhabricatorUserCache
extends
PhabricatorUserDAO
{
protected
$userPHID
;
protected
$cacheIndex
;
protected
$cacheKey
;
protected
$cacheData
;
protected
$cacheType
;
protected
function
getConfiguration
()
{
return
array
(
self
::
CONFIG_TIMESTAMPS
=>
false
,
self
::
CONFIG_COLUMN_SCHEMA
=>
array
(
'cacheIndex'
=>
'bytes12'
,
'cacheKey'
=>
'text255'
,
'cacheData'
=>
'text'
,
'cacheType'
=>
'text32'
,
),
self
::
CONFIG_KEY_SCHEMA
=>
array
(
'key_usercache'
=>
array
(
'columns'
=>
array
(
'userPHID'
,
'cacheIndex'
),
'unique'
=>
true
,
),
'key_cachekey'
=>
array
(
'columns'
=>
array
(
'cacheIndex'
),
),
'key_cachetype'
=>
array
(
'columns'
=>
array
(
'cacheType'
),
),
),
)
+
parent
::
getConfiguration
();
}
public
static
function
writeCache
(
PhabricatorUserCacheType
$type
,
$key
,
$user_phid
,
$raw_value
)
{
self
::
writeCaches
(
array
(
array
(
'type'
=>
$type
,
'key'
=>
$key
,
'userPHID'
=>
$user_phid
,
'value'
=>
$raw_value
,
),
));
}
public
static
function
writeCaches
(
array
$values
)
{
if
(
PhabricatorEnv
::
isReadOnly
())
{
return
;
}
if
(!
$values
)
{
return
;
}
$table
=
new
self
();
$conn_w
=
$table
->
establishConnection
(
'w'
);
$sql
=
array
();
foreach
(
$values
as
$value
)
{
$key
=
$value
[
'key'
];
$sql
[]
=
qsprintf
(
$conn_w
,
'(%s, %s, %s, %s, %s)'
,
$value
[
'userPHID'
],
PhabricatorHash
::
digestForIndex
(
$key
),
$key
,
$value
[
'value'
],
$value
[
'type'
]->
getUserCacheType
());
}
$unguarded
=
AphrontWriteGuard
::
beginScopedUnguardedWrites
();
foreach
(
PhabricatorLiskDAO
::
chunkSQL
(
$sql
)
as
$chunk
)
{
queryfx
(
$conn_w
,
'INSERT INTO %T (userPHID, cacheIndex, cacheKey, cacheData, cacheType)
VALUES %LQ
ON DUPLICATE KEY UPDATE
cacheData = VALUES(cacheData),
cacheType = VALUES(cacheType)'
,
$table
->
getTableName
(),
$chunk
);
}
unset
(
$unguarded
);
}
public
static
function
readCaches
(
PhabricatorUserCacheType
$type
,
$key
,
array
$user_phids
)
{
$table
=
new
self
();
$conn
=
$table
->
establishConnection
(
'r'
);
$rows
=
queryfx_all
(
$conn
,
'SELECT userPHID, cacheData FROM %T WHERE userPHID IN (%Ls)
AND cacheType = %s AND cacheIndex = %s'
,
$table
->
getTableName
(),
$user_phids
,
$type
->
getUserCacheType
(),
PhabricatorHash
::
digestForIndex
(
$key
));
return
ipull
(
$rows
,
'cacheData'
,
'userPHID'
);
}
public
static
function
clearCache
(
$key
,
$user_phid
)
{
return
self
::
clearCaches
(
$key
,
array
(
$user_phid
));
}
public
static
function
clearCaches
(
$key
,
array
$user_phids
)
{
if
(
PhabricatorEnv
::
isReadOnly
())
{
return
;
}
if
(!
$user_phids
)
{
return
;
}
$table
=
new
self
();
$conn_w
=
$table
->
establishConnection
(
'w'
);
$unguarded
=
AphrontWriteGuard
::
beginScopedUnguardedWrites
();
queryfx
(
$conn_w
,
'DELETE FROM %T WHERE cacheIndex = %s AND userPHID IN (%Ls)'
,
$table
->
getTableName
(),
PhabricatorHash
::
digestForIndex
(
$key
),
$user_phids
);
unset
(
$unguarded
);
}
public
static
function
clearCacheForAllUsers
(
$key
)
{
if
(
PhabricatorEnv
::
isReadOnly
())
{
return
;
}
$table
=
new
self
();
$conn_w
=
$table
->
establishConnection
(
'w'
);
$unguarded
=
AphrontWriteGuard
::
beginScopedUnguardedWrites
();
queryfx
(
$conn_w
,
'DELETE FROM %T WHERE cacheIndex = %s'
,
$table
->
getTableName
(),
PhabricatorHash
::
digestForIndex
(
$key
));
unset
(
$unguarded
);
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Tue, May 13, 1:11 PM (1 d, 23 h)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
98451
Default Alt Text
PhabricatorUserCache.php (3 KB)
Attached To
Mode
rP Phorge
Attached
Detach File
Event Timeline
Log In to Comment