Skip to content

Commit

Permalink
openapi: doc
Browse files Browse the repository at this point in the history
  • Loading branch information
eguzki committed Dec 10, 2018
1 parent d684939 commit 27a948e
Show file tree
Hide file tree
Showing 2 changed files with 91 additions and 0 deletions.
9 changes: 9 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
* [Copy a service](#copy-a-service)
* [Update a service](#update-a-service)
* [Import from CSV](#import-from-csv)
* [Import from OpenAPI definition](#import-openapi)
* [Development](#development)
* [Plugins](#plugins)
* [Troubleshooting](#troubleshooting)
Expand Down Expand Up @@ -170,6 +171,14 @@ Example:
3scale import csv --destination=https://[email protected] --file=examples/import_example.csv
```

### Import OpenAPI

Using an API definition format like OpenAPI, import to your 3Scale API

Currently, only OpenAPI __2.0__ specification (f.k.a. __swagger__) is supported.

[Import from OpenAPI](docs/openapi.md)

## Development

After checking out the repo, run `bin/setup` to install dependencies. You can also run `bin/console` for an interactive prompt that will allow you to experiment. Run `bundle exec 3scale` to use the gem in this directory, ignoring other installed copies of this gem.
Expand Down
82 changes: 82 additions & 0 deletions docs/openapi.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
## Import API definition to 3scale from OpenAPI definition

Features:

* OpenAPI __2.0__ specification (f.k.a. __swagger__)
* Create a new service. New service name will be taken from openapi definition `info.title` field.
* Update existing service, providing `SERVICE_ID` with `--service` option.
* Create methods in the 'Definition' section. Method names are taken from `operation.operationId` field.
* Attach newly created methods to the *Hits* metric.
* Create mapping rules and show them under `API > Integration`.
* Perform schema validation.
* OpenAPI definition resource can be provided by one of the following channels:
* *Filename* in the available path.
* *URL* format. Toolbox will try to download from given address.
* Read from *stdin* standard input stream.

### Usage

```shell
$ 3scale import openapi -h
NAME
openapi - Import API defintion in OpenAPI specification

USAGE
3scale import openapi [opts] -d <dst> <spec>

DESCRIPTION
Using an API definition format like OpenAPI, import to your 3Scale API

OPTIONS
-d --destination=<value> 3scale target instance. Url or
remote name
-s --service=<value> <service_id> of your 3Scale account

OPTIONS FOR IMPORT
-c --config-file=<value> 3scale CLI configuration file (default:
/home/eguzki/.3scalerc.yaml)
-h --help show help for this command
-k --insecure Proceed and operate even for server
connections otherwise considered insecure
-v --version Prints the version of this command
```

### Create new service

```shell
$ 3scale import openapi -d <destination> <openapi_resource>
```

### Update existing service

`SERVICE_ID` is required.

```shell
$ 3scale import openapi --service <SERVICE_ID> -d <destination> <openapi_resource>
```

### OpenAPI definition from filename in path

Allowed formats are `json` and `yaml`. Format is automatically detected from filename __extension__.

```shell
$ 3scale import openapi -d <destination> /path/to/your/spec/file.[json|yaml|yml]
```

### OpenAPI definition from URI

Allowed formats are `json` and `yaml`. Format is automatically detected from URL's path __extension__.

```shell
$ 3scale import openapi -d <destination> http[s]://domain/resource/path.[json|yaml|yml]
```

### OpenAPI definition from stdin

Command line parameter for the openapi resource is `-`.

Allowed formats are `json` and `yaml`. Format is automatically detected internally with parsers.

```shell
$ tool_to_read_openapi_from_source | 3scale import openapi -d <destination> -
```

0 comments on commit 27a948e

Please sign in to comment.