authlete 1.0.22 → 1.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (160) hide show
  1. checksums.yaml +5 -5
  2. data/.gitignore +2 -1
  3. data/Makefile +40 -0
  4. data/Rakefile +5 -0
  5. data/authlete.gemspec +2 -2
  6. data/lib/authlete.rb +28 -9
  7. data/lib/authlete/api.rb +153 -322
  8. data/lib/authlete/authentication-server.rb +2 -2
  9. data/lib/authlete/exception.rb +14 -15
  10. data/lib/authlete/model/base.rb +30 -0
  11. data/lib/authlete/model/client-extension.rb +17 -119
  12. data/lib/authlete/model/client.rb +205 -342
  13. data/lib/authlete/model/hashable.rb +13 -33
  14. data/lib/authlete/model/named-uri.rb +13 -74
  15. data/lib/authlete/model/pair.rb +13 -74
  16. data/lib/authlete/model/param-initializer.rb +45 -0
  17. data/lib/authlete/model/property.rb +15 -85
  18. data/lib/authlete/model/request/authentication-callback-request.rb +63 -55
  19. data/lib/authlete/model/request/authorization-fail-request.rb +14 -75
  20. data/lib/authlete/model/request/authorization-issue-request.rb +38 -119
  21. data/lib/authlete/model/request/authorization-request.rb +8 -73
  22. data/lib/authlete/model/request/backchannel-authentication-complete-request.rb +97 -0
  23. data/lib/authlete/model/request/backchannel-authentication-fail-request.rb +55 -0
  24. data/lib/authlete/model/request/backchannel-authentication-issue-request.rb +37 -0
  25. data/lib/authlete/model/request/backchannel-authentication-request.rb +63 -0
  26. data/lib/authlete/model/request/base.rb +26 -0
  27. data/lib/authlete/model/request/client-authorization-delete-request.rb +7 -93
  28. data/lib/authlete/model/request/client-authorization-get-list-request.rb +17 -89
  29. data/lib/authlete/model/request/client-authorization-update-request.rb +11 -86
  30. data/lib/authlete/model/request/client-registration-request.rb +49 -0
  31. data/lib/authlete/model/request/client-secret-update-request.rb +7 -89
  32. data/lib/authlete/model/request/developer-authentication-callback-request.rb +40 -43
  33. data/lib/authlete/model/request/device-authorization-request.rb +63 -0
  34. data/lib/authlete/model/request/device-complete-request.rb +99 -0
  35. data/lib/authlete/model/request/device-verification-request.rb +40 -0
  36. data/lib/authlete/model/request/granted-scopes-request.rb +8 -74
  37. data/lib/authlete/model/request/introspection-request.rb +24 -83
  38. data/lib/authlete/model/request/pushed-auth-req-request.rb +64 -0
  39. data/lib/authlete/model/request/revocation-request.rb +14 -88
  40. data/lib/authlete/model/request/standard-introspection-request.rb +8 -73
  41. data/lib/authlete/model/request/token-create-request.rb +52 -183
  42. data/lib/authlete/model/request/token-fail-request.rb +12 -74
  43. data/lib/authlete/model/request/token-issue-request.rb +22 -80
  44. data/lib/authlete/model/request/token-request.rb +44 -81
  45. data/lib/authlete/model/request/token-update-request.rb +35 -121
  46. data/lib/authlete/model/request/user-info-issue-request.rb +14 -80
  47. data/lib/authlete/model/request/user-info-request.rb +25 -70
  48. data/lib/authlete/model/response/access-token.rb +96 -0
  49. data/lib/authlete/model/response/authentication-callback-response.rb +24 -19
  50. data/lib/authlete/model/response/authorization-fail-response.rb +13 -15
  51. data/lib/authlete/model/response/authorization-issue-response.rb +29 -32
  52. data/lib/authlete/model/response/authorization-response.rb +97 -123
  53. data/lib/authlete/model/response/authorized-client-list-response.rb +37 -0
  54. data/lib/authlete/model/response/backchannel-authentication-complete-response.rb +143 -0
  55. data/lib/authlete/model/response/backchannel-authentication-fail-response.rb +47 -0
  56. data/lib/authlete/model/response/backchannel-authentication-issue-response.rb +63 -0
  57. data/lib/authlete/model/response/backchannel-authentication-response.rb +160 -0
  58. data/lib/authlete/model/response/client-list-response.rb +58 -0
  59. data/lib/authlete/model/response/client-registration-response.rb +50 -0
  60. data/lib/authlete/model/response/client-secret-refresh-response.rb +12 -12
  61. data/lib/authlete/model/response/client-secret-update-response.rb +12 -12
  62. data/lib/authlete/model/response/developer-authentication-callback-response.rb +24 -19
  63. data/lib/authlete/model/response/device-authorization-response.rb +134 -0
  64. data/lib/authlete/model/response/device-complete-response.rb +39 -0
  65. data/lib/authlete/model/response/device-verification-response.rb +96 -0
  66. data/lib/authlete/model/response/granted-scopes-get-response.rb +27 -19
  67. data/lib/authlete/model/response/introspection-response.rb +64 -58
  68. data/lib/authlete/model/response/pushed-auth-req-response.rb +59 -0
  69. data/lib/authlete/model/response/revocation-response.rb +12 -15
  70. data/lib/authlete/model/response/service-list-response.rb +54 -0
  71. data/lib/authlete/model/response/standard-introspection-response.rb +13 -15
  72. data/lib/authlete/model/response/token-create-response.rb +50 -55
  73. data/lib/authlete/model/response/token-fail-response.rb +14 -17
  74. data/lib/authlete/model/response/token-issue-response.rb +49 -62
  75. data/lib/authlete/model/response/token-list-response.rb +64 -0
  76. data/lib/authlete/model/response/token-response.rb +59 -79
  77. data/lib/authlete/model/response/token-update-response.rb +28 -23
  78. data/lib/authlete/model/response/user-info-issue-response.rb +16 -16
  79. data/lib/authlete/model/response/user-info-response.rb +48 -42
  80. data/lib/authlete/model/result.rb +14 -13
  81. data/lib/authlete/model/scope.rb +29 -119
  82. data/lib/authlete/model/service-owner.rb +32 -116
  83. data/lib/authlete/model/service.rb +491 -666
  84. data/lib/authlete/model/sns-credentials.rb +18 -91
  85. data/lib/authlete/model/tagged-value.rb +14 -69
  86. data/lib/authlete/utility.rb +3 -32
  87. data/lib/authlete/version.rb +3 -3
  88. data/test/authlete/model/request/test_authentication-callback-request.rb +100 -0
  89. data/test/authlete/model/request/test_authorization-fail-request.rb +67 -0
  90. data/test/authlete/model/request/test_authorization-issue-request.rb +94 -0
  91. data/test/authlete/model/request/test_authorization-request.rb +57 -0
  92. data/test/authlete/model/request/test_backchannel-authentication-complete-request.rb +102 -0
  93. data/test/authlete/model/request/test_backchannel-authentication-fail-request.rb +71 -0
  94. data/test/authlete/model/request/test_backchannel-authentication-issue-request.rb +57 -0
  95. data/test/authlete/model/request/test_backchannel-authentication-request.rb +75 -0
  96. data/test/authlete/model/request/test_client-authorization-delete-request.rb +57 -0
  97. data/test/authlete/model/request/test_client-authorization-get-list-request.rb +71 -0
  98. data/test/authlete/model/request/test_client-authorization-update-request.rb +63 -0
  99. data/test/authlete/model/request/test_client-registration-request.rb +68 -0
  100. data/test/authlete/model/request/test_device-authorization-request.rb +75 -0
  101. data/test/authlete/model/request/test_device-complete-request.rb +102 -0
  102. data/test/authlete/model/request/test_device-verification-request.rb +57 -0
  103. data/test/authlete/model/request/test_granted-scopes-request.rb +57 -0
  104. data/test/authlete/model/request/test_introspection-request.rb +79 -0
  105. data/test/authlete/model/request/test_pushed-auth-req-request.rb +75 -0
  106. data/test/authlete/model/request/test_revocation-request.rb +67 -0
  107. data/test/authlete/model/request/test_standard-introspection-request.rb +57 -0
  108. data/test/authlete/model/request/test_token-create-request.rb +110 -0
  109. data/test/authlete/model/request/test_token-fail-request.rb +63 -0
  110. data/test/authlete/model/request/test_token-issue-request.rb +70 -0
  111. data/test/authlete/model/request/test_token-request.rb +94 -0
  112. data/test/authlete/model/request/test_token-update-request.rb +82 -0
  113. data/test/authlete/model/request/test_user-info-issue-request.rb +67 -0
  114. data/test/authlete/model/request/test_user-info-request.rb +75 -0
  115. data/test/authlete/model/response/test_access-token.rb +101 -0
  116. data/test/authlete/model/response/test_authorization-fail-response.rb +68 -0
  117. data/test/authlete/model/response/test_authorization-issue-response.rb +92 -0
  118. data/test/authlete/model/response/test_authorization-response.rb +145 -0
  119. data/test/authlete/model/response/test_authorized-client-list-response.rb +83 -0
  120. data/test/authlete/model/response/test_backchannel-authentication-complete-response.rb +132 -0
  121. data/test/authlete/model/response/test_backchannel-authentication-fail-response.rb +68 -0
  122. data/test/authlete/model/response/test_backchannel-authentication-issue-response.rb +80 -0
  123. data/test/authlete/model/response/test_backchannel-authentication-response.rb +156 -0
  124. data/test/authlete/model/response/test_client-list-response.rb +79 -0
  125. data/test/authlete/model/response/test_client-secret-refresh-response.rb +68 -0
  126. data/test/authlete/model/response/test_client-secret-update-response.rb +68 -0
  127. data/test/authlete/model/response/test_device-authorization-response.rb +140 -0
  128. data/test/authlete/model/response/test_device-complete-response.rb +64 -0
  129. data/test/authlete/model/response/test_device-verification-response.rb +112 -0
  130. data/test/authlete/model/response/test_granted-scopes-get-response.rb +84 -0
  131. data/test/authlete/model/response/test_introspection-response.rb +127 -0
  132. data/test/authlete/model/response/test_pushed-auth-req-response.rb +76 -0
  133. data/test/authlete/model/response/test_revocation-response.rb +68 -0
  134. data/test/authlete/model/response/test_service-list-response.rb +72 -0
  135. data/test/authlete/model/response/test_standard-introspection-response.rb +68 -0
  136. data/test/authlete/model/response/test_token-create-response.rb +107 -0
  137. data/test/authlete/model/response/test_token-fail-response.rb +68 -0
  138. data/test/authlete/model/response/test_token-issue-response.rb +127 -0
  139. data/test/authlete/model/response/test_token-list-response.rb +84 -0
  140. data/test/authlete/model/response/test_token-response.rb +147 -0
  141. data/test/authlete/model/response/test_token-update-response.rb +87 -0
  142. data/test/authlete/model/response/test_user-info-issue-response.rb +68 -0
  143. data/test/authlete/model/response/test_user-info-response.rb +107 -0
  144. data/test/authlete/model/test_client-extension.rb +93 -0
  145. data/test/authlete/model/test_client.rb +469 -0
  146. data/test/authlete/model/test_named-uri.rb +83 -0
  147. data/test/authlete/model/test_pair.rb +83 -0
  148. data/test/authlete/model/test_property.rb +88 -0
  149. data/test/authlete/model/test_result.rb +68 -0
  150. data/test/authlete/model/test_scope.rb +104 -0
  151. data/test/authlete/model/test_service-owner.rb +80 -0
  152. data/test/authlete/model/test_service.rb +630 -0
  153. data/test/authlete/model/test_sns-credentials.rb +88 -0
  154. data/test/authlete/model/test_tagged-value.rb +83 -0
  155. data/test/authlete/test_exception.rb +70 -0
  156. metadata +173 -12
  157. data/lib/authlete/model/client-list.rb +0 -129
  158. data/lib/authlete/model/response/client-authorization-get-list-response.rb +0 -60
  159. data/lib/authlete/model/response/service-creatable-response.rb +0 -51
  160. data/lib/authlete/model/service-list.rb +0 -128
