Roughenough

Apache License 2 Build Status

Roughenough is a Roughtime secure time synchronization client and server implementation in Rust.

The server and client are functionally complete and at feature parity with the reference C++ and Golang implementations.

Areas for improvement remain, see limitations below. Contributions are welcome.

Links

Building and Running

```bash

Build roughenough

$ cargo build --release ```

The client binary is target/release/client. After building you can copy the binary and run on its own (no cargo needed) if you wish.

bash $ cp target/release/server /usr/local/bin

Using the Client to Query a Roughtime Server

bash $ target/release/client roughtime.int08h.com 2002 Requesting time from: "roughtime.int08h.com":2002 Received time from server: midpoint="Jul 28 2018 15:21:31", radius=1000000 (merkle_index=0, verified=false)

Validating Server Responses

Use the -p flag with the client to validate the server's response with its public key.

```bash

The public key of 'roughtime.int08h.com' is stored in a DNS TXT record

$ host -t TXT roughtime.int08h.com roughtime.int08h.com descriptive text "016e6e0284d24c37c6e4d7d8d5b4e1d3c1949ceaa545bf875616c9dce0c9bec1"

Validate the server response using its public key

$ target/release/client roughtime.int08h.com 2002 -p 016e6e0284d24c37c6e4d7d8d5b4e1d3c1949ceaa545bf875616c9dce0c9bec1 Requesting time from: "roughtime.int08h.com":2002 Received time from server: midpoint="Jul 28 2018 15:26:54", radius=1000000 (merkle_index=0, verified=true) ```

Note verified=true in the output which confirms that the server's response had a valid signature.

Starting the Server

bash $ cargo build --release $ target/release/server example.cfg 2018-07-25 00:05:09 INFO [server] Roughenough server v1.0.4 starting 2018-07-25 00:05:09 INFO [server] Long-term public key: d0756ee69ff5fe96cbcf9273208fec53124b1dd3a24d3910e07c7c54e2473012 2018-07-25 00:05:09 INFO [server] Ephemeral public key: 25fd5dc31ceee241aed3e643534e95ed0609e9a20982a45ac0312a5f55e2cc66 2018-07-25 00:05:09 INFO [server] Server listening on 127.0.0.1:8686

The resulting binary is target/release/server. After building you can copy the binary and run on its own (no cargo needed):

bash $ cp target/release/server /usr/local/bin $ /usr/local/bin/server /path/to/config.file

Configuration File

The server is configured via a YAML file:

yaml interface: 127.0.0.1 port: 8686 seed: f61075c988feb9cb700a4a6a3291bfbc9cab11b9c9eca8c802468eb38a43d7d3 batch_size: 64

Where:

Stopping the Server

Use Ctrl-C or kill the process.

Limitations

Roughtime features not implemented by the server:

Other notes:

About the Roughtime Protocol

Roughtime is a protocol that aims to achieve rough time synchronisation in a secure way that doesn't depend on any particular time server, and in such a way that, if a time server does misbehave, clients end up with cryptographic proof of it. It was created by Adam Langley and Robert Obryk.

Contributors

Copyright and License

Roughenough is copyright (c) 2017-2018 int08h LLC. All rights reserved.

int08h LLC licenses Roughenough (the "Software") to you under the Apache License, version 2.0 (the "License"); you may not use this Software except in compliance with the License. You may obtain a copy of the License from the LICENSE file included with the Software or at:

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.