aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/program/aedifex/repository
diff options
context:
space:
mode:
authorEduardo Julian2020-12-23 06:33:44 -0400
committerEduardo Julian2020-12-23 06:33:44 -0400
commitd29e091e98dabb8dfcf816899ada480ecbf7e357 (patch)
treea9d34c7fbb700cdb0c1f1226d377150614ce9914 /stdlib/source/program/aedifex/repository
parentcad959345afb8bf0bd1e5eefe6c63f136833b3ce (diff)
Refactored "export" common syntax.
Diffstat (limited to '')
-rw-r--r--stdlib/source/program/aedifex/repository.lux93
-rw-r--r--stdlib/source/program/aedifex/repository/identity.lux42
2 files changed, 82 insertions, 53 deletions
diff --git a/stdlib/source/program/aedifex/repository.lux b/stdlib/source/program/aedifex/repository.lux
index c351e9d0c..351d1c066 100644
--- a/stdlib/source/program/aedifex/repository.lux
+++ b/stdlib/source/program/aedifex/repository.lux
@@ -13,8 +13,7 @@
[data
["." binary (#+ Binary)]
["." text
- ["%" format (#+ format)]
- ["." encoding]]
+ ["%" format (#+ format)]]
[number
["n" nat]]]
[tool
@@ -26,27 +25,19 @@
[world
[net (#+ URL)
["." uri (#+ URI)]]]]
- ["." // #_
- ["#." artifact (#+ Artifact)
- ["#/." extension (#+ Extension)]]])
+ ["." / #_
+ ["#." identity (#+ Identity)]
+ ["/#" // #_
+ ["#." artifact (#+ Artifact)
+ ["#/." extension (#+ Extension)]]]])
(type: #export Address
URL)
-(type: #export User
- Text)
-
-(type: #export Password
- Text)
-
-(type: #export Identity
- {#user User
- #password Password})
-
(signature: #export (Repository !)
(: (-> URI (! (Try Binary)))
download)
- (: (-> Identity URI Binary (! (Try Any)))
+ (: (-> URI Binary (! (Try Any)))
upload))
(def: #export (async repository)
@@ -55,14 +46,14 @@
(def: (download uri)
(promise.future (\ repository download uri)))
- (def: (upload identity uri content)
- (promise.future (\ repository upload identity uri content)))
+ (def: (upload uri content)
+ (promise.future (\ repository upload uri content)))
))
(signature: #export (Simulation s)
(: (-> URI s (Try [s Binary]))
on-download)
- (: (-> Identity URI Binary s (Try s))
+ (: (-> URI Binary s (Try s))
on-upload))
(def: #export (mock simulation init)
@@ -82,11 +73,11 @@
(#try.Failure error)
(wrap (#try.Failure error))))))
- (def: (upload identity uri content)
+ (def: (upload uri content)
(stm.commit
(do {! stm.monad}
[|state| (stm.read state)]
- (case (\ simulation on-upload identity uri content |state|)
+ (case (\ simulation on-upload uri content |state|)
(#try.Success |state|)
(do !
[_ (stm.write |state| state)]
@@ -126,28 +117,19 @@
(new [java/lang/String])
(openConnection [] #io #try java/net/URLConnection)])
-(import: java/util/Base64$Encoder
- ["#::."
- (encodeToString [[byte]] java/lang/String)])
-
-(import: java/util/Base64
- ["#::."
- (#static getEncoder [] java/util/Base64$Encoder)])
-
(import: java/io/BufferedInputStream
["#::."
(new [java/io/InputStream])
(read [[byte] int int] #io #try int)])
+(exception: #export (no-credentials {address Address})
+ (exception.report
+ ["Address" (%.text address)]))
+
(exception: #export (deployment-failure {code Int})
(exception.report
["Code" (%.int code)]))
-(def: (basic-auth user password)
- (-> User Password Text)
- (format "Basic " (java/util/Base64$Encoder::encodeToString (\ encoding.utf8 encode (format user ":" password))
- (java/util/Base64::getEncoder))))
-
(def: #export (uri artifact extension)
(-> Artifact Extension URI)
(format (//artifact.uri artifact) extension))
@@ -158,8 +140,8 @@
(def: user-agent
(format "LuxAedifex/" (version.format language/lux.version)))
-(structure: #export (remote address)
- (All [s] (-> Address (Repository IO)))
+(structure: #export (remote identity address)
+ (All [s] (-> (Maybe Identity) Address (Repository IO)))
(def: (download uri)
(do {! (try.with io.monad)}
@@ -186,21 +168,26 @@
[chunk (\ io.monad wrap (binary.slice 0 (.nat bytes-read) buffer))]
(recur (\ binary.monoid compose output chunk)))))))))
- (def: (upload [user password] uri content)
- (do (try.with io.monad)
- [connection (|> (format address uri)
- java/net/URL::new
- java/net/URL::openConnection)
- #let [connection (:coerce java/net/HttpURLConnection connection)]
- _ (java/net/HttpURLConnection::setRequestMethod "PUT" connection)
- _ (java/net/URLConnection::setDoOutput true connection)
- _ (java/net/URLConnection::setRequestProperty "Authorization" (..basic-auth user password) connection)
- stream (java/net/URLConnection::getOutputStream connection)
- _ (java/io/OutputStream::write content stream)
- _ (java/io/OutputStream::flush stream)
- _ (java/lang/AutoCloseable::close stream)
- code (java/net/HttpURLConnection::getResponseCode connection)]
- (case code
- +201 (wrap [])
- _ (\ io.monad wrap (exception.throw ..deployment-failure [code])))))
+ (def: (upload uri content)
+ (case identity
+ #.None
+ (\ io.monad wrap (exception.throw ..no-credentials [address]))
+
+ (#.Some [user password])
+ (do (try.with io.monad)
+ [connection (|> (format address uri)
+ java/net/URL::new
+ java/net/URL::openConnection)
+ #let [connection (:coerce java/net/HttpURLConnection connection)]
+ _ (java/net/HttpURLConnection::setRequestMethod "PUT" connection)
+ _ (java/net/URLConnection::setDoOutput true connection)
+ _ (java/net/URLConnection::setRequestProperty "Authorization" (/identity.basic-auth user password) connection)
+ stream (java/net/URLConnection::getOutputStream connection)
+ _ (java/io/OutputStream::write content stream)
+ _ (java/io/OutputStream::flush stream)
+ _ (java/lang/AutoCloseable::close stream)
+ code (java/net/HttpURLConnection::getResponseCode connection)]
+ (case code
+ +201 (wrap [])
+ _ (\ io.monad wrap (exception.throw ..deployment-failure [code]))))))
)
diff --git a/stdlib/source/program/aedifex/repository/identity.lux b/stdlib/source/program/aedifex/repository/identity.lux
new file mode 100644
index 000000000..fbc93f367
--- /dev/null
+++ b/stdlib/source/program/aedifex/repository/identity.lux
@@ -0,0 +1,42 @@
+(.module:
+ [lux #*
+ ["." host (#+ import:)]
+ [abstract
+ [equivalence (#+ Equivalence)]]
+ [data
+ ["." product]
+ ["." text
+ ["%" format (#+ format)]
+ ["." encoding]]]])
+
+(type: #export User
+ Text)
+
+(type: #export Password
+ Text)
+
+(type: #export Identity
+ {#user User
+ #password Password})
+
+(def: #export equivalence
+ (Equivalence Identity)
+ ($_ product.equivalence
+ text.equivalence
+ text.equivalence
+ ))
+
+(import: java/util/Base64$Encoder
+ ["#::."
+ (encodeToString [[byte]] java/lang/String)])
+
+(import: java/util/Base64
+ ["#::."
+ (#static getEncoder [] java/util/Base64$Encoder)])
+
+(def: #export (basic-auth user password)
+ (-> User Password Text)
+ (let [credentials (\ encoding.utf8 encode (format user ":" password))]
+ (|> (java/util/Base64::getEncoder)
+ (java/util/Base64$Encoder::encodeToString credentials)
+ (format "Basic "))))