vgs_api_client 0.0.1.dev202204182306

Sign up to get free protection for your applications and to get access to all the features.
Files changed (44) hide show
  1. checksums.yaml +7 -0
  2. data/DEVELOPMENT.md +11 -0
  3. data/Gemfile +9 -0
  4. data/Gemfile.lock +70 -0
  5. data/LICENSE +11 -0
  6. data/RELEASE.md +15 -0
  7. data/Rakefile +10 -0
  8. data/docker-compose.yaml +32 -0
  9. data/lib/vgs.rb +82 -0
  10. data/lib/vgs_api_client/api/aliases_api.rb +346 -0
  11. data/lib/vgs_api_client/api_client.rb +390 -0
  12. data/lib/vgs_api_client/api_error.rb +57 -0
  13. data/lib/vgs_api_client/configuration.rb +286 -0
  14. data/lib/vgs_api_client/models/alias_format.rb +44 -0
  15. data/lib/vgs_api_client/models/api_error.rb +249 -0
  16. data/lib/vgs_api_client/models/create_aliases_request.rb +253 -0
  17. data/lib/vgs_api_client/models/create_aliases_request_new.rb +296 -0
  18. data/lib/vgs_api_client/models/create_aliases_request_reference.rb +238 -0
  19. data/lib/vgs_api_client/models/inline_response200.rb +220 -0
  20. data/lib/vgs_api_client/models/inline_response2001.rb +245 -0
  21. data/lib/vgs_api_client/models/inline_response201.rb +221 -0
  22. data/lib/vgs_api_client/models/inline_response_default.rb +236 -0
  23. data/lib/vgs_api_client/models/model_alias.rb +228 -0
  24. data/lib/vgs_api_client/models/revealed_data.rb +299 -0
  25. data/lib/vgs_api_client/models/update_alias_request.rb +223 -0
  26. data/lib/vgs_api_client/models/update_alias_request_data.rb +226 -0
  27. data/lib/vgs_api_client/version.rb +15 -0
  28. data/lib/vgs_api_client.rb +53 -0
  29. data/scripts/assemble/Dockerfile +5 -0
  30. data/scripts/assemble/run.sh +9 -0
  31. data/scripts/publish/Dockerfile +5 -0
  32. data/scripts/publish/run.sh +14 -0
  33. data/scripts/publish.sh +12 -0
  34. data/scripts/run-test-e2e.sh +13 -0
  35. data/scripts/run-test-local.sh +4 -0
  36. data/scripts/test/Dockerfile +10 -0
  37. data/scripts/test/run.sh +30 -0
  38. data/spec/api_client_spec.rb +226 -0
  39. data/spec/configuration_spec.rb +42 -0
  40. data/spec/spec_helper.rb +111 -0
  41. data/spec/test_api_spec.rb +97 -0
  42. data/vgs_api_client-0.0.1.dev202204181658.gem +0 -0
  43. data/vgs_api_client.gemspec +38 -0
  44. metadata +129 -0
