aboutsummaryrefslogblamecommitdiffstats
path: root/go/main.go
blob: ab902f2ba5bf4aba2e98164eae4e8fb90a829622 (plain) (tree)









































                                                                                          
package main

/*
#cgo CFLAGS:-I../include
#cgo LDFLAGS:-lbls -lbls_if -lmcl -lgmp -lgmpxx -L../lib -L../../mcl/lib -lstdc++ -lcrypto
#include "bls_if.h"
*/
import "C"
import "fmt"
import "unsafe"

func main() {
    fmt.Println("init")
    C.blsInit()

    fmt.Println("create secret key")
    sec := C.blsSecretKeyCreate()
    C.blsSecretKeyInit(sec)
    C.blsSecretKeyPut(sec)

    fmt.Println("create public key")
    pub := C.blsPublicKeyCreate()
    C.blsSecretKeyGetPublicKey(sec, pub)

    C.blsPublicKeyPut(pub)

    sign := C.blsSignCreate()

    msg := "Hello bls"
    pmsg := C.CString(msg)
    fmt.Println("sign message")
    C.blsSecretKeySign(sec, sign, pmsg, C.size_t(len(msg)))

    C.blsSignPut(sign)

    fmt.Println("verify:", C.blsSignVerify(sign, pub, pmsg, C.size_t(len(msg))))

    C.free(unsafe.Pointer(pmsg))

    C.blsPublicKeyDestroy(pub)
    C.blsSecretKeyDestroy(sec)
}