restedancestor
is a pretty simple REST API,
delivers quotes from the Ancestor of the
Darkest Dungeon in JSON format.
Online
restedancestor
is currently online at
https://restedancestor.herokuapp.com,
skip to the
Routes
section to see how you can consume the API.
Local Use
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.
Executables:
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!
From source code:
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
Usage
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.
Routes
/random
GET:
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
}
/search/{word}
GET:
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
}
]
/all
GET:
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
},
...
]
/senile
GET:
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
}
/top
GET:
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
},
...
]
/uuid/{uuid}/find
GET:
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
}
/uuid/{uuid}/like
POST:
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
/uuid/{uuid}/dislike
POST:
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
Notes
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
Contribute
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.
License
The MIT License (MIT)
Copyright (c) 2019 Bruno Chavez