2011-05-02 01:36:11 +00:00
|
|
|
{ "_for-emacs": "-*- mode: js2;-*-",
|
2012-03-19 20:09:00 +00:00
|
|
|
"handlerConfig": true,
|
2011-05-14 23:40:16 +00:00
|
|
|
"baseURL": ["_env", "${CAMLI_BASEURL}"],
|
2011-11-16 10:41:38 +00:00
|
|
|
"auth": ["_env", "${CAMLI_AUTH}"],
|
2011-11-28 17:45:08 +00:00
|
|
|
"https": ["_env", "${CAMLI_TLS}", false],
|
2013-06-25 14:44:49 +00:00
|
|
|
"TLSCertFile": "config/selfgen_pem.crt",
|
|
|
|
"TLSKeyFile": "config/selfgen_pem.key",
|
2011-05-02 01:36:11 +00:00
|
|
|
"prefixes": {
|
|
|
|
"/": {
|
|
|
|
"handler": "root",
|
|
|
|
"handlerArgs": {
|
2012-12-12 02:41:23 +00:00
|
|
|
"ownerName": ["_env", "${USER}-dev"],
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"blobRoot": "/bs-recv/",
|
2013-06-05 17:18:27 +00:00
|
|
|
"statusRoot": "/status/",
|
2012-11-07 17:57:43 +00:00
|
|
|
"searchRoot": "/my-search/",
|
2011-05-02 01:36:11 +00:00
|
|
|
"stealth": false
|
|
|
|
}
|
|
|
|
},
|
2011-06-17 03:45:47 +00:00
|
|
|
|
2011-06-19 20:09:43 +00:00
|
|
|
"/blog/": {
|
2014-01-14 04:11:43 +00:00
|
|
|
"enabled": ["_env", "${CAMLI_PUBLISH_ENABLED}"],
|
2011-06-17 03:45:47 +00:00
|
|
|
"handler": "publish",
|
|
|
|
"handlerArgs": {
|
2011-06-19 20:09:43 +00:00
|
|
|
"rootName": "dev-blog-root",
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"blobRoot": "/bs/",
|
2011-06-17 03:45:47 +00:00
|
|
|
"searchRoot": "/my-search/",
|
2011-06-23 19:11:01 +00:00
|
|
|
"cache": "/cache/",
|
2013-10-28 15:59:07 +00:00
|
|
|
"goTemplate": "blog.html",
|
2011-06-23 19:11:01 +00:00
|
|
|
"devBootstrapPermanodeUsing": "/sighelper/"
|
2011-06-17 03:45:47 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-06-19 20:09:43 +00:00
|
|
|
"/pics/": {
|
2014-01-14 04:11:43 +00:00
|
|
|
"enabled": ["_env", "${CAMLI_PUBLISH_ENABLED}"],
|
2011-06-19 20:09:43 +00:00
|
|
|
"handler": "publish",
|
2011-05-02 01:36:11 +00:00
|
|
|
"handlerArgs": {
|
2011-06-19 20:09:43 +00:00
|
|
|
"rootName": "dev-pics-root",
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"blobRoot": "/bs/",
|
2011-06-19 20:09:43 +00:00
|
|
|
"searchRoot": "/my-search/",
|
2011-06-23 19:11:01 +00:00
|
|
|
"cache": "/cache/",
|
2011-07-08 17:03:53 +00:00
|
|
|
"css": ["pics.css"],
|
2013-05-24 21:19:29 +00:00
|
|
|
"js": ["pics.js"],
|
2013-10-28 15:59:07 +00:00
|
|
|
"goTemplate": "gallery.html",
|
2011-06-23 19:11:01 +00:00
|
|
|
"devBootstrapPermanodeUsing": "/sighelper/"
|
2011-06-19 20:09:43 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-07-08 16:08:41 +00:00
|
|
|
"/stub-test-disable/": {
|
|
|
|
"handler": "publish",
|
|
|
|
"enabled": false,
|
|
|
|
"handlerArgs": {
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-06-19 20:09:43 +00:00
|
|
|
"/ui/": {
|
|
|
|
"handler": "ui",
|
|
|
|
"handlerArgs": {
|
2013-06-19 06:14:36 +00:00
|
|
|
"sourceRoot": ["_env", "${CAMLI_DEV_CAMLI_ROOT}", ""],
|
2011-06-04 16:58:50 +00:00
|
|
|
"jsonSignRoot": "/sighelper/",
|
2011-06-19 20:09:43 +00:00
|
|
|
"cache": "/cache/",
|
2013-12-14 17:37:56 +00:00
|
|
|
"scaledImage": {
|
|
|
|
"type": "kv",
|
|
|
|
"file": ["_env", "${CAMLI_ROOT_CACHE}/thumbnails.kv", ""]
|
|
|
|
},
|
2011-06-19 20:09:43 +00:00
|
|
|
"publishRoots": ["/blog/", "/pics/"]
|
|
|
|
}
|
2011-05-02 01:36:11 +00:00
|
|
|
},
|
|
|
|
|
2013-06-05 17:18:27 +00:00
|
|
|
"/status/": {
|
|
|
|
"handler": "status"
|
|
|
|
},
|
|
|
|
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"/sync-index/": {
|
2011-05-09 13:05:58 +00:00
|
|
|
"handler": "sync",
|
|
|
|
"handlerArgs": {
|
|
|
|
"from": "/bs/",
|
2012-11-07 21:40:17 +00:00
|
|
|
"to": ["_env", "${CAMLI_INDEXER_PATH}"],
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"queue": { "type": "memory" },
|
2013-12-11 08:20:22 +00:00
|
|
|
"fullSyncOnStart": ["_env", "${CAMLI_FULL_INDEX_SYNC_ON_START}"],
|
|
|
|
"blockingFullSyncOnStart": ["_env", "${CAMLI_FULL_INDEX_SYNC_ON_START}"]
|
2011-05-09 13:05:58 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"/sync-r1/": {
|
|
|
|
"handler": "sync",
|
|
|
|
"handlerArgs": {
|
|
|
|
"from": "/bs/",
|
|
|
|
"to": "/r1/",
|
|
|
|
"queue": { "type": "memory" }
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-05-02 01:36:11 +00:00
|
|
|
"/sighelper/": {
|
|
|
|
"handler": "jsonsign",
|
|
|
|
"handlerArgs": {
|
2011-05-02 04:23:31 +00:00
|
|
|
"secretRing": ["_env", "${CAMLI_SECRET_RING}"],
|
2013-09-20 13:42:05 +00:00
|
|
|
"keyId": ["_env", "${CAMLI_KEYID}"],
|
2011-06-04 01:42:31 +00:00
|
|
|
"publicKeyDest": "/bs/"
|
2011-05-02 01:36:11 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"/bs-recv/": {
|
2011-06-04 04:52:56 +00:00
|
|
|
"handler": "storage-replica",
|
|
|
|
"handlerArgs": {
|
2013-11-25 01:11:40 +00:00
|
|
|
"minWritesForSuccess": 2,
|
|
|
|
"backends": ["/bs/", ["_env", "${CAMLI_INDEXER_PATH}"]],
|
2013-11-23 06:50:40 +00:00
|
|
|
"readBackends": ["/bs/"]
|
2011-06-04 04:52:56 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"/cond-unused/": {
|
2011-06-04 04:52:56 +00:00
|
|
|
"handler": "storage-cond",
|
|
|
|
"handlerArgs": {
|
2011-06-04 15:46:42 +00:00
|
|
|
"write": {
|
|
|
|
"if": "isSchema",
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"then": "/bs-recv/",
|
2011-06-04 15:46:42 +00:00
|
|
|
"else": "/bs/"
|
|
|
|
},
|
|
|
|
"read": "/bs/"
|
2011-06-04 04:52:56 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-05-02 01:36:11 +00:00
|
|
|
"/bs/": {
|
2011-05-30 05:28:17 +00:00
|
|
|
"handler": "storage-filesystem",
|
2011-05-02 01:36:11 +00:00
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT}"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-06-04 16:58:50 +00:00
|
|
|
"/cache/": {
|
|
|
|
"handler": "storage-filesystem",
|
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT_CACHE}"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-05-21 16:26:20 +00:00
|
|
|
"/sharder/": {
|
2011-05-30 05:28:17 +00:00
|
|
|
"handler": "storage-shard",
|
2011-05-21 16:26:20 +00:00
|
|
|
"handlerArgs": {
|
|
|
|
"backends": ["/s1/", "/s2/"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
"/s1/": {
|
2011-05-30 05:28:17 +00:00
|
|
|
"handler": "storage-filesystem",
|
2011-05-21 16:26:20 +00:00
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT_SHARD1}"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-06-19 20:09:43 +00:00
|
|
|
"/s2/": {
|
|
|
|
"handler": "storage-filesystem",
|
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT_SHARD2}"]
|
2011-05-21 16:26:20 +00:00
|
|
|
}
|
2011-06-19 20:09:43 +00:00
|
|
|
},
|
2011-05-21 16:26:20 +00:00
|
|
|
|
2011-05-23 04:22:21 +00:00
|
|
|
"/repl/": {
|
2011-05-30 05:28:17 +00:00
|
|
|
"handler": "storage-replica",
|
2011-05-23 04:22:21 +00:00
|
|
|
"handlerArgs": {
|
|
|
|
"backends": ["/r1/", "/r2/", "/r3/"],
|
|
|
|
"minWritesForSuccess": 2
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
"/r1/": {
|
2013-11-30 21:06:04 +00:00
|
|
|
"handler": "storage-diskpacked",
|
2011-05-23 04:22:21 +00:00
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT_REPLICA1}"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
"/r2/": {
|
2011-05-30 05:28:17 +00:00
|
|
|
"handler": "storage-filesystem",
|
2011-05-23 04:22:21 +00:00
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT_REPLICA2}"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
"/r3/": {
|
2011-05-30 05:28:17 +00:00
|
|
|
"handler": "storage-filesystem",
|
2011-05-23 04:22:21 +00:00
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT_REPLICA3}"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2013-06-15 22:05:27 +00:00
|
|
|
"/enc/": {
|
|
|
|
"handler": "storage-encrypt",
|
|
|
|
"handlerArgs": {
|
2013-06-16 03:08:37 +00:00
|
|
|
"I_AGREE": "that encryption support hasn't been peer-reviewed, isn't finished, and its format might change.",
|
2013-06-15 22:05:27 +00:00
|
|
|
"meta": "/encmeta/",
|
|
|
|
"blobs": "/encblob/",
|
2013-11-23 19:11:05 +00:00
|
|
|
"metaIndex": { "type": "memory" },
|
2013-06-15 22:05:27 +00:00
|
|
|
"key": "000102030405060708090a0b0c0d0e0f"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
"/encmeta/": {
|
|
|
|
"handler": "storage-filesystem",
|
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT_ENCMETA}"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
"/encblob/": {
|
|
|
|
"handler": "storage-filesystem",
|
|
|
|
"handlerArgs": {
|
|
|
|
"path": ["_env", "${CAMLI_ROOT_ENCBLOB}"]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2013-08-23 22:19:21 +00:00
|
|
|
"/index-kv/": {
|
|
|
|
"enabled": ["_env", "${CAMLI_KVINDEX_ENABLED}"],
|
|
|
|
"handler": "storage-kvfileindexer",
|
|
|
|
"handlerArgs": {
|
|
|
|
"blobSource": "/bs/",
|
2013-09-19 23:01:22 +00:00
|
|
|
"file": ["_env", "${CAMLI_DBNAME}", ""]
|
2013-08-23 22:19:21 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-12-25 20:30:56 +00:00
|
|
|
"/index-mongo/": {
|
|
|
|
"enabled": ["_env", "${CAMLI_MONGO_ENABLED}", true],
|
|
|
|
"handler": "storage-mongodbindexer",
|
|
|
|
"handlerArgs": {
|
2013-09-09 20:54:32 +00:00
|
|
|
"host": "localhost",
|
2011-12-25 20:30:56 +00:00
|
|
|
"database": ["_env", "${CAMLI_DBNAME}"],
|
|
|
|
"blobSource": "/bs/"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-11-26 20:30:22 +00:00
|
|
|
"/index-mysql/": {
|
|
|
|
"enabled": ["_env", "${CAMLI_MYSQL_ENABLED}", true],
|
2011-05-30 05:28:17 +00:00
|
|
|
"handler": "storage-mysqlindexer",
|
2011-05-02 01:36:11 +00:00
|
|
|
"handlerArgs": {
|
2011-07-02 02:16:58 +00:00
|
|
|
"database": ["_env", "${CAMLI_DBNAME}"],
|
2011-06-09 00:49:31 +00:00
|
|
|
"user": "root",
|
|
|
|
"password": "root",
|
|
|
|
"host": "127.0.0.1",
|
|
|
|
"blobSource": "/bs/"
|
2011-05-02 01:36:11 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2012-11-03 18:58:50 +00:00
|
|
|
"/index-postgres/": {
|
|
|
|
"enabled": ["_env", "${CAMLI_POSTGRES_ENABLED}", true],
|
|
|
|
"handler": "storage-postgresindexer",
|
|
|
|
"handlerArgs": {
|
|
|
|
"database": ["_env", "${CAMLI_DBNAME}"],
|
|
|
|
"user": "postgres",
|
|
|
|
"password": "postgres",
|
|
|
|
"host": "127.0.0.1",
|
|
|
|
"blobSource": "/bs/"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2013-09-19 23:01:22 +00:00
|
|
|
"/index-sqlite/": {
|
|
|
|
"enabled": ["_env", "${CAMLI_SQLITE_ENABLED}", true],
|
|
|
|
"handler": "storage-sqliteindexer",
|
|
|
|
"handlerArgs": {
|
|
|
|
"file": ["_env", "${CAMLI_DBNAME}"],
|
|
|
|
"blobSource": "/bs/"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-05-02 01:36:11 +00:00
|
|
|
"/my-search/": {
|
|
|
|
"handler": "search",
|
|
|
|
"handlerArgs": {
|
2011-11-26 20:30:22 +00:00
|
|
|
"index": ["_env", "${CAMLI_INDEXER_PATH}"],
|
2013-12-28 23:56:45 +00:00
|
|
|
"owner": ["_env", "${CAMLI_PUBKEY_BLOBREF}"],
|
2013-11-16 23:18:16 +00:00
|
|
|
"slurpToMemory": true,
|
Get rid of QueueCreator and all its associated complexity.
Previous TODO entry was:
-- Get rid of QueueCreator entirely. Plan:
-- sync handler still has a source and dest (one pair) but
instead of calling CreateQueue on the source, it instead
has an index.Storage (configured via a RequiredObject
so it can be a kvfile, leveldb, mysql, postgres etc)
-- make all the index.Storage types be instantiable
from a jsonconfig Object, perhaps with constructors keyed
on a "type" field.
-- make sync handler support blobserver.Receiver (or StatReceiver)
like indexes, so it can receive blobs. but all it needs to
do to acknowledge the ReceiveBlob is write and flush to its
index.Storage. the syncing is async by default. (otherwise callers
could just use "replica" if they wanted sync replication).
But maybe for ease of configuration switching, we could also
support a sync mode. when it needs to replicate a blob,
it uses the source.
-- future option: sync mirror to an alternate path on ReceiveBlob
that can delete. e.g. you're uploading to s3 and google,
but don't want to upload to both at once, so you use the localdisk
as a buffer to spread out your upstream bandwidth.
-- end result: no more hardlinks or queue creator.
Change-Id: I6244fc4f3a655f08470ae3160502659399f468ed
2013-11-22 22:33:31 +00:00
|
|
|
"devBlockStartupOn": "/sync-index/"
|
2011-05-02 01:36:11 +00:00
|
|
|
}
|
2013-06-23 20:50:02 +00:00
|
|
|
},
|
|
|
|
|
2013-10-19 22:48:05 +00:00
|
|
|
"/importer-dummy/": {
|
|
|
|
"handler": "importer-dummy",
|
|
|
|
"handlerArgs": {
|
|
|
|
"url": "http://localhost:8080/foo.json",
|
|
|
|
"username": "alice",
|
|
|
|
"authToken": "xyz"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2013-11-19 04:53:46 +00:00
|
|
|
"/importer-flickr/": {
|
|
|
|
"handler": "importer-flickr",
|
|
|
|
"enabled": ["_env", "${CAMLI_FLICKR_ENABLED}", false],
|
|
|
|
"handlerArgs": {
|
|
|
|
"apiKey": ["_env", "${CAMLI_FLICKR_API_KEY}", ""]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2014-01-15 04:45:23 +00:00
|
|
|
"/importer-foursquare/": {
|
|
|
|
"handler": "importer-foursquare",
|
|
|
|
"enabled": ["_env", "${CAMLI_FOURSQUARE_ENABLED}", false],
|
|
|
|
"handlerArgs": {
|
|
|
|
"apiKey": ["_env", "${CAMLI_FOURSQUARE_API_KEY}", ""]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2013-06-23 20:50:02 +00:00
|
|
|
"/share/": {
|
|
|
|
"handler": "share",
|
|
|
|
"handlerArgs": {
|
|
|
|
"blobRoot": "/bs/"
|
|
|
|
}
|
2011-05-02 01:36:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|