Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F97009801
PhabricatorHighSecurityRequestExceptionHandler.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
Wed, Jan 1, 14:34
Size
2 KB
Mime Type
text/x-php
Expires
Fri, Jan 3, 14:34 (2 d)
Engine
blob
Format
Raw Data
Handle
23311006
Attached To
rPH Phabricator
PhabricatorHighSecurityRequestExceptionHandler.php
View Options
<?php
final
class
PhabricatorHighSecurityRequestExceptionHandler
extends
PhabricatorRequestExceptionHandler
{
public
function
getRequestExceptionHandlerPriority
()
{
return
310000
;
}
public
function
getRequestExceptionHandlerDescription
()
{
return
pht
(
'Handles high security exceptions which occur when a user needs '
.
'to present MFA credentials to take an action.'
);
}
public
function
canHandleRequestThrowable
(
AphrontRequest
$request
,
$throwable
)
{
if
(!
$this
->
isPhabricatorSite
(
$request
))
{
return
false
;
}
return
(
$throwable
instanceof
PhabricatorAuthHighSecurityRequiredException
);
}
public
function
handleRequestThrowable
(
AphrontRequest
$request
,
$throwable
)
{
$viewer
=
$this
->
getViewer
(
$request
);
$form
=
id
(
new
PhabricatorAuthSessionEngine
())->
renderHighSecurityForm
(
$throwable
->
getFactors
(),
$throwable
->
getFactorValidationResults
(),
$viewer
,
$request
);
$dialog
=
id
(
new
AphrontDialogView
())
->
setUser
(
$viewer
)
->
setTitle
(
pht
(
'Entering High Security'
))
->
setShortTitle
(
pht
(
'Security Checkpoint'
))
->
setWidth
(
AphrontDialogView
::
WIDTH_FORM
)
->
addHiddenInput
(
AphrontRequest
::
TYPE_HISEC
,
true
)
->
setErrors
(
array
(
pht
(
'You are taking an action which requires you to enter '
.
'high security.'
),
))
->
appendParagraph
(
pht
(
'High security mode helps protect your account from security '
.
'threats, like session theft or someone messing with your stuff '
.
'while you
\'
re grabbing a coffee. To enter high security mode, '
.
'confirm your credentials.'
))
->
appendChild
(
$form
->
buildLayoutView
())
->
appendParagraph
(
pht
(
'Your account will remain in high security mode for a short '
.
'period of time. When you are finished taking sensitive '
.
'actions, you should leave high security.'
))
->
setSubmitURI
(
$request
->
getPath
())
->
addCancelButton
(
$throwable
->
getCancelURI
())
->
addSubmitButton
(
pht
(
'Enter High Security'
));
$request_parameters
=
$request
->
getPassthroughRequestParameters
(
$respect_quicksand
=
true
);
foreach
(
$request_parameters
as
$key
=>
$value
)
{
$dialog
->
addHiddenInput
(
$key
,
$value
);
}
return
$dialog
;
}
}
Event Timeline
Log In to Comment