;; webid-oidc, implementation of the Solid specification ;; Copyright (C) 2020, 2021 Vivien Kraus ;; This program is free software: you can redistribute it and/or modify ;; it under the terms of the GNU Affero General Public License as ;; published by the Free Software Foundation, either version 3 of the ;; License, or (at your option) any later version. ;; This program is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU Affero General Public License for more details. ;; You should have received a copy of the GNU Affero General Public License ;; along with this program. If not, see . (use-modules (webid-oidc authorization-endpoint) (webid-oidc jwk) (webid-oidc testing) (web uri) (web request) (web response) (srfi srfi-19) (web response) (ice-9 optargs) (ice-9 receive)) (with-test-environment "authorization-endpoint-get-form" (lambda () (define alg 'RS256) (define key (generate-key #:n-size 2048)) (define subject (string->uri "https://authorization-endpoint-get-form.scm/profile/card#me")) (define password "p4ssw0rd") (define validity 120) (define the-time 0) (define (current-time) (make-time time-utc 0 the-time)) (define* (http-get uri #:key (headers '())) (exit 2)) (define endpoint (make-authorization-endpoint subject password alg key validity #:http-get http-get #:current-time current-time)) (receive (response response-body) (endpoint (build-request (string->uri (format #f "https://authorization-endpoint-get-form.scm/authorize?client_id=~a&redirect_uri=~a" (uri-encode "https://authorization-endpoint-get-form.scm/client/card#app") (uri-encode "https://authorization-endpoint-get-form.scm/client/redirect")))) "") (unless (eq? (response-code response) 200) (exit 3)) (unless (response-content-type response) (exit 4)) (unless (eq? (car (response-content-type response)) 'application/xhtml+xml) (exit 5)))))