@spacemesh/sm-codec
v0.9.0-athena.1
Published
Spacemesh Transaction Codec library
Downloads
157
Readme
@spacemesh/sm-codec
TypeScript library provides easy way to encode, decode, and sign transactions.
See usage examples below:
// Import
import { SingleSigTemplate, StdMethods } from '@spacemesh/sm-codec';
import { sign } from '@noble/ed25519';
// SingleSig example
(() => {
// Get method
const spawnTpl = SingleSigTemplate.methods[StdMethods.Spawn];
// Prepare SpawnPayload
const spawnPayload = {
Nonce: 0n,
GasPrice: 1n,
Arguments: {
PublicKey: Uint8Array.from([/* your public key: 32 bytes */]),
},
};
// Calculate Principal address (of your new account)
const principal = spawnTpl.principal(spawnPayload.Arguments);
// Encode SpawnTransaction
const rawTx = spawnTpl.encode(principal, spawnPayload);
// Get transaction hash, it is used in signing
const txHash = hash(rawTx);
// Then use `ed25519` library to sign the hash with your private key
const sig = sign(myPrivateKey, txHash);
// And finally sign tx (actualy it concatenates bytes)
const signedTx = spawnTpl.sign(rawTx, sig);
// Note: Principal method exists on any method
// So this example will work as well:
SingleSigTemplate.methods[StdMethods.Spend].principal(spawnPayload.Arguments);
})();
Example of creating your own template:
import { PublicKey, SingleSig, Codecs } from '@spacemesh/sm-codec';
import { Struct, str } from 'scale-ts';
const spawnCodec = Struct({
Owner: PublicKey,
});
const saySmthCodec = Struct({
message: str,
})
// Address of the template in the network
// 24 bytes length
const address = Uint8Array.from([
0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 100,
]);
// Creating own templates
const spawnTpl = new Transaction({
address,
methodSelector: 0,
spawnArgsCodec: spawnCodec,
// For Spawn transaction it is neccessary to add a template address into payload
payloadCodec: withTemplateAddress(address, spawnCodec),
sigCodec: SingleSig,
});
const saySmthTpl =
new Transaction({
address,
methodSelector: 1,
spawnArgsCodec: spawnCodec,
payloadCodec: saySmthCodec,
sigCodec: SingleSig,
});
// Use as in examples above
const principal = saySmthTpl.principal({
Owner: Uint8Array.from([ /* 32 bytes */ ]),
});
const rawTx = saySmthTpl.encode(principal, {
message: 'hello world',
});
})();