comet_backup_ruby_sdk 1.10.0 → 1.11.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/CHANGELOG.md +6 -1
- data/comet_backup_ruby_sdk.gemspec +1 -1
- data/lib/comet/comet_server.rb +61 -3
- data/lib/comet/definitions.rb +3 -3
- data/lib/comet/models/admin_security_options.rb +23 -0
- data/lib/comet/models/admin_web_authn_registration.rb +112 -0
- data/lib/comet/models/allowed_admin_user.rb +212 -0
- data/lib/comet/models/browse_office_365list_virtual_accounts_response.rb +99 -0
- data/lib/comet/models/office_365custom_setting_v2.rb +108 -0
- data/lib/comet/models/office_365mixed_virtual_account.rb +203 -0
- data/lib/comet/models/stat_result.rb +9 -0
- data/lib/comet/models/web_authn_authenticator_selection.rb +96 -0
- data/lib/comet/models/web_authn_credential.rb +105 -0
- data/lib/comet/models/web_authn_credential_assertion.rb +74 -0
- data/lib/comet/models/web_authn_credential_descriptor.rb +101 -0
- data/lib/comet/models/web_authn_credential_entity.rb +86 -0
- data/lib/comet/models/web_authn_credential_parameter.rb +84 -0
- data/lib/comet/models/web_authn_public_key_credential_creation_options.rb +173 -0
- data/lib/comet/models/web_authn_public_key_credential_request_options.rb +141 -0
- data/lib/comet/models/web_authn_registration_challenge_response.rb +101 -0
- data/lib/comet/models/web_authn_relying_party_entity.rb +95 -0
- data/lib/comet/models/web_authn_sign_request.rb +83 -0
- data/lib/comet/models/web_authn_sign_response.rb +84 -0
- data/lib/comet/models/web_authn_user_entity.rb +105 -0
- data/lib/comet_backup_ruby_sdk.rb +15 -0
- metadata +20 -2
@@ -0,0 +1,101 @@
|
|
1
|
+
#!/usr/bin/env ruby --enable-frozen-string-literal
|
2
|
+
#
|
3
|
+
# Copyright (c) 2020-2021 Comet Licensing Ltd.
|
4
|
+
# Please see the LICENSE file for usage information.
|
5
|
+
#
|
6
|
+
# SPDX-License-Identifier: MIT
|
7
|
+
#
|
8
|
+
# frozen_string_literal: true
|
9
|
+
|
10
|
+
require 'base64'
|
11
|
+
require 'json'
|
12
|
+
|
13
|
+
module Comet
|
14
|
+
|
15
|
+
# WebAuthnCredentialDescriptor is a typed class wrapper around the underlying Comet Server API data structure.
|
16
|
+
class WebAuthnCredentialDescriptor
|
17
|
+
|
18
|
+
# @type [String] type
|
19
|
+
attr_accessor :type
|
20
|
+
|
21
|
+
# @type [Array<Object>] credential_id
|
22
|
+
attr_accessor :credential_id
|
23
|
+
|
24
|
+
# @type [Array<String>] transport
|
25
|
+
attr_accessor :transport
|
26
|
+
|
27
|
+
# @type [Hash] Hidden storage to preserve future properties for non-destructive roundtrip operations
|
28
|
+
attr_accessor :unknown_json_fields
|
29
|
+
|
30
|
+
def initialize
|
31
|
+
clear
|
32
|
+
end
|
33
|
+
|
34
|
+
def clear
|
35
|
+
@type = ''
|
36
|
+
@credential_id = []
|
37
|
+
@transport = []
|
38
|
+
@unknown_json_fields = {}
|
39
|
+
end
|
40
|
+
|
41
|
+
# @param [String] json_string The complete object in JSON format
|
42
|
+
def from_json(json_string)
|
43
|
+
raise TypeError, "'json_string' expected String, got #{json_string.class}" unless json_string.is_a? String
|
44
|
+
|
45
|
+
from_hash(JSON.parse(json_string))
|
46
|
+
end
|
47
|
+
|
48
|
+
# @param [Hash] obj The complete object as a Ruby hash
|
49
|
+
def from_hash(obj)
|
50
|
+
raise TypeError, "'obj' expected Hash, got #{obj.class}" unless obj.is_a? Hash
|
51
|
+
|
52
|
+
obj.each do |k, v|
|
53
|
+
case k
|
54
|
+
when 'type'
|
55
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
56
|
+
|
57
|
+
@type = v
|
58
|
+
when 'id'
|
59
|
+
@credential_id = Base64.decode64(v)
|
60
|
+
when 'transports'
|
61
|
+
if v.nil?
|
62
|
+
@transport = []
|
63
|
+
else
|
64
|
+
@transport = Array.new(v.length)
|
65
|
+
v.each_with_index do |v1, i1|
|
66
|
+
raise TypeError, "'v1' expected String, got #{v1.class}" unless v1.is_a? String
|
67
|
+
|
68
|
+
@transport[i1] = v1
|
69
|
+
end
|
70
|
+
end
|
71
|
+
else
|
72
|
+
@unknown_json_fields[k] = v
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
# @return [Hash] The complete object as a Ruby hash
|
78
|
+
def to_hash
|
79
|
+
ret = {}
|
80
|
+
ret['type'] = @type
|
81
|
+
ret['id'] = Base64.strict_encode64(@credential_id)
|
82
|
+
unless @transport.nil?
|
83
|
+
ret['transports'] = @transport
|
84
|
+
end
|
85
|
+
@unknown_json_fields.each do |k, v|
|
86
|
+
ret[k] = v
|
87
|
+
end
|
88
|
+
ret
|
89
|
+
end
|
90
|
+
|
91
|
+
# @return [Hash] The complete object as a Ruby hash
|
92
|
+
def to_h
|
93
|
+
to_hash
|
94
|
+
end
|
95
|
+
|
96
|
+
# @return [String] The complete object as a JSON string
|
97
|
+
def to_json(options = {})
|
98
|
+
to_hash.to_json(options)
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|
@@ -0,0 +1,86 @@
|
|
1
|
+
#!/usr/bin/env ruby --enable-frozen-string-literal
|
2
|
+
#
|
3
|
+
# Copyright (c) 2020-2021 Comet Licensing Ltd.
|
4
|
+
# Please see the LICENSE file for usage information.
|
5
|
+
#
|
6
|
+
# SPDX-License-Identifier: MIT
|
7
|
+
#
|
8
|
+
# frozen_string_literal: true
|
9
|
+
|
10
|
+
require 'json'
|
11
|
+
|
12
|
+
module Comet
|
13
|
+
|
14
|
+
# WebAuthnCredentialEntity is a typed class wrapper around the underlying Comet Server API data structure.
|
15
|
+
class WebAuthnCredentialEntity
|
16
|
+
|
17
|
+
# @type [String] name
|
18
|
+
attr_accessor :name
|
19
|
+
|
20
|
+
# @type [String] icon
|
21
|
+
attr_accessor :icon
|
22
|
+
|
23
|
+
# @type [Hash] Hidden storage to preserve future properties for non-destructive roundtrip operations
|
24
|
+
attr_accessor :unknown_json_fields
|
25
|
+
|
26
|
+
def initialize
|
27
|
+
clear
|
28
|
+
end
|
29
|
+
|
30
|
+
def clear
|
31
|
+
@name = ''
|
32
|
+
@icon = ''
|
33
|
+
@unknown_json_fields = {}
|
34
|
+
end
|
35
|
+
|
36
|
+
# @param [String] json_string The complete object in JSON format
|
37
|
+
def from_json(json_string)
|
38
|
+
raise TypeError, "'json_string' expected String, got #{json_string.class}" unless json_string.is_a? String
|
39
|
+
|
40
|
+
from_hash(JSON.parse(json_string))
|
41
|
+
end
|
42
|
+
|
43
|
+
# @param [Hash] obj The complete object as a Ruby hash
|
44
|
+
def from_hash(obj)
|
45
|
+
raise TypeError, "'obj' expected Hash, got #{obj.class}" unless obj.is_a? Hash
|
46
|
+
|
47
|
+
obj.each do |k, v|
|
48
|
+
case k
|
49
|
+
when 'name'
|
50
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
51
|
+
|
52
|
+
@name = v
|
53
|
+
when 'icon'
|
54
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
55
|
+
|
56
|
+
@icon = v
|
57
|
+
else
|
58
|
+
@unknown_json_fields[k] = v
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
# @return [Hash] The complete object as a Ruby hash
|
64
|
+
def to_hash
|
65
|
+
ret = {}
|
66
|
+
ret['name'] = @name
|
67
|
+
unless @icon.nil?
|
68
|
+
ret['icon'] = @icon
|
69
|
+
end
|
70
|
+
@unknown_json_fields.each do |k, v|
|
71
|
+
ret[k] = v
|
72
|
+
end
|
73
|
+
ret
|
74
|
+
end
|
75
|
+
|
76
|
+
# @return [Hash] The complete object as a Ruby hash
|
77
|
+
def to_h
|
78
|
+
to_hash
|
79
|
+
end
|
80
|
+
|
81
|
+
# @return [String] The complete object as a JSON string
|
82
|
+
def to_json(options = {})
|
83
|
+
to_hash.to_json(options)
|
84
|
+
end
|
85
|
+
end
|
86
|
+
end
|
@@ -0,0 +1,84 @@
|
|
1
|
+
#!/usr/bin/env ruby --enable-frozen-string-literal
|
2
|
+
#
|
3
|
+
# Copyright (c) 2020-2021 Comet Licensing Ltd.
|
4
|
+
# Please see the LICENSE file for usage information.
|
5
|
+
#
|
6
|
+
# SPDX-License-Identifier: MIT
|
7
|
+
#
|
8
|
+
# frozen_string_literal: true
|
9
|
+
|
10
|
+
require 'json'
|
11
|
+
|
12
|
+
module Comet
|
13
|
+
|
14
|
+
# WebAuthnCredentialParameter is a typed class wrapper around the underlying Comet Server API data structure.
|
15
|
+
class WebAuthnCredentialParameter
|
16
|
+
|
17
|
+
# @type [String] type
|
18
|
+
attr_accessor :type
|
19
|
+
|
20
|
+
# @type [Number] algorithm
|
21
|
+
attr_accessor :algorithm
|
22
|
+
|
23
|
+
# @type [Hash] Hidden storage to preserve future properties for non-destructive roundtrip operations
|
24
|
+
attr_accessor :unknown_json_fields
|
25
|
+
|
26
|
+
def initialize
|
27
|
+
clear
|
28
|
+
end
|
29
|
+
|
30
|
+
def clear
|
31
|
+
@type = ''
|
32
|
+
@algorithm = 0
|
33
|
+
@unknown_json_fields = {}
|
34
|
+
end
|
35
|
+
|
36
|
+
# @param [String] json_string The complete object in JSON format
|
37
|
+
def from_json(json_string)
|
38
|
+
raise TypeError, "'json_string' expected String, got #{json_string.class}" unless json_string.is_a? String
|
39
|
+
|
40
|
+
from_hash(JSON.parse(json_string))
|
41
|
+
end
|
42
|
+
|
43
|
+
# @param [Hash] obj The complete object as a Ruby hash
|
44
|
+
def from_hash(obj)
|
45
|
+
raise TypeError, "'obj' expected Hash, got #{obj.class}" unless obj.is_a? Hash
|
46
|
+
|
47
|
+
obj.each do |k, v|
|
48
|
+
case k
|
49
|
+
when 'type'
|
50
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
51
|
+
|
52
|
+
@type = v
|
53
|
+
when 'alg'
|
54
|
+
raise TypeError, "'v' expected Numeric, got #{v.class}" unless v.is_a? Numeric
|
55
|
+
|
56
|
+
@algorithm = v
|
57
|
+
else
|
58
|
+
@unknown_json_fields[k] = v
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
# @return [Hash] The complete object as a Ruby hash
|
64
|
+
def to_hash
|
65
|
+
ret = {}
|
66
|
+
ret['type'] = @type
|
67
|
+
ret['alg'] = @algorithm
|
68
|
+
@unknown_json_fields.each do |k, v|
|
69
|
+
ret[k] = v
|
70
|
+
end
|
71
|
+
ret
|
72
|
+
end
|
73
|
+
|
74
|
+
# @return [Hash] The complete object as a Ruby hash
|
75
|
+
def to_h
|
76
|
+
to_hash
|
77
|
+
end
|
78
|
+
|
79
|
+
# @return [String] The complete object as a JSON string
|
80
|
+
def to_json(options = {})
|
81
|
+
to_hash.to_json(options)
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
@@ -0,0 +1,173 @@
|
|
1
|
+
#!/usr/bin/env ruby --enable-frozen-string-literal
|
2
|
+
#
|
3
|
+
# Copyright (c) 2020-2021 Comet Licensing Ltd.
|
4
|
+
# Please see the LICENSE file for usage information.
|
5
|
+
#
|
6
|
+
# SPDX-License-Identifier: MIT
|
7
|
+
#
|
8
|
+
# frozen_string_literal: true
|
9
|
+
|
10
|
+
require 'base64'
|
11
|
+
require 'json'
|
12
|
+
|
13
|
+
module Comet
|
14
|
+
|
15
|
+
# WebAuthnPublicKeyCredentialCreationOptions is a typed class wrapper around the underlying Comet Server API data structure.
|
16
|
+
class WebAuthnPublicKeyCredentialCreationOptions
|
17
|
+
|
18
|
+
# @type [Array<Object>] challenge
|
19
|
+
attr_accessor :challenge
|
20
|
+
|
21
|
+
# @type [Comet::WebAuthnRelyingPartyEntity] relying_party
|
22
|
+
attr_accessor :relying_party
|
23
|
+
|
24
|
+
# @type [Comet::WebAuthnUserEntity] user
|
25
|
+
attr_accessor :user
|
26
|
+
|
27
|
+
# @type [Array<Comet::WebAuthnCredentialParameter>] parameters
|
28
|
+
attr_accessor :parameters
|
29
|
+
|
30
|
+
# @type [Comet::WebAuthnAuthenticatorSelection] authenticator_selection
|
31
|
+
attr_accessor :authenticator_selection
|
32
|
+
|
33
|
+
# @type [Number] timeout
|
34
|
+
attr_accessor :timeout
|
35
|
+
|
36
|
+
# @type [Array<Comet::WebAuthnCredentialDescriptor>] credential_exclude_list
|
37
|
+
attr_accessor :credential_exclude_list
|
38
|
+
|
39
|
+
# @type [Hash{String => Comet::interface}] extensions
|
40
|
+
attr_accessor :extensions
|
41
|
+
|
42
|
+
# @type [String] attestation
|
43
|
+
attr_accessor :attestation
|
44
|
+
|
45
|
+
# @type [Hash] Hidden storage to preserve future properties for non-destructive roundtrip operations
|
46
|
+
attr_accessor :unknown_json_fields
|
47
|
+
|
48
|
+
def initialize
|
49
|
+
clear
|
50
|
+
end
|
51
|
+
|
52
|
+
def clear
|
53
|
+
@challenge = []
|
54
|
+
@relying_party = Comet::WebAuthnRelyingPartyEntity.new
|
55
|
+
@user = Comet::WebAuthnUserEntity.new
|
56
|
+
@parameters = []
|
57
|
+
@authenticator_selection = Comet::WebAuthnAuthenticatorSelection.new
|
58
|
+
@timeout = 0
|
59
|
+
@credential_exclude_list = []
|
60
|
+
@extensions = {}
|
61
|
+
@attestation = ''
|
62
|
+
@unknown_json_fields = {}
|
63
|
+
end
|
64
|
+
|
65
|
+
# @param [String] json_string The complete object in JSON format
|
66
|
+
def from_json(json_string)
|
67
|
+
raise TypeError, "'json_string' expected String, got #{json_string.class}" unless json_string.is_a? String
|
68
|
+
|
69
|
+
from_hash(JSON.parse(json_string))
|
70
|
+
end
|
71
|
+
|
72
|
+
# @param [Hash] obj The complete object as a Ruby hash
|
73
|
+
def from_hash(obj)
|
74
|
+
raise TypeError, "'obj' expected Hash, got #{obj.class}" unless obj.is_a? Hash
|
75
|
+
|
76
|
+
obj.each do |k, v|
|
77
|
+
case k
|
78
|
+
when 'challenge'
|
79
|
+
@challenge = Base64.decode64(v)
|
80
|
+
when 'rp'
|
81
|
+
@relying_party = Comet::WebAuthnRelyingPartyEntity.new
|
82
|
+
@relying_party.from_hash(v)
|
83
|
+
when 'user'
|
84
|
+
@user = Comet::WebAuthnUserEntity.new
|
85
|
+
@user.from_hash(v)
|
86
|
+
when 'pubKeyCredParams'
|
87
|
+
if v.nil?
|
88
|
+
@parameters = []
|
89
|
+
else
|
90
|
+
@parameters = Array.new(v.length)
|
91
|
+
v.each_with_index do |v1, i1|
|
92
|
+
@parameters[i1] = Comet::WebAuthnCredentialParameter.new
|
93
|
+
@parameters[i1].from_hash(v1)
|
94
|
+
end
|
95
|
+
end
|
96
|
+
when 'authenticatorSelection'
|
97
|
+
@authenticator_selection = Comet::WebAuthnAuthenticatorSelection.new
|
98
|
+
@authenticator_selection.from_hash(v)
|
99
|
+
when 'timeout'
|
100
|
+
raise TypeError, "'v' expected Numeric, got #{v.class}" unless v.is_a? Numeric
|
101
|
+
|
102
|
+
@timeout = v
|
103
|
+
when 'excludeCredentials'
|
104
|
+
if v.nil?
|
105
|
+
@credential_exclude_list = []
|
106
|
+
else
|
107
|
+
@credential_exclude_list = Array.new(v.length)
|
108
|
+
v.each_with_index do |v1, i1|
|
109
|
+
@credential_exclude_list[i1] = Comet::WebAuthnCredentialDescriptor.new
|
110
|
+
@credential_exclude_list[i1].from_hash(v1)
|
111
|
+
end
|
112
|
+
end
|
113
|
+
when 'extensions'
|
114
|
+
@extensions = {}
|
115
|
+
if v.nil?
|
116
|
+
@extensions = {}
|
117
|
+
else
|
118
|
+
v.each do |k1, v1|
|
119
|
+
@extensions[k1] = Comet::interface.new
|
120
|
+
@extensions[k1].from_hash(v1)
|
121
|
+
end
|
122
|
+
end
|
123
|
+
when 'attestation'
|
124
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
125
|
+
|
126
|
+
@attestation = v
|
127
|
+
else
|
128
|
+
@unknown_json_fields[k] = v
|
129
|
+
end
|
130
|
+
end
|
131
|
+
end
|
132
|
+
|
133
|
+
# @return [Hash] The complete object as a Ruby hash
|
134
|
+
def to_hash
|
135
|
+
ret = {}
|
136
|
+
ret['challenge'] = Base64.strict_encode64(@challenge)
|
137
|
+
ret['rp'] = @relying_party
|
138
|
+
ret['user'] = @user
|
139
|
+
unless @parameters.nil?
|
140
|
+
ret['pubKeyCredParams'] = @parameters
|
141
|
+
end
|
142
|
+
unless @authenticator_selection.nil?
|
143
|
+
ret['authenticatorSelection'] = @authenticator_selection
|
144
|
+
end
|
145
|
+
unless @timeout.nil?
|
146
|
+
ret['timeout'] = @timeout
|
147
|
+
end
|
148
|
+
unless @credential_exclude_list.nil?
|
149
|
+
ret['excludeCredentials'] = @credential_exclude_list
|
150
|
+
end
|
151
|
+
unless @extensions.nil?
|
152
|
+
ret['extensions'] = @extensions
|
153
|
+
end
|
154
|
+
unless @attestation.nil?
|
155
|
+
ret['attestation'] = @attestation
|
156
|
+
end
|
157
|
+
@unknown_json_fields.each do |k, v|
|
158
|
+
ret[k] = v
|
159
|
+
end
|
160
|
+
ret
|
161
|
+
end
|
162
|
+
|
163
|
+
# @return [Hash] The complete object as a Ruby hash
|
164
|
+
def to_h
|
165
|
+
to_hash
|
166
|
+
end
|
167
|
+
|
168
|
+
# @return [String] The complete object as a JSON string
|
169
|
+
def to_json(options = {})
|
170
|
+
to_hash.to_json(options)
|
171
|
+
end
|
172
|
+
end
|
173
|
+
end
|
@@ -0,0 +1,141 @@
|
|
1
|
+
#!/usr/bin/env ruby --enable-frozen-string-literal
|
2
|
+
#
|
3
|
+
# Copyright (c) 2020-2021 Comet Licensing Ltd.
|
4
|
+
# Please see the LICENSE file for usage information.
|
5
|
+
#
|
6
|
+
# SPDX-License-Identifier: MIT
|
7
|
+
#
|
8
|
+
# frozen_string_literal: true
|
9
|
+
|
10
|
+
require 'base64'
|
11
|
+
require 'json'
|
12
|
+
|
13
|
+
module Comet
|
14
|
+
|
15
|
+
# WebAuthnPublicKeyCredentialRequestOptions is a typed class wrapper around the underlying Comet Server API data structure.
|
16
|
+
class WebAuthnPublicKeyCredentialRequestOptions
|
17
|
+
|
18
|
+
# @type [Array<Object>] challenge
|
19
|
+
attr_accessor :challenge
|
20
|
+
|
21
|
+
# @type [Number] timeout
|
22
|
+
attr_accessor :timeout
|
23
|
+
|
24
|
+
# @type [String] relying_party_id
|
25
|
+
attr_accessor :relying_party_id
|
26
|
+
|
27
|
+
# @type [Array<Comet::WebAuthnCredentialDescriptor>] allowed_credentials
|
28
|
+
attr_accessor :allowed_credentials
|
29
|
+
|
30
|
+
# @type [String] user_verification
|
31
|
+
attr_accessor :user_verification
|
32
|
+
|
33
|
+
# @type [Hash{String => Comet::interface}] extensions
|
34
|
+
attr_accessor :extensions
|
35
|
+
|
36
|
+
# @type [Hash] Hidden storage to preserve future properties for non-destructive roundtrip operations
|
37
|
+
attr_accessor :unknown_json_fields
|
38
|
+
|
39
|
+
def initialize
|
40
|
+
clear
|
41
|
+
end
|
42
|
+
|
43
|
+
def clear
|
44
|
+
@challenge = []
|
45
|
+
@timeout = 0
|
46
|
+
@relying_party_id = ''
|
47
|
+
@allowed_credentials = []
|
48
|
+
@user_verification = ''
|
49
|
+
@extensions = {}
|
50
|
+
@unknown_json_fields = {}
|
51
|
+
end
|
52
|
+
|
53
|
+
# @param [String] json_string The complete object in JSON format
|
54
|
+
def from_json(json_string)
|
55
|
+
raise TypeError, "'json_string' expected String, got #{json_string.class}" unless json_string.is_a? String
|
56
|
+
|
57
|
+
from_hash(JSON.parse(json_string))
|
58
|
+
end
|
59
|
+
|
60
|
+
# @param [Hash] obj The complete object as a Ruby hash
|
61
|
+
def from_hash(obj)
|
62
|
+
raise TypeError, "'obj' expected Hash, got #{obj.class}" unless obj.is_a? Hash
|
63
|
+
|
64
|
+
obj.each do |k, v|
|
65
|
+
case k
|
66
|
+
when 'challenge'
|
67
|
+
@challenge = Base64.decode64(v)
|
68
|
+
when 'timeout'
|
69
|
+
raise TypeError, "'v' expected Numeric, got #{v.class}" unless v.is_a? Numeric
|
70
|
+
|
71
|
+
@timeout = v
|
72
|
+
when 'rpId'
|
73
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
74
|
+
|
75
|
+
@relying_party_id = v
|
76
|
+
when 'allowCredentials'
|
77
|
+
if v.nil?
|
78
|
+
@allowed_credentials = []
|
79
|
+
else
|
80
|
+
@allowed_credentials = Array.new(v.length)
|
81
|
+
v.each_with_index do |v1, i1|
|
82
|
+
@allowed_credentials[i1] = Comet::WebAuthnCredentialDescriptor.new
|
83
|
+
@allowed_credentials[i1].from_hash(v1)
|
84
|
+
end
|
85
|
+
end
|
86
|
+
when 'userVerification'
|
87
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
88
|
+
|
89
|
+
@user_verification = v
|
90
|
+
when 'extensions'
|
91
|
+
@extensions = {}
|
92
|
+
if v.nil?
|
93
|
+
@extensions = {}
|
94
|
+
else
|
95
|
+
v.each do |k1, v1|
|
96
|
+
@extensions[k1] = Comet::interface.new
|
97
|
+
@extensions[k1].from_hash(v1)
|
98
|
+
end
|
99
|
+
end
|
100
|
+
else
|
101
|
+
@unknown_json_fields[k] = v
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
105
|
+
|
106
|
+
# @return [Hash] The complete object as a Ruby hash
|
107
|
+
def to_hash
|
108
|
+
ret = {}
|
109
|
+
ret['challenge'] = Base64.strict_encode64(@challenge)
|
110
|
+
unless @timeout.nil?
|
111
|
+
ret['timeout'] = @timeout
|
112
|
+
end
|
113
|
+
unless @relying_party_id.nil?
|
114
|
+
ret['rpId'] = @relying_party_id
|
115
|
+
end
|
116
|
+
unless @allowed_credentials.nil?
|
117
|
+
ret['allowCredentials'] = @allowed_credentials
|
118
|
+
end
|
119
|
+
unless @user_verification.nil?
|
120
|
+
ret['userVerification'] = @user_verification
|
121
|
+
end
|
122
|
+
unless @extensions.nil?
|
123
|
+
ret['extensions'] = @extensions
|
124
|
+
end
|
125
|
+
@unknown_json_fields.each do |k, v|
|
126
|
+
ret[k] = v
|
127
|
+
end
|
128
|
+
ret
|
129
|
+
end
|
130
|
+
|
131
|
+
# @return [Hash] The complete object as a Ruby hash
|
132
|
+
def to_h
|
133
|
+
to_hash
|
134
|
+
end
|
135
|
+
|
136
|
+
# @return [String] The complete object as a JSON string
|
137
|
+
def to_json(options = {})
|
138
|
+
to_hash.to_json(options)
|
139
|
+
end
|
140
|
+
end
|
141
|
+
end
|
@@ -0,0 +1,101 @@
|
|
1
|
+
#!/usr/bin/env ruby --enable-frozen-string-literal
|
2
|
+
#
|
3
|
+
# Copyright (c) 2020-2021 Comet Licensing Ltd.
|
4
|
+
# Please see the LICENSE file for usage information.
|
5
|
+
#
|
6
|
+
# SPDX-License-Identifier: MIT
|
7
|
+
#
|
8
|
+
# frozen_string_literal: true
|
9
|
+
|
10
|
+
require 'json'
|
11
|
+
|
12
|
+
module Comet
|
13
|
+
|
14
|
+
# WebAuthnRegistrationChallengeResponse is a typed class wrapper around the underlying Comet Server API data structure.
|
15
|
+
class WebAuthnRegistrationChallengeResponse
|
16
|
+
|
17
|
+
# @type [Number] status
|
18
|
+
attr_accessor :status
|
19
|
+
|
20
|
+
# @type [String] message
|
21
|
+
attr_accessor :message
|
22
|
+
|
23
|
+
# @type [String] challenge_id
|
24
|
+
attr_accessor :challenge_id
|
25
|
+
|
26
|
+
# @type [Comet::WebAuthnPublicKeyCredentialCreationOptions] credential_creation_options
|
27
|
+
attr_accessor :credential_creation_options
|
28
|
+
|
29
|
+
# @type [Hash] Hidden storage to preserve future properties for non-destructive roundtrip operations
|
30
|
+
attr_accessor :unknown_json_fields
|
31
|
+
|
32
|
+
def initialize
|
33
|
+
clear
|
34
|
+
end
|
35
|
+
|
36
|
+
def clear
|
37
|
+
@status = 0
|
38
|
+
@message = ''
|
39
|
+
@challenge_id = ''
|
40
|
+
@credential_creation_options = Comet::WebAuthnPublicKeyCredentialCreationOptions.new
|
41
|
+
@unknown_json_fields = {}
|
42
|
+
end
|
43
|
+
|
44
|
+
# @param [String] json_string The complete object in JSON format
|
45
|
+
def from_json(json_string)
|
46
|
+
raise TypeError, "'json_string' expected String, got #{json_string.class}" unless json_string.is_a? String
|
47
|
+
|
48
|
+
from_hash(JSON.parse(json_string))
|
49
|
+
end
|
50
|
+
|
51
|
+
# @param [Hash] obj The complete object as a Ruby hash
|
52
|
+
def from_hash(obj)
|
53
|
+
raise TypeError, "'obj' expected Hash, got #{obj.class}" unless obj.is_a? Hash
|
54
|
+
|
55
|
+
obj.each do |k, v|
|
56
|
+
case k
|
57
|
+
when 'Status'
|
58
|
+
raise TypeError, "'v' expected Numeric, got #{v.class}" unless v.is_a? Numeric
|
59
|
+
|
60
|
+
@status = v
|
61
|
+
when 'Message'
|
62
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
63
|
+
|
64
|
+
@message = v
|
65
|
+
when 'ChallengeID'
|
66
|
+
raise TypeError, "'v' expected String, got #{v.class}" unless v.is_a? String
|
67
|
+
|
68
|
+
@challenge_id = v
|
69
|
+
when 'CredentialCreationOptions'
|
70
|
+
@credential_creation_options = Comet::WebAuthnPublicKeyCredentialCreationOptions.new
|
71
|
+
@credential_creation_options.from_hash(v)
|
72
|
+
else
|
73
|
+
@unknown_json_fields[k] = v
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
# @return [Hash] The complete object as a Ruby hash
|
79
|
+
def to_hash
|
80
|
+
ret = {}
|
81
|
+
ret['Status'] = @status
|
82
|
+
ret['Message'] = @message
|
83
|
+
ret['ChallengeID'] = @challenge_id
|
84
|
+
ret['CredentialCreationOptions'] = @credential_creation_options
|
85
|
+
@unknown_json_fields.each do |k, v|
|
86
|
+
ret[k] = v
|
87
|
+
end
|
88
|
+
ret
|
89
|
+
end
|
90
|
+
|
91
|
+
# @return [Hash] The complete object as a Ruby hash
|
92
|
+
def to_h
|
93
|
+
to_hash
|
94
|
+
end
|
95
|
+
|
96
|
+
# @return [String] The complete object as a JSON string
|
97
|
+
def to_json(options = {})
|
98
|
+
to_hash.to_json(options)
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|