Crates.io | encon |
lib.rs | encon |
version | 0.0.3 |
source | src |
created_at | 2020-11-04 19:04:59.398132 |
updated_at | 2020-11-07 17:49:53.459394 |
description | an optionally-encrypted config format, built on top of JSON |
homepage | |
repository | |
max_upload_size | |
id | 308678 |
size | 69,808 |
Encon is an optionally-encrypted config format, built on top of JSON. A mix of encrypted and plain fields, and support for encrypting arbitrary JSON values make it very flexible.
use serde_json::json;
use encon::{Password, Map, Encryptable};
let pass = Password::new("strongpassword");
let mut map = Map::new();
map.insert("foo", Encryptable::Plain("Foo".into()));
map.insert("bar", Encryptable::Plain("Bar".into()));
map.get_mut(&"foo".to_owned()).unwrap().intend_encrypted();
assert_eq!(map.get(&"foo".to_owned()).unwrap().is_encrypted(), false);
assert_eq!(map.get(&"bar".to_owned()).unwrap().is_encrypted(), false);
map.apply_all_intents(&pass).unwrap();
assert_eq!(map.get(&"foo".to_owned()).unwrap().is_encrypted(), true);
assert_eq!(map.get(&"bar".to_owned()).unwrap().is_encrypted(), false);
let json = map.to_json_pretty().unwrap();
let mut map2: Map = serde_json::from_str(&json).unwrap();
assert_eq!(map2.get(&"foo".to_owned()).unwrap().is_encrypted(), true);
assert_eq!(map2.get(&"bar".to_owned()).unwrap().is_encrypted(), false);
let value = map2.get_mut(&"foo".to_owned()).unwrap()
.to_decrypted(&pass).unwrap()
.as_plain().unwrap().clone();
assert_eq!(value, json!("Foo"));
Current version: 0.0.1
encon-cli
: a command line tool for interacting with encon JSON filesencon-js
: an npm package (npm install encon
)All crates licensed as MIT