@@ -0,0 +1,42 @@
1
+ =begin
2
+ #Vault HTTP API
3
+
4
+ #The VGS Vault HTTP API is used for storing, retrieving, and managing sensitive data (aka Tokenization) within a VGS Vault. The VGS API is organized around REST. Our API is built with a predictable resource-oriented structure, uses JSON-encoded requests and responses, follows standard HTTP verbs/responses, and uses industry standard authentication. ## What is VGS Storing sensitive data on your company’s infrastructure often comes with a heavy compliance burden. For instance, storing payments data yourself greatly increases the amount of work needed to become PCI compliant. It also increases your security risk in general. To combat this, companies will minimize the amount of sensitive information they have to handle or store. VGS provides multiple methods for minimizing the sensitive information that needs to be stored which allows customers to secure any type of data for any use-case. **Tokenization** is a method that focuses on securing the storage of data. This is the quickest way to get started and is free. [Get started with Tokenization](https://www.verygoodsecurity.com/docs/tokenization/getting-started). **Zero Data** is a unique method invented by VGS in 2016 that securely stores data like Tokenization, however it also removes the customer’s environment from PCI scope completely providing maximum security, and minimum compliance scope. [Get started with Zero Data](https://www.verygoodsecurity.com/docs/getting-started/before-you-start). Additionally, for scenarios where neither technology is a complete solution, for instance with legacy systems, VGS provides a compliance product which guarantees customers are able to meet their compliance needs no matter what may happen. [Get started with Control](https://www.verygoodsecurity.com/docs/control). ## Learn about Tokenization - [Create an Account for Free Tokenization](https://dashboard.verygoodsecurity.com/tokenization) - [Try a Tokenization Demo](https://www.verygoodsecurity.com/docs/tokenization/getting-started) - [Install a Tokenization SDK](https://www.verygoodsecurity.com/docs/tokenization/client-libraries) ### Authentication This API uses `Basic` authentication. Credentials to access the API can be generated on the [dashboard](https://dashboard.verygoodsecurity.com) by going to the Settings section of the vault of your choosing. [Docs » Guides » Access credentials](https://www.verygoodsecurity.com/docs/settings/access-credentials) ## Resource Limits ### Data Limits This API allows storing data up to 32MB in size. ### Rate Limiting The API allows up to 3,000 requests per minute. Requests are associated with the vault, regardless of the access credentials used to authenticate the request. Your current rate limit is included as HTTP headers in every API response: | Header Name | Description | |-------------------------|----------------------------------------------------------| | `x-ratelimit-remaining` | The number of requests remaining in the 1-minute window. | If you exceed the rate limit, the API will reject the request with HTTP [429 Too Many Requests](https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/429). ### Errors The API uses standard HTTP status codes to indicate whether the request succeeded or not. In case of failure, the response body will be JSON in a predefined format. For example, trying to create too many aliases at once results in the following response: ```json { \"errors\": [ { \"status\": 400, \"title\": \"Bad request\", \"detail\": \"Too many values (limit: 20)\", \"href\": \"https://api.sandbox.verygoodvault.com/aliases\" } ] } ```
5
+
6
+ The version of the OpenAPI document: 1.0.0
7
+ Contact: support@verygoodsecurity.com
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.4.0
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+
15
+ describe VgsApiClient::Configuration do
16
+ let(:config) { VgsApiClient::Configuration.default }
17
+
18
+ before(:each) do
19
+ # uncomment below to setup host and base_path
20
+ # require 'URI'
21
+ # uri = URI.parse("https://api.sandbox.verygoodvault.com")
22
+ # VgsApiClient.configure do |c|
23
+ # c.host = uri.host
24
+ # c.base_path = uri.path
25
+ # end
26
+ end
27
+
28
+ describe '#base_url' do
29
+ it 'should have the default value' do
30
+ # uncomment below to test default value of the base path
31
+ # expect(config.base_url).to eq("https://api.sandbox.verygoodvault.com")
32
+ end
33
+
34
+ it 'should remove trailing slashes' do
35
+ [nil, '', '/', '//'].each do |base_path|
36
+ config.base_path = base_path
37
+ # uncomment below to test trailing slashes
38
+ # expect(config.base_url).to eq("https://api.sandbox.verygoodvault.com")
39
+ end
40
+ end
41
+ end
42
+ end
@@ -0,0 +1,111 @@
1
+ =begin
2
+ #Vault HTTP API
3
+
4
+ #The VGS Vault HTTP API is used for storing, retrieving, and managing sensitive data (aka Tokenization) within a VGS Vault. The VGS API is organized around REST. Our API is built with a predictable resource-oriented structure, uses JSON-encoded requests and responses, follows standard HTTP verbs/responses, and uses industry standard authentication. ## What is VGS Storing sensitive data on your company’s infrastructure often comes with a heavy compliance burden. For instance, storing payments data yourself greatly increases the amount of work needed to become PCI compliant. It also increases your security risk in general. To combat this, companies will minimize the amount of sensitive information they have to handle or store. VGS provides multiple methods for minimizing the sensitive information that needs to be stored which allows customers to secure any type of data for any use-case. **Tokenization** is a method that focuses on securing the storage of data. This is the quickest way to get started and is free. [Get started with Tokenization](https://www.verygoodsecurity.com/docs/tokenization/getting-started). **Zero Data** is a unique method invented by VGS in 2016 that securely stores data like Tokenization, however it also removes the customer’s environment from PCI scope completely providing maximum security, and minimum compliance scope. [Get started with Zero Data](https://www.verygoodsecurity.com/docs/getting-started/before-you-start). Additionally, for scenarios where neither technology is a complete solution, for instance with legacy systems, VGS provides a compliance product which guarantees customers are able to meet their compliance needs no matter what may happen. [Get started with Control](https://www.verygoodsecurity.com/docs/control). ## Learn about Tokenization - [Create an Account for Free Tokenization](https://dashboard.verygoodsecurity.com/tokenization) - [Try a Tokenization Demo](https://www.verygoodsecurity.com/docs/tokenization/getting-started) - [Install a Tokenization SDK](https://www.verygoodsecurity.com/docs/tokenization/client-libraries) ### Authentication This API uses `Basic` authentication. Credentials to access the API can be generated on the [dashboard](https://dashboard.verygoodsecurity.com) by going to the Settings section of the vault of your choosing. [Docs » Guides » Access credentials](https://www.verygoodsecurity.com/docs/settings/access-credentials) ## Resource Limits ### Data Limits This API allows storing data up to 32MB in size. ### Rate Limiting The API allows up to 3,000 requests per minute. Requests are associated with the vault, regardless of the access credentials used to authenticate the request. Your current rate limit is included as HTTP headers in every API response: | Header Name | Description | |-------------------------|----------------------------------------------------------| | `x-ratelimit-remaining` | The number of requests remaining in the 1-minute window. | If you exceed the rate limit, the API will reject the request with HTTP [429 Too Many Requests](https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/429). ### Errors The API uses standard HTTP status codes to indicate whether the request succeeded or not. In case of failure, the response body will be JSON in a predefined format. For example, trying to create too many aliases at once results in the following response: ```json { \"errors\": [ { \"status\": 400, \"title\": \"Bad request\", \"detail\": \"Too many values (limit: 20)\", \"href\": \"https://api.sandbox.verygoodvault.com/aliases\" } ] } ```
5
+
6
+ The version of the OpenAPI document: 1.0.0
7
+ Contact: support@verygoodsecurity.com
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.4.0
10
+
11
+ =end
12
+
13
+ # load the gem
14
+ require 'vgs_api_client'
15
+
16
+ # The following was generated by the `rspec --init` command. Conventionally, all
17
+ # specs live under a `spec` directory, which RSpec adds to the `$LOAD_PATH`.
18
+ # The generated `.rspec` file contains `--require spec_helper` which will cause
19
+ # this file to always be loaded, without a need to explicitly require it in any
20
+ # files.
21
+ #
22
+ # Given that it is always loaded, you are encouraged to keep this file as
23
+ # light-weight as possible. Requiring heavyweight dependencies from this file
24
+ # will add to the boot time of your test suite on EVERY test run, even for an
25
+ # individual file that may not need all of that loaded. Instead, consider making
26
+ # a separate helper file that requires the additional dependencies and performs
27
+ # the additional setup, and require it from the spec files that actually need
28
+ # it.
29
+ #
30
+ # The `.rspec` file also contains a few flags that are not defaults but that
31
+ # users commonly want.
32
+ #
33
+ # See http://rubydoc.info/gems/rspec-core/RSpec/Core/Configuration
34
+ RSpec.configure do |config|
35
+ # rspec-expectations config goes here. You can use an alternate
36
+ # assertion/expectation library such as wrong or the stdlib/minitest
37
+ # assertions if you prefer.
38
+ config.expect_with :rspec do |expectations|
39
+ # This option will default to `true` in RSpec 4. It makes the `description`
40
+ # and `failure_message` of custom matchers include text for helper methods
41
+ # defined using `chain`, e.g.:
42
+ # be_bigger_than(2).and_smaller_than(4).description
43
+ # # => "be bigger than 2 and smaller than 4"
44
+ # ...rather than:
45
+ # # => "be bigger than 2"
46
+ expectations.include_chain_clauses_in_custom_matcher_descriptions = true
47
+ end
48
+
49
+ # rspec-mocks config goes here. You can use an alternate test double
50
+ # library (such as bogus or mocha) by changing the `mock_with` option here.
51
+ config.mock_with :rspec do |mocks|
52
+ # Prevents you from mocking or stubbing a method that does not exist on
53
+ # a real object. This is generally recommended, and will default to
54
+ # `true` in RSpec 4.
55
+ mocks.verify_partial_doubles = true
56
+ end
57
+
58
+ # The settings below are suggested to provide a good initial experience
59
+ # with RSpec, but feel free to customize to your heart's content.
60
+ =begin
61
+ # These two settings work together to allow you to limit a spec run
62
+ # to individual examples or groups you care about by tagging them with
63
+ # `:focus` metadata. When nothing is tagged with `:focus`, all examples
64
+ # get run.
65
+ config.filter_run :focus
66
+ config.run_all_when_everything_filtered = true
67
+
68
+ # Allows RSpec to persist some state between runs in order to support
69
+ # the `--only-failures` and `--next-failure` CLI options. We recommend
70
+ # you configure your source control system to ignore this file.
71
+ config.example_status_persistence_file_path = "spec/examples.txt"
72
+
73
+ # Limits the available syntax to the non-monkey patched syntax that is
74
+ # recommended. For more details, see:
75
+ # - http://rspec.info/blog/2012/06/rspecs-new-expectation-syntax/
76
+ # - http://www.teaisaweso.me/blog/2013/05/27/rspecs-new-message-expectation-syntax/
77
+ # - http://rspec.info/blog/2014/05/notable-changes-in-rspec-3/#zero-monkey-patching-mode
78
+ config.disable_monkey_patching!
79
+
80
+ # This setting enables warnings. It's recommended, but in some cases may
81
+ # be too noisy due to issues in dependencies.
82
+ config.warnings = true
83
+
84
+ # Many RSpec users commonly either run the entire suite or an individual
85
+ # file, and it's useful to allow more verbose output when running an
86
+ # individual spec file.
87
+ if config.files_to_run.one?
88
+ # Use the documentation formatter for detailed output,
89
+ # unless a formatter has already been configured
90
+ # (e.g. via a command-line flag).
91
+ config.default_formatter = 'doc'
92
+ end
93
+
94
+ # Print the 10 slowest examples and example groups at the
95
+ # end of the spec run, to help surface which specs are running
96
+ # particularly slow.
97
+ config.profile_examples = 10
98
+
99
+ # Run specs in random order to surface order dependencies. If you find an
100
+ # order dependency and want to debug it, you can fix the order by providing
101
+ # the seed, which is printed after each run.
102
+ # --seed 1234
103
+ config.order = :random
104
+
105
+ # Seed global randomization in this process using the `--seed` CLI option.
106
+ # Setting this allows you to use `--seed` to deterministically reproduce
107
+ # test failures related to randomization by passing the same `--seed` value
108
+ # as the one that triggered the failure.
109
+ Kernel.srand config.seed
110
+ =end
111
+ end
@@ -0,0 +1,97 @@
1
+ require 'spec_helper'
2
+ require 'securerandom'
3
+ require 'vgs'
4
+
5
+ describe 'AliasesApiSpec' do
6
+ before(:all) do
7
+ config = VGS.config(username = ENV["VAULT_API_USERNAME"], password = ENV["VAULT_API_PASSWORD"])
8
+ @aliases_api = VGS::Aliases.new(config)
9
+ end
10
+
11
+ describe 'redact' do
12
+ it 'should redact values' do
13
+ data = [
14
+ {
15
+ :format => 'UUID',
16
+ :value => '5201784564572092',
17
+ :classifiers => %w[credit-card number],
18
+ :storage => 'PERSISTENT',
19
+ },
20
+ {
21
+ :format => 'UUID',
22
+ :value => 'Joe Doe',
23
+ :storage => 'VOLATILE',
24
+ }
25
+ ]
26
+ aliases = @aliases_api.redact(data)
27
+ expect(aliases.length).to eq 2
28
+ data.each_with_index do |item, index|
29
+ expect(aliases[index].value).to eq item[:value]
30
+ expect(aliases[index].storage).to eq item[:storage]
31
+ expect(aliases[index].aliases[0]._alias).to start_with "tok_"
32
+ end
33
+ expect(Set.new(aliases[0].classifiers)).to eq Set.new(%w[credit-card number])
34
+ expect(Set.new(aliases[1].classifiers)).to eq Set.new
35
+ end
36
+ end
37
+
38
+ describe 'reveal' do
39
+ it 'should reveal aliases' do
40
+ data = [
41
+ {
42
+ :format => 'UUID',
43
+ :value => '5201784564572092',
44
+ :classifiers => %w[credit-card number],
45
+ :storage => 'PERSISTENT',
46
+ },
47
+ {
48
+ :format => 'UUID',
49
+ :value => 'Joe Doe',
50
+ :storage => 'VOLATILE',
51
+ }
52
+ ]
53
+ aliases = @aliases_api.redact(data).map { |item| item.aliases[0]._alias }
54
+
55
+ response = @aliases_api.reveal(aliases)
56
+
57
+ expect(response.length).to eq 2
58
+ original_values = data.map { |i| i[:value] }
59
+ revealed_values = response.values.map { |i| i.value }
60
+ expect(Set.new(original_values)).to eq Set.new(revealed_values)
61
+ end
62
+ end
63
+
64
+ describe 'update' do
65
+ it 'should update alias' do
66
+ data = [
67
+ {
68
+ :format => 'UUID',
69
+ :value => SecureRandom.alphanumeric(10),
70
+ }
71
+ ]
72
+ _alias = @aliases_api.redact(data).map { |item| item.aliases[0]._alias }[0]
73
+
74
+ @aliases_api.update(_alias = _alias, data = { :classifiers => ["secure"] })
75
+
76
+ response = @aliases_api.reveal(_alias)
77
+ expect(response[_alias].classifiers).to eq %w[secure]
78
+ end
79
+ end
80
+
81
+ describe 'delete' do
82
+ it 'should delete alias' do
83
+ data = [
84
+ {
85
+ :format => 'UUID',
86
+ :value => '5201784564572092',
87
+ }
88
+ ]
89
+ _alias = @aliases_api.redact(data).map { |item| item.aliases[0]._alias }[0]
90
+
91
+ @aliases_api.delete(_alias = _alias)
92
+
93
+ expect { @aliases_api.reveal(_alias) }.to raise_error(VGS::VgsApiException)
94
+ end
95
+ end
96
+
97
+ end
@@ -0,0 +1,38 @@
1
+ # -*- encoding: utf-8 -*-
2
+
3
+ =begin
4
+ #Vault HTTP API
5
+
6
+ #The VGS Vault HTTP API is used for storing, retrieving, and managing sensitive data (aka Tokenization) within a VGS Vault. The VGS API is organized around REST. Our API is built with a predictable resource-oriented structure, uses JSON-encoded requests and responses, follows standard HTTP verbs/responses, and uses industry standard authentication. ## What is VGS Storing sensitive data on your company’s infrastructure often comes with a heavy compliance burden. For instance, storing payments data yourself greatly increases the amount of work needed to become PCI compliant. It also increases your security risk in general. To combat this, companies will minimize the amount of sensitive information they have to handle or store. VGS provides multiple methods for minimizing the sensitive information that needs to be stored which allows customers to secure any type of data for any use-case. **Tokenization** is a method that focuses on securing the storage of data. This is the quickest way to get started and is free. [Get started with Tokenization](https://www.verygoodsecurity.com/docs/tokenization/getting-started). **Zero Data** is a unique method invented by VGS in 2016 that securely stores data like Tokenization, however it also removes the customer’s environment from PCI scope completely providing maximum security, and minimum compliance scope. [Get started with Zero Data](https://www.verygoodsecurity.com/docs/getting-started/before-you-start). Additionally, for scenarios where neither technology is a complete solution, for instance with legacy systems, VGS provides a compliance product which guarantees customers are able to meet their compliance needs no matter what may happen. [Get started with Control](https://www.verygoodsecurity.com/docs/control). ## Learn about Tokenization - [Create an Account for Free Tokenization](https://dashboard.verygoodsecurity.com/tokenization) - [Try a Tokenization Demo](https://www.verygoodsecurity.com/docs/tokenization/getting-started) - [Install a Tokenization SDK](https://www.verygoodsecurity.com/docs/tokenization/client-libraries) ### Authentication This API uses `Basic` authentication. Credentials to access the API can be generated on the [dashboard](https://dashboard.verygoodsecurity.com) by going to the Settings section of the vault of your choosing. [Docs » Guides » Access credentials](https://www.verygoodsecurity.com/docs/settings/access-credentials) ## Resource Limits ### Data Limits This API allows storing data up to 32MB in size. ### Rate Limiting The API allows up to 3,000 requests per minute. Requests are associated with the vault, regardless of the access credentials used to authenticate the request. Your current rate limit is included as HTTP headers in every API response: | Header Name | Description | |-------------------------|----------------------------------------------------------| | `x-ratelimit-remaining` | The number of requests remaining in the 1-minute window. | If you exceed the rate limit, the API will reject the request with HTTP [429 Too Many Requests](https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/429). ### Errors The API uses standard HTTP status codes to indicate whether the request succeeded or not. In case of failure, the response body will be JSON in a predefined format. For example, trying to create too many aliases at once results in the following response: ```json { \"errors\": [ { \"status\": 400, \"title\": \"Bad request\", \"detail\": \"Too many values (limit: 20)\", \"href\": \"https://api.sandbox.verygoodvault.com/aliases\" } ] } ```
7
+
8
+ The version of the OpenAPI document: 1.0.0
9
+ Contact: support@verygoodsecurity.com
10
+ Generated by: https://openapi-generator.tech
11
+ OpenAPI Generator version: 5.4.0
12
+
13
+ =end
14
+
15
+ $:.push File.expand_path("../lib", __FILE__)
16
+ require "vgs_api_client/version"
17
+
18
+ Gem::Specification.new do |s|
19
+ s.name = "vgs_api_client"
20
+ s.version = VgsApiClient::VERSION
21
+ s.platform = Gem::Platform::RUBY
22
+ s.authors = ["Very Good Security"]
23
+ s.email = ["dev@verygoodsecurity.com"]
24
+ s.homepage = "https://openapi-generator.tech"
25
+ s.summary = "A ruby wrapper for the VGS Vault API"
26
+ s.description = "This gem maps to VGS Vault API"
27
+ s.license = "Unlicense"
28
+ s.required_ruby_version = ">= 2.4"
29
+
30
+ s.add_runtime_dependency 'typhoeus', '~> 1.0', '>= 1.0.1'
31
+
32
+ s.add_development_dependency 'rspec', '~> 3.6', '>= 3.6.0'
33
+
34
+ s.files = `find *`.split("\n").uniq.sort.select { |f| !f.empty? }
35
+ s.test_files = `find spec/*`.split("\n")
36
+ s.executables = []
37
+ s.require_paths = ["lib"]
38
+ end
metadata ADDED
@@ -0,0 +1,129 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: vgs_api_client
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1.dev202204182306
5
+ platform: ruby
6
+ authors:
7
+ - Very Good Security
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2022-04-18 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: typhoeus
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.0'
20
+ - - ">="
21
+ - !ruby/object:Gem::Version
22
+ version: 1.0.1
23
+ type: :runtime
24
+ prerelease: false
25
+ version_requirements: !ruby/object:Gem::Requirement
26
+ requirements:
27
+ - - "~>"
28
+ - !ruby/object:Gem::Version
29
+ version: '1.0'
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: 1.0.1
33
+ - !ruby/object:Gem::Dependency
34
+ name: rspec
35
+ requirement: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - "~>"
38
+ - !ruby/object:Gem::Version
39
+ version: '3.6'
40
+ - - ">="
41
+ - !ruby/object:Gem::Version
42
+ version: 3.6.0
43
+ type: :development
44
+ prerelease: false
45
+ version_requirements: !ruby/object:Gem::Requirement
46
+ requirements:
47
+ - - "~>"
48
+ - !ruby/object:Gem::Version
49
+ version: '3.6'
50
+ - - ">="
51
+ - !ruby/object:Gem::Version
52
+ version: 3.6.0
53
+ description: This gem maps to VGS Vault API
54
+ email:
55
+ - dev@verygoodsecurity.com
56
+ executables: []
57
+ extensions: []
58
+ extra_rdoc_files: []
59
+ files:
60
+ - DEVELOPMENT.md
61
+ - Gemfile
62
+ - Gemfile.lock
63
+ - LICENSE
64
+ - RELEASE.md
65
+ - Rakefile
66
+ - docker-compose.yaml
67
+ - lib/vgs.rb
68
+ - lib/vgs_api_client.rb
69
+ - lib/vgs_api_client/api/aliases_api.rb
70
+ - lib/vgs_api_client/api_client.rb
71
+ - lib/vgs_api_client/api_error.rb
72
+ - lib/vgs_api_client/configuration.rb
73
+ - lib/vgs_api_client/models/alias_format.rb
74
+ - lib/vgs_api_client/models/api_error.rb
75
+ - lib/vgs_api_client/models/create_aliases_request.rb
76
+ - lib/vgs_api_client/models/create_aliases_request_new.rb
77
+ - lib/vgs_api_client/models/create_aliases_request_reference.rb
78
+ - lib/vgs_api_client/models/inline_response200.rb
79
+ - lib/vgs_api_client/models/inline_response2001.rb
80
+ - lib/vgs_api_client/models/inline_response201.rb
81
+ - lib/vgs_api_client/models/inline_response_default.rb
82
+ - lib/vgs_api_client/models/model_alias.rb
83
+ - lib/vgs_api_client/models/revealed_data.rb
84
+ - lib/vgs_api_client/models/update_alias_request.rb
85
+ - lib/vgs_api_client/models/update_alias_request_data.rb
86
+ - lib/vgs_api_client/version.rb
87
+ - scripts/assemble/Dockerfile
88
+ - scripts/assemble/run.sh
89
+ - scripts/publish.sh
90
+ - scripts/publish/Dockerfile
91
+ - scripts/publish/run.sh
92
+ - scripts/run-test-e2e.sh
93
+ - scripts/run-test-local.sh
94
+ - scripts/test/Dockerfile
95
+ - scripts/test/run.sh
96
+ - spec/api_client_spec.rb
97
+ - spec/configuration_spec.rb
98
+ - spec/spec_helper.rb
99
+ - spec/test_api_spec.rb
100
+ - vgs_api_client-0.0.1.dev202204181658.gem
101
+ - vgs_api_client.gemspec
102
+ homepage: https://openapi-generator.tech
103
+ licenses:
104
+ - Unlicense
105
+ metadata: {}
106
+ post_install_message:
107
+ rdoc_options: []
108
+ require_paths:
109
+ - lib
110
+ required_ruby_version: !ruby/object:Gem::Requirement
111
+ requirements:
112
+ - - ">="
113
+ - !ruby/object:Gem::Version
114
+ version: '2.4'
115
+ required_rubygems_version: !ruby/object:Gem::Requirement
116
+ requirements:
117
+ - - ">"
118
+ - !ruby/object:Gem::Version
119
+ version: 1.3.1
120
+ requirements: []
121
+ rubygems_version: 3.3.7
122
+ signing_key:
123
+ specification_version: 4
124
+ summary: A ruby wrapper for the VGS Vault API
125
+ test_files:
126
+ - spec/api_client_spec.rb
127
+ - spec/configuration_spec.rb
128
+ - spec/spec_helper.rb
129
+ - spec/test_api_spec.rb