Make pkg git credential format extensible.

Thanks to Eli.
This commit is contained in:
Vincent St-Amour 2016-10-07 14:17:31 -05:00
parent 456a72a36c
commit d597983bb9
2 changed files with 37 additions and 29 deletions

View File

@ -944,10 +944,12 @@ for @nonterm{key}.
documentation; an empty string, which is the default, disables
the URL so that the local filesystem is used. This key can be
set only in @exec{installation} scope.}
@item{@exec{git-checkout-credentials} --- A list of git credentials in the form
@nonterm{username}@litchar{:}@nonterm{password} that are tried when downloading
packages with git sources using the HTTP or HTTPS protocols. The credentials are
currently stored @bold{unencrypted} on the filesystem.}
@item{@exec{git-checkout-credentials} --- A list that starts with a format
specification (currently only @racket['basic] is supported), followed
by git credentials in the form @nonterm{username}@litchar{:}@nonterm{password}
that are tried when downloading packages with git sources using the
HTTP or HTTPS protocols. The credentials are currently stored
@bold{unencrypted} on the filesystem.}
@item{@exec{trash-max-packages} --- A limit on the number of package implementations
that are kept in a trash folder when the package is removed or updated.}
@item{@exec{trash-max-seconds} --- A limit on the time since a package is removed or

View File

@ -39,8 +39,13 @@
(read-pkg-cfg/def 'network-retries)))
(define (get-git-checkout-credentials)
(define format+creds
(or (current-pkg-git-checkout-credentials)
(read-pkg-cfg/def 'git-checkout-credentials)))
(define format-spec (car format+creds))
(unless (eq? format-spec 'basic)
(pkg-error "only 'basic credentials are supported"))
(cdr format+creds))
(define (read-pkg-cfg/def k)
;; Lock is held for the current scope, but if
@ -61,7 +66,7 @@
['trash-max-packages 512]
['trash-max-seconds (* 60 60 24 2)] ; 2 days
['network-retries 5]
['git-checkout-credentials '()]
['git-checkout-credentials '(basic)]
[_ #f]))
(define c (read-pkg-file-hash (pkg-config-file)))
(define v (hash-ref c k 'none))
@ -210,6 +215,7 @@
" expected: value in the form <username>:<password>")
val))
(update-pkg-cfg! 'git-checkout-credentials
(cons 'basic
(for/list ([val (in-list vals)])
(match (string-split val ":" #:trim? #f)
[(list "" _)
@ -230,7 +236,7 @@
[(list _)
(credentials-format-error
"not enough elements for git checkout credentials"
val)])))
val)]))))
(displayln "WARNING: checkout credentials are stored UNENCRYPTED" (current-error-port))]
[(list* key args)
(pkg-error "unsupported config key\n key: ~a" key)])]
@ -256,7 +262,7 @@
["doc-open-url"
(printf "~a~a\n" indent (or (read-pkg-cfg/def 'doc-open-url) ""))]
["git-checkout-credentials"
(for ([creds (in-list (read-pkg-cfg/def 'git-checkout-credentials))])
(for ([creds (in-list (cdr (read-pkg-cfg/def 'git-checkout-credentials)))])
(printf "~a~a:~a\n" indent (hash-ref creds 'username) (hash-ref creds 'password)))]
[_
(pkg-error "unsupported config key\n key: ~e" key)])]