Intro
So you're new to Praxis, you've read some of the interesting stuff that it can do and you're ready to see it in action? Great! You're in the right place.
Let's show you how easy it is to create a fully functioning API from scratch, capable of serving posts (that are authored by users), each of which can contain comments where each comment is also made by one of the existing users. We'll design and build it from soup to nuts, from being able to query the API for Posts, with filtering, sorting and pagination, to being able to create, update and delete the Posts as well.
To simplify the setup, we will use an embedded SQLite DB, but you can easily configure the app to work with MySQL or PostgreSQL later if you'd like.
The fastest way to start is to create a simple Praxis application example. To do so, let's use the Praxis
example app generator to build us one. We'll call it firstapp
:
gem install praxis # Let's make sure we have Praxis 2.x installed in the system
praxis example firstapp && cd firstapp
bundle
This example Praxis app is a very simple API that is able to list users stored in a DB, which have only a few attributes defined (i.e., id, uuid, email, first_name and last_name). That's it, there is not much in there, but at least it has the basic directory structure, Gemfile, etc.
Ok so at this point we already have a fully bundled Praxis app. We can now create, migrate and populate its DB with some users, and then we can trivially start it up on port 9292 with bundle exec rake db:recreate && bundle exec rackup
.
If you are curious about what you just started, you can test it out by getting the list of all populated users by issuing the following curl command from a different shell:
# Get all Users in the DB
# Note that api version can also be requested through an X-Api-Version header
curl 'http://localhost:9292/users?api_version=1'
Alright then. We have a basic app scaffold and some users in a database. Seems like a good starting point to build on. Let's stop our server (CTRL-C) for now, and start building our Posts and Comments API.