glogin 0.11.0 → 0.13.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
 - data/.github/workflows/codecov.yml +1 -1
 - data/.github/workflows/pdd.yml +1 -1
 - data/.github/workflows/xcop.yml +1 -1
 - data/.rubocop.yml +2 -2
 - data/Gemfile +4 -4
 - data/glogin.gemspec +2 -2
 - data/lib/glogin/codec.rb +13 -4
 - data/lib/glogin/version.rb +1 -1
 - data/test/glogin/test_codec.rb +7 -0
 - metadata +8 -8
 
    
        checksums.yaml
    CHANGED
    
    | 
         @@ -1,7 +1,7 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            ---
         
     | 
| 
       2 
2 
     | 
    
         
             
            SHA256:
         
     | 
| 
       3 
     | 
    
         
            -
              metadata.gz:  
     | 
| 
       4 
     | 
    
         
            -
              data.tar.gz:  
     | 
| 
      
 3 
     | 
    
         
            +
              metadata.gz: 676ad5d1a6bca2ec2d76ab9939299b3a561d86151d5fda5cf256db88e0710b61
         
     | 
| 
      
 4 
     | 
    
         
            +
              data.tar.gz: d43e3c48a754d4a1be1d2e22e6665d10fd311afb45b2bc7bdab800b0d65c631f
         
     | 
| 
       5 
5 
     | 
    
         
             
            SHA512:
         
     | 
| 
       6 
     | 
    
         
            -
              metadata.gz:  
     | 
| 
       7 
     | 
    
         
            -
              data.tar.gz:  
     | 
| 
      
 6 
     | 
    
         
            +
              metadata.gz: 827cee7b4b9e198cd05c46fd91a02db8df3a76121d1f94a5892f4c83fd93c8689366a7e9c36146c7efd7db1bec9321d697893a6cd6497ee386bcfc1c514a9e4c
         
     | 
| 
      
 7 
     | 
    
         
            +
              data.tar.gz: df68d65779e90da7a79dac9f97d101f9d7a1a37c5e3711b1170c94021334c09f873bec55fd3c438e525cfdd575a877d8bbfcf91ffbc12d2bad14c96162e82e6a
         
     | 
    
        data/.github/workflows/pdd.yml
    CHANGED
    
    
    
        data/.github/workflows/xcop.yml
    CHANGED
    
    
    
        data/.rubocop.yml
    CHANGED
    
    
    
        data/Gemfile
    CHANGED
    
    | 
         @@ -24,11 +24,11 @@ 
     | 
|
| 
       24 
24 
     | 
    
         
             
            source 'https://rubygems.org'
         
     | 
| 
       25 
25 
     | 
    
         
             
            gemspec
         
     | 
| 
       26 
26 
     | 
    
         | 
| 
       27 
     | 
    
         
            -
            gem 'minitest', '5. 
     | 
| 
      
 27 
     | 
    
         
            +
            gem 'minitest', '5.19.0', require: false
         
     | 
| 
       28 
28 
     | 
    
         
             
            gem 'rake', '13.0.6', require: false
         
     | 
| 
       29 
29 
     | 
    
         
             
            gem 'rdoc', '6.5.0', require: false
         
     | 
| 
       30 
     | 
    
         
            -
            gem 'rspec-rails', ' 
     | 
| 
       31 
     | 
    
         
            -
            gem 'rubocop', '1. 
     | 
| 
       32 
     | 
    
         
            -
            gem 'rubocop-rspec', '2. 
     | 
| 
      
 30 
     | 
    
         
            +
            gem 'rspec-rails', '6.0.3', require: false
         
     | 
| 
      
 31 
     | 
    
         
            +
            gem 'rubocop', '1.56.0', require: false
         
     | 
| 
      
 32 
     | 
    
         
            +
            gem 'rubocop-rspec', '2.23.2', require: false
         
     | 
| 
       33 
33 
     | 
    
         
             
            gem 'simplecov', '0.22.0', require: false
         
     | 
| 
       34 
