summaryrefslogtreecommitdiff
path: root/src/scm/webid-oidc/client/client.scm
diff options
context:
space:
mode:
Diffstat (limited to 'src/scm/webid-oidc/client/client.scm')
-rw-r--r--src/scm/webid-oidc/client/client.scm8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/scm/webid-oidc/client/client.scm b/src/scm/webid-oidc/client/client.scm
index 1bf1c7c..5da701b 100644
--- a/src/scm/webid-oidc/client/client.scm
+++ b/src/scm/webid-oidc/client/client.scm
@@ -58,6 +58,8 @@
)
#:declarative? #t)
+(define <jwk:key-pair> jwk:<key-pair>)
+
(define-class <client> ()
(client-id #:init-keyword #:client-id #:getter client-id)
(key-pair #:init-keyword #:key-pair #:getter client-key-pair)
@@ -65,10 +67,10 @@
(define-method (->sexp (client <client>))
`(begin
- (use-modules (oop goops) (webid-oidc client))
+ (use-modules (oop goops) (webid-oidc client) (webid-oidc jwk))
(make <client>
#:client-id ,(uri->string (client-id client))
- #:key-pair (quote ,(client-key-pair client))
+ #:key-pair (jwk->key (quote ,(key->jwk (client-key-pair client))))
#:redirect-uri ,(uri->string (client-redirect-uri client)))))
(define-method (write (client <client>) port)
@@ -92,7 +94,7 @@
(match `(,client-id ,key-pair ,redirect-uri)
(((or (? string? (= string->uri (? uri? client-id)))
(? uri? client-id))
- (? jwk:jwk? client-key)
+ (? (cute is-a? <> <jwk:key-pair>) client-key)
(or (? string? (= string->uri (? uri? redirect-uri)))
(? uri? redirect-uri)))
(begin