comet_backup_ruby_sdk 1.10.0 → 1.11.0
Sign up to get free protection for your applications and to get access to all the features.
- 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
|