34 
     | 
    
         
             
            gem 'webmock', '3.18.1', require: false
         
     | 
    
        data/glogin.gemspec
    CHANGED
    
    | 
         @@ -41,7 +41,7 @@ Gem::Specification.new do |s| 
     | 
|
| 
       41 
41 
     | 
    
         
             
              s.executables = s.files.grep(%r{^bin/}) { |f| File.basename(f) }
         
     | 
| 
       42 
42 
     | 
    
         
             
              s.rdoc_options = ['--charset=UTF-8']
         
     | 
| 
       43 
43 
     | 
    
         
             
              s.extra_rdoc_files = ['README.md', 'LICENSE.txt']
         
     | 
| 
       44 
     | 
    
         
            -
              s.add_runtime_dependency 'base58', ' 
     | 
| 
       45 
     | 
    
         
            -
              s.add_runtime_dependency 'openssl', ' 
     | 
| 
      
 44 
     | 
    
         
            +
              s.add_runtime_dependency 'base58', '>= 0.2'
         
     | 
| 
      
 45 
     | 
    
         
            +
              s.add_runtime_dependency 'openssl', '>= 2.0'
         
     | 
| 
       46 
46 
     | 
    
         
             
              s.metadata['rubygems_mfa_required'] = 'true'
         
     | 
| 
       47 
47 
     | 
    
         
             
            end
         
     | 
    
        data/lib/glogin/codec.rb
    CHANGED
    
    | 
         @@ -25,6 +25,7 @@ require 'securerandom' 
     | 
|
| 
       25 
25 
     | 
    
         
             
            require 'openssl'
         
     | 
| 
       26 
26 
     | 
    
         
             
            require 'digest/sha1'
         
     | 
| 
       27 
27 
     | 
    
         
             
            require 'base58'
         
     | 
| 
      
 28 
     | 
    
         
            +
            require 'base64'
         
     | 
| 
       28 
29 
     | 
    
         | 
| 
       29 
30 
     | 
    
         
             
            # Codec.
         
     | 
| 
       30 
31 
     | 
    
         
             
            # Author:: Yegor Bugayenko (yegor256@gmail.com)
         
     | 
| 
         @@ -36,9 +37,13 @@ module GLogin 
     | 
|
| 
       36 
37 
     | 
    
         
             
                # When can't decode.
         
     | 
| 
       37 
38 
     | 
    
         
             
                class DecodingError < StandardError; end
         
     | 
| 
       38 
39 
     | 
    
         | 
| 
       39 
     | 
    
         
            -
                 
     | 
| 
      
 40 
     | 
    
         
            +
                # Ctor.
         
     | 
| 
      
 41 
     | 
    
         
            +
                # +secret+: The secret to do the encoding
         
     | 
| 
      
 42 
     | 
    
         
            +
                # +base64+: If TRUE, Base-64 will be used, otherwise Base-58
         
     | 
| 
      
 43 
     | 
    
         
            +
                def initialize(secret = '', base64: false)
         
     | 
| 
       40 
44 
     | 
    
         
             
                  raise 'Secret can\'t be nil' if secret.nil?
         
     | 
| 
       41 
45 
     | 
    
         
             
                  @secret = secret
         
     | 
| 
      
 46 
     | 
    
         
            +
                  @base64 = base64
         
     | 
| 
       42 
47 
     | 
    
         
             
                end
         
     | 
| 
       43 
48 
     | 
    
         | 
| 
       44 
49 
     | 
    
         
             
                def decrypt(text)
         
     | 
| 
         @@ -49,8 +54,12 @@ module GLogin 
     | 
|
| 
       49 
54 
     | 
    
         
             
                    cpr = cipher
         
     | 
| 
       50 
55 
     | 
    
         
             
                    cpr.decrypt
         
     | 
| 
       51 
56 
     | 
    
         
             
                    cpr.key = digest(cpr.key_len)
         
     | 
| 
       52 
     | 
    
         
            -
                     
     | 
| 
       53 
     | 
    
         
            -
             
     | 
| 
      
 57 
     | 
    
         
            +
                    if @base64
         
     | 
