Skip to content

Latest commit

 

History

History
73 lines (62 loc) · 3.64 KB

README.md

File metadata and controls

73 lines (62 loc) · 3.64 KB

rails-badge ruby-badge

Sweater Weather

This repository is a fully functional/callable API that aggregates various outside APIs and combines them into useful endpoints ready to be called. These Endpoint are set up to be used in a weather app with current, hourly, and daily weather data. Another useful endpoint that will make the weather app stand out from the rest is the ability to pick an origin and a destination and automatically get the weather of the destination when you are scheduled to arrive.

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
  • Research, select, and consume an API based on your needs as a developer

Personal Learning Goals

  • Combine multiple outside APIs into my own API
  • Make an API that would be useful to others
  • Get a better understanding of API consumptions and exposures
  • Get a better understanding of fully testing APIs (both ones I consume and expose)
  • Become better at structuring my API responses and triming out the data that is not useful

Readme Content

Sweater Weather Endpoints

  • GET /api/v1/forecast?location=location
    • This endpoint lets you get the current, hourly, and daily weather at the given location
  • GET /api/v1/backgrounds?location=location
    • This enpoint gives you a background image to use from the given location
  • POST /api/v1/road_trip
    • This endpoint allows you to enter an origin and destination and gives you the travel time and weather information based on the time you would get to the destination
    • This API need a JSON payload with an origin, destination and api key

Stack

  • Ruby on Rails, RSpec, PostgreSQL
  • Some of the gems: jsonapi-serializer, pry, simplecov, vcr, webmock, figaro, bcrypt

Local Setup

  • Versions
    • Rails 5.2.6
    • Ruby 2.7.2
  • Fork and clone the repository
  • cd in your local repo version and run the following commands
    • To install gems:
      • bundle (if this fails, try to bundle update and then retry)
    • This API uses a few external APIs
      • Add a local application.yml file at the root (this will be ignored in gitcoverage)
      • Sign up for a free Mapquest account to get a key for both the Geolocation and a Direction apis
      • Get an API key for OpenWeather
      • Get an API key for Unsplash
      • Add to your application.yml config:
        mapquest_api_key: your_key_here
        OpenWeather_api_key: your_key_here
        Unsplash_api_key: your_key_here
      
    • To setup database:
      • rails db:create
      • rails db:migrate
      • rails db:seed
  • Run your own development server:

External APIs

This API consumes the following APIs: