aboutsummaryrefslogtreecommitdiff
path: root/src/libstore/store-api.cc
diff options
context:
space:
mode:
authorEelco Dolstra <eelco.dolstra@logicblox.com>2016-04-29 16:26:16 +0200
committerEelco Dolstra <eelco.dolstra@logicblox.com>2016-04-29 16:26:16 +0200
commit95d20dfde94fc715f39e2ffeadefc5b5bd5e570b (patch)
treea13f06fd7b0d28f2610eb87dcb4a52203742e51d /src/libstore/store-api.cc
parentaa3bc3d5dcff5ff6567a4e00320cb9caa28c5a93 (diff)
Allow parameters in store URIs
This is to allow store-specific configuration, e.g. s3://my-cache?compression=bzip2&secret-key=/path/to/key.
Diffstat (limited to 'src/libstore/store-api.cc')
-rw-r--r--src/libstore/store-api.cc21
1 files changed, 18 insertions, 3 deletions
diff --git a/src/libstore/store-api.cc b/src/libstore/store-api.cc
index 2763f5ad4..463e132e0 100644
--- a/src/libstore/store-api.cc
+++ b/src/libstore/store-api.cc
@@ -461,10 +461,22 @@ namespace nix {
RegisterStoreImplementation::Implementations * RegisterStoreImplementation::implementations = 0;
-ref<Store> openStoreAt(const std::string & uri)
+ref<Store> openStoreAt(const std::string & uri_)
{
+ auto uri(uri_);
+ StoreParams params;
+ auto q = uri.find('?');
+ if (q != std::string::npos) {
+ for (auto s : tokenizeString<Strings>(uri.substr(q + 1), "&")) {
+ auto e = s.find('=');
+ if (e != std::string::npos)
+ params[s.substr(0, e)] = s.substr(e + 1);
+ }
+ uri = uri_.substr(0, q);
+ }
+
for (auto fun : *RegisterStoreImplementation::implementations) {
- auto store = fun(uri);
+ auto store = fun(uri, params);
if (store) return ref<Store>(store);
}
@@ -478,7 +490,10 @@ ref<Store> openStore()
}
-static RegisterStoreImplementation regStore([](const std::string & uri) -> std::shared_ptr<Store> {
+static RegisterStoreImplementation regStore([](
+ const std::string & uri, const StoreParams & params)
+ -> std::shared_ptr<Store>
+{
enum { mDaemon, mLocal, mAuto } mode;
if (uri == "daemon") mode = mDaemon;