doc_integrity_check 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: e262d0c469f1d8a494a964dbb388c4612d98c13a
4
+ data.tar.gz: ab4a7d06153f43e00e04b0e518d00c6368fa2cd3
5
+ SHA512:
6
+ metadata.gz: 9c6d8612e9995f127aeaa344b4773677a9558bb6c02591c6f837850e6a3fbd65e9c07bd56c9b338d10414086a554d46579efad1cd3b8d8766d81bdb62d3b21e3
7
+ data.tar.gz: 6e1057f70754b0c1c84e985f9a84e7ec34d3040735fb35a1395853b3599ce1a52386e296de9eb75eb9cd4d0627fb8bf6259119b38fd1546512ff6947a59bdf9f
@@ -0,0 +1,6 @@
1
+
2
+ # Wrapper for various methods to check doc integry
3
+ module DocIntegrityCheck
4
+ include HashVerify
5
+ include EncryptDecrypt
6
+ end
@@ -0,0 +1,16 @@
1
+ require "gpgme"
2
+
3
+ # Handles encryption and decryption of files
4
+ module EncryptDecrypt
5
+ # Encrypt file
6
+ def encrypt_data(file_obj, recipient)
7
+ crypto = GPGME::Crypto.new
8
+ return crypto.encrypt(file_obj, recipients: recipient, armor: true)
9
+ end
10
+
11
+ # Decrypt data
12
+ def decrypt(data)
13
+ crypto = GPGME::Crypto.new
14
+ return crypto.decrypt(data).to_s
15
+ end
16
+ end
@@ -0,0 +1,16 @@
1
+ require "digest"
2
+ require "pry"
3
+
4
+ module HashVerify
5
+ # Hash file object
6
+ def hash_file(encrypted_file_obj)
7
+ Digest::SHA256.hexdigest(encrypted_file_obj.to_s)
8
+ end
9
+
10
+ # Verify the hash to a file
11
+ def hash_verified?(file_details)
12
+ hash = file_details["file_hash"]
13
+ rechecked_hash = hash_file(file_details[:encrypted_text])
14
+ return hash == rechecked_hash
15
+ end
16
+ end
metadata ADDED
@@ -0,0 +1,46 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: doc_integrity_check
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - M. C. McGrath
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2018-02-25 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description: Encrypts, verifies, and checks hashes of files
14
+ email: shidash@transparencytoolkit.org
15
+ executables: []
16
+ extensions: []
17
+ extra_rdoc_files: []
18
+ files:
19
+ - lib/doc_integrity_check.rb
20
+ - lib/encrypt_decrypt.rb
21
+ - lib/hash_verify.rb
22
+ homepage: https://github.com/TransparencyToolkit/DocIntegrityCheck
23
+ licenses:
24
+ - GPL
25
+ metadata: {}
26
+ post_install_message:
27
+ rdoc_options: []
28
+ require_paths:
29
+ - lib
30
+ required_ruby_version: !ruby/object:Gem::Requirement
31
+ requirements:
32
+ - - ">="
33
+ - !ruby/object:Gem::Version
34
+ version: '0'
35
+ required_rubygems_version: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - ">="
38
+ - !ruby/object:Gem::Version
39
+ version: '0'
40
+ requirements: []
41
+ rubyforge_project:
42
+ rubygems_version: 2.6.11
43
+ signing_key:
44
+ specification_version: 4
45
+ summary: Checks the integrity of files
46
+ test_files: []