Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F97211028
PhabricatorAuthSession.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
Fri, Jan 3, 11:54
Size
2 KB
Mime Type
text/x-php
Expires
Sun, Jan 5, 11:54 (2 d)
Engine
blob
Format
Raw Data
Handle
23285942
Attached To
rPH Phabricator
PhabricatorAuthSession.php
View Options
<?php
final
class
PhabricatorAuthSession
extends
PhabricatorAuthDAO
implements
PhabricatorPolicyInterface
{
const
TYPE_WEB
=
'web'
;
const
TYPE_CONDUIT
=
'conduit'
;
protected
$userPHID
;
protected
$type
;
protected
$sessionKey
;
protected
$sessionStart
;
protected
$sessionExpires
;
protected
$highSecurityUntil
;
protected
$isPartial
;
private
$identityObject
=
self
::
ATTACHABLE
;
protected
function
getConfiguration
()
{
return
array
(
self
::
CONFIG_TIMESTAMPS
=>
false
,
self
::
CONFIG_COLUMN_SCHEMA
=>
array
(
'type'
=>
'text32'
,
'sessionKey'
=>
'bytes40'
,
'sessionStart'
=>
'epoch'
,
'sessionExpires'
=>
'epoch'
,
'highSecurityUntil'
=>
'epoch?'
,
'isPartial'
=>
'bool'
,
),
self
::
CONFIG_KEY_SCHEMA
=>
array
(
'sessionKey'
=>
array
(
'columns'
=>
array
(
'sessionKey'
),
'unique'
=>
true
,
),
'key_identity'
=>
array
(
'columns'
=>
array
(
'userPHID'
,
'type'
),
),
'key_expires'
=>
array
(
'columns'
=>
array
(
'sessionExpires'
),
),
),
)
+
parent
::
getConfiguration
();
}
public
function
getApplicationName
()
{
// This table predates the "Auth" application, and really all applications.
return
'user'
;
}
public
function
getTableName
()
{
// This is a very old table with a nonstandard name.
return
PhabricatorUser
::
SESSION_TABLE
;
}
public
function
attachIdentityObject
(
$identity_object
)
{
$this
->
identityObject
=
$identity_object
;
return
$this
;
}
public
function
getIdentityObject
()
{
return
$this
->
assertAttached
(
$this
->
identityObject
);
}
public
static
function
getSessionTypeTTL
(
$session_type
)
{
switch
(
$session_type
)
{
case
self
::
TYPE_WEB
:
return
phutil_units
(
'30 days in seconds'
);
case
self
::
TYPE_CONDUIT
:
return
phutil_units
(
'24 hours in seconds'
);
default
:
throw
new
Exception
(
pht
(
'Unknown session type "%s".'
,
$session_type
));
}
}
/* -( PhabricatorPolicyInterface )----------------------------------------- */
public
function
getCapabilities
()
{
return
array
(
PhabricatorPolicyCapability
::
CAN_VIEW
,
);
}
public
function
getPolicy
(
$capability
)
{
return
PhabricatorPolicies
::
POLICY_NOONE
;
}
public
function
hasAutomaticCapability
(
$capability
,
PhabricatorUser
$viewer
)
{
if
(!
$viewer
->
getPHID
())
{
return
false
;
}
$object
=
$this
->
getIdentityObject
();
if
(
$object
instanceof
PhabricatorUser
)
{
return
(
$object
->
getPHID
()
==
$viewer
->
getPHID
());
}
else
if
(
$object
instanceof
PhabricatorExternalAccount
)
{
return
(
$object
->
getUserPHID
()
==
$viewer
->
getPHID
());
}
return
false
;
}
public
function
describeAutomaticCapability
(
$capability
)
{
return
pht
(
'A session is visible only to its owner.'
);
}
}
Event Timeline
Log In to Comment