crystal-demo
CrystalDemo
Sample API using IMDB database.
Database
This project uses IMDB database. It does not import from list files.
To import IMDB database we recommend IMDbPy.
Warning: This software and the authors have no rights to give you any permission to use IMDB data.
Usage
In order not to change the schema of the database the auth is managed by the table name
using just md5sum
to match a user.
This way if you are importing the list files from IMDB you already have 6064219 users.
Get your user, for example:
postgres@pgsrv:/$ psql imdb
psql (9.6.2)
Type "help" for help.
imdb=# select id,md5sum from name limit 1;
id | md5sum
-----+----------------------------------
719 | cf45e7b42fbc800c61462988ad1156d2
(1 row)
imdb=#
And the next requests:
% curl -i -H "Authorization: Token token:cf45e7b42fbc800c61462988ad1156d2" "http://localhost:3000/titles?page=100"
HTTP/1.1 200 OK
Connection: keep-alive
X-Powered-By: Kemal
Content-Type: text/html
Content-Length: 839
[{"id":4218231,"title":"Tony Robinson and...","kind":{"name":"tv series","id":2}},{"id":4218230,"title":"Wonders of the Universe","kind":{"name":"tv series","id":2}},{"id":4218229,"title":"(1955-11-01)","kind":{"name":"episode","id":7}},{"id":4218228,"title":"(1954-11-01)","kind":{"name":"episode","id":7}},{"id":4218227,"title":"Yagyu bugeicho - Ninjitsu","kind":{"name":"movie","id":1}},{"id":4218226,"title":"Why Dunblane?","kind":{"name":"episode","id":7}},{"id":4218225,"title":"The Siege of Kontum","kind":{"name":"episode","id":7}},{"id":4218224,"title":"The Quiet Mutiny","kind":{"name":"episode","id":7}},{"id":4218223,"title":"The Man Who Stole Uganda","kind":{"name":"episode","id":7}},{"id":4218222,"title":"The Life and Death of Steve Biko","kind":{"name":"episode","id":7}}]
If you don't provide your token:
% curl -i "http://localhost:3000/titles?page=100"
HTTP/1.1 403 Forbidden
Connection: keep-alive
X-Powered-By: Kemal
Content-Type: text/html
Content-Length: 35
{"error":403,"message":"Forbidden"}
POST create
:
curl -i --data '{"title":"Ghost","kind_id":1,"production_year":2007}' -H "Content-Type: application/json" -H "Authorization: Token token:cf45e7b42fbc800c61462988ad1156d2" "http://localhost:3000/titles"
HTTP/1.1 200 OK
Connection: keep-alive
X-Powered-By: Kemal
Content-Type: application/json
Content-Length: 60
{"title":"Ghost","kind_id":1,"production_year":2007,"id":93}
List of endpoints
GET /current_user
;GET /titles
, params:page
(optional);POST /titles
, content type: "application/json, params:title
(required),kind_id
(required),production_year
(required);PUT /titles/:id
, content type: "application/json, params:id
(required),title
(required),kind_id
(required),production_year
(required);
Development
Run:
% DATABASE_URL=postgres://postgres@localhost:5432/imdb crystal ./src/crystal_demo.cr
Production
Build an optimized release with:
% crystal build --release ./src/crystal_demo.cr -o bin/app
Copy the binary to server and run your app:
% DATABASE_URL=postgres://postgres@localhost:5432/imdb PORT=80 ./app
Heroku
Use the following commands to create an app in heroku with Crystal's buildpack:
% heroku login
% heroku create --buildpack https://github.com/crystal-lang/heroku-buildpack-crystal.git
% heroku addons:create heroku-postgresql:hobby-dev
% git push heroku master
You have to import IMDB database to heroku as well, but if you are just testing follow the instructions bellow to create a minimal database with minimal data:
-
Run migrations:
% DATABASE_URL=postgres://user:pass@ec2-66-66-66-66.compute-1.amazonaws.com:5432/db123kd6i30pac ./bin/migrate up
-
Connect to database to insert initial data:
% psql "postgres://user:pass@ec2-66-66-66-66.compute-1.amazonaws.com:5432/db123kd6i30pac" psql (9.6.1, server 9.6.2) SSL connection (protocol: TLSv1.2, cipher: ECDHE-RSA-AES256-GCM-SHA384, bits: 256, compression: off) Type "help" for help.
db522kd6i30pac=> insert into name (name, md5sum) values ('John', 'cf45e7b42fbc800c61462988ad1156d2'); INSERT 0 1
Now everthing is ready in Heroku.
Tests
This project uses IMDB database, in order to run the tests you have to migrate the test database:
% createdb imdb_test
% DATABASE_URL=postgres://postgres@localhost:5432/imdb_test ./bin/migrate up
And run the test suite with:
% DATABASE_URL=postgres://postgres@localhost:5432/imdb_test crystal spec
Contributing
- Fork it
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
Contributors
- dmitryrck Dmitry Rocha - creator, maintainer
crystal-demo
- 9
- 1
- 1
- 0
- 3
- over 7 years ago
- April 27, 2017
MIT License
Tue, 21 Jan 2025 16:50:55 GMT