bisani
( ͡° ͜ʖ├┬┴┬ Bisani
Crystal implementation of Go's Hide
Role
Bisani's role is to hide the actual id
from a database, using Modular Multiplicative Inverse.
Installation
Add this to your application's shard.yml
:
dependencies:
bisani:
github: kuende/bisani
Usage
require "bisani"
To obfuscate
(hide) a certain value you simply need to do this:
##
# Random Int32 number.
# Works for Int32, Int64, UInt32, UInt64
# EXPLICIT CONVERSION MUST BE MADE!
##
x = 3_i32
# Bisani Magic
x = x.to_bis
# x will now be 206383517
To deobfuscate
(revert/unhide) the value to the one it used to be:
# Let's asume x's value is 206383517
x = Bisani.to_i32(x)
# x will now be 3
That's it. Pretty simple, huh?
Custom primes
This library comes with custom primes set in Bisani::Values
class. You should replace them with your own primes. Using the default ones is a serious security vulnerability and will yield this library useless for you.
Bisani.set_i32_prime(1234567.to_i32)
Bisani.set_i64_prime(1234567.to_i64)
Bisani.set_u32_prime(1234567.to_u32)
Bisani.set_u64_prime(1234567.to_u64)
Notes
It currently works only on
Int32
Int64
UInt32
UInt64
therefore, explicit conversion must be made:
my_int_var.to_i32
my_int_var.to_i64
my_int_var.to_u32
my_int_var.to_u64
TODO
- Accept
Int
without conversion - Implement Miller-Rabin primality test for BigInt
- Accept custom prime numbers (Currently default ones)
Contributing
- Fork it ( https://github.com/kuende/bisani/fork )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
Contributors
- dumitraand - creator, maintainer
- teodor-pripoae - creator, maintainer
Repository
bisani
Owner
Statistic
- 0
- 0
- 0
- 0
- 1
- over 8 years ago
- April 27, 2016
License
Other
Links
Synced at
Tue, 21 Jan 2025 14:19:33 GMT
Languages