Skip to content

This is the Order-preserving encryption (OPE) lib extracted from the CryptoDB.And we build a lib make sure Golang code call

License

Notifications You must be signed in to change notification settings

slper001/ope-lib-golang

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Golang OPE from CryptDB

This is the Order-preserving encryption (OPE) lib extracted from the CryptoDB (http://css.csail.mit.edu/cryptdb/). we just want OPE lib, so this it is not necessary to compile the whole CryptDB to use the OPE lib.

Then, use C function to wrap C++ class method. At last, use CGO to promise Golang code call.

requirenments

  • GO
  • g++
  • make
  • OpenSSL
  • NTL

Install

make install
go run main.go

Usage

ope.NewOPE("this is a key")
input := []int{10, 20, 30, 33, 56, 78, 90, 138, 245, 678}
for _, in := range input {
        cipherText := ope.Encrypt(in)
	plainText := ope.Decrypt(cipherText)
	fmt.Printf("num:%d cipherText=%d plainText=%d\n", in, cipherText, plainText)
}
num:10 cipherText=49732388173 plainText=10
num:20 cipherText=102598871581 plainText=20
num:30 cipherText=149743672874 plainText=30
num:33 cipherText=156633669267 plainText=33
num:56 cipherText=245525400720 plainText=56
num:78 cipherText=349751403748 plainText=78
num:90 cipherText=408944270601 plainText=90
num:138 cipherText=617561141893 plainText=138
num:245 cipherText=1072964940705 plainText=245
num:678 cipherText=2851591790460 plainText=678

Enjoy it!

About

This is the Order-preserving encryption (OPE) lib extracted from the CryptoDB.And we build a lib make sure Golang code call

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages