2015-07-26 21:32:30 +00:00
|
|
|
# Configuring a client
|
2013-12-10 16:52:52 +00:00
|
|
|
|
2018-04-22 19:35:28 +00:00
|
|
|
The various clients (pk put, pk-get, pk-mount...) use a common JSON config
|
2015-07-26 21:32:30 +00:00
|
|
|
file. This page documents the configuration parameters in that file. Run
|
2018-03-05 23:07:54 +00:00
|
|
|
`pk env clientconfig` to see the default location for that file
|
2018-05-03 04:35:37 +00:00
|
|
|
(**$HOME/.config/perkeep/client-config.json** on linux). In the following
|
2018-03-05 23:07:54 +00:00
|
|
|
let **$CONFIGDIR** be the location returned by `pk env configdir`.
|
2013-12-10 16:52:52 +00:00
|
|
|
|
2015-07-26 21:32:30 +00:00
|
|
|
## Generating a default config file
|
|
|
|
|
2018-03-06 21:39:14 +00:00
|
|
|
Run `pk put init`.
|
2013-12-10 16:52:52 +00:00
|
|
|
|
2014-01-05 02:43:58 +00:00
|
|
|
On unix,
|
2015-07-26 21:32:30 +00:00
|
|
|
|
|
|
|
cat $CONFIGDIR/client-config.json
|
|
|
|
|
2014-01-05 02:43:58 +00:00
|
|
|
should look something like:
|
|
|
|
|
2015-07-26 21:32:30 +00:00
|
|
|
{
|
|
|
|
"identity": "43AD73B1",
|
|
|
|
"ignoredFiles": [
|
|
|
|
".DS_Store"
|
|
|
|
],
|
|
|
|
"servers": {
|
|
|
|
"localhost": {
|
|
|
|
"auth": "localhost",
|
|
|
|
"default": true,
|
|
|
|
"server": "http://localhost:3179"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
## Configuration Keys & Values
|
|
|
|
|
|
|
|
### Top-level keys
|
|
|
|
|
2018-03-06 21:39:14 +00:00
|
|
|
* `identity`: your GPG fingerprint. Run `pk put init` for help on how to
|
2015-07-26 21:32:30 +00:00
|
|
|
generate a new keypair.
|
|
|
|
|
|
|
|
* `identitySecretRing`: Optional. If non-empty, it specifies the location of
|
|
|
|
your GPG secret keyring. Defaults to **$CONFIGDIR/identity-secring.gpg**. Run
|
2018-03-06 21:39:14 +00:00
|
|
|
`pk put init` for help on how to generate a new keypair.
|
2015-07-26 21:32:30 +00:00
|
|
|
|
2018-03-06 21:39:14 +00:00
|
|
|
* `ignoredFiles`: Optional. The list of of files that pk put should ignore and
|
2015-07-26 21:32:30 +00:00
|
|
|
not try to upload.
|
|
|
|
|
|
|
|
### Servers
|
|
|
|
|
|
|
|
`servers`: Each server the client connects to may have its own configuration
|
|
|
|
section under an alias name as the key. The `servers` key is the collection of
|
|
|
|
server configurations. For example:
|
|
|
|
|
|
|
|
"servers": {
|
|
|
|
"localhost": {
|
|
|
|
"server": "http://localhost:3179",
|
|
|
|
"default": true,
|
|
|
|
"auth": "userpass:foo:bar"
|
|
|
|
},
|
|
|
|
"backup": {
|
|
|
|
"server": "https://some.remote.com",
|
|
|
|
"auth": "userpass:pony:magic",
|
|
|
|
"trustedCerts": ["ffc7730f4b"]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
* `trustedCerts`: Optional. This is the list of TLS server certificate
|
|
|
|
fingerprints that the client will trust when using HTTPS. It is required when
|
2017-12-15 17:57:42 +00:00
|
|
|
the server is using a self-signed certificate (as Perkeep generates by
|
2015-07-26 21:32:30 +00:00
|
|
|
default) instead of a Root Certificate Authority-signed cert (sometimes known
|
|
|
|
as a "commercial SSL cert"). The format of each item is the first 20 hex
|
|
|
|
digits of the SHA-256 digest of the cert. Example: `"trustedCerts":
|
|
|
|
["ffc7730f4bf00ba4bad0"]`
|
|
|
|
|
|
|
|
* `auth`: the authentication mechanism to use. Only supported for now is HTTP
|
|
|
|
basic authentication, of the form: `userpass:alice:secret`. Username "alice",
|
|
|
|
password "secret".
|
|
|
|
|
2016-02-18 07:02:14 +00:00
|
|
|
If the server is not on the same host, it is highly recommended to use TLS
|
|
|
|
or another form of secure connection to the server.
|
2015-07-26 21:32:30 +00:00
|
|
|
|
2018-04-21 18:04:53 +00:00
|
|
|
* `server`: The perkeepd server to connect to, of the form:
|
2015-07-26 21:32:30 +00:00
|
|
|
"[http[s]://]host[:port][/prefix]". Defaults to https. This option can be
|
|
|
|
overriden with the "-server" command-line flag.
|
2016-02-18 07:02:14 +00:00
|
|
|
|
|
|
|
Most client commands are meant to communicate with a blobserver. For such
|
|
|
|
commands, instead of the client relying on discovery to choose the actual
|
|
|
|
URL, the server URL can point directly to a specific blobserver handler,
|
|
|
|
of the form: "[http[s]://]host[:port][/prefix][/handler/]".
|
|
|
|
|
2018-03-05 23:07:54 +00:00
|
|
|
For example, to speed up syncing with `pk sync`, one could write
|
2016-02-18 07:02:14 +00:00
|
|
|
directly to the destination's blobserver, instead of the default, which is
|
|
|
|
to write to both the destination blobserver and index.
|
|
|
|
The above configuration sample can be extended by adding the following
|
|
|
|
alias, where "`/bs/`" is the handler of the primary blobserver:
|
|
|
|
|
|
|
|
"servers": {
|
|
|
|
...
|
|
|
|
"backup-bs": {
|
|
|
|
"server": "https://some.remote.com/bs/",
|
|
|
|
"auth": "userpass:pony:magic",
|
|
|
|
"trustedCerts": ["ffc7730f4b"]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
And the alias `backup-bs` can then be used as a destination by
|
2018-03-05 23:07:54 +00:00
|
|
|
`pk sync`.
|