Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/emancu/ork-encryption
The ork-encryption gem provides encryption and decryption for Ork models.
https://github.com/emancu/ork-encryption
Last synced: 24 days ago
JSON representation
The ork-encryption gem provides encryption and decryption for Ork models.
- Host: GitHub
- URL: https://github.com/emancu/ork-encryption
- Owner: emancu
- License: apache-2.0
- Created: 2013-11-02T23:28:04.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2014-02-17T13:48:44.000Z (almost 11 years ago)
- Last Synced: 2024-11-24T17:32:54.800Z (about 1 month ago)
- Language: Ruby
- Size: 195 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
ork-encryption
==============
[![Gem Version](https://badge.fury.io/rb/ork-encryption.png)](http://badge.fury.io/rb/rork-encryption)
[![Build Status](https://travis-ci.org/emancu/ork-encryption.png)](https://travis-ci.org/emancu/ork-encryption)
[![Code Climate](https://codeclimate.com/github/emancu/ork-encryption.png)](https://codeclimate.com/github/emancu/ork-encryption)
[![Coverage Status](https://coveralls.io/repos/emancu/ork-encryption/badge.png)](https://coveralls.io/r/emancu/ork-encryption)
[![Dependency Status](https://gemnasium.com/emancu/ork-encryption.png)](https://gemnasium.com/emancu/ork-encryption)The ork-encryption gem provides encryption and decryption for Ork models.
## Dependencies
`ork-encryption` requires:
* Ruby 1.9 or later.
* `riak-client` to connect to **Riak**.
* `ork` 0.1.1 or later.Install Dependencies using `dep` is easy as run:
$ dep insatll
## Installation
Install [Riak](http://basho.com/riak/) with your package manager:
$ brew install riak
Or download it from [Riak's download page](http://docs.basho.com/riak/latest/downloads/)
Once you have it installed, you can execute `riak start` and it will run on `localhost:8098` by default.
If you don't have `Ork-encryption`, try this:
$ gem install ork-encryption
## Overview
Any object that gets saved with content-type 'application/x-json-encrypted'
the `Ork::Encryption::Serializers::Json` will take care of load or unload the data from **Riak**.`Serializers::Json` stores the encrypted data wrapped in JSON encapsulation so
that you can still introspect the **Riak** object and see which version of
this gem was used to encrypt it. As of version 0.0.1, this is now the only
supported serialization format for JSON data.## Getting started
You must initialize the `Ork::Encryption` module before using it.
Initialization needs a _configuration hash_ with __key__ and __cipher__ to be used.
[See how to choose the configuration](http://www.ruby-doc.org/stdlib-1.9.3/libdoc/openssl/rdoc/OpenSSL/Cipher.html#documentation)```ruby
config = {
cipher: 'AES-256-CBC',
key: 'fantasticobscurekeygoesherenowty',
}Ork::Encryption.init config
```Then include the Ork::Encryption module in your Ork::Document class:
```ruby
class SomeDocument
include Ork::Document
include Ork::Encryptionattribute :message
end
```These documents will now be stored encrypted and also the **IV** used.
## Running the Tests
Adjust the variable to point to a test riak database. Default is `http://localhost:8098`
```bash
$ ORK_RIAK_URL='http://localhost:8198' rake
```