Tools for Cyber wallet management, offline transaction signing and broadcasting
Project description
cyberpy
Version 1.0.9
Tools for Cyber wallet management and offline transaction signing
Bostrom network release
Installing
Installing from PyPI repository:
pip install cyberpy
Installing from source code:
git clone https://github.com/SaveTheAles/cyberpy
cd cyberpy
pip3 install .
Usage
Generating a wallet
from cyberpy import generate_wallet
wallet = generate_wallet()
The value assigned to wallet
will be a dictionary just like:
{
"seed": "arch skill acquire abuse frown reject front second album pizza hill slogan guess random wonder benefit industry custom green ill moral daring glow elevator",
"derivation_path": "m/44'/118'/0'/0/0",
"private_key": b'\xbb\xec^\xf6\xdcg\xe6\xb5\x89\xed\x8cG\x05\x03\xdf0:\xc9\x8b \x85\x8a\x14\x12\xd7\xa6a\x01\xcd\xf8\x88\x93',
"public_key": b"\x03h\x1d\xae\xa7\x9eO\x8e\xc5\xff\xa3sAw\xe6\xdd\xc9\xb8b\x06\x0eo\xc5a%z\xe3\xff\x1e\xd2\x8e5\xe7",
"address": "bostrom1uuhna3psjqfxnw4msrfzsr0g08yuyfxesqggqd",
}
Converter functions
Mnemonic seed to private key
from cyberpy import seed_to_privkey
seed = "teach there dream chase fatigue abandon lava super senior artefact close upgrade"
privkey = seed_to_privkey(seed, path="m/44'/118'/0'/0/0")
Private key to public key
from cyberpy import privkey_to_pubkey
privkey = bytes.fromhex("6dcd05d7ac71e09d3cf7da666709ebd59362486ff9e99db0e8bc663570515afa")
pubkey = privkey_to_pubkey(privkey)
Public key to address
from cyberpy import pubkey_to_address
pubkey = bytes.fromhex("03e8005aad74da5a053602f86e3151d4f3214937863a11299c960c28d3609c4775")
addr = pubkey_to_address(pubkey)
Private key to address
from cyberpy import privkey_to_address
privkey = bytes.fromhex("6dcd05d7ac71e09d3cf7da666709ebd59362486ff9e99db0e8bc663570515afa")
addr = privkey_to_address(privkey)
Address to address
from cyberpy import address_to_address
addr = address_to_address(address, prefix)
Signing transactions
Send transaction
from cyberpy import Transaction
tx = Transaction(
privkey=bytes.fromhex("26d167d549a4b2b66f766b0d3f2bdbe1cd92708818c338ff453abde316a2bd59"),
account_num=11335,
sequence=0,
fee=0,
gas=200000,
memo="",
chain_id="bostrom-testnet-1",
sync_mode="broadcast_tx_sync", # "broadcast_tx_sync", "broadcast_tx_async", "broadcast_tx_commit"
)
tx.add_transfer(recipient="bostrom103l758ps7403sd9c0y8j6hrfw4xyl70j4mmwkf", amount=387000)
tx.add_transfer(recipient="bostrom1lzumfk6xvwf9k9rk72mqtztv867xyem393um48", amount=123)
One or more token transfers can be added to a transaction by calling the add_transfer
method.
Link transaction
from cyberpy import Transaction
tx = Transaction(
privkey=bytes.fromhex("26d167d549a4b2b66f766b0d3f2bdbe1cd92708818c338ff453abde316a2bd59"),
account_num=11335,
sequence=0,
fee=0,
gas=200000,
memo="",
chain_id=bostrom-testnet-1",
sync_mode="broadcast_tx_sync", # "broadcast_tx_sync", "broadcast_tx_async", "broadcast_tx_commit"
)
tx.add_cyberlink(cid_from="QmceNpj6HfS81PcCaQXrFMQf7LR5FTLkdG9sbSRNy3UXoZ", cid_to="QmRX8qYgeZoYM3M5zzQaWEpVFdpin6FvVXvp6RPQK3oufV")
tx.add_cyberlink(cid_from="QmXsJKAog3tTNEGfHNmSYjdiLYFkq4URrxDpMQpwfBRUtP", cid_to="QmTiXybNXEYbfVEy6bhBSw67u6NHXsB2h36xhwPcCQyRgp")
One or more cyberlink messages can be added to a transaction by calling the add_cyberlink
method.
When the transaction is fully prepared, calling get_pushable
will return a signed transaction in the form of a JSON string.
pushable_tx = tx.get_pushable()
This can be used as request body when calling endpoint of the https://grpc_api:26657
, more detailes here
import requests
res = requests.post(url=<grpc_api>, data=pushable_tx)
Or you can call broadcast(grps: str)
method and it will make a signed transaction and POST it with defined gRPC_api.
res = tx.broadcast(url=<gRPC_api>)
Signing message
Offchain signing transaction-like according to ADR 036
string message signing:
from cyberpy._message_signer import Message
from cyberpy._wallet import seed_to_privkey
seed = "arch skill acquire abuse frown reject front second album pizza hill slogan guess random wonder benefit industry custom green ill moral daring glow elevator"
msg = Message(
privkey=seed_to_privkey(seed)
)
msg.add_message('some_string_here', 'prefix') // as prefix it should be bostrom, cosmos, osmo etc.
signed_msg = msg.get_signed_message()
list of strings message signing:
from cyberpy._message_signer import Message
from cyberpy._wallet import seed_to_privkey
seed = "arch skill acquire abuse frown reject front second album pizza hill slogan guess random wonder benefit industry custom green ill moral daring glow elevator"
msg = Message(
privkey=seed_to_privkey(seed)
)
strings_list = ['some', 'string', 'here'] // will have : separated string
msg.add_message_custom(strings_list, 'prefix')
signed_msg = msg.get_signed_message()
the output like:
{
"pub_key": "A+MXFp7YeLMvoVlAU66Uu0z3Wtc9Cuwq0eocUhtNOmnw",
"signature": "9O89CUdRRZj011BphnTs5JnYM9/0O0ch+XLG2DNiWqtYnA4xA5B0wmFQDOQogOxL5xKWILVMnv1IA/7s05QsIA=="
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file cyberpy-1.0.9.tar.gz
.
File metadata
- Download URL: cyberpy-1.0.9.tar.gz
- Upload date:
- Size: 20.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.26.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f852e6d57fac01d4f722a5232b52599ba881b7c07131495c6bfd2556db0b75ec |
|
MD5 | 5b47d334dc9cc2e1dffb3f34a569cd7d |
|
BLAKE2b-256 | bd8cf9f7de9241761cb37e0ef49a98011a8e705f6d2652d7ac74fcea548c6eb9 |