Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F3282286
PhutilOpaqueEnvelope.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Award Token
Flag For Later
Advanced/Developer...
View Handle
View Hovercard
Size
1 KB
Referenced Files
None
Subscribers
None
PhutilOpaqueEnvelope.php
View Options
<?php
/**
* Opaque reference to a string (like a password) that won't put any sensitive
* data in stack traces, var_dump(), print_r(), error logs, etc. Usage:
*
* $envelope = new PhutilOpaqueEnvelope($password);
* do_stuff($envelope);
* // ...
* $password = $envelope->openEnvelope();
*
* Any time you're passing sensitive data into a stack, you should obscure it
* with an envelope to prevent it leaking if something goes wrong.
*
* The key for the envelope is stored elsewhere, in
* @{class:PhutilOpaqueEnvelopeKey}. This prevents it from appearing in
* any sort of logs related to the envelope, even if the logger is very
* aggressive.
*
* @task envelope Using Opaque Envelopes
* @task internal Internals
*/
final
class
PhutilOpaqueEnvelope
extends
Phobject
{
private
$value
;
/* -( Using Opaque Envelopes )--------------------------------------------- */
/**
* @task envelope
*/
public
function
__construct
(
$string
)
{
$this
->
value
=
$this
->
mask
(
$string
,
PhutilOpaqueEnvelopeKey
::
getKey
(
)
)
;
}
/**
* @task envelope
*/
public
function
openEnvelope
(
)
{
return
$this
->
mask
(
$this
->
value
,
PhutilOpaqueEnvelopeKey
::
getKey
(
)
)
;
}
/**
* @task envelope
*/
public
function
__toString
(
)
{
return
pht
(
'<opaque envelope>'
)
;
}
/* -( Internals )---------------------------------------------------------- */
/**
* @task internal
*/
private
function
mask
(
$string
,
$noise
)
{
$result
=
''
;
for
(
$ii
=
0
;
$ii
<
strlen
(
$string
)
;
$ii
++
)
{
$s
=
$string
[
$ii
]
;
$n
=
$noise
[
$ii
%
strlen
(
$noise
)
]
;
$result
.=
chr
(
ord
(
$s
)
^
ord
(
$n
)
)
;
}
return
$result
;
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Mon, Mar 24, 06:51 (1 w, 2 d ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
1142503
Default Alt Text
PhutilOpaqueEnvelope.php (1 KB)
Attached To
Mode
rARC Arcanist
Attached
Detach File
Event Timeline
Log In to Comment