restedancestor
is a pretty simple REST API,
delivers quotes from the Ancestor of the
Darkest Dungeon in JSON format.
restedancestor
is currently online at
https://restedancestor.herokuapp.com,
skip to the
Routes
section to see how you can consume the API.
restedancestor
's master branch can be used
to deploy a local copy for development,
testing or for whatever fits your needs,
you can either download a binary or compile it yourself,
either way follow instructions below.
restedancestor
supports Linux, Windows and Mac, but you need
to compile it yourself since the project uses CGO,
cross-compiling can't be enabled.
After its downloaded, place the executable in a directory with
a subdirectory name database and the database.db
file in it copy
the db file database.db
in it, then you can run the executable
and use it!
Requires Go to be installed on your machine. You can install Go from here.
Once installed, and with a correctly configured GOPATH, on a terminal type:
$ go get github.com/bruno-chavez/restedancestor
Then go to:
$GOPATH/src/github.com/bruno-chavez/restedancestor
And last, on a terminal type:
$ make install
Once installed and depending on how you installed the API should see a message like this:
$ restedancestor
Welcome to restedancestor, the API is running in a maddening fashion!
The Ancestor is waiting and listening on port 8080 of localhost
You can communicate with the API in various ways,
for example going to your browser and typing on your search
bar localhost:8080
, followed with one of the routes listed on
the Routes section, if succesful you should see something like this:
There are more complete ways of doing requests to the API, and choosing one depends completly on preference, if you like Desktop Apps Postman is a pretty powerful tool, prefer web tools? check Hurl it, like CLI apps? HTTPie is good enough for the job.
Responds with a JSON body with a random quote in it.
HTTP/1.1 200 OK
Content-Type: application/json
Date: Mon, 04 Jun 2018 09:46:36 GMT
Content-Length: 67
{
"quote": "Towering. Fierce. Terrible. Nightmare made material.",
"uuid": "8aa2653b-2a4a-48c9-b0e5-e221aa9237bd",
"score": 0
}
Where {word} is the word that wants to be found in the database.
For example requesting a GET method on /search/prince will return a JSON body and a NotFoundStatus Header like this:
HTTP/1.1 404 Not Found
Content-Type: application/json
Date: Mon, 04 Jun 2018 09:37:24 GMT
Content-Length: 70
{
"code": "404",
"message": "'prince' was not found in the database"
}
But requesting at /search/swine will return a JSON body with all the quotes that the word was found on and a OKStatus Header:
HTTP/1.1 200 OK
Content-Type: application/json
Date: Mon, 04 Jun 2018 09:39:54 GMT
Content-Length: 99
[
{
"quote": "To prosecute our war against the swine, we must first scout their squalid homes.",
"uuid": "9bc3e097-5a25-4cbd-80de-e2a77999e979",
"score": 0
}
]
Responds with a JSON body with all the quotes available in the API.
HTTP/1.1 200 OK
Content-Type: application/json
Date: Mon, 04 Jun 2018 09:47:14 GMT
Transfer-Encoding: chunked
[
{
"quote": "Brigands have the run of these lanes, keep to the side path, the Hamlet is just ahead.",
"uuid": "66d6ae53-c78f-4c31-9331-fdce84e29d57",
"score": 0
},
{
"id": 10,
"quote": "Dispatch this thug in brutal fashion, that all may hear of your arrival!",
"uuid": "f8cabf02-0af1-43e7-ab19-e927ca02fa67",
"score": 0
},
...
]
Responds with a JSON body with an original quote made from merging parts of two existing quotes.
HTTP/1.1 200 OK
Content-Type: application/json
Date: Mon, 04 Jun 2018 09:46:36 GMT
Content-Length: 134
{
"quote": "invention! A spark without kindling is a goal without hope.",
"uuid": "00000000-0000-0000-0000-000000000000",
"score": 0
}
Responds with the top five most liked quotes in a JSON body.
HTTP/1.1 200 OK
Content-Type: application/json
Date: Mon, 04 Jun 2018 09:47:14 GMT
Transfer-Encoding: chunked
[
{
"quote": "Brigands have the run of these lanes, keep to the side path, the Hamlet is just ahead.",
"uuid": "66d6ae53-c78f-4c31-9331-fdce84e29d57",
"score": 18
},
{
"quote": "Dispatch this thug in brutal fashion, that all may hear of your arrival!",
"uuid": "f8cabf02-0af1-43e7-ab19-e927ca02fa67",
"score": 13
},
...
]
Where {uuid} is the unique identifier of a quote, respondes with a JSON body with that quote in it.
HTTP/1.1 200 OK
Content-Type: application/json
Date: Mon, 04 Jun 2018 09:46:36 GMT
Content-Length: 67
{
"quote": "Towering. Fierce. Terrible. Nightmare made material.",
"uuid": "8aa2653b-2a4a-48c9-b0e5-e221aa9237bd",
"score": 0
}
Responds with a Not Found Error in case the uuid is wrong, or an OK status if not.
HTTP/1.1 200 OK
Date: Mon, 04 Jun 2018 09:46:36 GMT
Content-Length: 0
Responds with a Not Found Error in case the uuid is wrong, or an OK status if not.
HTTP/1.1 200 OK
Date: Mon, 04 Jun 2018 09:46:36 GMT
Content-Length: 0
This is a pretty small and niche project, created mainly to have fun and learn, so do that!
Only tested on Linux.
Sister project of ancestorquotes.
Current version: 2.0
Found an bug or an error? Post it in the issue tracker.
Want to add an awesome new feature? Fork this repository and add your feature, then send a pull request.
The MIT License (MIT) Copyright (c) 2019 Bruno Chavez