SimpleCrypto is a JavaScript library that simplify the process of encryption and decryption of JavaScript objects, as simple as just calling encrypt()
and decrypt()
function. This library implements brix's crypto-js library. This library is pure JavaScript library built with TypeScript targeting CommonJS ECMAScript 5 (ES5), so it is compatible with most NodeJS back-end applications or JavaScript front-end (client browser).
What's New in 2.1.3
- Fix jsDelivr link
Included from 2.1.2
- Update missing file in NPM release
Included from 2.1.0
- Update dependency
- Fix missing web bundler as distribution build tool for the Web (using webpack)
- Use of partial import instead of full import to minimise the size of distributed build file
Included from 2.0.2
- Bugs fixed
- Remove gulp
Included from 2.0.1
- Add coverage service
Included from 2.0.0
- Using only these functions to encrypt or decrypt:
encrypt()
anddecrypt()
(accepts string, object, number, or boolean data type). FunctionencryptObject()
anddecryptObject()
is in deprecation as these functions are enough. - Securing instance's properties from public access. Access to instance properties, like
instance.secret
, is not allowed anymore. - New TypeScript definition file of this library is now available.
- Fixed documentation (typos, diction, etc).
- For contributor: Using
mocha
,chai
andcoveralls
to create full unit-testing of the library. You could see testing result on top of this README. - For contributor: Using
gulp
to compile the TypeScript source code into JavaScript ES5.
This library is available through package manager (npm and yarn) and through jsDelivr CDN.
To get this library included on your project, first, you can use package manager like npm or yarn command to get SimpleCrypto.
# If you're using NPM
npm install --save simple-crypto-js
# If you're using Yarn
yarn add simple-crypto-js
Then, include SimpleCrypto your project. If you are using the new ECMAScript 6 (ECMAScript 2015) and later, you may use the new import statement:
// ES6 and later
import SimpleCrypto from "simple-crypto-js";
However, if you are using ECMAScript 5 and older, use the require statement:
// ES5 and older
var SimpleCrypto = require("simple-crypto-js").default;
SimpleCrypto has a single class with only two instance's functions and a single static function. This is by intention to keep it's simplicity. This is full documentation about the library and how to use it on your project. All examples work on both ECMAScript 6 (and later) and ECMAScript 5 (and older).
List of SimpleCrypto constructor parameter.
Parameter | Type | Information | Default |
---|---|---|---|
secret | required | The secret string (key or password) that will be used to create the secret key for encryption and decryption process. | undefined |
List of SimpleCrypto instance's properties.
Property | Information | Default |
---|---|---|
_secret | Contains the secret string (key or password) that will be used to create the secret key for encryption and decryption process. | undefined |
_keySize | Contains a number that represent the size of the secret key. | 256 |
_iterations | Contains a number that represent the number of iterations done to create the secret key. | 100 |
List of SimpleCrypto functions.
Functions | Information | Parameter | Return |
---|---|---|---|
static generateRandom() | Generate a random string based on the key length. | length: number (optional) - The length of key used to generating random. (default: 128 ) expectsWordArray: boolean (optional) - If set to true , this function will return a CryptoJS.WordArray instance instead of string. (default: false ) |
random: string - Generated random key. |
encrypt() | Encrypt data. | data: object/string/number/boolean - The data to be encrypted. | ciphered: string - Ciphered data. |
decrypt() | Decrypt ciphered data. | ciphered: string - Ciphered data to be decrypted. expectsObject: boolean (optional) - If set to true , this function will return an object instead of string. Set to true if decrypted data is expected as object. (default: false ) encoder: string (optional) - Encoder used transform data back to string. (default: UTF-8 ) |
data: string/object - The decrypted data (it might be string or object, depends on expectsObject parameter). |
deprecation encryptObject() use encrypt() instead |
Encrypt JavaScript object literal. | object: object - The object to be enrypted. | ciphered: string - Ciphered data. |
deprecation decryptObject() use decrypt() instead |
Decrypt ciphered data that is expected as object and turn it back into object literal. | ciphered: string - Ciphered data to be decrypted. encoder: string (optional) - Encoder used transform data back to string. (default: UTF-8 ) |
object: object - The decrypted object. |
setSecret() | Change the secret of the instance. | secret: string - The new secret string. | void |
Note:
- Function marked with static indicating a static function.
- Function marked with deprecation indicating deprecated function that still can be used. However, it would be deprecated (and fully gone) in future version.
- Function marked with deprecated indicating deprecated function that has been removed in this version of release.
- The rest (not marked with anything) are normal instance's functions.
To use SimpleCrypto, first create a SimpleCrypto instance with a secret key (password). Secret key parameter MUST be defined when creating a SimpleCrypto instance.
To encrypt and decrypt data, simply use encrypt()
and decrypt()
function from an instance. This will use AES-CBC encryption algorithm.
// If you would like to generate a random unique key, you may use static function generateRandom() like so
// var _secretKey = SimpleCrypto.generateRandom();
// You may also set the strength of the random key, as example 256 (default is 128);
// var _secretKey = SimpleCrypto.generateRandom(256);
// Or just defined the key by yourself (key is must!)
var _secretKey = "some-unique-key";
var simpleCrypto = new SimpleCrypto(_secretKey);
var plainText = "Hello World!";
var chiperText = simpleCrypto.encrypt(plainText);
console.log("Encryption process...");
console.log("Plain Text : " + plainText);
console.log("Cipher Text : " + cipherText);
var decipherText = simpleCrypto.decrypt(cipherText);
console.log("... and then decryption...");
console.log("Decipher Text : " + decipherText);
console.log("... done.");
You could also perform the encryption and decryption process using different SimpleCrypto instances, PROVIDED THAT the secret key ARE STAY THE SAME between the instances. For example:
var _secretKey = "some-unique-key";
var simpleCrypto1 = new SimpleCrypto(_secretKey);
var simpleCrypto2 = new SimpleCrypto(_secretKey);
var plainText = "Hello World!";
// Encryption using the first instance (simpleCrypto1)
var chiperText = simpleCrypto1.encrypt(plainText);
console.log("Encryption process...");
console.log("Plain Text : " + plainText);
console.log("Cipher Text : " + cipherText);
// Decyption using the second instance (simpleCrypto2)
var decipherText = simpleCrypto2.decrypt(cipherText);
console.log("... and then decryption...");
console.log("Decipher Text : " + decipherText);
console.log("... done.");
If you want to change the secret key of a SimpleCrypto instance, call the setSecret()
function with the new secret as parameter.
var simpleCrypto = new SimpleCrypto("some-unique-key");
simpleCrypto.setSecret("new-more-unique-key");
On version 1.1.1 and before, you may programmatically get and set the secret using it's secret
property. However, since version 2.0, direct access to instance's properties are deprecated. You can't get the secret
property programmatically, but still allowed to re-set the secret using the setSecret()
function.
Encryption and decryption of JavaScript object literal has never been simpler than this.
To encrypt and decrypt JavaScript object literal, simply use encrypt()
and decrypt()
function from an instance. This will use AES-CBC encryption algorithm.
var _secretKey = SimpleCrypto.generateRandom();
var simpleCrypto = new SimpleCrypto(_secretKey);
var object = {
SimpleCrypto: "is great.",
You: "should try it!"
};
var encrypted = simpleCrypto.encrypt(plainObject);
console.log("Encryption process...");
console.log("Plain Object : " + plainObject);
console.log("Encrypted Object : " + encrypted);
// Set the second paramter to true, then it will return object instead of string
var decrypted = simpleCrypto.decrypt(encrypted, true);
console.log("... and then decryption...");
console.log("Decrypted object : " + decrypted);
console.log("... done.");
On version 1.1.1 and before, you might have use encryptObject()
and decryptObject()
function. In version 2.0, this function is in deprecation
and soon would be gone in future release. This is because our goal is to keep the simplicity and a single function is enough to do encryption or decryption process.
Anywhere, after importing SimpleCrypto, you may use static function generateRandom()
to produce a random key based on the length of key you have provided on the parameter (default is 128
).
var randomString = SimpleCrypto.generateRandom();
var randomStringCustomKey = SimpleCrypto.generateRandom(256);
Yes, and of course it is obvious, because it is a static function, you are not required to create any SimpleCrypto instances.
Written in TypeScript, built into ECMAScript 5 using the TypeScript compiler and webpack bundler.
To contribute, simply fork this project, and issue a pull request.
We use SemVer for version management. For the versions available, see the tags on this repository.
- Danang Galuh Tegar Prasetyo - Initial work - danang-id
See also the list of contributors who participated in this project.
This project is licensed under the MIT License - see the LICENSE file for details
- This library was developed to support and simplify the Secure Cookies library.
- Made available by open source and of course brix's crypto-js library