Skip to content

the Admin portal for ApiOpenStudio. Here, you can manage your teams, users, clients and create/update and delete resources.

License

Notifications You must be signed in to change notification settings

naala89/apiopenstudio_admin

Repository files navigation

ApiOpenStudio

ApiOpenStudio Public License

Introduction

ApiOpenStudio Admin is an open source product, and contributions are welcome.

At heart, ApiOpenStudio is a complete end to end REST API solution.

This codebase is an add-on to ApiOpenStudio provides a GUI to completely manage your API, users, roles, resources, etc.

More are planned, to allow more choices of GUI and single-page applications, and give the community more choice.

Requirements

The package.json file will need node:13 to install the npm dependencies.

Installation

It assumed that you already have ApiOpenStudio up and running.

The quickest way to install ApiOpenStudio Admin is to create a project with composer:

composer create-project apiopenstudio/apiopenstudio_admin:1.0.0-alpha

Or checkout the repository GitHub mirror:

git clone https://github.com/naala89/api_open_studio_admin

Or checkout the main repository GitLab:

git clone https://gitlab.com/john89/api_open_studio_admin

Serve ApiOpenStudio and admin through api_open_studio_docker or on a server instance.

Setup

If you are serving ApiOpenStudio Admin through docker, you can skip these steps

  • they are automated by docker.
  1. Ensure that you have gulp-cli installed globally:

    npm install --global gulp-cli

  2. Install from composer:

    composer install

  3. Install the npm dependencies:

    npm install

  4. Run gulp:

    gulp

Configuration

cp example.settings.yml settings.yml

Set the following settings as a minimum:

  1. api.url
  2. admin.url
  3. admin.base_path

Hello world

Requirements

You will need:

  • Postman (Download) or similar REST client to view results from your 'hello world' resource.

Create a new account

Login to admin.apiopenstudio.local with your admin account.

Click on "Accounts" in the menu or navigate to the accounts page .

Click on the Plus icon:

Add account

Name new account: "tutorial"

Create tutorial account

You have now created a new top level account:

Tutorial account created

Create a new application

Click on "Applications" in the menu or navigate to applications page.

Click on the Plus icon to create a new application. Assign the application to the "tutorial" account and call it "quick_start".

Create application

You have now created the "quick-start" application that our resource will belong to:

Application created

Configure users and roles

Create a developer role for the new application

Click on "User Roles" in the menu or navigate to roles page.

Click on the plus icon and assign yourself the developer role for

  • Account: tutorial
  • application: quick_start.

Create developer role

You now have permission to create a resource for the newly created quick_start application.

Create a "Hello world!" resource

This resource will display "Hello world!" in the result in whatever format the client requires, and will have security that requires an active token from a user with a developer role. The authentication method will vbe bearer token.

Define the resource name, description, and URL

Fill out the following fields in the interface:

  • Name: Hello world
  • Description: A quick-start hello world resource
    • This is the description of the resource that appears in resources page.
  • Account: tutorial
    • This assigns the resource to the account tutorial.
  • Application: quick_start
    • This assigns the resource to the application quick_start.
  • Method: GET
    • This declares the HTTP method.
  • URI: hello/world
    • This defines the URI fragment for the request that comes after / //. 8 TTL: 30
    • This gives the resource a cache time of 30 seconds.

Resource definition

So far, we have defined a resource that can be called from ( GET) api.apiopenstudio.local/tutorial/quick_start/hello/world.

However, it does nothing and has no security yet.

Define the security

Add the following snippet to the Security section:

function: token_role
id: security
token:
  function: bearer_token
  id: security_token
role: Developer

This calls the processor token_role. We're giving the processor an ID name of "security", so that if there are any bugs we can see where the error is in the result.

The token_role processor requires 2 inpute:

  • token - the requesting user's token.
  • role - the role to validate the requesting user against.

token will use another processor to pass its result into token_role. This is bearer_token. This will return the bearer token value from the request header. We will assign this an ID name of "security_token".

role will not require processing from another processor, because this does not need to be dynamic. So we're using a static string: "Developer".

Resource security

Define the process

Add the following snippet to the Process section:

function: var_str
id: process
value: 'Hello world!'

This will use a single processor: var_str. This processor returns the value of a strictly typed string.

It's input value does not need to be dynamic here, so we're giving it a static string value.

Resource process

Save

Click on the Upload button.

The resource will be parsed and checked for any error, and saved to the database.

If you navigate back to resources page, you should see your new resource.

Resource created

If you click on the download button in the listing for Hello world and select YAML format, it should look like this:

name: 'Hello world'
description: 'A quick-start hello world resource'
uri: hello/world
method: get
appid: 2
ttl: ''
security:
    function: token_role
    id: security
    token:
        function: bearer_token
        id: security_token
    role: Developer
process:
    function: var_str
    id: process
    value: 'Hello world'

You can edit and upload this yaml file as you wish.

Run the new resource

Open up your REST client

Get a new token for your user

User login request header

User login request body

The result should be something similar to:

{
    "token": "13ae430eb19a6651378e22e3a37de8cf",
    "uid": 2
}

Copy the value for the token.

Run Hello world!

The result should be something similar to:

"Hello world!"

Hello world result

If we change the Accept value in the header to application/xml, we will get something similar to:

<?xml version="1.0"?>
<apiopenstudioWrapper>Hello world!</apiopenstudioWrapper>

About

the Admin portal for ApiOpenStudio. Here, you can manage your teams, users, clients and create/update and delete resources.

Resources

License

Stars

Watchers

Forks

Packages

No packages published