| 
      
 58 
     | 
    
         
            +
                      raise DecodingError, 'This is not Base64' unless %r{^[a-zA-Z0-9\\+/=]+$}.match?(text)
         
     | 
| 
      
 59 
     | 
    
         
            +
                    else
         
     | 
| 
      
 60 
     | 
    
         
            +
                      raise DecodingError, 'This is not Base58' unless /^[a-zA-Z0-9]+$/.match?(text)
         
     | 
| 
      
 61 
     | 
    
         
            +
                    end
         
     | 
| 
      
 62 
     | 
    
         
            +
                    plain = @base64 ? Base64.decode64(text) : Base58.base58_to_binary(text)
         
     | 
| 
       54 
63 
     | 
    
         
             
                    raise DecodingError if plain.empty?
         
     | 
| 
       55 
64 
     | 
    
         
             
                    decrypted = cpr.update(plain)
         
     | 
| 
       56 
65 
     | 
    
         
             
                    decrypted << cpr.final
         
     | 
| 
         @@ -75,7 +84,7 @@ module GLogin 
     | 
|
| 
       75 
84 
     | 
    
         
             
                    salt = SecureRandom.base64(Random.rand(8..32))
         
     | 
| 
       76 
85 
     | 
    
         
             
                    encrypted = cpr.update("#{salt} #{text}")
         
     | 
| 
       77 
86 
     | 
    
         
             
                    encrypted << cpr.final
         
     | 
| 
       78 
     | 
    
         
            -
                    Base58.binary_to_base58(encrypted)
         
     | 
| 
      
 87 
     | 
    
         
            +
                    @base64 ? Base64.encode64(encrypted).gsub("\n", '') : Base58.binary_to_base58(encrypted)
         
     | 
| 
       79 
88 
     | 
    
         
             
                  end
         
     | 
| 
       80 
89 
     | 
    
         
             
                end
         
     | 
| 
       81 
90 
     | 
    
         | 
    
        data/lib/glogin/version.rb
    CHANGED
    
    
    
        data/test/glogin/test_codec.rb
    CHANGED
    
    | 
         @@ -54,6 +54,13 @@ class TestCodec < Minitest::Test 
     | 
|
| 
       54 
54 
     | 
    
         
             
                assert(!text.include?("\n"), text)
         
     | 
| 
       55 
55 
     | 
    
         
             
              end
         
     | 
| 
       56 
56 
     | 
    
         | 
| 
      
 57 
     | 
    
         
            +
              def test_encrypts_using_base64
         
     | 
| 
      
 58 
     | 
    
         
            +
                codec = GLogin::Codec.new('6hFGrte5LLmwi', base64: true)
         
     | 
| 
      
 59 
     | 
    
         
            +
                text = 'Hello, world!'
         
     | 
| 
      
 60 
     | 
    
         
            +
                enc = codec.encrypt(text)
         
     | 
| 
      
 61 
     | 
    
         
            +
                assert_equal(text, codec.decrypt(enc))
         
     | 
| 
      
 62 
     | 
    
         
            +
              end
         
     | 
| 
      
 63 
     | 
    
         
            +
             
     | 
| 
       57 
64 
     | 
    
         
             
              def test_decrypts_broken_text
         
     | 
| 
       58 
65 
     | 
    
         
             
                assert_raises GLogin::Codec::DecodingError do
         
     | 
| 
       59 
66 
     | 
    
         
             
                  GLogin::Codec.new('the key').decrypt('этот текст не был зашифрован')
         
     | 
    
        metadata
    CHANGED
    
    | 
         @@ -1,43 +1,43 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            --- !ruby/object:Gem::Specification
         
     | 
| 
       2 
2 
     | 
    
         
             
            name: glogin
         
     | 
| 
       3 
3 
     | 
    
         
             
            version: !ruby/object:Gem::Version
         
     | 
| 
       4 
     | 
    
         
            -
              version: 0. 
     | 
| 
      
 4 
     | 
    
         
            +
              version: 0.13.0
         
     | 