@@ -0,0 +1,87 @@
1
+ # :nodoc:
2
+ #
3
+ # Copyright (C) 2014-2020 Authlete, Inc.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+
18
+ require 'authlete'
19
+ require 'json'
20
+ require 'minitest/autorun'
21
+
22
+
23
+ class TokenUpdateResponseTest < Minitest::Test
24
+ RESULT_CODE = '<result-code>'
25
+ RESULT_MESSAGE = '<result-message>'
26
+ ACTION = 'OK'
27
+ ACCESS_TOKEN = '<access-token>'
28
+ TOKEN_TYPE = 'Bearer'
29
+ ACCESS_TOKEN_EXPIRES_AT = 1000
30
+ SCOPES = [ 'scope0', 'scope1' ]
31
+ PROPERTY_KEY = '<property0-key>'
32
+ PROPERTY_VALUE = '<property0-value>'
33
+ PROPERTIES = [ Authlete::Model::Property.new(key: PROPERTY_KEY, value: PROPERTY_VALUE) ]
34
+
35
+
36
+ def generate_json
37
+ return <<~JSON
38
+ {
39
+ "resultCode": "<result-code>",
40
+ "resultMessage": "<result-message>",
41
+ "action": "OK",
42
+ "accessToken": "<access-token>",
43
+ "tokenType": "Bearer",
44
+ "accessTokenExpiresAt": 1000,
45
+ "scopes": [ "scope0", "scope1" ],
46
+ "properties": [ { "key": "<property0-key>", "value": "<property0-value>" } ]
47
+ }
48
+ JSON
49
+ end
50
+
51
+
52
+ def match(obj)
53
+ assert_equal RESULT_CODE, obj.resultCode
54
+ assert_equal RESULT_MESSAGE, obj.resultMessage
55
+ assert_equal ACTION, obj.action
56
+ assert_equal ACCESS_TOKEN, obj.accessToken
57
+ assert_equal TOKEN_TYPE, obj.tokenType
58
+ assert_equal ACCESS_TOKEN_EXPIRES_AT, obj.accessTokenExpiresAt
59
+ assert_equal SCOPES, obj.scopes
60
+ assert_equal PROPERTY_KEY, obj.properties[0].key
61
+ assert_equal PROPERTY_VALUE, obj.properties[0].value
62
+ end
63
+
64
+
65
+ def test_from_json
66
+ jsn = generate_json
67
+ hsh = JSON.parse(jsn)
68
+ actual = Authlete::Model::Response::TokenUpdateResponse.new(hsh)
69
+
70
+ match(actual)
71
+ end
72
+
73
+
74
+ def test_setters
75
+ actual = Authlete::Model::Response::TokenUpdateResponse.new
76
+ actual.result_code = RESULT_CODE
77
+ actual.result_message = RESULT_MESSAGE
78
+ actual.action = ACTION
79
+ actual.access_token = ACCESS_TOKEN
80
+ actual.token_type = TOKEN_TYPE
81
+ actual.access_token_expires_at = ACCESS_TOKEN_EXPIRES_AT
82
+ actual.scopes = SCOPES
83
+ actual.properties = PROPERTIES
84
+
85
+ match(actual)
86
+ end
87
+ end
@@ -0,0 +1,68 @@
1
+ # :nodoc:
2
+ #
3
+ # Copyright (C) 2014-2020 Authlete, Inc.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+
18
+ require 'authlete'
19
+ require 'json'
20
+ require 'minitest/autorun'
21
+
22
+
23
+ class UserInfoIssueResponseTest < Minitest::Test
24
+ RESULT_CODE = '<result-code>'
25
+ RESULT_MESSAGE = '<result-message>'
26
+ ACTION = 'JWT'
27
+ RESPONSE_CONTENT = '<response-content>'
28
+
29
+
30
+ def generate_json
31
+ return <<~JSON
32
+ {
33
+ "resultCode": "<result-code>",
34
+ "resultMessage": "<result-message>",
35
+ "action": "JWT",
36
+ "responseContent": "<response-content>"
37
+ }
38
+ JSON
39
+ end
40
+
41
+
42
+ def match(obj)
43
+ assert_equal RESULT_CODE, obj.resultCode
44
+ assert_equal RESULT_MESSAGE, obj.resultMessage
45
+ assert_equal ACTION, obj.action
46
+ assert_equal RESPONSE_CONTENT, obj.responseContent
47
+ end
48
+
49
+
50
+ def test_from_json
51
+ jsn = generate_json
52
+ hsh = JSON.parse(jsn)
53
+ actual = Authlete::Model::Response::UserInfoIssueResponse.new(hsh)
54
+
55
+ match(actual)
56
+ end
57
+
58
+
59
+ def test_setters
60
+ actual = Authlete::Model::Response::UserInfoIssueResponse.new
61
+ actual.result_code = RESULT_CODE
62
+ actual.result_message = RESULT_MESSAGE
63
+ actual.action = ACTION
64
+ actual.response_content = RESPONSE_CONTENT
65
+
66
+ match(actual)
67
+ end
68
+ end
@@ -0,0 +1,107 @@
1
+ # :nodoc:
2
+ #
3
+ # Copyright (C) 2014-2020 Authlete, Inc.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+
18
+ require 'authlete'
19
+ require 'json'
20
+ require 'minitest/autorun'
21
+
22
+
23
+ class UserInfoResponseTest < Minitest::Test
24
+ RESULT_CODE = '<result-code>'
25
+ RESULT_MESSAGE = '<result-message>'
26
+ ACTION = 'OK'
27
+ CLIENT_ID = 12345
28
+ SUBJECT = '<subject>'
29
+ SCOPES = [ 'scope0', 'scope1' ]
30
+ CLAIMS = [ 'claim0', 'claim1' ]
31
+ TOKEN = '<token>'
32
+ RESPONSE_CONTENT = '<response-content>'
33
+ PROPERTY_KEY = '<property0-key>'
34
+ PROPERTY_VALUE = '<property0-value>'
35
+ PROPERTIES = [ Authlete::Model::Property.new(key: PROPERTY_KEY, value: PROPERTY_VALUE) ]
36
+ CLIENT_ID_ALIAS = '<client-id-alias>'
37
+ CLIENT_ID_ALIAS_USED = true
38
+ USER_INFO_CLAIMS = '<user-info-claims>'
39
+
40
+
41
+ def generate_json
42
+ return <<~JSON
43
+ {
44
+ "resultCode": "<result-code>",
45
+ "resultMessage": "<result-message>",
46
+ "action": "OK",
47
+ "clientId": 12345,
48
+ "subject": "<subject>",
49
+ "scopes": [ "scope0", "scope1" ],
50
+ "claims": [ "claim0", "claim1" ],
51
+ "token": "<token>",
52
+ "responseContent": "<response-content>",
53
+ "properties": [ { "key": "<property0-key>", "value": "<property0-value>" } ],
54
+ "clientIdAlias": "<client-id-alias>",
55
+ "clientIdAliasUsed": true,
56
+ "userInfoClaims": "<user-info-claims>"
57
+ }
58
+ JSON
59
+ end
60
+
61
+
62
+ def match(obj)
63
+ assert_equal RESULT_CODE, obj.resultCode
64
+ assert_equal RESULT_MESSAGE, obj.resultMessage
65
+ assert_equal ACTION, obj.action
66
+ assert_equal CLIENT_ID, obj.clientId
67
+ assert_equal SUBJECT, obj.subject
68
+ assert_equal SCOPES, obj.scopes
69
+ assert_equal CLAIMS, obj.claims
70
+ assert_equal TOKEN, obj.token
71
+ assert_equal RESPONSE_CONTENT, obj.responseContent
72
+ assert_equal PROPERTY_KEY, obj.properties[0].key
73
+ assert_equal PROPERTY_VALUE, obj.properties[0].value
74
+ assert_equal CLIENT_ID_ALIAS, obj.clientIdAlias
75
+ assert_equal CLIENT_ID_ALIAS_USED, obj.clientIdAliasUsed
76
+ assert_equal USER_INFO_CLAIMS, obj.userInfoClaims
77
+ end
78
+
79
+
80
+ def test_from_json
81
+ jsn = generate_json
82
+ hsh = JSON.parse(jsn)
83
+ actual = Authlete::Model::Response::UserInfoResponse.new(hsh)
84
+
85
+ match(actual)
86
+ end
87
+
88
+
89
+ def test_setters
90
+ actual = Authlete::Model::Response::UserInfoResponse.new
91
+ actual.result_code = RESULT_CODE
92
+ actual.result_message = RESULT_MESSAGE
93
+ actual.action = ACTION
94
+ actual.client_id = CLIENT_ID
95
+ actual.subject = SUBJECT
96
+ actual.scopes = SCOPES
97
+ actual.claims = CLAIMS
98
+ actual.token = TOKEN
99
+ actual.response_content = RESPONSE_CONTENT
100
+ actual.properties = PROPERTIES
101
+ actual.client_id_alias = CLIENT_ID_ALIAS
102
+ actual.client_id_alias_used = CLIENT_ID_ALIAS_USED
103
+ actual.user_info_claims = USER_INFO_CLAIMS
104
+
105
+ match(actual)
106
+ end
107
+ end
@@ -0,0 +1,93 @@
1
+ # :nodoc:
2
+ #
3
+ # Copyright (C) 2014-2020 Authlete, Inc.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+
18
+ require 'authlete'
19
+ require 'json'
20
+ require 'minitest/autorun'
21
+
22
+
23
+ class ClientExtensionTest < Minitest::Test
24
+ REQUESTABLE_SCOPES = %w(<requestable-scope0> <requestable-scope1>)
25
+ REQUESTABLE_SCOPES_ENABLED = true
26
+ ACCESS_TOKEN_DURATION = 10000
27
+ REFRESH_TOKEN_DURATION = 10000
28
+
29
+
30
+ def generate_json
31
+ return <<~JSON
32
+ {
33
+ "requestableScopes": [ "<requestable-scope0>", "<requestable-scope1>" ],
34
+ "requestableScopesEnabled": true,
35
+ "accessTokenDuration": 10000,
36
+ "refreshTokenDuration": 10000
37
+ }
38
+ JSON
39
+ end
40
+
41
+
42
+ def generate_hash
43
+ {
44
+ requestableScopes: %w(<requestable-scope0> <requestable-scope1>),
45
+ requestableScopesEnabled: true,
46
+ accessTokenDuration: 10000,
47
+ refreshTokenDuration: 10000
48
+ }
49
+ end
50
+
51
+
52
+ def set_params(obj)
53
+ obj.requestable_scopes = REQUESTABLE_SCOPES
54
+ obj.requestable_scopes_enabled = REQUESTABLE_SCOPES_ENABLED
55
+ obj.access_token_duration = ACCESS_TOKEN_DURATION
56
+ obj.refresh_token_duration = REFRESH_TOKEN_DURATION
57
+ end
58
+
59
+
60
+ def match(obj)
61
+ assert_equal REQUESTABLE_SCOPES, obj.requestableScopes
62
+ assert_equal REQUESTABLE_SCOPES_ENABLED, obj.requestableScopesEnabled
63
+ assert_equal ACCESS_TOKEN_DURATION, obj.accessTokenDuration
64
+ assert_equal REFRESH_TOKEN_DURATION, obj.refreshTokenDuration
65
+ end
66
+
67
+
68
+ def test_from_json
69
+ jsn = generate_json
70
+ hsh = JSON.parse(jsn)
71
+ actual = Authlete::Model::ClientExtension.new(hsh)
72
+
73
+ match(actual)
74
+ end
75
+
76
+
77
+ def test_setters
78
+ actual = Authlete::Model::ClientExtension.new
79
+ set_params(actual)
80
+
81
+ match(actual)
82
+ end
83
+
84
+
85
+ def test_to_hash
86
+ obj = Authlete::Model::ClientExtension.new
87
+ set_params(obj)
88
+ actual = obj.to_hash
89
+ expected = generate_hash
90
+
91
+ assert_equal expected, actual
92
+ end
93
+ end
@@ -0,0 +1,469 @@
1
+ # :nodoc:
2
+ #
3
+ # Copyright (C) 2014-2020 Authlete, Inc.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+
18
+ require 'authlete'
19
+ require 'json'
20
+ require 'minitest/autorun'
21
+
22
+
23
+ class ClientTest < Minitest::Test
24
+ NUMBER = 100
25
+ SERVICE_NUMBER = 1000
26
+ DEVELOPER = '<developer>'
27
+ CLIENT_ID = 12345
28
+ CLIENT_ID_ALIAS = '<client-id-alias>'
29
+ CLIENT_ID_ALIAS_ENABLED = true
30
+ CLIENT_SECRET = '<client-secret>'
31
+ CLIENT_TYPE = 'PUBLIC'
32
+ REDIRECT_URIS = [ '<redirect-uri0>', '<redirect-uri1>' ]
33
+ RESPONSE_TYPES = [ 'NONE', 'CODE', 'TOKEN', 'ID_TOKEN' ]
34
+ GRANT_TYPES = [ 'AUTHORIZATION_CODE', 'REFRESH_TOKEN' ]
35
+ APPLICATION_TYPE = 'WEB'
36
+ CONTACTS = [ '<contact0>', '<contact1>' ]
37
+ CLIENT_NAME = '<client-name>'
38
+ CLIENT_NAME_TAG = '<client-name0-tag>'
39
+ CLIENT_NAME_VALUE = '<client-name0-value>'
40
+ CLIENT_NAMES = [ Authlete::Model::TaggedValue.new(tag: CLIENT_NAME_TAG, value: CLIENT_NAME_VALUE) ]
41
+ LOGO_URI = '<logo-uri>'
42
+ LOGO_URI_TAG = '<logo-uri0-tag>'
43
+ LOGO_URI_VALUE = '<logo-uri0-value>'
44
+ LOGO_URIS = [ Authlete::Model::TaggedValue.new(tag: LOGO_URI_TAG, value: LOGO_URI_VALUE) ]
45
+ CLIENT_URI = '<client-uri>'
46
+ CLIENT_URI_TAG = '<client-uri0-tag>'
47
+ CLIENT_URI_VALUE = '<client-uri0-value>'
48
+ CLIENT_URIS = [ Authlete::Model::TaggedValue.new(tag: CLIENT_URI_TAG, value: CLIENT_URI_VALUE) ]
49
+ POLICY_URI = '<policy-uri>'
50
+ POLICY_URI_TAG = '<policy-uri0-tag>'
51
+ POLICY_URI_VALUE = '<policy-uri0-value>'
52
+ POLICY_URIS = [ Authlete::Model::TaggedValue.new(tag: POLICY_URI_TAG, value: POLICY_URI_VALUE) ]
53
+ TOS_URI = '<tos-uri>'
54
+ TOS_URI_TAG = '<tos-uri0-tag>'
55
+ TOS_URI_VALUE = '<tos-uri0-value>'
56
+ TOS_URIS = [ Authlete::Model::TaggedValue.new(tag: TOS_URI_TAG, value: TOS_URI_VALUE) ]
57
+ JWKS_URI = '<jwks-uri>'
58
+ JWKS = '<jwks>'
59
+ DERIVED_SECTOR_IDENTIFIER = '<derived-sector-identifier>'
60
+ SECTOR_IDENTIFIER_URI = '<sector-identifier-uri>'
61
+ SUBJECT_TYPE = 'PUBLIC'
62
+ ID_TOKEN_SIGN_ALG = 'HS256'
63
+ ID_TOKEN_ENCRYPTION_ALG = 'PBES2_HS256_A128KW'
64
+ ID_TOKEN_ENCRYPTION_ENC = 'A128CBC_HS256'
65
+ USER_INFO_SIGN_ALG = 'HS256'
66
+ USER_INFO_ENCRYPTION_ALG = 'PBES2_HS256_A128KW'
67
+ USER_INFO_ENCRYPTION_ENC = 'A128CBC_HS256'
68
+ REQUEST_SIGN_ALG = 'HS256'
69
+ REQUEST_ENCRYPTION_ALG = 'PBES2_HS256_A128KW'
70
+ REQUEST_ENCRYPTION_ENC = 'A128CBC_HS256'
71
+ TOKEN_AUTH_METHOD = 'CLIENT_SECRET_BASIC'
72
+ TOKEN_AUTH_SIGN_ALG = 'HS256'
73
+ DEFAULT_MAX_AGE = 1000
74
+ DEFAULT_ACRS = [ '<default-acr0>', '<default-acr1>' ]
75
+ AUTH_TIME_REQUIRED = true
76
+ LOGIN_URI = '<login-uri>'
77
+ REQUEST_URIS = [ '<request-uri0>', '<request-uri1>' ]
78
+ DESCRIPTION = '<description>'
79
+ DESCRIPTION_TAG = '<description0-tag>'
80
+ DESCRIPTION_VALUE = '<description0-value>'
81
+ DESCRIPTIONS = [ Authlete::Model::TaggedValue.new(tag: DESCRIPTION_TAG, value: DESCRIPTION_VALUE) ]
82
+ CREATED_AT = 10000
83
+ MODIFIED_AT = 10000
84
+ REQUESTABLE_SCOPES = [ '<requestable-scope0>', '<requestable-scope1>' ]
85
+ REQUESTABLE_SCOPES_ENABLED = true
86
+ ACCESS_TOKEN_DURATION = 10000
87
+ REFRESH_TOKEN_DURATION = 10000
88
+ EXTENSION = Authlete::Model::ClientExtension.new(
89
+ requestableScopes: REQUESTABLE_SCOPES,
90
+ requestableScopesEnabled: REQUESTABLE_SCOPES_ENABLED,
91
+ accessTokenDuration: ACCESS_TOKEN_DURATION,
92
+ refreshTokenDuration: REFRESH_TOKEN_DURATION
93
+ )
94
+ TLS_CLIENT_AUTH_SUBJECT_DN = '<tls-client-auth-subject-dn>'
95
+ TLS_CLIENT_AUTH_SAN_DNS = '<tls-client-auth-san-dns>'
96
+ TLS_CLIENT_AUTH_SAN_URI = '<tls-client-auth-san-uri>'
97
+ TLS_CLIENT_AUTH_SAN_IP = '<tls-client-auth-san-ip>'
98
+ TLS_CLIENT_AUTH_SAN_EMAIL = '<tls-client-auth-san-email>'
99
+ TLS_CLIENT_CERTIFICATE_BOUND_ACCESS_TOKENS = false
100
+ SELF_SIGNED_CERTIFICATE_KEY_ID = '<self-signed-certificate-key-id>'
101
+ SOFTWARE_ID = '<software-id>'
102
+ SOFTWARE_VERSION = '<software-version>'
103
+ AUTHORIZATION_SIGN_ALG = 'HS256'
104
+ AUTHORIZATION_ENCRYPTION_ALG = 'PBES2_HS256_A128KW'
105
+ AUTHORIZATION_ENCRYPTION_ENC = 'A128CBC_HS256'
106
+ BC_DELIVERY_MODE = 'POLL'
107
+ BC_NOTIFICATION_ENDPOINT = '<bc-notification-endpoint>'
108
+ BC_REQUEST_SIGN_ALG = 'HS256'
109
+ BC_USER_CODE_REQUIRED = true
110
+ DYNAMICALLY_REGISTERED = false
111
+ REGISTRATION_ACCESS_TOKEN_HASH = '<registration-access-token-hash>'
112
+ AUTHORIZATION_DATA_TYPES = [ '<authorization-data-type0>', '<authorization-data-type1>' ]
113
+ PAR_REQUIRED = false
114
+ REQUEST_OBJECT_REQUIRED = true
115
+ ATTRIBUTE_KEY = '<attribute0-key>'
116
+ ATTRIBUTE_VALUE = '<attribute0-value>'
117
+ ATTRIBUTES = [ Authlete::Model::Pair.new(key: ATTRIBUTE_KEY, value: ATTRIBUTE_VALUE) ]
118
+
119
+
120
+ def generate_json
121
+ return <<~JSON
122
+ {
123
+ "number": 100,
124
+ "serviceNumber": 1000,
125
+ "developer": "<developer>",
126
+ "clientId": 12345,
127
+ "clientIdAlias": "<client-id-alias>",
128
+ "clientIdAliasEnabled": true,
129
+ "clientSecret": "<client-secret>",
130
+ "clientType": "PUBLIC",
131
+ "redirectUris": [ "<redirect-uri0>", "<redirect-uri1>" ],
132
+ "responseTypes": [ "NONE", "CODE", "TOKEN", "ID_TOKEN" ],
133
+ "grantTypes": [ "AUTHORIZATION_CODE", "REFRESH_TOKEN" ],
134
+ "applicationType": "WEB",
135
+ "contacts": [ "<contact0>", "<contact1>" ],
136
+ "clientName": "<client-name>",
137
+ "clientNames": [{ "tag": "<client-name0-tag>", "value": "<client-name0-value>" }],
138
+ "logoUri": "<logo-uri>",
139
+ "logoUris": [{ "tag": "<logo-uri0-tag>", "value": "<logo-uri0-value>" }],
140
+ "clientUri": "<client-uri>",
141
+ "clientUris": [{ "tag": "<client-uri0-tag>", "value": "<client-uri0-value>" }],
142
+ "policyUri": "<policy-uri>",
143
+ "policyUris": [{ "tag": "<policy-uri0-tag>", "value": "<policy-uri0-value>" }],
144
+ "tosUri": "<tos-uri>",
145
+ "tosUris": [{ "tag": "<tos-uri0-tag>", "value": "<tos-uri0-value>" }],
146
+ "jwksUri": "<jwks-uri>",
147
+ "jwks": "<jwks>",
148
+ "derivedSectorIdentifier": "<derived-sector-identifier>",
149
+ "sectorIdentifierUri": "<sector-identifier-uri>",
150
+ "subjectType": "PUBLIC",
151
+ "idTokenSignAlg": "HS256",
152
+ "idTokenEncryptionAlg": "PBES2_HS256_A128KW",
153
+ "idTokenEncryptionEnc": "A128CBC_HS256",
154
+ "userInfoSignAlg": "HS256",
155
+ "userInfoEncryptionAlg": "PBES2_HS256_A128KW",
156
+ "userInfoEncryptionEnc": "A128CBC_HS256",
157
+ "requestSignAlg": "HS256",
158
+ "requestEncryptionAlg": "PBES2_HS256_A128KW",
159
+ "requestEncryptionEnc": "A128CBC_HS256",
160
+ "tokenAuthMethod": "CLIENT_SECRET_BASIC",
161
+ "tokenAuthSignAlg": "HS256",
162
+ "defaultMaxAge": 1000,
163
+ "defaultAcrs": [ "<default-acr0>", "<default-acr1>" ],
164
+ "authTimeRequired": true,
165
+ "loginUri": "<login-uri>",
166
+ "requestUris": [ "<request-uri0>", "<request-uri1>" ],
167
+ "description": "<description>",
168
+ "descriptions": [{ "tag": "<description0-tag>", "value": "<description0-value>" }],
169
+ "createdAt": 10000,
170
+ "modifiedAt": 10000,
171
+ "extension": {
172
+ "requestableScopes": [ "<requestable-scope0>", "<requestable-scope1>" ],
173
+ "requestableScopesEnabled": true,
174
+ "accessTokenDuration": 10000,
175
+ "refreshTokenDuration": 10000
176
+ },
177
+ "tlsClientAuthSubjectDn": "<tls-client-auth-subject-dn>",
178
+ "tlsClientAuthSanDns": "<tls-client-auth-san-dns>",
179
+ "tlsClientAuthSanUri": "<tls-client-auth-san-uri>",
180
+ "tlsClientAuthSanIp": "<tls-client-auth-san-ip>",
181
+ "tlsClientAuthSanEmail": "<tls-client-auth-san-email>",
182
+ "tlsClientCertificateBoundAccessTokens": false,
183
+ "selfSignedCertificateKeyId": "<self-signed-certificate-key-id>",
184
+ "softwareId": "<software-id>",
185
+ "softwareVersion": "<software-version>",
186
+ "authorizationSignAlg": "HS256",
187
+ "authorizationEncryptionAlg": "PBES2_HS256_A128KW",
188
+ "authorizationEncryptionEnc": "A128CBC_HS256",
189
+ "bcDeliveryMode": "POLL",
190
+ "bcNotificationEndpoint": "<bc-notification-endpoint>",
191
+ "bcRequestSignAlg": "HS256",
192
+ "bcUserCodeRequired": true,
193
+ "dynamicallyRegistered": false,
194
+ "registrationAccessTokenHash": "<registration-access-token-hash>",
195
+ "authorizationDataTypes": [ "<authorization-data-type0>", "<authorization-data-type1>" ],
196
+ "parRequired": false,
197
+ "requestObjectRequired": true,
198
+ "attributes": [{ "key": "<attribute0-key>", "value": "<attribute0-value>" }]
199
+ }
200
+ JSON
201
+ end
202
+
203
+
204
+ def generate_hash
205
+ {
206
+ number: 100,
207
+ serviceNumber: 1000,
208
+ developer: '<developer>',
209
+ clientId: 12345,
210
+ clientIdAlias: '<client-id-alias>',
211
+ clientIdAliasEnabled: true,
212
+ clientSecret: '<client-secret>',
213
+ clientType: 'PUBLIC',
214
+ redirectUris: [ '<redirect-uri0>', '<redirect-uri1>' ],
215
+ responseTypes: [ 'NONE', 'CODE', 'TOKEN', 'ID_TOKEN' ],
216
+ grantTypes: [ 'AUTHORIZATION_CODE', 'REFRESH_TOKEN' ],
217
+ applicationType: 'WEB',
218
+ contacts: [ '<contact0>', '<contact1>' ],
219
+ clientName: '<client-name>',
220
+ clientNames: [{ tag: '<client-name0-tag>', value: '<client-name0-value>' }],
221
+ logoUri: '<logo-uri>',
222
+ logoUris: [{ tag: '<logo-uri0-tag>', value: '<logo-uri0-value>' }],
223
+ clientUri: '<client-uri>',
224
+ clientUris: [{ tag: '<client-uri0-tag>', value: '<client-uri0-value>' }],
225
+ policyUri: '<policy-uri>',
226
+ policyUris: [{ tag: '<policy-uri0-tag>', value: '<policy-uri0-value>' }],
227
+ tosUri: '<tos-uri>',
228
+ tosUris: [{ tag: '<tos-uri0-tag>', value: '<tos-uri0-value>' }],
229
+ jwksUri: '<jwks-uri>',
230
+ jwks: '<jwks>',
231
+ derivedSectorIdentifier: '<derived-sector-identifier>',
232
+ sectorIdentifierUri: '<sector-identifier-uri>',
233
+ subjectType: 'PUBLIC',
234
+ idTokenSignAlg: 'HS256',
235
+ idTokenEncryptionAlg: 'PBES2_HS256_A128KW',
236
+ idTokenEncryptionEnc: 'A128CBC_HS256',
237
+ userInfoSignAlg: 'HS256',
238
+ userInfoEncryptionAlg: 'PBES2_HS256_A128KW',
239
+ userInfoEncryptionEnc: 'A128CBC_HS256',
240
+ requestSignAlg: 'HS256',
241
+ requestEncryptionAlg: 'PBES2_HS256_A128KW',
242
+ requestEncryptionEnc: 'A128CBC_HS256',
243
+ tokenAuthMethod: 'CLIENT_SECRET_BASIC',
244
+ tokenAuthSignAlg: 'HS256',
245
+ defaultMaxAge: 1000,
246
+ defaultAcrs: [ '<default-acr0>', '<default-acr1>' ],
247
+ authTimeRequired: true,
248
+ loginUri: '<login-uri>',
249
+ requestUris: [ '<request-uri0>', '<request-uri1>' ],
250
+ description: '<description>',
251
+ descriptions: [{ tag: '<description0-tag>', value: '<description0-value>' }],
252
+ createdAt: 10000,
253
+ modifiedAt: 10000,
254
+ extension: {
255
+ requestableScopes: [ '<requestable-scope0>', '<requestable-scope1>' ],
256
+ requestableScopesEnabled: true,
257
+ accessTokenDuration: 10000,
258
+ refreshTokenDuration: 10000
259
+ },
260
+ tlsClientAuthSubjectDn: '<tls-client-auth-subject-dn>',
261
+ tlsClientAuthSanDns: '<tls-client-auth-san-dns>',
262
+ tlsClientAuthSanUri: '<tls-client-auth-san-uri>',
263
+ tlsClientAuthSanIp: '<tls-client-auth-san-ip>',
264
+ tlsClientAuthSanEmail: '<tls-client-auth-san-email>',
265
+ tlsClientCertificateBoundAccessTokens: false,
266
+ selfSignedCertificateKeyId: '<self-signed-certificate-key-id>',
267
+ softwareId: '<software-id>',
268
+ softwareVersion: '<software-version>',
269
+ authorizationSignAlg: 'HS256',
270
+ authorizationEncryptionAlg: 'PBES2_HS256_A128KW',
271
+ authorizationEncryptionEnc: 'A128CBC_HS256',
272
+ bcDeliveryMode: 'POLL',
273
+ bcNotificationEndpoint: '<bc-notification-endpoint>',
274
+ bcRequestSignAlg: 'HS256',
275
+ bcUserCodeRequired: true,
276
+ dynamicallyRegistered: false,
277
+ registrationAccessTokenHash: '<registration-access-token-hash>',
278
+ authorizationDataTypes: [ '<authorization-data-type0>', '<authorization-data-type1>' ],
279
+ parRequired: false,
280
+ requestObjectRequired: true,
281
+ attributes: [{ key: '<attribute0-key>', value: '<attribute0-value>' }]
282
+ }
283
+ end
284
+
285
+
286
+ def set_params(obj)
287
+ obj.number = NUMBER
288
+ obj.service_number = SERVICE_NUMBER
289
+ obj.developer = DEVELOPER
290
+ obj.client_id = CLIENT_ID
291
+ obj.client_id_alias = CLIENT_ID_ALIAS
292
+ obj.client_id_alias_enabled = CLIENT_ID_ALIAS_ENABLED
293
+ obj.client_secret = CLIENT_SECRET
294
+ obj.client_type = CLIENT_TYPE
295
+ obj.redirect_uris = REDIRECT_URIS
296
+ obj.response_types = RESPONSE_TYPES
297
+ obj.grant_types = GRANT_TYPES
298
+ obj.application_type = APPLICATION_TYPE
299
+ obj.contacts = CONTACTS
300
+ obj.client_name = CLIENT_NAME
301
+ obj.client_names = CLIENT_NAMES
302
+ obj.logo_uri = LOGO_URI
303
+ obj.logo_uris = LOGO_URIS
304
+ obj.client_uri = CLIENT_URI
305
+ obj.client_uris = CLIENT_URIS
306
+ obj.policy_uri = POLICY_URI
307
+ obj.policy_uris = POLICY_URIS
308
+ obj.tos_uri = TOS_URI
309
+ obj.tos_uris = TOS_URIS
310
+ obj.jwks_uri = JWKS_URI
311
+ obj.jwks = JWKS
312
+ obj.derived_sector_identifier = DERIVED_SECTOR_IDENTIFIER
313
+ obj.sector_identifier_uri = SECTOR_IDENTIFIER_URI
314
+ obj.subject_type = SUBJECT_TYPE
315
+ obj.id_token_sign_alg = ID_TOKEN_SIGN_ALG
316
+ obj.id_token_encryption_alg = ID_TOKEN_ENCRYPTION_ALG
317
+ obj.id_token_encryption_enc = ID_TOKEN_ENCRYPTION_ENC
318
+ obj.user_info_sign_alg = USER_INFO_SIGN_ALG
319
+ obj.user_info_encryption_alg = USER_INFO_ENCRYPTION_ALG
320
+ obj.user_info_encryption_enc = USER_INFO_ENCRYPTION_ENC
321
+ obj.request_sign_alg = REQUEST_SIGN_ALG
322
+ obj.request_encryption_alg = REQUEST_ENCRYPTION_ALG
323
+ obj.request_encryption_enc = REQUEST_ENCRYPTION_ENC
324
+ obj.token_auth_method = TOKEN_AUTH_METHOD
325
+ obj.token_auth_sign_alg = TOKEN_AUTH_SIGN_ALG
326
+ obj.default_max_age = DEFAULT_MAX_AGE
327
+ obj.default_acrs = DEFAULT_ACRS
328
+ obj.auth_time_required = AUTH_TIME_REQUIRED
329
+ obj.login_uri = LOGIN_URI
330
+ obj.request_uris = REQUEST_URIS
331
+ obj.description = DESCRIPTION
332
+ obj.descriptions = DESCRIPTIONS
333
+ obj.created_at = CREATED_AT
334
+ obj.modified_at = MODIFIED_AT
335
+ obj.extension = EXTENSION
336
+ obj.tls_client_auth_subject_dn = TLS_CLIENT_AUTH_SUBJECT_DN
337
+ obj.tls_client_auth_san_dns = TLS_CLIENT_AUTH_SAN_DNS
338
+ obj.tls_client_auth_san_uri = TLS_CLIENT_AUTH_SAN_URI
339
+ obj.tls_client_auth_san_ip = TLS_CLIENT_AUTH_SAN_IP
340
+ obj.tls_client_auth_san_email = TLS_CLIENT_AUTH_SAN_EMAIL
341
+ obj.tls_client_certificate_bound_access_tokens = TLS_CLIENT_CERTIFICATE_BOUND_ACCESS_TOKENS
342
+ obj.self_signed_certificate_key_id = SELF_SIGNED_CERTIFICATE_KEY_ID
343
+ obj.software_id = SOFTWARE_ID
344
+ obj.software_version = SOFTWARE_VERSION
345
+ obj.authorization_sign_alg = AUTHORIZATION_SIGN_ALG
346
+ obj.authorization_encryption_alg = AUTHORIZATION_ENCRYPTION_ALG
347
+ obj.authorization_encryption_enc = AUTHORIZATION_ENCRYPTION_ENC
348
+ obj.bc_delivery_mode = BC_DELIVERY_MODE
349
+ obj.bc_notification_endpoint = BC_NOTIFICATION_ENDPOINT
350
+ obj.bc_request_sign_alg = BC_REQUEST_SIGN_ALG
351
+ obj.bc_user_code_required = BC_USER_CODE_REQUIRED
352
+ obj.dynamically_registered = DYNAMICALLY_REGISTERED
353
+ obj.registration_access_token_hash = REGISTRATION_ACCESS_TOKEN_HASH
354
+ obj.authorization_data_types = AUTHORIZATION_DATA_TYPES
355
+ obj.par_required = PAR_REQUIRED
356
+ obj.request_object_required = REQUEST_OBJECT_REQUIRED
357
+ obj.attributes = ATTRIBUTES
358
+ end
359
+
360
+
361
+ def match(obj)
362
+ assert_equal NUMBER, obj.number
363
+ assert_equal SERVICE_NUMBER, obj.serviceNumber
364
+ assert_equal DEVELOPER, obj.developer
365
+ assert_equal CLIENT_ID, obj.clientId
366
+ assert_equal CLIENT_ID_ALIAS, obj.clientIdAlias
367
+ assert_equal CLIENT_ID_ALIAS_ENABLED, obj.clientIdAliasEnabled
368
+ assert_equal CLIENT_SECRET, obj.clientSecret
369
+ assert_equal CLIENT_TYPE, obj.clientType
370
+ assert_equal REDIRECT_URIS, obj.redirectUris
371
+ assert_equal RESPONSE_TYPES, obj.responseTypes
372
+ assert_equal GRANT_TYPES, obj.grantTypes
373
+ assert_equal APPLICATION_TYPE, obj.applicationType
374
+ assert_equal CONTACTS, obj.contacts
375
+ assert_equal CLIENT_NAME, obj.clientName
376
+ assert_equal CLIENT_NAME_TAG, obj.clientNames[0].tag
377
+ assert_equal CLIENT_NAME_VALUE, obj.clientNames[0].value
378
+ assert_equal LOGO_URI, obj.logoUri
379
+ assert_equal LOGO_URI_TAG, obj.logoUris[0].tag
380
+ assert_equal LOGO_URI_VALUE, obj.logoUris[0].value
381
+ assert_equal CLIENT_URI, obj.clientUri
382
+ assert_equal CLIENT_URI_TAG, obj.clientUris[0].tag
383
+ assert_equal CLIENT_URI_VALUE, obj.clientUris[0].value
384
+ assert_equal POLICY_URI, obj.policyUri
385
+ assert_equal POLICY_URI_TAG, obj.policyUris[0].tag
386
+ assert_equal POLICY_URI_VALUE, obj.policyUris[0].value
387
+ assert_equal TOS_URI, obj.tosUri
388
+ assert_equal TOS_URI_TAG, obj.tosUris[0].tag
389
+ assert_equal TOS_URI_VALUE, obj.tosUris[0].value
390
+ assert_equal JWKS_URI, obj.jwksUri
391
+ assert_equal JWKS, obj.jwks
392
+ assert_equal DERIVED_SECTOR_IDENTIFIER, obj.derivedSectorIdentifier
393
+ assert_equal SECTOR_IDENTIFIER_URI, obj.sectorIdentifierUri
394
+ assert_equal SUBJECT_TYPE, obj.subjectType
395
+ assert_equal ID_TOKEN_SIGN_ALG, obj.idTokenSignAlg
396
+ assert_equal ID_TOKEN_ENCRYPTION_ALG, obj.idTokenEncryptionAlg
397
+ assert_equal ID_TOKEN_ENCRYPTION_ENC, obj.idTokenEncryptionEnc
398
+ assert_equal USER_INFO_SIGN_ALG, obj.userInfoSignAlg
399
+ assert_equal USER_INFO_ENCRYPTION_ALG, obj.userInfoEncryptionAlg
400
+ assert_equal USER_INFO_ENCRYPTION_ENC, obj.userInfoEncryptionEnc
401
+ assert_equal REQUEST_SIGN_ALG, obj.requestSignAlg
402
+ assert_equal REQUEST_ENCRYPTION_ALG, obj.requestEncryptionAlg
403
+ assert_equal REQUEST_ENCRYPTION_ENC, obj.requestEncryptionEnc
404
+ assert_equal TOKEN_AUTH_METHOD, obj.tokenAuthMethod
405
+ assert_equal TOKEN_AUTH_SIGN_ALG, obj.tokenAuthSignAlg
406
+ assert_equal DEFAULT_MAX_AGE, obj.defaultMaxAge
407
+ assert_equal DEFAULT_ACRS, obj.defaultAcrs
408
+ assert_equal AUTH_TIME_REQUIRED, obj.authTimeRequired
409
+ assert_equal LOGIN_URI, obj.loginUri
410
+ assert_equal REQUEST_URIS, obj.requestUris
411
+ assert_equal DESCRIPTION, obj.description
412
+ assert_equal DESCRIPTION_TAG, obj.descriptions[0].tag
413
+ assert_equal DESCRIPTION_VALUE, obj.descriptions[0].value
414
+ assert_equal CREATED_AT, obj.createdAt
415
+ assert_equal MODIFIED_AT, obj.modifiedAt
416
+ assert_equal REQUESTABLE_SCOPES, obj.extension.requestableScopes
417
+ assert_equal REQUESTABLE_SCOPES_ENABLED, obj.extension.requestableScopesEnabled
418
+ assert_equal ACCESS_TOKEN_DURATION, obj.extension.accessTokenDuration
419
+ assert_equal REFRESH_TOKEN_DURATION, obj.extension.refreshTokenDuration
420
+ assert_equal TLS_CLIENT_AUTH_SUBJECT_DN, obj.tlsClientAuthSubjectDn
421
+ assert_equal TLS_CLIENT_AUTH_SAN_DNS, obj.tlsClientAuthSanDns
422
+ assert_equal TLS_CLIENT_AUTH_SAN_URI, obj.tlsClientAuthSanUri
423
+ assert_equal TLS_CLIENT_AUTH_SAN_IP, obj.tlsClientAuthSanIp
424
+ assert_equal TLS_CLIENT_AUTH_SAN_EMAIL, obj.tlsClientAuthSanEmail
425
+ assert_equal TLS_CLIENT_CERTIFICATE_BOUND_ACCESS_TOKENS, obj.tlsClientCertificateBoundAccessTokens
426
+ assert_equal SELF_SIGNED_CERTIFICATE_KEY_ID, obj.selfSignedCertificateKeyId
427
+ assert_equal AUTHORIZATION_SIGN_ALG, obj.authorizationSignAlg
428
+ assert_equal AUTHORIZATION_ENCRYPTION_ALG, obj.authorizationEncryptionAlg
429
+ assert_equal AUTHORIZATION_ENCRYPTION_ENC, obj.authorizationEncryptionEnc
430
+ assert_equal BC_DELIVERY_MODE, obj.bcDeliveryMode
431
+ assert_equal BC_NOTIFICATION_ENDPOINT, obj.bcNotificationEndpoint
432
+ assert_equal BC_REQUEST_SIGN_ALG, obj.bcRequestSignAlg
433
+ assert_equal BC_USER_CODE_REQUIRED, obj.bcUserCodeRequired
434
+ assert_equal DYNAMICALLY_REGISTERED, obj.dynamicallyRegistered
435
+ assert_equal REGISTRATION_ACCESS_TOKEN_HASH, obj.registrationAccessTokenHash
436
+ assert_equal AUTHORIZATION_DATA_TYPES, obj.authorizationDataTypes
437
+ assert_equal PAR_REQUIRED, obj.parRequired
438
+ assert_equal REQUEST_OBJECT_REQUIRED, obj.requestObjectRequired
439
+ assert_equal ATTRIBUTE_KEY, obj.attributes[0].key
440
+ assert_equal ATTRIBUTE_VALUE, obj.attributes[0].value
441
+ end
442
+
443
+
444
+ def test_from_json
445
+ jsn = generate_json
446
+ hsh = JSON.parse(jsn)
447
+ actual = Authlete::Model::Client.new(hsh)
448
+
449
+ match(actual)
450
+ end
451
+
452
+
453
+ def test_setters
454
+ actual = Authlete::Model::Client.new
455
+ set_params(actual)
456
+
457
+ match(actual)
458
+ end
459
+
460
+
461
+ def test_to_hash
462
+ obj = Authlete::Model::Client.new
463
+ set_params(obj)
464
+ actual = obj.to_hash
465
+ expected = generate_hash
466
+
467
+ assert_equal expected, actual
468
+ end
469
+ end