Skip to content

henrygraesberg/deno-shotegories

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Shotegories API

A rewrite of the Shotegories API using Deno

An API for getting a random category for a game of categories, and potentially a letter for a game of shotegories
(Inpired by the drinking game that the Godfrey Twins like to play)

Using the API

With the public endpoint

The API is hosted on Deno Deploy, and running on "https://shotegories.graesberg.com/api"
From here it can be used the same as if it was running locally, with the query option ?withLetter=true returning an object with a category and letter, and anything else returning only a category. A simple frontend is also hosted with Deno Deploy, at the root, which queries the API and displays a category, with the option to include a letter in the response.

Locally

Once the repository has been cloned, run the commands

deno install

#then
deno run dev #If you want hot reload
#OR
deno run start #If you are deploying the API and don't need hot reload

to install dependencies and start the server. A frontend simply supplying an html file and a request to the api wil run on localhost:3000, while the API will run on http://localhost:3000/api by default, but this can be changed by adding a .env file and setting HTTP_PORT to your desired port. Upon the server starting the port the server is running on will be printed to the console.

The response is an object matching the following TypeScript interface:

interface ShotegoriesResponse {
  category: string
}

if you do not have the query withLetter set to true, and

interface ShotegoriesResponse {
  category: string
  letter: string
}

if you do

To prevent certain categories from being rolled, simply add them to an array called preventCategories in the body of the request
Example using fetch:

const response = await fetch("https://shotegories.graesberg.com/api" {
  method: "POST",
  body: JSON.stringify({
    preventCategories: ["Artists", "Citites", "Shooter games"]
    //Keep in mind, it is case sensitive
  })
})

const category = await response.json()
/*
Example response:
{
  category: "Pokémon"
}

Works as normal, but is guaranteed to not match any categories from the "preventCategories" array
*/

If there is a 500 error, the return will match:

interface ShotegoriesErrorResponse {
  error: "Internal server error"
  errorStack: {
    code: string
  }
}

Ergo, a response to a request sent to http://localhost:3000/api could look like:

{
  "category": "Alcohol brands"
}

and a response to a request sent to http://localhost:3000/api?withLetter=true could look like:

{
  "category": "Alcohol brands",
  "letter": "S"
}

while a failed response could look like:

{
  "error": "Internal server error",
  "errorStack": {
    "code": "ERR_MODULE_NOT_FOUND" //The error code if the server cannot find the categories.json file
  }
}

Developing

Follow the first steps of "Using the API" to install dependencies and run the server.\

The project was built with Deno, and you should be able to get far with the Deno documentation