Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
File Manager
/
wp-content
/
plugins
/
google-site-kit
/
third-party
/
phpseclib
/
phpseclib
/
phpseclib
/
Math
:
PrimeField.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php /** * Prime Finite Fields * * Utilizes the factory design pattern * * PHP version 5 and 7 * * @author Jim Wigginton <terrafrost@php.net> * @copyright 2017 Jim Wigginton * @license http://www.opensource.org/licenses/mit-license.html MIT License * @link http://pear.php.net/package/Math_BigInteger */ namespace Google\Site_Kit_Dependencies\phpseclib3\Math; use Google\Site_Kit_Dependencies\phpseclib3\Math\Common\FiniteField; use Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer; /** * Prime Finite Fields * * @author Jim Wigginton <terrafrost@php.net> */ class PrimeField extends \Google\Site_Kit_Dependencies\phpseclib3\Math\Common\FiniteField { /** * Instance Counter * * @var int */ private static $instanceCounter = 0; /** * Keeps track of current instance * * @var int */ protected $instanceID; /** * Default constructor */ public function __construct(\Google\Site_Kit_Dependencies\phpseclib3\Math\BigInteger $modulo) { if (!$modulo->isPrime()) { throw new \UnexpectedValueException('PrimeField requires a prime number be passed to the constructor'); } $this->instanceID = self::$instanceCounter++; \Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer::setModulo($this->instanceID, $modulo); \Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer::setRecurringModuloFunction($this->instanceID, $modulo->createRecurringModuloFunction()); } /** * Use a custom defined modular reduction function * * @return void */ public function setReduction(\Closure $func) { $this->reduce = $func->bindTo($this, $this); } /** * Returns an instance of a dynamically generated PrimeFieldInteger class * * @return Integer */ public function newInteger(\Google\Site_Kit_Dependencies\phpseclib3\Math\BigInteger $num) { return new \Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer($this->instanceID, $num); } /** * Returns an integer on the finite field between one and the prime modulo * * @return Integer */ public function randomInteger() { static $one; if (!isset($one)) { $one = new \Google\Site_Kit_Dependencies\phpseclib3\Math\BigInteger(1); } return new \Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer($this->instanceID, \Google\Site_Kit_Dependencies\phpseclib3\Math\BigInteger::randomRange($one, \Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer::getModulo($this->instanceID))); } /** * Returns the length of the modulo in bytes * * @return int */ public function getLengthInBytes() { return \Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer::getModulo($this->instanceID)->getLengthInBytes(); } /** * Returns the length of the modulo in bits * * @return int */ public function getLength() { return \Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer::getModulo($this->instanceID)->getLength(); } /** * Destructor */ public function __destruct() { \Google\Site_Kit_Dependencies\phpseclib3\Math\PrimeField\Integer::cleanupCache($this->instanceID); } }