Page MenuHomeDevCentral

Use cryptographically secure pseudo-random integers
ClosedPublic

Authored by dereckson on Apr 9 2022, 12:04.
Tags
None
Referenced Files
F10082618: D2656.id6716.diff
Wed, Jun 18, 16:06
F10064398: D2656.id6715.diff
Wed, Jun 18, 10:48
F10041326: D2656.id6715.diff
Wed, Jun 18, 01:38
F10041211: D2656.id6716.diff
Wed, Jun 18, 01:35
Unknown Object (File)
Thu, Jun 12, 14:37
Unknown Object (File)
Wed, Jun 11, 19:31
Unknown Object (File)
Sat, Jun 7, 12:07
Unknown Object (File)
Fri, Jun 6, 05:15
Subscribers
None

Details

Summary

Methods from Identifiers\Random were currently implemented using
the Mersenne Twister general-purpose pseudorandom number generator.

As randomness is often used as a source to generate credentials,
and to also offer unbiaised results for games, this changes switch
to the CSPRNG method random_int. The random_bytes method was already used.

According PHP manual, the "cryptographically secure pseudo-random number
generator (CSPRNG) API provides an easy and reliable way to generate
crypto-strong random integers and bytes for use within cryptographic contexts."

As our library is PHP 7+ (actually PHP 8.1+), the CSPRNG methods are always
available.

Test Plan

Run unit tests, no regression detected.

Diff Detail

Repository
rKERUALD Keruald libraries development repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable