Skip to content

Commit

Permalink
[automated commit] Bump docs to version 1.14.2
Browse files Browse the repository at this point in the history
  • Loading branch information
leorossi authored and github-actions[bot] committed Dec 7, 2023
1 parent 1c7a122 commit 9cc9244
Show file tree
Hide file tree
Showing 156 changed files with 427 additions and 4 deletions.
293 changes: 293 additions & 0 deletions versioned_docs/version-1.14.2/guides/api-versioning.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,293 @@
# Versionize a Platformatic application

## Introduction

Platformatic applications support versioning of the API without the need to deploy a new application for each version. Every time you bump a new API version of your application platformatic calculates the diff between the previous and current versions and maps API routes to the current one. In cases when it's not possible to automatically map the routes, platformatic generates a mapper plugin that can be used to map the routes manually or generated automatically by OpenAI. As a result, you have a single instance of the application that handles all the requests.

## Setup platformatic application versioning

### Setup the application

Lets start with a basic platformatic service application that can be generated by running `create-platformatic` command.

```bash
npx create-platformatic@latest
```

Lets add a new route to the application that will be used to test the versioning. Add the following code to the `routes/root.js` file.

```js
fastify.get('/users', {
schema: {
response: {
200: {
type: 'array',
items: {
type: 'object',
properties: {
id: { type: 'number' },
name: { type: 'string' }
}
}
}
}
}
}, async (request, reply) => {
return [
{ id: 1, name: 'Larry Lute' },
{ id: 2, name: 'Marcus Miller' },
{ id: 3, name: 'Devin Booker' }
]
})
```

It's important to add the `schema` property to the route definition. Platformatic uses the OpenAPI schema to find the differences between the versions.

You can start the application and test that the route is working as expected.

```bash
npx platformatic@latest start
```

Testing `/users` route:

```bash
curl http://localhost:3042/users
```

Response:

```json
[
{
"id": 1,
"name": "Larry Lute"
},
{
"id": 2,
"name": "Marcus Miller"
},
{
"id": 3,
"name": "Devin Booker"
}
]
```

### Bump the first API version

Now when we have a basic application we can bump the first API version. To do that we need to run the following command:

```bash
npx platformatic@latest service versions bump
```

It will create a first version of the application `v1` and will map all the routes to the current version. If you start the application, you will see that now the route is available under the `/v1/users` path. If you want to create a different version name you can use the `--version` option.

Testing `/v1/users` route:

```bash
curl http://localhost:3042/v1/users
```
```
[
{
"id": 1,
"name": "Larry Lute"
},
{
"id": 2,
"name": "Marcus Miller"
},
{
"id": 3,
"name": "Devin Booker"
}
]
```

**API "v1" swagger page**
![Platformatic versions guide: "v1" swagger screenshot](./images/versions-1.png)

### Bump the second API version

Now when we have the first version of the application we can bump the second version. To do that we need to run the same command as before:

```bash
npx platformatic@latest service versions bump
```

It will create a second version of the application `v2` and will map all the routes to the current version. If you start the application, you will see that now the same under `/v1/users` and `/v2/users` paths. These routes were mapped automatically because the OpenAPI schema was the same for both versions.


Testing `/v2/users` route:

```bash
curl http://localhost:3042/v2/users
```
```bash
[
{
"id": 1,
"name": "Larry Lute"
},
{
"id": 2,
"name": "Marcus Miller"
},
{
"id": 3,
"name": "Devin Booker"
}
]
```

**API "v2" swagger page**
![Platformatic versions guide: "v2" swagger screenshot](./images/versions-2.png)

### Update the second API version

Lets make some changes to the latest version of the application. Lets modify the `/users` route in a following way:


```js
fastify.get('/users', {
schema: {
response: {
200: {
type: 'array',
items: {
type: 'object',
properties: {
id: { type: 'number' },
firstName: { type: 'string' },
lastName: { type: 'string' }
}
}
}
}
}
}, async (request, reply) => {
return [
{ id: 1, firstName: 'Larry', lastName: 'Lute' },
{ id: 2, firstName: 'Marcus', lastName: 'Miller' },
{ id: 3, firstName: 'Devin', lastName: 'Booker' }
]
})
```

Now the route returns the `firstName` and `lastName` instead of the `name`. Lets update the second version of the application to reflect the changes. To do that we need to run the following command:

```bash
npx platformatic@latest service versions update
```

Having that now the second version of the route can't be mapped automatically, platformatic will generate a mapper plugin that can be used to map the routes manually or generated automatically by OpenAI. The mapper plugin will be generated in the `versions/v1/get-users.js` file.

In the mappers plugin you can find a lot of useful information about the changes and code that proxies the "v1" route to the "v2" route. All you need to do is to update the `mapOutputData200` function to map the response from the "v2" route to the "v1" route.

```js
function mapOutputData200 (outputData) {
const mappedBody = outputData.responseBody.map((user) => {
return {
id: user.id,
name: `${user.firstName} ${user.lastName}`
}
})

return {
headers: outputData.headers,
responseBody: mappedBody
}
}
```

Now when you start the application and see that the `/v1/users` route returns response with the `name` property when the `/v2/users` route returns response with the `firstName` and `lastName` properties.

Testing `/v1/users` route:

```bash
curl http://localhost:3042/v1/users
```
```bash
[
{
"id": 1,
"name": "Larry Lute"
},
{
"id": 2,
"name": "Marcus Miller"
},
{
"id": 3,
"name": "Devin Booker"
}
]
```

![Platformatic versions guide: "v1" updated swagger screenshot](./images/versions-1.png)

Testing `/v2/users` route:

```bash
curl http://localhost:3042/v2/users
```
```bash
[
{
"id": 1,
"firstName": "Larry",
"lastName": "Lute"
},
{
"id": 2,
"firstName": "Marcus",
"lastName": "Miller"
},
{
"id": 3,
"firstName": "Devin",
"lastName": "Booker"
}
]
```

**API "v2" swagger page**
![Platformatic versions guide: "v2" updated swagger screenshot](./images/versions-3.png)

### Generating the mapper plugin with OpenAI

Platformatic supports generating the mapper plugin automatically using the OpenAI. Before doing make sure that you have a platformatic user API key. If not you can generate it by running the following command:

```bash
npx platformatic@latest login
```

Now when you have the API key you can generate the mapper plugin by running the following command:

```bash
npx platformatic@latest service versions update --openai
```

It will update the same mapper plugin as before but this time it will use OpenAI to generate the request and response mappers. You should always be careful and check the generated code. In my case OpenAI generated the following code for the same `mapOutputData200` function:

```js
// !!! This function was generated by OpenAI. Check before use !!!
function mapOutputData200 (output) {
const mappedOutput = {
headers: {},
responseBody: output.responseBody.map(item => ({
id: item.id,
name: `${item.firstName} ${item.lastName}`
}))
}
return mappedOutput
}
```

As you can see the code is a little bit different but the result is the same. You can use the code generated by OpenAI or write your own.

### Shared routes

Sometimes you may want to have a route that is shared between all the versions. For example, you may want to have a `/health` route that is available under all the versions. To do that you need to set the plugin with this route in the platformatic `plugins` config section rather than in the `versions` config section.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
Expand Up @@ -762,9 +762,12 @@ You can find more details about the configuration format here:
Available commands:

* `help` - show this help message.
* `help <command>` - shows more information about a command.
* `help <command>` - show more information about a command.
* `start` - start the server.
* `schema config` - generate the schema configuration file.
* `compile` - compile the typescript files.
* `versions bump` - bump a new version of the API.
* `versions update` - update the latest version of the API.


#### schema
Expand Down Expand Up @@ -807,6 +810,62 @@ save the following as `platformatic.service.json`:
```


#### versions bump

Bump a new version of platformatic application API.

``` bash
$ platformatic service versions bump
```

As a result, a new application API version will be created, and mappers for the previous version will be generated.

Options:

* `-c, --config <path>` - Path to the configuration file.
* `-v, --version <string>` - The name of the version to bump. Default: if first version, then `v1`, else `vX`.
* `-p, --prefix <string>` - The prefix to use for the new version. Default: if first version, then `/v1`, else `/vX`.
* `--openai` - Use OpenAI to generate the version mappers plugins. Default: false.
* `--user-api-key <string>` - Platformatic user API key. If not specified, the key will be loaded from the `~/.platformatic/config` file.

If not specified, the configuration will be loaded from any of the following, in the current directory.

* `platformatic.db.json`, or
* `platformatic.db.yml`, or
* `platformatic.db.tml`

You can find more details about the configuration format here:
* [Platformatic DB Configuration](https://docs.platformatic.dev/docs/reference/db/configuration)



#### versions update

Update the latest version of platformatic application API.

``` bash
$ platformatic service versions update
```

As a result, the latest application API version will be updated, and mappers for the previous version will be generated.

Options:

* `-c, --config <path>` - Path to the configuration file.
* `--openai <boolean>` - Use OpenAI to generate the version mappers plugins. Default: false.
* `--user-api-key <string>` - Platformatic user API key. If not specified, the key will be loaded from the `~/.platformatic/config` file.

If not specified, the configuration will be loaded from any of the following, in the current directory.

* `platformatic.db.json`, or
* `platformatic.db.yml`, or
* `platformatic.db.tml`

You can find more details about the configuration format here:
* [Platformatic DB Configuration](https://docs.platformatic.dev/docs/reference/db/configuration)



### frontend

```bash
Expand Down
Loading

0 comments on commit 9cc9244

Please sign in to comment.