Skip to content

Latest commit

 

History

History
66 lines (44 loc) · 1.89 KB

README.md

File metadata and controls

66 lines (44 loc) · 1.89 KB

mtrjs

Small collection of JavaScript functions for Metro. Allows for local signing of transactions, token creation/validation and encryption/decryption of arbitrary messages.

Install

npm install mtrjs

Test

npm test

Usage

node.js:
var mtrjs = require('mtrjs');

// Create an account
var acc = mtrjs.secretPhraseToAccountId('secret');
console.log(acc);
Browser:

Create the bundle with browserify:

browserify index.js -s mtrjs > build/mtrjs.js

Use in HTML file:

<script src="mtrjs.js"></script>
<script>
    var acc = mtrjs.secretPhraseToAccountId('secret');
    console.log(acc);
</script>

Functions

secretPhraseToPublicKey(secretPhrase)

Returns public key of a given passphrase

publicKeyToAccountId(publicKey, numeric)

Returns account ID of a given public key. Set the second parameter to true to get numeric account ID instead of RS format

secretPhraseToAccountId(secretPhrase, numeric)

Returns account ID of a given passphrase. Set the second parameter to true to get numeric account ID instead of RS format.

signTransactionBytes(unsignedTransactionBytes, secretPhrase)

Signs a hex string of unsigned transaction bytes (e.g. as received from NRS API) with the provided passphrase and returns it.

createToken(string, secretPhrase)

Generates a Metro cryptographic token

parseToken(token, string)

Parses a Metro cryptographic token. Returns an object with the keys isValid, timestamp, publicKey and accountRS.

encryptMessage(plainText, recipientPublicKey, senderSecretPhrase)

Returns an object with the keys nonce and message

decryptMessage(cipherText, nonce, senderPublicKey, recipientSecretPhrase)

Returns the deciphered text as string

rsConvert(address)

Converts address in numeric format to Reed-Solomon format, or vice versa. Returns an object with the keys account and accountRS