Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/timwis/static-api
Creates a static API from a CSV file
https://github.com/timwis/static-api
Last synced: about 1 month ago
JSON representation
Creates a static API from a CSV file
- Host: GitHub
- URL: https://github.com/timwis/static-api
- Owner: timwis
- Created: 2016-03-03T12:40:02.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2016-08-01T18:26:31.000Z (over 8 years ago)
- Last Synced: 2024-12-30T18:11:54.022Z (about 2 months ago)
- Language: Ruby
- Homepage: http://timwis.github.io/static-api/sample-data.json
- Size: 205 KB
- Stars: 29
- Watchers: 2
- Forks: 4
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Static API [data:image/s3,"s3://crabby-images/61a97/61a9712ba276967e3c7b1860efde7d0dbf2f5365" alt="Build Status"](https://travis-ci.org/timwis/static-api)
Creates a static API from a CSV file and publishes it to a static web server using Travis CI.
Inspired by @waldoj's [instant-api](https://github.com/waldoj/instant-api).Animals.csv
```csv
Name, Animal, Color
Fido, Dog, Brown
Whiskers, Cat, Black
Mini, Elephant, Grey
```
becomes
```
/animals.json
[
{"Name": "Fido", "Animal": "Dog", ...},
{"Name": "Whiskers", ...}
...
]/animals/fido.json
{"Name": "Fido", "Animal": "Dog", ...}/animals/whiskers.json
{"Name": "Whiskers", ...}
```# Example
The example file in this repository, [sample_data.csv](sample_data.csv), is automatically
published to the [gh-pages branch](https://github.com/timwis/static-api/tree/gh-pages)
by [Travis CI](https://travis-ci.org/timwis/static-api) and can thus be viewed at
[timwis.github.io/static-api/sample-data.json](http://timwis.github.io/static-api/sample-data.json),
[/sample-data/23.json](http://timwis.github.io/static-api/sample-data/23.json), etc..# Manual Usage
1. Clone this repository
2. run `bundle install` to install dependencies
3. Execute via command line using an environment variable
```bash
PRIMARY_KEY= ruby static-api.rb
```# Automated Usage via Travis CI
1. Fork this repository
2. Enable Travis CI integration for your fork on the [travis dashboard](https://travis-ci.org/profile)
3. Generate a new GitHub [personal access token](https://github.com/settings/tokens/new) (with `public_repo` access)
4. On the Travis CI settings page for your fork (travis-ci.org/your-username/static-api/settings),
add your new personal access token as an environment variable with the name `GITHUB_TOKEN`.
Do **not** enable the "Display value in build log" toggle (it's disabled by default).
5. Add another environment variable called `PRIMARY_KEY` set to the field name to use as the CSV file's primary key.
6. Add your `.csv` file to your fork by [drag-and-dropping](https://github.com/blog/2105-upload-files-to-your-repositories),
using [prose.io](http://prose.io)'s [CSV editor](https://github.com/prose/prose/pull/911), or using
traiditional git and push your changes to the `master` branch (default).Travis CI will be triggered by a push to the `master` branch, build your Static API, and push it
to the `gh-pages` branch, allowing you to view it at `username.github.io/repo-name/file_name.json`**Hey,** do you have thoughts on a better way to use this? [Join the conversation!](https://github.com/timwis/static-api/issues/8)