mullinsand / lunch-and-learn

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Lunch and Learn

Table of contents


Project Description

You are a back-end developer working on a team that is building an application to search for cuisines by country, and provide opportunity to learn more about that countries culture. This app will allow users to search for recipes by country, favorite recipes, and learn more about a particular country.

Your team is working in a service-oriented architecture. The front-end will communicate with your back-end through an API. Your job is to expose that API that satisfies the front-end team’s requirements.


Learning Goals

  • Expose an API that aggregates data from multiple external APIs
  • Expose an API that requires an authentication token
  • Expose an API for CRUD functionality
  • Determine completion criteria based on the needs of other developers
  • Test both API consumption and exposure, making use of at least one mocking tool (VCR, Webmock, etc).

Setup

  • Ruby 2.7.4
  • Rails 5.2.8.1'
  • Fork this repository
  • Clone your fork
  • From the command line, install gems and set up your DB:
  • bundle install
  • rails db:{create,migrate,seed}
  • This app uses the Figaro gem to handle ENV VARS
    • bundle exec figaro install
    • ENV VARS in the config/application.yml are
      UNSPLASH_KEY
      YOUTUBE_KEY
      EDAMAM_ID
      EDAMAM_KEY
      PLACES_KEY
      
  • run the server with 'rails s'
  • Go to Postman and use one of these endpoints. The endpoints must look something like: http://localhost:3000/api/v1/recipes
  • Alternatively you can download the Postman Suite and run the premade endpoints

APIs Used


Schema:

The schema of the project includes a table for Users and Favorites.


Endpoints

GET /api/v1/recipes

  • Provides a list of up to 10 recipes from a country
  • Each recipe contains:
    • recipe name (title)
    • url link to the recipe (url)
    • country used for the search (country)
    • an image's url from the recipe (image)
  • Set country using query params (eg. /api/v1/recipes?country=thailand)
  • If no country is selected, a random country is chosen
  • Standard response looks like:
{
    "data": [
        {
            "id": null,
            "type": "recipe",
            "attributes": {
                "title": "Andy Ricker's Naam Cheuam Naam Taan Piip (Palm Sugar Simple Syrup)",
                "url": "https://www.seriouseats.com/recipes/2013/11/andy-rickers-naam-cheuam-naam-taan-piip-palm-sugar-simple-syrup.html",
                "country": "thailand",
                "image": "https://edamam-product-images.s3.amazonaws.com..."
            }
        },
        {
            "id": null,
            "type": "recipe",
            "attributes": {
                "title": "Sriracha",
                "url": "http://www.jamieoliver.com/recipes/vegetables-recipes/sriracha/",
                "country": "thailand",
                "image": "https://edamam-product-images.s3.amazonaws.com/."
            }
        },
        {...},
        {...},
        {...},
        {etc},
    ]
}
  • No results response
{
  "data": []
}

GET /api/v1/learning_resources

  • Provides learning resources for a specific country
  • Learning resources includes:
    • Short video from Mr. History YouTube channel (with video title and YouTube id)
    • 10 images pertaining to the specified country (each with an alt tag and url)
  • If no images or video are available for that country, these attributes will be empty ([])
  • Set country using query params (eg. /api/v1/learning_resources?country=thailand)
  • If no country is selected, a random country is chosen
  • Standard response looks like:
{
    "data": {
        "id": null,
        "type": "learning_resource",
        "attributes": {
            "country": "laos",
            "video": {
                "title": "A Super Quick History of Laos",
                "youtube_video_id": "uw8hjVqxMXw"
            },
            "images": [
                {
                    "alt_tag": "standing statue and temples landmark during daytime",
                    "url": "https://images.unsplash.com/photo-1528181304800-259b08848526?ixid=MnwzNzg2NzV8MHwxfHNlYXJjaHwxfHx0aGFpbGFuZHxlbnwwfHx8fDE2Njc4Njk1NTA&ixlib=rb-4.0.3"
                },
                {
                    "alt_tag": "five brown wooden boats",
                    "url": "https://images.unsplash.com/photo-1552465011-b4e21bf6e79a?ixid=MnwzNzg2NzV8MHwxfHNlYXJjaHwyfHx0aGFpbGFuZHxlbnwwfHx8fDE2Njc4Njk1NTA&ixlib=rb-4.0.3"
                },
                {
                    "alt_tag": "orange temples during daytime",
                    "url": "https://images.unsplash.com/photo-1563492065599-3520f775eeed?ixid=MnwzNzg2NzV8MHwxfHNlYXJjaHwzfHx0aGFpbGFuZHxlbnwwfHx8fDE2Njc4Njk1NTA&ixlib=rb-4.0.3"
                },
                {...},
                {...},
                {...},
                {etc},
              ]
        }
    }
}

