Package Exports
- @spacemesh/sm-codec
- @spacemesh/sm-codec/lib/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@spacemesh/sm-codec) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
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',
});
})();