summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRicardo Wurmus <rekado@elephly.net>2021-03-18 11:36:03 +0100
committerRicardo Wurmus <rekado@elephly.net>2021-03-18 11:36:03 +0100
commitba29d0b6cb352169d3f961c40b301ccbcba96247 (patch)
tree86a18b10336737ee433c9022a84f7ee4428db673
parentd0563a5533554ee35ff8dd7f00b414d610c71dfe (diff)
Move serialization code to (aws serialize).
-rw-r--r--Makefile.am1
-rw-r--r--aws/request.scm85
-rw-r--r--aws/serialize.scm111
3 files changed, 113 insertions, 84 deletions
diff --git a/Makefile.am b/Makefile.am
index ca30379..963ec6d 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -23,6 +23,7 @@ godir=$(libdir)/guile/$(GUILE_EFFECTIVE_VERSION)/site-ccache
GUILE_SOURCES = \
aws/base.scm \
+ aws/serialize.scm \
aws/request.scm \
aws/utils/json.scm \
language/aws/spec.scm
diff --git a/aws/request.scm b/aws/request.scm
index 69d71bb..d8338f7 100644
--- a/aws/request.scm
+++ b/aws/request.scm
@@ -17,6 +17,7 @@
(define-module (aws request)
#:use-module (aws base)
+ #:use-module (aws serialize)
#:use-module (ice-9 match)
#:use-module (ice-9 format)
#:use-module (srfi srfi-1)
@@ -73,58 +74,6 @@
((@@ (web http) write-key-value-list) params port my-val-writer)))))
-;; See https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Query-Requests.html
-(define* (serialize-aws-value thing #:key (path '()) n (depth 0))
- (define top? (zero? depth))
- (cond
- ((aws-structure? thing)
- (filter-map (lambda (member)
- (match (aws-member-value member)
- ('__unspecified__ #f)
- (value
- (serialize-aws-value value
- #:path
- (if top?
- (list (or (aws-member-location-name member)
- (aws-member-name member)))
- (cons* (or (aws-member-location-name member)
- (aws-member-name member))
- n
- (aws-structure-aws-name thing)
- path))
- #:depth
- (1+ depth)))))
- (aws-structure-members thing)))
- ((aws-shape? thing)
- (cond
- ((aws-shape-primitive? thing)
- (serialize-aws-value (aws-shape-value thing)
- #:path path
- #:depth (1+ depth)))
- (else
- (serialize-aws-value (aws-shape-value thing)
- #:path
- (cons (or (aws-shape-location-name thing)
- (aws-shape-aws-name thing)) path)
- #:depth (1+ depth)))))
- ((boolean? thing)
- (serialize-aws-value (or (and thing "true") "false")
- #:path path
- #:depth (1+ depth)))
- ((list? thing)
- (append-map (lambda (item n)
- (serialize-aws-value item
- #:path path
- #:n n
- #:depth (1+ depth)))
- thing
- (iota (length thing) 1)))
- (else (format #f "~a=~a"
- (string-join (map (cut format #f "~a" <>)
- (reverse (filter identity path)))
- ".")
- thing))))
-
(define (request-query-string operation-name api-version input)
"Return a request query string."
(string-join (cons* (format #false "Action=~a" operation-name)
@@ -134,38 +83,6 @@
'()))
"&"))
-(define* (aws-value->scm thing #:optional strip-name?)
- "Transform the potentially nested AWS value THING into an alist,
-which can easily be converted to JSON."
- (cond
- ((aws-structure? thing)
- (let ((members
- (filter-map (lambda (member)
- (match (aws-member-value member)
- ('__unspecified__ #false)
- (value
- `(,(format #false "~a"
- (or (aws-member-location-name member)
- (aws-member-name member)))
- .
- ,(aws-value->scm value)))))
- (aws-structure-members thing))))
- (if strip-name?
- members
- `((,(format #false "~a" (aws-structure-aws-name thing))
- . ,members)))))
- ((aws-shape? thing)
- (match (aws-shape-value thing)
- ((? list? l)
- (list->vector (map aws-value->scm l)))
- (x x)))
- ;; TODO: what about the primitive "map" type? That would also
- ;; appear as a pair, wouldn't it?
- ((pair? thing)
- (list->vector (map (cut aws-value->scm <> 'strip-name) thing)))
- ;; Other primitive value, e.g. string or boolean
- (else thing)))
-
(define (input-arguments->scm input)
"Return the arguments of the INPUT value as an alist. Drop the
operation name."
diff --git a/aws/serialize.scm b/aws/serialize.scm
new file mode 100644
index 0000000..068ccdf
--- /dev/null
+++ b/aws/serialize.scm
@@ -0,0 +1,111 @@
+;;; guile-aws --- Scheme DSL for the AWS APIs
+;;; Copyright © 2019, 2020, 2021 Ricardo Wurmus <rekado@elephly.net>
+;;;
+;;; Guile-AWS is free software: you can redistribute it and/or modify
+;;; it under the terms of the GNU General Public License as published
+;;; by the Free Software Foundation, either version 3 of the License,
+;;; or (at your option) any later version.
+;;;
+;;; Guile-AWS 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
+;;; General Public License for more details.
+;;;
+;;; You should have received a copy of the GNU General Public License
+;;; along with this program. If not, see
+;;; <http://www.gnu.org/licenses/>.
+
+(define-module (aws serialize)
+ #:use-module (aws base)
+ #:use-module (ice-9 match)
+ #:use-module (ice-9 format)
+ #:use-module (srfi srfi-1)
+ #:use-module (srfi srfi-26)
+ #:export (serialize-aws-value
+ aws-value->scm))
+
+;; See https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Query-Requests.html
+(define* (serialize-aws-value thing #:key (path '()) n (depth 0))
+ (define top? (zero? depth))
+ (cond
+ ((aws-structure? thing)
+ (filter-map (lambda (member)
+ (match (aws-member-value member)
+ ('__unspecified__ #f)
+ (value
+ (serialize-aws-value value
+ #:path
+ (if top?
+ (list (or (aws-member-location-name member)
+ (aws-member-name member)))
+ (cons* (or (aws-member-location-name member)
+ (aws-member-name member))
+ n
+ (aws-structure-aws-name thing)
+ path))
+ #:depth
+ (1+ depth)))))
+ (aws-structure-members thing)))
+ ((aws-shape? thing)
+ (cond
+ ((aws-shape-primitive? thing)
+ (serialize-aws-value (aws-shape-value thing)
+ #:path path
+ #:depth (1+ depth)))
+ (else
+ (serialize-aws-value (aws-shape-value thing)
+ #:path
+ (cons (or (aws-shape-location-name thing)
+ (aws-shape-aws-name thing)) path)
+ #:depth (1+ depth)))))
+ ((boolean? thing)
+ (serialize-aws-value (or (and thing "true") "false")
+ #:path path
+ #:depth (1+ depth)))
+ ((list? thing)
+ (apply append
+ (map (lambda (item n)
+ (serialize-aws-value item
+ #:path path
+ #:n n
+ #:depth (1+ depth)))
+ thing
+ (iota (length thing) 1))))
+ (else
+ (format #f "~a=~a"
+ (string-join (map (cut format #f "~a" <>)
+ (reverse (filter identity path)))
+ ".")
+ thing))))
+
+(define* (aws-value->scm thing #:optional strip-name?)
+ "Transform the potentially nested AWS value THING into an alist,
+which can easily be converted to JSON."
+ (cond
+ ((aws-structure? thing)
+ (let ((members
+ (filter-map (lambda (member)
+ (match (aws-member-value member)
+ ('__unspecified__ #false)
+ (value
+ `(,(format #false "~a"
+ (or (aws-member-location-name member)
+ (aws-member-name member)))
+ .
+ ,(aws-value->scm value)))))
+ (aws-structure-members thing))))
+ (if strip-name?
+ members
+ `((,(format #false "~a" (aws-structure-aws-name thing))
+ . ,members)))))
+ ((aws-shape? thing)
+ (match (aws-shape-value thing)
+ ((? list? l)
+ (list->vector (map aws-value->scm l)))
+ (x x)))
+ ;; TODO: what about the primitive "map" type? That would also
+ ;; appear as a pair, wouldn't it?
+ ((pair? thing)
+ (list->vector (map (cut aws-value->scm <> 'strip-name) thing)))
+ ;; Other primitive value, e.g. string or boolean
+ (else thing)))