POST /api/v1/users

  • User information requested through the body as a JSON payload
  • Unique API key will be generated and included in response
  • Email addresses must be unique for successful POST
  • Request format:
Content-Type: application/json
Accept: application/json

{
  "name": "Athena Dao",
  "email": "athenadao@bestgirlever.com",
  "password": "123456",
  "password_confirmation": "123456"
}
  • Successful response format:
{
  "data": {
    "type": "user",
    "id": "1",
    "attributes": {
      "name": "Athena Dao",
      "email": "athenadao@bestgirlever.com",
      "api_key": "jgn983hy48thw9begh98h4539h4"
    }
  }
}

POST /api/v1/user

  • Login endpoint
  • User information requested through the body as a JSON payload
  • Password and email required
  • Response contains name, email, and api_key
  • Request format:
Content-Type: application/json
Accept: application/json

{
  "email": "athenadao@bestgirlever.com",
  "password": "123456"
}
  • Successful response format:
{
  "data": {
    "type": "user",
    "id": "1",
    "attributes": {
      "name": "Athena Dao",
      "email": "athenadao@bestgirlever.com",
      "api_key": "jgn983hy48thw9begh98h4539h4"
    }
  }
}

POST /api/v1/favorites

  • Add a recipe to a user's favorite recipes list
  • Stores the country, recipe link, and recipe title as a favorite
  • Request format:
POST /api/v1/favorites
Content-Type: application/json
Accept: application/json

{
    "api_key": "jgn983hy48thw9begh98h4539h4",
    "country": "thailand",
    "recipe_link": "https://www.tastingtable.com/.....",
    "recipe_title": "Crab Fried Rice (Khaao Pad Bpu)"
}
  • Successful response format:
{
    "success": "Favorite added successfully"
}

GET /api/v1/favorites

  • Get a list of all a user's favorites
  • Request format:
Content-Type: application/json
Accept: application/json

{
    "api_key": "jgn983hy48thw9begh98h4539h4"
}
  • Response format:
{
    "data": [
        {
            "id": "1",
            "type": "favorite",
            "attributes": {
                "recipe_title": "Recipe: Egyptian Tomato Soup",
                "recipe_link": "http://www.thekitchn.com/recipe-egyptian-tomato-soup-weeknight....",
                "country": "egypt",
                "created_at": "2022-11-02T02:17:54.111Z"
            }
        },
        {
            "id": "2",
            "type": "favorite",
            "attributes": {
                "recipe_title": "Crab Fried Rice (Khaao Pad Bpu)",
                "recipe_link": "https://www.tastingtable.com/.....",
                "country": "thailand",
                "created_at": "2022-11-07T03:44:08.917Z"
            }
        }
    ]
 }
  • Response will be an empty array if user has no favorites

DELETE /api/v1/favorites

  • Removes a favorite from a user's favorites list
  • Request format:
Content-Type: application/json
Accept: application/json

{
    "api_key": "jgn983hy48thw9begh98h4539h4",
    "favorite_id": "14"
}

About


Languages

Language:Ruby 99.7%Language:HTML 0.3%