Skip to content

Latest commit

 

History

History
82 lines (60 loc) · 4.37 KB

README.md

File metadata and controls

82 lines (60 loc) · 4.37 KB

the-starry-night

CircleCI

REST api written in golang that indicates whether the ISS is visible overhead

sequenceDiagram
    participant C as Client
    participant A as App
    participant W as WeatherBit
    participant ISS as ISS Now
    C->>A: /iss-position
    par App to Weather API
        A->>+W: get weather
        W-->>-A: weather
    and App to ISS API
        A->>+ISS: get ISS location
        ISS-->>-A: ISS location
    end
    A-->>C: response
Loading

Build

  1. To build executable run make from the root directory
  2. To run the compiled binary run ./main

An api key from weatherbit.io is necessary to run this application.

This API key should must be configured using an environment variable WEATHER_BIT_API_KEY

For local development & convenience you can create a settings_private.yaml to store the api key, to create the file run make create-settings-private

This file is in the gitignore and should not be committed

command
Build then run app WEATHER_BIT_API_KEY=your-api-key; make start
Watch files then auto-compile then start WEATHER_BIT_API_KEY=your-api-key; make dev

Configuration

The default values are loaded from settings.yaml and can be overridden by environment variables

Description ENV VARIABLE DEFAULT VALUE Required
Port that application listen on SERVER_PORT 8080
Logging level, options are "DEBUG", "INFO", "WARN" & "ERROR" LOG_LEVEL INFO
ISS Rest API URL ISS_API_URL http://api.open-notify.org/iss-now.json
Weatherbit Rest API key WEATHER_BIT_API_KEY: none yes
Weatherbit Rest API base URL WEATHER_BIT_API_BASE_URL: https://api.weatherbit.io/v2.0
Threshold value over which visibility is considered possible CLOUD_COVER_THRESHOLD 30
How many decimal places of accuracy to use to consider ISS overhead ACCURACY_NUM_DECIMAL_PLACES 4

Prerequisites

Dependency Installation Optional
go (min v1.17)
go-swagger installation
golangci-lint installation
air run: go install github.com/cosmtrek/air@latest *
richgo run: go install github.com/kyoh86/richgo@v0.3.10 *

To check if you have the required dependencies installed run make check.dependencies

To set up git hooks run make setup-git-hooks

Tests

  • To run unit tests run make test
  • To view unit test coverage breakdown in html run make test.html-report
  • To run integration tests run make test.integration (ensure the app is running before running integration tests)

API documentation

Rest API documentation is auto-generated by go-swagger