RESTool (demo)
The best tool in the neighborhood. Managing your RESTful APIs has never been so easy. RESTool gives you an out of the box UI that connects to your RESTful API with a simple configuration file.
The idea behind it is simple. Given the fact that each entity in your API has a RESTful implementation, RESTool will provide you UI tool for managing these entities in no time by simply editing a configuration file. No front end engineers, no JavaScript, no CSS, no html. Just a simple JSON file.
Live Demo: https://restool-sample-app.herokuapp.com/
Clone RESTool repository to get started.
git clone https://github.com/dsternlicht/RESTool.git
cd RESTool
If you only interesed of using RESTool on its latest version as a management tool for your RESTful API, read the docs about configuration and deployment.
If you wish to extend RESTool's functionallity and develop on top of it, please go to the development section.
One of the best things about RESTool (and the reason we actually we built it) is that you don't need to develop anything. Everything is configurable and may be set simply by editing the config.json
file under the /src
folder.
Here's a detailed list of properties you could add to your configuration file (just in case we added a config-sample.json
file you could learn from).
The name of your app.
A list of pages in your app, each page will be presented as a separated tab, and will have his own methods and properties.
The path within an error response object to look for an error message. If multiple are provided, each will be tried in order until a message is found.
Path to navigate to when the api returns a 401 (Unauthorized) error. You can use :returnUrl
to pass a return location. For example: "/login/myLoginPage?return=:returnUrl"
Base url of the api. This will prefix the url of all the api methods defined for all pages. This is normally the domain plus a base path. For example: "https://restool-sample-app.herokuapp.com/api"
If different pages use different base urls this should not be used. Instead expliclty define full urls for each method.
Each 'page' is an object. And could have the following properties:
The name of the page. Will be presented in the app's menu.
A unique identifier for the page. RESTool will use it to navigate between pages.
A short description about the page and its usage.
Set to true if you want this page to be the first to load in your app. If you haven't marked any page as 'default' we'll just use the first one.
A list of key-value headers you wish to add to every request we're making. For example: { Authentication: 'SECRET_KEY', 'X-USER-ID': 'USER_ID' }
.
A list of all methods which are available in your RESTful API. Available methods:
- get
- post
- put
- post
A list of extra (non RESTful) endpoints available in your RESTful API. Specifically customActions
is a list of PUT or POST method objects. For example this could enable an endpoint like: PUT /users/:id/disable
These use the same format as the method objects defined below.
The default HTTP method used is PUT but this can be overidden using the
actualMethod
parameter.
If
customActions
is not empty then a drop down apears in the Edit Item dialog which allows users to select the action they want to perform.
Each method has the following common properties:
The url for making the request. The url could contain parameters that we'll extract if needed. For example: http://website.com/users/:id
. Note that the parameter name in the url should match the one you're returning in your API. If baseUrl
is defined then only provide the api path. For example: /users/:id
We aware that not everyone implements REST as they should. So if for some reason you need to make a 'post' request in order to update an exiting document, you may use this property.
Same as above, but for specific method.
There are two types of GET requests we support. Get all, and get single. Each one has its own purpose.
We'll use this request in order to a list of items from the API. This type of GET request has the following additional parameters:
Use this field to let us know where we should take the data from. For example, if your server is returning the following JSON object:
{
success: true,
data: []
}
Your data path will be data
.
If your server returning:
{
success: true,
data: {
created: SOME_DATE,
items: []
}
}
Your data path will be data.items
.
An array of query param objects you want to add to your GET request.
If your URL includes the name of the parameter, it will be used as part of the path rather than as a query param. For example if your url is /api/contact/234/address
you might make a parameter called contactId
then set the URL as follows: /api/contact/:contactId/address
.
Each query param item is an object. See Input fields
RESTool is going to present the data somehow. This is the object that defines how. It contains the following properties:
How would you like to present the data (at the moment we only support table view).
One or more paths to properties in the result object to sort the list by.
The list of fields you want to present in your main view. Each one is an object and could have the following properties:
The name of the field that contains the value in the results.
The type of the returning value.
A colorbox
type will render a #RRGGBB hex string as an 80 x 20 pixel colored rectangle, overlaid with the hex color string.
A label that describes the field. Will be presented as table headers in RESTool.
Use this field to let us know what is the path to get to the field value. For example, if this is a single result:
[
{
name: 'Daniel',
email: 'daniel@awesome.com',
details: {
isAwesome: true,
numberOfChildrens: 1
}
},
...
]
And you want to present the numberOfChildrens
field in the display view, your data path for this field is details
, and the name
should be numberOfChildrens
.
Set to true
to enable a text control to do simple client-side filtering by values of this field. Can be specified for multiple fields.
Causes long values to be truncated. By default, truncation is not enabled for fields.
We'll use this type of get request to get a single item. By default, if you won't config this request, when editing an item we'll take the row data from the original "get all" request.
The properties a "get single" request could have are url
, dataPath
, requestHeaders
, and queryParams
.
The list of fields you want us to send as the body of the request. Each one is an object and could have the following properties:
The name of the field/parameter to be sent.
A label that describes the field. This is the label the user will see in the form.
Use this field to let us know what is the path to set to the field value. For example, if the body of the request looks like below:
{
name: 'Daniel',
details: {
thumbnail: {
url: 'http://bit.ly/2fqDxfQ'
}
}
}
So the field name will be url
, the type will be text
, and the data path will be details.thumbnail
.
For POST and PUT pages only.
Use the "type" field to define the type of the field. Available options:
text
- A simple text input (if "type" is not defined, text will be the default).long-text
- A larger text inputobject
- An object type of field (will use JSON.stringify() to present it, and will parse on update).encode
- If you want the value to be encoded before being sent, use this type. GET All page only.integer
- A text box for positive and negative integers.number
- A text box for positive and negative floating point numbers.boolean
- This will render a checkbox.email
- A text box for an email address. Falls back to a simple text input on unsupported browsers.color
- A color selector yielding #RRGGBB hex value strings. Falls back to a simple text input on unsupported browsers.select
- This will render a select box. See options and optionSource propertiesarray
- Enter multiple values. POST and PUT page only.file
- A file-input form element, to upload files asContent-Type: multipart/form-data
. All non-file form inputs will be sent as individual string values. The current implementation supports only one file input per form.password
- A password text boxnote
- A plain text note within the other fields. Usenote
property for text.label
is optional.hidden
- Set to true if you want the value to be sent but not to be editable.
Add the options
field if you chose a select
as a type. This field should contain an array of options to be displayed in the select box.
For example:
fields: [
{
name: 'heroes',
label: 'Select your hero',
type: 'select',
options: ['Spiderman', 'Batman', { display: 'Ironman', value: '324'}]
},
// ...
]
Use the optionSource
field to load options for a select box from a REST service. If this is used with options
, the items from options
will be added to the select box before those fetched from the api.
You can use the following properties on the optionSource
object:
url
- url to fetch data fromdataPath
- let us know where we should take the data fromdisplayPath
- property of the object to take the display value fromvaluePath
- property of the object to take the option value fromsortBy
- one or more properties to sort the objects by
For example:
fields: [
{
name: 'bestFriend',
label: 'Best Friend',
type: 'select',
optionSource: {
url: 'https://restool-sample-app.herokuapp.com/api/character',
dataPath: null,
displayPath: 'name',
valuePath: 'id',
sortBy: ['name']
}
},
// ...
]
For 'array' field type, you should specify another property called arrayType
so we'll how to present & send the data in the POST and PUT pages.
A default value. For GET All query params and POST pages only.
If true, a field will be marked as required on PUT and POST pages.
If true, a field will be displayed, but not editable. It's data will still be added to the PUT request.
If true, a field can be used as a paramter in a PUT url. Otherwise only fields retreived in the original GET can be used as paramters. It's data will still be added to the PUT request body.
An optional setting for type="file"
POST and PUT inputs. When set, the file input's accept property will perform file type filtering when browsing for files.
For example:
"post": {
"url": "/images",
"fields": [
{
"name": "File",
"label": "Upload your image",
"type": "file",
"required": true,
"accept": ".png,.jpeg,image/*"
}
]
},
If you haven't done it already, install all of the project's dependencies by running npm i
.
We used Angular for developing this awesome tool, so make sure you install Angular CLI by running npm install -g @angular/cli
.
- In order to start the development server, run
ng serve
. - Browse to
http://localhost:4200/
. - The app will automatically reload if you change source files.
Once you're ready, run npm run build
to build the project. The build artifacts will be stored in the dist/
folder.
The dist
folder is the one you want to deploy to your server.
- Copy the
dist
folder with all of its content. - Edit the
config.json
file, and add your configuration. - Deploy the
dist
folder to your servers, and make sure you serve theindex.html
file. - Enjoy!
Run ng test
to execute the unit tests via Karma.
Run ng e2e
to execute the end-to-end tests via Protractor.
Before running the tests make sure you are serving the app via ng serve
.
- Daniel Sternlicht
- Oreli Levi
- Jonathan Sellam