Skip to content

Latest commit

 

History

History
348 lines (311 loc) · 12.5 KB

README.md

File metadata and controls

348 lines (311 loc) · 12.5 KB

Sweater Weather

rails-badge ruby-badge build-badge

RESTful API serving up endpoints for a roadtrip planning app

trip duration, current and forecasted weather upon arrival, background image for a city, user creation and authentication

Readme Content


Setup

Prerequisites

  • Ruby 2.5.3
  • Rails 5.2.4.3

Installation

Install gems and setup your database:

bundle install
rails db:create
rails db:migrate

Run your own development server:

rails s

Running the Tests

  • Run with $ bundle exec rspec. All tests should be passing.

API Endpoints

  • This API is available at https://sweater-weather-lriff.herokuapp.com/
  • Responses are sent as JSON

Get Forecast

Returns the forecast for a given location

  • Returns the current weather, daily forecast for the next 5 days, and the hourly forecast for the next 8 hours
  • Required parameters:
    • location: city and state (ex: 'New York, NY')
  • Example request: GET https://sweater-weather-lriff.herokuapp.com/api/v1/forecast?location=denver,co
  • Example response:
    {:data=>
    {:id=>nil,
     :type=>"forecast",
     :attributes=>
      {:current_weather=>
        {:datetime=>"2020-11-08T20:25:08.000-07:00",
         :sunrise=>"2020-11-08T05:22:11.000-07:00",
         :sunset=>"2020-11-08T15:37:42.000-07:00",
         :temperature=>59.68,
         :feels_like=>56.53,
         :humidity=>76,
         :uvi=>2.96,
         :visibility=>10000,
         :conditions=>"clear sky",
         :icon=>"01n"},
       :daily_weather=>
        [{:date=>"2020-11-09",
          :sunrise=>"2020-11-09T05:23:19.000-07:00",
          :sunset=>"2020-11-09T15:36:46.000-07:00",
          :max_temp=>72.66,
          :min_temp=>56.64,
          :conditions=>"light rain",
          :icon=>"10d"},
         {:date=>"2020-11-10",
          :sunrise=>"2020-11-10T05:24:27.000-07:00",
          :sunset=>"2020-11-10T15:35:52.000-07:00",
          :max_temp=>69.75,
          :min_temp=>56.57,
          :conditions=>"light rain",
          :icon=>"10d"},
         {:date=>"2020-11-11",
          :sunrise=>"2020-11-11T05:25:36.000-07:00",
          :sunset=>"2020-11-11T15:34:59.000-07:00",
          :max_temp=>54.3,
          :min_temp=>41.05,
          :conditions=>"light rain",
          :icon=>"10d"},
         {:date=>"2020-11-12",
          :sunrise=>"2020-11-12T05:26:44.000-07:00",
          :sunset=>"2020-11-12T15:34:08.000-07:00",
          :max_temp=>52.84,
          :min_temp=>36.48,
          :conditions=>"clear sky",
          :icon=>"01d"},
         {:date=>"2020-11-13",
          :sunrise=>"2020-11-13T05:27:52.000-07:00",
          :sunset=>"2020-11-13T15:33:19.000-07:00",
          :max_temp=>55.11,
          :min_temp=>37.2,
          :conditions=>"clear sky",
          :icon=>"01d"}],
       :hourly_weather=>
        [{:time=>"21:00:00", :temperature=>59.18, :wind_speed=>"6.29 mph", :wind_direction=>"from SE", :conditions=>"clear sky", :icon=>"01n"},
         {:time=>"22:00:00", :temperature=>58.26, :wind_speed=>"6.35 mph", :wind_direction=>"from SE", :conditions=>"clear sky", :icon=>"01n"},
         {:time=>"23:00:00", :temperature=>57.63, :wind_speed=>"6.64 mph", :wind_direction=>"from SE", :conditions=>"clear sky", :icon=>"01n"},
         {:time=>"00:00:00", :temperature=>57.02, :wind_speed=>"5.68 mph", :wind_direction=>"from SE", :conditions=>"clear sky", :icon=>"01n"},
         {:time=>"01:00:00", :temperature=>56.62, :wind_speed=>"5.14 mph", :wind_direction=>"from SE", :conditions=>"clear sky", :icon=>"01n"},
         {:time=>"02:00:00", :temperature=>56.5, :wind_speed=>"5.06 mph", :wind_direction=>"from SE", :conditions=>"clear sky", :icon=>"01n"},
         {:time=>"03:00:00", :temperature=>56.39, :wind_speed=>"4.85 mph", :wind_direction=>"from SE", :conditions=>"clear sky", :icon=>"01n"},
         {:time=>"04:00:00", :temperature=>56.35, :wind_speed=>"4.76 mph", :wind_direction=>"from SE", :conditions=>"clear sky", :icon=>"01n"}]}}}
    
  • Fields in Response
    Attribute Definition
    datetime current date and time
    sunrise date and time of sunrise
    sunset date and time of sunset
    temperature temp in Fahrenheit
    feels_like temp in Fahrenheit
    humidity humidity percentage
    uvi midday UV index
    visibility average visibility in meters
    conditions description of weather
    icon weather icon
    date date at forecast
    max_temp max daily temp
    min_temp min daily temp
    time time at forecast
    wind_speed speed in mph
    wind_direction cardinal direction of wind

