承接 olifanton/utils 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

olifanton/utils

最新稳定版本:0.4.0

Composer 安装命令:

composer require olifanton/utils

包简介

Olifanton utils library

README 文档

README

Olifanton PHP utils library

Code Coverage Badge Tests Latest Stable Version Total Downloads

PHP port of tonweb-utils JS library

Installation

composer require olifanton/utils

Documentation

Getting started

Install olifanton/utils package via Composer and include autoload script:

<?php declare(strict_types=1);

require __DIR__ . "/vendor/autoload.php";

use Olifanton\Utils\Address;
use Olifanton\Utils\Bytes;
use Olifanton\Utils\Crypto;
use Olifanton\Utils\Units;

// Now you can use Olifanton utils classes

Library classes

Olifanton\Utils\Address

Address is a class that allows you to work with smart contract addresses in the TON network. Read more about Addresses in official documentation.

Address constructor
/**
 * @param string | \Olifanton\Utils\Address $anyForm
 */
public function __construct(string | Address $anyForm)

Parameters:

  • $anyForm — Address in supported form. Supported values are:
    • Friendly format (base64 encoded, URL safe or not): EQBvI0aFLnw2QbZgjMPCLRdtRHxhUyinQudg6sdiohIwg5jL;
    • Raw form: -1:fcb91a3a3816d0f7b8c2c76108b8a9bc5a6b7a55bd79f8ab101c52db29232260;
    • Other Address instance, in this case the new instance will be an immutable copy of the other address.

Depending on the passed value, the Address instance will store information about the input address flags.

If the input value is not a valid address, then \InvalidArgumentException will be thrown.

Address static methods
isValid(string | \Olifanton\Utils\Address $anyForm): bool

Checks if the passed value is a valid address in any form.

Address methods
toString(): string
/**
 * @param bool|null $isUserFriendly User-friendly flag
 * @param bool|null $isUrlSafe URL safe encoded flag
 * @param bool|null $isBounceable Bounceable address flag
 * @param bool|null $isTestOnly Testnet Only flag
 */
public function toString(?bool $isUserFriendly = null,
                         ?bool $isUrlSafe = null,
                         ?bool $isBounceable = null,
                         ?bool $isTestOnly = null): string

Returns a string representation of Address.

If all parameters are left as default, then the address will be formatted with the same flags whose value was recognized in the constructor.

getWorkchain(): int

Returns Workchain ID. Returns -1 for Masterchain and 0 for basic workchain.

getHashPart(): Uint8Array

Returns address Account ID.

isTestOnly(): bool

Returns true if the address has the isTestnetOnly flag.

isBounceable(): bool

Returns true if the address has the isBounceable flag.

isUserFriendly(): bool

Returns true if the address is user-friendly.

isUrlSafe(): bool

Returns true if the address was encoded with URL-safe characters only.

Olifanton\Utils\Bytes

This is a helper class for working with Uint8Array. You are unlikely to use this class directly because it is designed to handle the internal representation of Cells. However, this documentation describes the methods that you may find useful.

Bytes static methods
readNBytesUIntFromArray(): int

Returns $n bytes from Uint8Array.

compareBytes(): bool

Returns true if Uint8Array's $a and $b are equal.

arraySlice(): Uint8Array

Returns an immutable fragment from the given Uint8Array.

concatBytes(): bool

Returns a new Uint8Array from the given ones.

concatBytes(): Uint8Array

Returns a new Uint8Array from the given ones.

stringToBytes(): Uint8Array

Returns a Uint8Array from a PHP byte string.

Example:

$a = \Olifanton\Utils\Bytes::stringToBytes('a');
$a[0] === 97; // True, because the ASCII code of `a` is 97 in decimal
hexStringToBytes(): Uint8Array

Returns a Uint8Array from a hexadecimal string.

Example:

$a = \Olifanton\Utils\Bytes::hexStringToBytes('0a');
$a[0] === 10; // True
bytesToHexString(): string

Returns a hexadecimal string representation of the Uint8Array.

Example:

$s = \Olifanton\Utils\Bytes::bytesToHexString(new \ajf\TypedArrays\Uint8Array([10]));
$s === '0a'; // True

Olifanton\Utils\Crypto

Crypto methods

@TODO

Olifanton\Utils\Units

Units methods

@TODO

Tests

composer run test

License

MIT

统计信息

  • 总下载量: 84
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 4
  • 点击次数: 2
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 4
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-07-06

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固