Skip to content

Latest commit

 

History

History
220 lines (163 loc) · 5.25 KB

README.md

File metadata and controls

220 lines (163 loc) · 5.25 KB

Recipe Book API

An open-source API for managing recipes, built with Express and TypeScript using Prisma.

API Documentation

Currently supporting Minecraft PC (Java) V.1.19

Table of Contents

Quick Nav

Installation

  1. Clone the repository

SSH

$ git clone [email protected]:ejkorol/recipe-book.git

HTTPS

$ git clone https://github.com/ejkorol/recipe-book.git
  1. Install dependencies
$ cd recipe-book
$ npm install
  1. Set up ENV variables

    1. Create a .env file in the root directory and add .env.sample variables with your own sercrets:
    $ touch .env
    $ cat .env.sample > .env

    For development purposes, set NODE_ENV=development

    1. Add the DATABASE_URL variable with your own config:
    PORT=8080 // localhost port
    DATABASE_URL=mysql://username:password@localhost:port/db // This prisma config uses mySQL
    NODE_ENV=development
  2. Set up Prisma client

    1. Reset db
    $ npx prisma migrate reset
    1. Run the migration
    $ npx prisma migrate dev
    1. Generate prisma client
    $ npx prisma generate

    Ensure database exists prior to migrating.

  3. Seeding the database

    Quick Note: Located in ./data/index.ts exists versions of Minecraft (pc/java edition) that have the data supported for this API.

    Formatted as:

    const data = {
        "VERSION": {
            files: {
                blocks: "./path/from/root/to/data/file",
                biomes: "./path/from/root/to/data/file",
                foods: "./path/from/root/to/data/file",
                entities: "./path/from/root/to/data/file",
                items: "./path/from/root/to/data/file",
                materials: "./path/from/root/to/data/file",
                recipes: "./path/from/root/to/data/file" 
            }
        }
    };
    1. Setup seeding script:

    Located in ./src/seed/seed.ts exists the script to handle the seeding process of the above data:

    import { data } from "../../data";
    import {
        blocks,
        foods,
        biomes,
        entities,
        items,
        materials,
        recipes
    } from "./scripts/1.20.2/index" // this is the version of the scripts
    
    const version = "1.20.2"; // this is the version of data
    const paths = data[version].files
    
    const main = async () => {
        await blocks(paths.blocks);
        await foods(paths.foods);
        await biomes(paths.biomes);
        await entities(paths.entities);
        await items(paths.items);
        await materials(paths.materials);
        await recipes(paths.recipes);
    };
    
    main();

    Ensure that version is the version of data you intend to seed, and such that it exists in ./data/index.ts.

    Ensure that the scripts for that version exists in ./src/seed/scripts.

    In the event that the seed script for the latest version does not exist, please use the most recent script.

    1. Seed the database:

    Prior to running the seed script, do a reset of the last seeded data in prisma, and migrate the latest version of schemas:

    $ npx prisma migrate reset
    $ npx prisma migrate dev

    Run the seeding script:

    $ npm run seed
    1. To ensure the data has been successfully seeded:
    $ npx prisma studio

    Will open a front-end to preview the seeded data in prisma.

Project Structure

recipe-book/
├── data/
│ ├── DATA_VERSION/
│ └── index.ts
├── src/
│ ├── controllers/
│ ├── middleware/
│ ├── routes/
│ │ └── index.ts
│ ├── schemas/
│ ├── seed/
│ │  ├── scripts/
│ │  │ └──  DATA_VERSION/
│ │  └── seed.ts
│ ├── services/
│ ├── utils/
│ └── api.ts
├── dist/
├── types/
├── .env
└── README.md
  • data/: Contains versionized data of (pc/java) data used in the API
  • src/controllers/: Manages request processing and response generation
  • src/middleware/: Manages useful middlware used by the api (i.e. error handling, typeguards, rate limits)
  • src/routes/: Maps HTTP requests to controller functions
  • src/schemas/: Manages schemas for zod typechecks
  • src/seed/: Manages seed scripts and versionized seed history
  • src/services/: Contains business logic and operations
  • src/utils/: Provides utility functions and configurations
  • types/: For organizing types (always prefaced with I and exported from singular index)
  • dist/: Compiled JavaScript files

Development

To start the development server with automatic reloading, run:

$ npm run dev

Ensure that you have correctly performed the Installation.