Get Location Background Image

Returns a background image for a given location

  • Requirements for use:

  • Required parameters:

    • location: location (ex: 'New York, NY')
  • Example request: GET https://sweater-weather-lriff.herokuapp.com/api/v1/backgrounds?location=new%20york,%20new%20york

  • Example response:

    {
      "data": {
        "id": null,
        "type": "image",
        "attributes": {
          "description": null,
          "url": "https://images.unsplash.com/photo-1553484604-9f524520c793?ixlib=rb-1.2.1&q=80&fm=jpg&crop=entropy&cs=tinysrgb&w=1080&fit=max&ixid=eyJhcHBfaWQiOjE4MTA0N30",
          "credits": {
            "artist_username": "capdfrawy",
              "artist_name": "CapDfrawy",
              "profile_url": "https://unsplash.com/@capdfrawy"
          }
        }
      }
    }
    
  • Fields in Response

    Attribute Definition
    description artist provided description of photo
    url link to photo
    artist_username artist's Unsplash username
    artist_name artist's first and last name
    profile_url link to artist's Unsplash profile

User Management: Register New User

Register a new user and generate their API key

  • Required arguments:

    • Send user information as JSON payload in body of the request
      • email
      • password
      • password confirmation
  • Example request:

    POST https://sweater-weather-lriff.herokuapp.com/api/v1/users
    Content-Type: application/json
    Accept: application/json
    
    {
      'email': 'user@example.com',
      'password': 'password',
      'password_confirmation': 'password'
    }
    
  • Example response:

    {
        "data": {
            "id": "3",
            "type": "users",
            "attributes": {
                "email": "user@example.com",
                "api_key": "d4982803-cdb8-461a-a3f6-e4ce334eeaee"
            }
        }
    }
    
  • Fields in Response

    Attribute Definition
    email user's email
    api_key user's unique api key

User Management: Login User

Login user and return their API key

  • Required arguments:

    • Send user information as JSON payload in body of the request
      • email
      • password
  • Example request:

    POST https://sweater-weather-lriff.herokuapp.com/api/v1/sessions
    Content-Type: application/json
    Accept: application/json
    
    {
      "email": "whatever@example.com",
      "password": "password"
    }
    
  • Example response:

    {
        "data": {
            "id": "3",
            "type": "users",
            "attributes": {
                "email": "user@example.com",
                "api_key": "d4982803-cdb8-461a-a3f6-e4ce334eeaee"
            }
        }
    }
    
  • Definition of Attributes

    Attribute Definition
    email user's email
    api_key user's unique api key

Create Roadtrip

Posts a new roadtrip for a user and returns origin, destination, duration and weather info upon arrival

  • Required arguments:

    • Send user information as JSON payload in body of the request
      • origin
      • destination
      • api_key
  • Example request:

    POST https://sweater-weather-lriff.herokuapp.com/api/v1/road_trip
    Content-Type: application/json
    Accept: application/json
    
    {
      'origin': 'Denver, CO',
      'destination': 'Los Angeles, CA',
      'api_key': 'jgn983hy48thw9begh98h4539h4'
    }
    
  • Example response:

    {
      "data": {
        "id": null,
        "type": "roadtrip",
        "attributes": {
          "start_city": "Denver, CO",
          "end_city": "Los Angeles, CA",
          "travel_time": "14:30:48"
          "weather_at_eta": {
            "temperature": 63,
            "conditions": "winds light and variable"
          }
        }
      }
    }
    
  • Fields in Response

    Attribute Definition
    start_city origin location
    end_city destination location
    travel_time total time of estimated travel
    temperature forecasted temp in Fahrenheit at time of arrival
    conditions description of forecasted weather at time of arrival

Database Schema


Organizational Design

  • Implemented facades as the middle-layer between controllers and services
    • They send plain old Ruby objects (POROs) to the controller
  • Utilized services as the middle-layer between facades and external API or database calls
Facades:
  • Forecast
  • Image
  • Road Trip
  • User
Services:
  • Image (hits Unsplash API)
  • Map (hits MapQuest API)
  • Weather (hits OpenWeather API)

Next Steps

  • Allow user to fetch weather at ETA even if trip duration is over 48 hours
    • The Open Weater API currently returns the hourly forecast for 48 hours but by also using the daily forecast this call provides, I could return forecasted weather at ETA for a trip up to 7 days
  • Convert datetime fields to UTC to avoid timezone issues
  • Implement caching for certain data points (latitude, longitude, etc.)
  • Allow user to add parameters to endpoints to designate response in imperial vs. metric units

Author