Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat!: split out definitions #128

Merged
Merged
Show file tree
Hide file tree
Changes from 44 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
f72a1b9
Initial definitions
jonaslagoni Nov 11, 2021
f2428ce
Changed indentation to 2 char spaces
jonaslagoni Nov 11, 2021
bb8c0ce
Moved definition files
jonaslagoni Nov 11, 2021
8f684d1
Added $id to all files used for later bundling
jonaslagoni Nov 13, 2021
a78e012
Fixed regex problems and id's
jonaslagoni Nov 16, 2021
9dc083a
Moved definition files and replaced 2.2.0 schema with bundled example
jonaslagoni Nov 16, 2021
93f43c7
Merge branch 'master' into feature/improve_maintainability
jonaslagoni Nov 24, 2021
dcc9576
Added bundler to generate assets
jonaslagoni Nov 25, 2021
8ef1274
Removed unused file
jonaslagoni Nov 25, 2021
2309079
Added docs and comments
jonaslagoni Nov 25, 2021
462592e
Correct bundling behavior
jonaslagoni Nov 29, 2021
99f943f
Fixed bundler
jonaslagoni Nov 29, 2021
75b2fd9
Fixed id
jonaslagoni Nov 29, 2021
d558af6
Merge branch 'master' into feature/improve_maintainability
jonaslagoni Dec 2, 2021
bd614ac
Added local file ids and refs.
jonaslagoni Dec 6, 2021
788de6d
Reverted asyncapi file
jonaslagoni Dec 7, 2021
6a9995f
added try catch
jonaslagoni Dec 7, 2021
4bf78e4
Fixed URI resolution to not require breaking change.
jonaslagoni Dec 7, 2021
bc1d7ca
Added proper ids and references
jonaslagoni Dec 8, 2021
76e6bd4
Added sh script
jonaslagoni Dec 8, 2021
118d626
Merge branch 'master' into feature/improve_maintainability
jonaslagoni Dec 9, 2021
7910ebb
Updated readme and schemas
jonaslagoni Dec 9, 2021
c899ebc
Removed splitter
jonaslagoni Dec 9, 2021
15409c0
Ensured script checks if version exists
jonaslagoni Dec 9, 2021
b5c438c
Added better readme
jonaslagoni Dec 9, 2021
fe30188
Add migration and readme changes
jonaslagoni Dec 9, 2021
05f58ac
Split and bundled all versions.
jonaslagoni Dec 9, 2021
87c3c59
Merge branch 'master' into feature/improve_maintainability
jonaslagoni Dec 9, 2021
ec3c194
Updated migration guide
jonaslagoni Dec 9, 2021
2917fa3
Fixed tests
jonaslagoni Dec 9, 2021
126582d
Fixed tests
jonaslagoni Dec 9, 2021
54f7ee5
Added file ending to all definitions for consistency
jonaslagoni Dec 10, 2021
3f38322
Apply suggestions from code review
jonaslagoni Dec 10, 2021
dc88790
Apply suggestions from code review
jonaslagoni Dec 10, 2021
2658864
Added migration link in README.md
jonaslagoni Dec 10, 2021
40a636d
Merge branch 'master-github-upstream' into feature/improve_maintainab…
jonaslagoni Feb 2, 2022
e592d07
Applied 2.3.0 to definitions
jonaslagoni Feb 3, 2022
4ef1943
Auto generated the bundled schema
jonaslagoni Feb 3, 2022
f826036
Added build and prepubishOnly script
jonaslagoni Feb 4, 2022
71b9923
Removed bundled schemas
jonaslagoni Feb 4, 2022
5d8adb2
Adapted scripts to build bundled schemas accordingly.
jonaslagoni Feb 4, 2022
2255af7
Re-added schemas
jonaslagoni Feb 7, 2022
3c903ab
Reverted back to old pattern properties format
jonaslagoni Feb 7, 2022
dd45797
Fixed a copy/paste error
jonaslagoni Feb 9, 2022
17c99f9
Add prerelease branch
jonaslagoni Mar 4, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
node_modules
.nyc_output
.vscode
coverage
coverage
28 changes: 27 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
![npm](https://img.shields.io/npm/v/@asyncapi/specs?style=for-the-badge) ![npm](https://img.shields.io/npm/dt/@asyncapi/specs?style=for-the-badge)

> If you are currently using version 2, check out [migration guideline to version 3](./migrations/Migrate%20to%20version%203.md). You might be able to update it without any change.
# AsyncAPI

This package provides all the versions of the AsyncAPI schema.
This is a mono repository, which provides all the JSON Schema documents for validating AsyncAPI documents.

## Installation

Expand Down Expand Up @@ -37,3 +38,28 @@ const asyncapi = versions['1.1.0'];

// Do something with the schema.
```

## Repository structure
This is the current project structure explained.
- [./definitions](./definitions) - contain all the individual schemas that will automatically be bundled together to provide the schemas in [./schemas](./schemas).
- [./tools/bundler](./tools/bundler) - is the tool that bundles all the individual schemas together.
- [./schemas](./schemas) - contain all automatically bundled and complete schemas for each AsyncAPI version. These schemas should **NOT** be manually changed as they are automatically generated. Any changes should be done in [./definitions](./definitions).

## Schema Bundling
Changes should not be done manually to the schemas in [./schemas](./schemas), but instead be done in their individual definitions located in [./definitions](./definitions).

These definitions are automatically bundled together on new releases through the npm script `prepublishOnly`, which ensures the project is build. This is where the [bundler](./tools/bundler) is called.

For example, for [2.2.0](./definitions/2.2.0), the [bundler](./tools/bundler/index.js) starts with the [asyncapi.json](definitions/2.2.0/asyncapi.json) file and recursively goes through all references (`$ref`) to create the [appropriate bundled version](./schemas/2.2.0.json).

### Creating a new version
To create a new version, simply run the following command:
```
npm run startNewVersion --new-version=x.x.x
```
Where `x.x.x` is the new version you want to create.

The manual process of creating a new version is to:
1. Duplicate the latest version (`y.y.y`) under definitions (so we have the correct base to make changes from).
2. Rename the folder to the new version (`x.x.x`).
3. Search and replace in the new duplicated folder for `y.y.y` and replace it with `x.x.x`.
36 changes: 36 additions & 0 deletions definitions/1.0.0/APIKeyHTTPSecurityScheme.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
{
"type": "object",
"required": [
"type",
"name",
"in"
],
"properties": {
"type": {
"type": "string",
"enum": [
"httpApiKey"
]
},
"name": {
"type": "string"
},
"in": {
"type": "string",
"enum": [
"header",
"query",
"cookie"
]
},
"description": {
"type": "string"
}
},
"patternProperties": {
"^x-": {}
},
"additionalProperties": false,
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/APIKeyHTTPSecurityScheme.json"
}
33 changes: 33 additions & 0 deletions definitions/1.0.0/BearerHTTPSecurityScheme.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
{
"type": "object",
"required": [
"type",
"scheme"
],
"properties": {
"scheme": {
"type": "string",
"enum": [
"bearer"
]
},
"bearerFormat": {
"type": "string"
},
"type": {
"type": "string",
"enum": [
"http"
]
},
"description": {
"type": "string"
}
},
"patternProperties": {
"^x-": {}
},
"additionalProperties": false,
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/BearerHTTPSecurityScheme.json"
}
15 changes: 15 additions & 0 deletions definitions/1.0.0/HTTPSecurityScheme.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
{
"oneOf": [
{
"$ref": "http://asyncapi.com/definitions/1.0.0/NonBearerHTTPSecurityScheme.json"
},
{
"$ref": "http://asyncapi.com/definitions/1.0.0/BearerHTTPSecurityScheme.json"
},
{
"$ref": "http://asyncapi.com/definitions/1.0.0/APIKeyHTTPSecurityScheme.json"
}
],
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/HTTPSecurityScheme.json"
}
38 changes: 38 additions & 0 deletions definitions/1.0.0/NonBearerHTTPSecurityScheme.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
{
"not": {
"type": "object",
"properties": {
"scheme": {
"type": "string",
"enum": [
"bearer"
]
}
}
},
"type": "object",
"required": [
"scheme",
"type"
],
"properties": {
"scheme": {
"type": "string"
},
"description": {
"type": "string"
},
"type": {
"type": "string",
"enum": [
"http"
]
}
},
"patternProperties": {
"^x-": {}
},
"additionalProperties": false,
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/NonBearerHTTPSecurityScheme.json"
}
14 changes: 14 additions & 0 deletions definitions/1.0.0/Reference.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"type": "object",
"required": [
"$ref"
],
"properties": {
"$ref": {
"type": "string",
"format": "uri"
}
},
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/Reference.json"
}
11 changes: 11 additions & 0 deletions definitions/1.0.0/SecurityRequirement.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"type": "object",
"additionalProperties": {
"type": "array",
"items": {
"type": "string"
}
},
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/SecurityRequirement.json"
}
24 changes: 24 additions & 0 deletions definitions/1.0.0/SecurityScheme.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
{
"oneOf": [
{
"$ref": "http://asyncapi.com/definitions/1.0.0/userPassword.json"
},
{
"$ref": "http://asyncapi.com/definitions/1.0.0/apiKey.json"
},
{
"$ref": "http://asyncapi.com/definitions/1.0.0/X509.json"
},
{
"$ref": "http://asyncapi.com/definitions/1.0.0/symmetricEncryption.json"
},
{
"$ref": "http://asyncapi.com/definitions/1.0.0/asymmetricEncryption.json"
},
{
"$ref": "http://asyncapi.com/definitions/1.0.0/HTTPSecurityScheme.json"
}
],
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/SecurityScheme.json"
}
23 changes: 23 additions & 0 deletions definitions/1.0.0/X509.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
{
"type": "object",
"required": [
"type"
],
"properties": {
"type": {
"type": "string",
"enum": [
"X509"
]
},
"description": {
"type": "string"
}
},
"patternProperties": {
"^x-": {}
},
"additionalProperties": false,
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/X509.json"
}
31 changes: 31 additions & 0 deletions definitions/1.0.0/apiKey.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
{
"type": "object",
"required": [
"type",
"in"
],
"properties": {
"type": {
"type": "string",
"enum": [
"apiKey"
]
},
"in": {
"type": "string",
"enum": [
"user",
"password"
]
},
"description": {
"type": "string"
}
},
"patternProperties": {
"^x-": {}
},
"additionalProperties": false,
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/apiKey.json"
}
23 changes: 23 additions & 0 deletions definitions/1.0.0/asymmetricEncryption.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
{
"type": "object",
"required": [
"type"
],
"properties": {
"type": {
"type": "string",
"enum": [
"asymmetricEncryption"
]
},
"description": {
"type": "string"
}
},
"patternProperties": {
"^x-": {}
},
"additionalProperties": false,
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://asyncapi.com/definitions/1.0.0/asymmetricEncryption.json"
}
64 changes: 64 additions & 0 deletions definitions/1.0.0/asyncapi.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
{
"title": "AsyncAPI 1.0 schema.",
"id": "http://asyncapi.com/definitions/1.0.0/asyncapi.json",
"$schema": "http://json-schema.org/draft-04/schema#",
"type": "object",
"required": [
"asyncapi",
"info",
"topics"
],
"additionalProperties": false,
"patternProperties": {
"^x-": {
"$ref": "http://asyncapi.com/definitions/1.0.0/vendorExtension.json"
}
},
"properties": {
"asyncapi": {
"type": "string",
"enum": [
"1.0.0"
],
"description": "The AsyncAPI specification version of this document."
},
"info": {
"$ref": "http://asyncapi.com/definitions/1.0.0/info.json"
},
"baseTopic": {
"type": "string",
"pattern": "^[^/.]",
"description": "The base topic to the API. Example: 'hitch'.",
"default": ""
},
"servers": {
"type": "array",
"items": {
"$ref": "http://asyncapi.com/definitions/1.0.0/server.json"
},
"uniqueItems": true
},
"topics": {
"$ref": "http://asyncapi.com/definitions/1.0.0/topics.json"
},
"components": {
"$ref": "http://asyncapi.com/definitions/1.0.0/components.json"
},
"tags": {
"type": "array",
"items": {
"$ref": "http://asyncapi.com/definitions/1.0.0/tag.json"
},
"uniqueItems": true
},
"security": {
"type": "array",
"items": {
"$ref": "http://asyncapi.com/definitions/1.0.0/SecurityRequirement.json"
}
},
"externalDocs": {
"$ref": "http://asyncapi.com/definitions/1.0.0/externalDocs.json"
}
}
}
Loading