| 
       5 
5 
     | 
    
         
             
            platform: ruby
         
     | 
| 
       6 
6 
     | 
    
         
             
            authors:
         
     | 
| 
       7 
7 
     | 
    
         
             
            - Yegor Bugayenko
         
     | 
| 
       8 
8 
     | 
    
         
             
            autorequire: 
         
     | 
| 
       9 
9 
     | 
    
         
             
            bindir: bin
         
     | 
| 
       10 
10 
     | 
    
         
             
            cert_chain: []
         
     | 
| 
       11 
     | 
    
         
            -
            date: 2023- 
     | 
| 
      
 11 
     | 
    
         
            +
            date: 2023-08-25 00:00:00.000000000 Z
         
     | 
| 
       12 
12 
     | 
    
         
             
            dependencies:
         
     | 
| 
       13 
13 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       14 
14 
     | 
    
         
             
              name: base58
         
     | 
| 
       15 
15 
     | 
    
         
             
              requirement: !ruby/object:Gem::Requirement
         
     | 
| 
       16 
16 
     | 
    
         
             
                requirements:
         
     | 
| 
       17 
     | 
    
         
            -
                - - " 
     | 
| 
      
 17 
     | 
    
         
            +
                - - ">="
         
     | 
| 
       18 
18 
     | 
    
         
             
                  - !ruby/object:Gem::Version
         
     | 
| 
       19 
19 
     | 
    
         
             
                    version: '0.2'
         
     | 
| 
       20 
20 
     | 
    
         
             
              type: :runtime
         
     | 
| 
       21 
21 
     | 
    
         
             
              prerelease: false
         
     | 
| 
       22 
22 
     | 
    
         
             
              version_requirements: !ruby/object:Gem::Requirement
         
     | 
| 
       23 
23 
     | 
    
         
             
                requirements:
         
     | 
| 
       24 
     | 
    
         
            -
                - - " 
     | 
| 
      
 24 
     | 
    
         
            +
                - - ">="
         
     | 
| 
       25 
25 
     | 
    
         
             
                  - !ruby/object:Gem::Version
         
     | 
| 
       26 
26 
     | 
    
         
             
                    version: '0.2'
         
     | 
| 
       27 
27 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       28 
28 
     | 
    
         
             
              name: openssl
         
     | 
| 
       29 
29 
     | 
    
         
             
              requirement: !ruby/object:Gem::Requirement
         
     | 
| 
       30 
30 
     | 
    
         
             
                requirements:
         
     | 
| 
       31 
     | 
    
         
            -
                - - " 
     | 
| 
      
 31 
     | 
    
         
            +
                - - ">="
         
     | 
| 
       32 
32 
     | 
    
         
             
                  - !ruby/object:Gem::Version
         
     | 
| 
       33 
     | 
    
         
            -
                    version: ' 
     | 
| 
      
 33 
     | 
    
         
            +
                    version: '2.0'
         
     | 
| 
       34 
34 
     | 
    
         
             
              type: :runtime
         
     | 
| 
       35 
35 
     | 
    
         
             
              prerelease: false
         
     | 
| 
       36 
36 
     | 
    
         
             
              version_requirements: !ruby/object:Gem::Requirement
         
     | 
| 
       37 
37 
     | 
    
         
             
                requirements:
         
     | 
| 
       38 
     | 
    
         
            -
                - - " 
     | 
| 
      
 38 
     | 
    
         
            +
                - - ">="
         
     | 
| 
       39 
39 
     | 
    
         
             
                  - !ruby/object:Gem::Version
         
     | 
| 
       40 
     | 
    
         
            -
                    version: ' 
     | 
| 
      
 40 
     | 
    
         
            +
                    version: '2.0'
         
     | 
| 
       41 
41 
     | 
    
         
             
            description: Enables login/logout functionality for a Ruby web app
         
     | 
| 
       42 
42 
     | 
    
         
             
            email: yegor256@gmail.com
         
     | 
| 
       43 
43 
     | 
    
         
             
            executables: []
         
     |