summaryrefslogtreecommitdiff
path: root/src/scm/webid-oidc/stubs.scm
diff options
context:
space:
mode:
authorVivien Kraus <vivien@planete-kraus.eu>2020-01-01 00:00:00 +0100
committerVivien Kraus <vivien@planete-kraus.eu>2021-06-19 15:44:24 +0200
commit6bc2ce4c55af6d3f3af7be494c149cbe33d6e08e (patch)
tree5152c6bec3b1583ef123d0ef58c403831fe98792 /src/scm/webid-oidc/stubs.scm
parentfadfd29ceb64c8a60a369c0d3f225cfd0f46157b (diff)
Add a strip function
Diffstat (limited to 'src/scm/webid-oidc/stubs.scm')
-rw-r--r--src/scm/webid-oidc/stubs.scm21
1 files changed, 20 insertions, 1 deletions
diff --git a/src/scm/webid-oidc/stubs.scm b/src/scm/webid-oidc/stubs.scm
index 0ef3fb5..ff94497 100644
--- a/src/scm/webid-oidc/stubs.scm
+++ b/src/scm/webid-oidc/stubs.scm
@@ -14,12 +14,31 @@
(lambda error
(raise-not-base64 data error))))
+(define (fix-generate-key . args)
+ (catch 'unsupported-crv
+ (lambda ()
+ (apply generate-key args))
+ (lambda (error)
+ (raise-unsupported-crv (cadr error)))))
+
+(define (fix-kty key)
+ (catch 'unsupported-crv
+ (lambda ()
+ (let ((ret (kty key)))
+ (unless ret
+ (raise-not-a-jwk key #f))
+ ret))
+ (lambda (error)
+ (raise-unsupported-crv (cadr error)))))
+
(export
base64-encode
(fix-base64-decode . base64-decode)
random
random-init!
- generate-key)
+ (fix-generate-key . generate-key)
+ (fix-kty . kty)
+ strip-key)
;; json reader from guile-json will not behave consistently with
;; SRFI-180 with objects: keys will be mapped to strings, not