summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
4b8ba73)
Protect constructor from unset range
Cleanup
# Register slugger util service
rapsyspack.slugger_util:
class: 'Rapsys\PackBundle\Util\SluggerUtil'
# Register slugger util service
rapsyspack.slugger_util:
class: 'Rapsys\PackBundle\Util\SluggerUtil'
- arguments: [ '%env(string:RAPSYSPACK_RANGE)%', '%kernel.secret%' ]
+ arguments: [ '%kernel.secret%' ]
public: true
# Register range command
Rapsys\PackBundle\Command\RangeCommand:
public: true
# Register range command
Rapsys\PackBundle\Command\RangeCommand:
/**
* Construct slugger util
*
/**
* Construct slugger util
*
- * @description Run "php bin/console rapsyspack:range" to generate RAPSYSPACK_RANGE="ayl[...]z9w" range in .env.local
+ * Run "bin/console rapsyspack:range" to generate RAPSYSPACK_RANGE="ayl[...]z9w" range in .env.local
*
* @todo Use Cache like in calendar controller through FilesystemAdapter ?
*
*
* @todo Use Cache like in calendar controller through FilesystemAdapter ?
*
- * @param string $range The shuffled range string
* @param string $secret The secret string
*/
* @param string $secret The secret string
*/
- public function __construct(protected string $range, protected string $secret) {
+ public function __construct(protected string $secret) {
+ //Without range
+ if (empty($range = $_ENV['RAPSYSPACK_RANGE']) || $range === 'Ch4ng3m3!') {
+ //Protect member variable setup
+ return;
+ }
+
/**
* Get pseuto-random alphabet by splitting range string
* TODO: see required range by json_encode result and short input (0->255 ???)
* XXX: The key count mismatch, count(alpha)>count(rev), resulted in a data corruption due to duplicate numeric values
*/
/**
* Get pseuto-random alphabet by splitting range string
* TODO: see required range by json_encode result and short input (0->255 ???)
* XXX: The key count mismatch, count(alpha)>count(rev), resulted in a data corruption due to duplicate numeric values
*/
- $this->alpha = str_split($this->range);
+ $this->alpha = str_split($range);
//Init rev array
$this->count = count($rev = $this->rev = array_flip($this->alpha));
//Init rev array
$this->count = count($rev = $this->rev = array_flip($this->alpha));
$split = str_split($this->secret);
//Set offset
$split = str_split($this->secret);
//Set offset
+ //TODO: protect undefined index ?
$this->offset = array_reduce($split, function ($res, $a) use ($rev) { return $res += $rev[$a]; }, count($split)) % $this->count;
}
$this->offset = array_reduce($split, function ($res, $a) use ($rev) { return $res += $rev[$a]; }, count($split)) % $this->count;
}