Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

draft: Final touches (closes #147, #135, #133, #132, #124, #111, #100, #92, #82, #81, #57, #54) #154

Open
wants to merge 50 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
2480131
chore: remove deprecated classes
recanman May 2, 2024
2c8311e
chore: remove old example.php
recanman May 2, 2024
5e417b6
style: format files
recanman May 2, 2024
ac1513f
feat: rename library, bump php, add phpunit test support
recanman May 2, 2024
612c909
feat: add new Mnemonic class
recanman May 2, 2024
ea70d6d
ci: add security and test workflows
recanman May 2, 2024
32702a5
feat: partially-refactored varint class and tests
recanman May 2, 2024
dc74c82
chore: delete old base58 class
recanman May 9, 2024
4eead4b
feat: implement base58 encode and tests
recanman May 9, 2024
95d72fc
docs: block comments for Base58
recanman May 9, 2024
1a699c7
feat: implement Monero base58 decode
recanman May 9, 2024
d374296
fix: use base58 static methods in Cryptonote, set namespace
recanman May 9, 2024
0b269e5
feat: add some Cryptonote tests
recanman May 16, 2024
793f73e
feat: BigInt, use it in base58
recanman May 16, 2024
1c89c99
chore: improve composer.json gmp suggestion msg
recanman May 16, 2024
5f5eecc
docs: grammatical error in comment
recanman May 16, 2024
6bbbac1
feat: add tests for BigInteger class
recanman May 16, 2024
69b9a6f
ci: add release action
recanman May 25, 2024
461773f
docs: add documentation on publishing
recanman May 25, 2024
2d5d318
ci: change main to master
recanman May 25, 2024
873fdb0
fix: allow mixed input to various BigInteger functions
recanman May 27, 2024
9b05ea7
chore: remove ext-curl dependency
recanman May 27, 2024
cfb4d06
feat: BigInteger bitshift left and right
recanman May 27, 2024
8b9bf27
feat: add bitshift left/right to BigInteger
recanman Jun 1, 2024
51a0bf9
feat: partially implement new ed25519 class
recanman Jun 1, 2024
c9273b7
chore: delete redundant subaddress class
recanman Jun 1, 2024
5d9a8f4
chore: delete old ed25519 class
recanman Jun 1, 2024
457ab44
feat: MoneroNetwork enum in Cryptonote, declare strict types
recanman Jun 1, 2024
95b081c
fix: declare Cryptonote type in test
recanman Jun 1, 2024
8db754c
chore: comment out failing Cryptonote tests until functions fixed (te…
recanman Jun 1, 2024
4945605
feat: accept MoneroNetwork enum in Cryptonote constructor
recanman Jun 1, 2024
87497ea
feat: implement Ed25519 point encoding
recanman Jun 2, 2024
a7b9059
test: add another point test
recanman Jun 2, 2024
a76b1ab
feat: implement bit and decodepoint
recanman Jun 2, 2024
f0a0e6a
chore: remove unused parameter
recanman Jun 2, 2024
54f8d73
chore: fix wordset docstrings
recanman Jun 2, 2024
b4db214
chore: fix many phpstan errors
recanman Jun 2, 2024
40d5f0a
test: add negative base58 test
recanman Jun 2, 2024
04e86f1
test: edwards and scalarmult test, formatting
recanman Jun 5, 2024
2e1d826
fix: edwards implementation
recanman Jun 5, 2024
b6f49d2
fix: don't convert to int in bit
recanman Jun 5, 2024
f732277
fix: decodepoint
recanman Jun 5, 2024
002394c
test: ed25519 public key
recanman Jun 5, 2024
114fbaa
test: sc_reduce
recanman Jun 5, 2024
43f11ad
fix: duplicate declaration of network_prefixes
recanman Aug 3, 2024
b2831a5
style: add editorconfig and format files
recanman Aug 3, 2024
8611a82
refactor: use new classes and clean up cryptonote code
recanman Aug 3, 2024
b2d91ab
chore: remove unneeded extension
recanman Aug 3, 2024
40031d0
docs: rewrite readme
recanman Aug 3, 2024
d3d8223
docs: add mnemonic.md
recanman Aug 3, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat: BigInt, use it in base58
  • Loading branch information
recanman committed May 16, 2024
commit 793f73ebfbb385ae5049f5c2f48ce24a0328fed5
50 changes: 24 additions & 26 deletions src/Base58.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,27 +4,26 @@

namespace MoneroIntegrations\MoneroCrypto;

use \Exception;
use Exception;

class Base58
{
const ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';
const ALPHABET_SIZE = "58";
const BLOCK_SIZE = 8;
const ENCODED_BLOCK_SIZES = [0, 2, 3, 5, 6, 7, 9, 10, 11];
const FULL_ENCODED_BLOCK_SIZE = 11;
public const ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';
public const ALPHABET_SIZE = 58;
public const BLOCK_SIZE = 8;
public const ENCODED_BLOCK_SIZES = [0, 2, 3, 5, 6, 7, 9, 10, 11];
public const FULL_ENCODED_BLOCK_SIZE = 11;

/**
* Converts an array of unsigned 8-bit big-endian integers to a 64-bit unsigned integer.
*/
private static function uint8beTo64(array $data): string
private static function uint8beTo64(array $data): BigInteger
{
$res = '0';
$res = new BigInteger(0);
$size = count($data);

for ($i = 0; $i < $size; $i++) {
$res = bcmul($res, '256');
$res = bcadd($res, (string)ord($data[$i]));
$res = $res->mul(256)->add(ord($data[$i]));
}

return $res;
Expand All @@ -33,13 +32,13 @@ private static function uint8beTo64(array $data): string
/**
* Converts a decimal string to a hexadecimal string.
*/
private static function decToHex(string $dec): string
private static function decToHex(BigInteger $dec): string
{
$res = '';
while (bccomp($dec, '0') > 0) {
$remainder = bcmod($dec, '16');
$dec = bcdiv($dec, '16');
$res = dechex((int)$remainder) . $res;
while (!$dec->equals(0)) {
$remainder = $dec->mod(16);
$dec = $dec->div(16);
$res = dechex((int)$remainder->toDec()).$res;
}

return $res;
Expand All @@ -53,16 +52,16 @@ private static function encodeBlock(array $data, array $res, int $res_offset): a
$length = count($data);

if ($length < 1 || $length > self::FULL_ENCODED_BLOCK_SIZE) {
throw new Exception("Invalid block length: " . $length);
throw new Exception("Invalid block length: ". $length);
}

$num = self::uint8beTo64($data);
$i = self::ENCODED_BLOCK_SIZES[$length] - 1;

while ($num > 0) {
$remainder = bcmod($num, self::ALPHABET_SIZE);
$num = bcdiv($num, self::ALPHABET_SIZE);
$res[$res_offset + $i] = self::ALPHABET[$remainder];
while (!$num->equals(0)) {
$remainder = $num->mod(self::ALPHABET_SIZE);
$num = $num->div(self::ALPHABET_SIZE);
$res[$res_offset + $i] = self::ALPHABET[$remainder->toDec()];
$i--;
}

Expand Down Expand Up @@ -106,21 +105,20 @@ private static function decodeBlock(array $data, array $res, int $res_offset): a
$length = count($data);

if ($length < 1 || $length > self::FULL_ENCODED_BLOCK_SIZE) {
throw new Exception("Invalid block length: " . $length);
throw new Exception("Invalid block length: ". $length);
}

$num = '0';
$num = new BigInteger(0);

for ($i = 0; $i < $length; $i++) {
$char = $data[$i];
$char_value = strpos(self::ALPHABET, $char);

if ($char_value === false) {
throw new Exception("Invalid character: " . $char);
throw new Exception("Invalid character: ". $char);
}

$num = bcmul($num, self::ALPHABET_SIZE);
$num = bcadd($num, (string)$char_value);
$num = $num->mul(self::ALPHABET_SIZE)->add($char_value);
}

$res = array_merge($res, str_split(pack('H*', self::decToHex($num))));
Expand Down Expand Up @@ -153,4 +151,4 @@ public static function decode(string $base58): string

return bin2hex(implode('', $res));
}
}
}
Loading