-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Minor cleanup. Refactor to use build-id as user
- Loading branch information
Showing
14 changed files
with
444 additions
and
275 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,3 @@ | ||
slurp | ||
build/ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
<!-- [data:image/s3,"s3://crabby-images/29e97/29e97530146ea743bda966dc403849a678668780" alt="Build Status"](https://travis-ci.org/nanobox-io/slurp) --> | ||
[data:image/s3,"s3://crabby-images/ec4a0/ec4a0709ecf74152fc068ccf2d8428c8bc968e58" alt="GoDoc"](https://godoc.org/github.com/nanobox-io/slurp) | ||
|
||
# Slurp | ||
Intermediary to the stored build/blob, used specifically to speed up publishing nanobox builds. | ||
|
||
## Quickstart: | ||
```sh | ||
# Once hoarder is running, slurp can be quickly started by running () | ||
slurp -b /tmp/build | ||
|
||
# register a new build | ||
curl -k https://localhost:1566/stages -d '{"new-id": "test"}' | ||
# sync up your build (current directory) | ||
rsync -v --delete -aR . -e 'ssh -p 1567' [email protected]:test | ||
# tell slurp you are done syncing | ||
curl -k https://localhost:1566/stages/test -X PUT | ||
# Congratulations! | ||
``` | ||
**Part II:** | ||
```sh | ||
# after modifying your code, register a new build | ||
curl -k https://localhost:1566/stages -d '{"old-id": "test", "new-id": "test2"}' | ||
# sync up your build (current directory) | ||
rsync -v --delete -aR . -e 'ssh -p 1567' [email protected]:this-location-really-doesnt-matter | ||
# tell slurp you are done syncing | ||
curl -k https://localhost:1566/stages/test2 -X PUT | ||
# Congratulations! | ||
``` | ||
|
||
## Usage: | ||
|
||
### As a Server | ||
To start slurp as a server, run: | ||
|
||
`slurp` | ||
|
||
An optional config file can also be passed on startup: | ||
|
||
`slurp -c /path/to/config.json` | ||
|
||
>config.json | ||
>```json | ||
{ | ||
"api-token": "secret", | ||
"api-address": "127.0.0.1:1566", | ||
"build-dir": "/var/db/slurp/build/", | ||
"config-file": "", | ||
"insecure": false, | ||
"log-level": "info", | ||
"ssh-addr": "127.0.0.1:1567", | ||
"ssh-host": "/var/db/slurp/slurp_rsa", | ||
"store-addr": "hoarder://127.0.0.1:7410", | ||
"store-token": "" | ||
} | ||
``` | ||
`slurp -h` will show usage and a list of commands: | ||
|
||
``` | ||
slurp - build intermediary | ||
Usage: | ||
slurp [flags] | ||
Flags: | ||
-a, --api-address="127.0.0.1:1566": Listen address for the API | ||
-t, --api-token="secret": Token for API Access | ||
-b, --build-dir="/var/db/slurp/build/": Build staging directory | ||
-c, --config-file="": Configuration file to load | ||
-i, --insecure[=false]: Disable tls key checking (client) and listen on http (server) | ||
-l, --log-level="info": Log level to output [fatal|error|info|debug|trace] | ||
-s, --ssh-addr="127.0.0.1:1567": Address ssh server will listen on (ip:port combo) | ||
-k, --ssh-host="/var/db/slurp/slurp_rsa": SSH host (private) key file | ||
-S, --store-addr="hoarder://127.0.0.1:7410": Storage host address | ||
-T, --store-token="": Storage auth token | ||
``` | ||
|
||
## API: | ||
|
||
| Route | Description | Payload | Output | | ||
| --- | --- | --- | --- | | ||
| **POST** | /stages | Stage a new build | json stage object | json auth object | | ||
| **PUT** | /stages/:id | Commit a new build | nil | success/err message | | ||
| **DELETE** | /stages/:id | Delete a build | nil | success/err message | | ||
- Commit will clean up the staged build *after* pushing it to storage | ||
- Delete will clean up the staged build *without* pushing it to storage | ||
|
||
## Data types: | ||
|
||
### Stage | ||
json: | ||
```json | ||
{ | ||
"old-id": "abc123", | ||
"new-id": "def456" | ||
} | ||
``` | ||
Fields: | ||
- **old-id**: ID (in storage) of build to update | ||
- **new-id**: ID for the new build (required) | ||
|
||
### Auth | ||
json: | ||
```json | ||
{ | ||
"secret": "def456" | ||
} | ||
``` | ||
Fields: | ||
- **secret**: Contains the username to ssh with (ID of new build) | ||
|
||
## Todo | ||
- tests | ||
- rebuild auth user list on reboot | ||
- routinely clean up undeleted builds | ||
|
||
## Changelog | ||
- v0.0.1 (April 25, 2016) | ||
- slurp is born | ||
|
||
[data:image/s3,"s3://crabby-images/b1dc3/b1dc3c89de1226aff0652ed41575d7acf2fb78bb" alt="nanobox oss logo"](http://nanobox.io/open-source) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
## Sample Usage Demo | ||
This demo has [Hoarder](github.com/nanopack/hoarder) running locally | ||
|
||
### create some thing | ||
```sh | ||
dd if=/dev/urandom of=thing bs=1M count=10 | ||
``` | ||
|
||
#### tell slurp about new build | ||
```sh | ||
curl -k -H "X-AUTH-TOKEN: secret" https://localhost:1566/stages -d '{"new-id": "test"}' | ||
``` | ||
|
||
#### sync files | ||
```sh | ||
rsync -v --delete -aR . -e 'ssh -p 1567' [email protected]:test/ | ||
``` | ||
|
||
#### commit update (done syncing) | ||
```sh | ||
curl -k -H "X-AUTH-TOKEN: secret" https://localhost:1566/stages/test -X PUT | ||
``` | ||
|
||
#### delete temp build dir | ||
```sh | ||
curl -k -H "X-AUTH-TOKEN: secret" https://localhost:1566/stages/test -X DELETE | ||
``` | ||
|
||
#### *get build from hoarder | ||
```sh | ||
curl localhost:7410/blobs/test | tar -zxf - | ||
du -h thing | ||
# 10M thing | ||
``` | ||
|
||
### make changes | ||
```sh | ||
echo '{things"}' > file | ||
``` | ||
|
||
#### tell slurp about new build | ||
```sh | ||
curl -k -H "X-AUTH-TOKEN: secret" https://localhost:1566/stages -d '{"old-id": "test", "new-id": "test2"}' | ||
``` | ||
|
||
#### sync files | ||
```sh | ||
rsync --delete -aR . -e 'ssh -p 1567' [email protected]:this-location-really-doesnt-matter | ||
``` | ||
|
||
#### commit update (done syncing) | ||
```sh | ||
curl -k -H "X-AUTH-TOKEN: secret" https://localhost:1566/stages/test2 -X PUT | ||
``` | ||
|
||
#### *get build from hoarder | ||
```sh | ||
curl localhost:7410/blobs/test2 | tar -zxf - | ||
ls | ||
# file thing | ||
``` | ||
- *new directory |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.