trsa

node-forge rsa with an API that you understand

Usage no npm install needed!

<script type="module">
  import trsa from 'https://cdn.skypack.dev/trsa';
</script>

README

trsa

node-rsa rsa with an API that you understand.

node-rsa is a great module, it offers good encryption. Sadly its API is to complex. This module reduce the API for rsa signing / verification and encryption/decryption to a minimum of just 6 functions. Also it let you work with plane old javascript objects and data types. You don't need to hassle with internal classes.

  • generateKeyPair({bits: 512}) to create 512 bit public and private key

  • sign(data, privateKey) to sign data

  • verify(data, signature, publicKey) to verify the source of the data

  • encrypt(data, publicKey) to encrypt something that only the corresponding privateKey can decrypt

  • decrypt(data, privateKey) decrypt data that was encrypted specially for you.

you can use webpack or browserify to use the rsa module in the browser. And the now it has a corresponding implementation in golang.

const rsa = require('trsa')
const keypair = rsa.generateKeyPair({bits:512});

// encryption
const messageForAlice = rsa.encrypt('Hallo, this is Bob. I have something to tell you.', keyPair.publicKey);
const decryptedMessage = rsa.decrypt(messageForAlice, keypair.privateKey);

// signature
const statement = "very tough statement";
const signature = rsa.sign(statement, keypair.privateKey);
const isSigned = rsa.verify(statement, signature, keypair.publicKey);

// save key: using node-rsa directly, this is not possible so easy ! !
// as you see, that you can easily return the key as it is, to a client, without any extra transformation.
fs.writeKeySync('./keyFile.json', JSON.stringify(keypair));

GOLANG

For golang you simple import github.com/tobiasnickel/trsa/golang/trsa or run the following command for installation:

go get github.com/tobiasnickel/trsa/golang/trsa

and then you can do the same as before:

package main

import (
    "fmt"
    "io/ioutil"

    "github.com/tobiasnickel/trsa/golang/trsa"
)

func main() {
    publicKey, privateKey, err := trsa.GenerateKeys(2048)
    if err != nil {
        fmt.Println(err)
        return
    }

    golangMessage := []byte("Hallo Javascript from Golang !!!")
    
    encryptedMessage, err := trsa.Encrypt(golangMessage, publicKey)
    if err != nil {
        fmt.Println(err)
        return
    }
    decryptedMessage, err := trsa.Decrypt(encryptedMessage, privateKey) 
    if err != nil {
        fmt.Println(err)
        return
    }
    fmt.Println("decrypted message:", string(decryptedMessage));
    signature, err := trsa.Sign(golangMessage, privateKey)
    if err != nil {
        fmt.Println(err)
        return
    }

    err = trsa.Verify(golangMessage, signature, publicKey);
    if err != nil {
        fmt.Println(err)
        return
    }
    fmt.Println("done")
}