Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@asyncapi/avro-schema-parser
Advanced tools
An AsyncAPI schema parser for Avro 1.x schemas.
@asyncapi/avro-schema-parser is an npm package designed to parse Avro schemas within the context of AsyncAPI documents. It allows developers to integrate Avro schema parsing capabilities into their AsyncAPI workflows, enabling seamless schema validation and manipulation.
Parse Avro Schema
This feature allows you to parse an Avro schema string into a JavaScript object. The code sample demonstrates how to use the AvroSchemaParser to parse a simple Avro schema for a 'User' record.
const { AvroSchemaParser } = require('@asyncapi/avro-schema-parser');
const parser = new AvroSchemaParser();
const avroSchema = `{
"type": "record",
"name": "User",
"fields": [
{ "name": "name", "type": "string" },
{ "name": "age", "type": "int" }
]
}`;
parser.parse(avroSchema).then(parsedSchema => {
console.log(parsedSchema);
}).catch(err => {
console.error(err);
});
Validate Avro Schema
This feature allows you to validate an Avro schema string. The code sample demonstrates how to use the AvroSchemaParser to validate a simple Avro schema for a 'User' record.
const { AvroSchemaParser } = require('@asyncapi/avro-schema-parser');
const parser = new AvroSchemaParser();
const avroSchema = `{
"type": "record",
"name": "User",
"fields": [
{ "name": "name", "type": "string" },
{ "name": "age", "type": "int" }
]
}`;
parser.validate(avroSchema).then(() => {
console.log('Schema is valid');
}).catch(err => {
console.error('Schema is invalid:', err);
});
The 'avsc' package is a comprehensive library for working with Avro schemas in JavaScript. It provides functionalities for schema parsing, validation, and serialization/deserialization of Avro data. Compared to @asyncapi/avro-schema-parser, 'avsc' offers a broader range of features for general Avro schema manipulation but does not specifically integrate with AsyncAPI documents.
The 'avro-js' package is another library for working with Avro schemas in JavaScript. It supports schema parsing, validation, and data serialization/deserialization. While 'avro-js' is similar to 'avsc' in terms of functionality, it is known for its ease of use and simplicity. However, it does not provide specific integration with AsyncAPI documents like @asyncapi/avro-schema-parser.
An AsyncAPI schema parser for Avro 1.x schemas.
Note Version >=
3.0.0
of this package is only supported by the@asyncapi/parser
version >=2.0.0
.
npm install @asyncapi/avro-schema-parser
// OR
yarn add @asyncapi/avro-schema-parser
import { Parser } from '@asyncapi/parser';
import { AvroSchemaParser } from '@asyncapi/avro-schema-parser';
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload: # The following is an Avro schema in YAML format (JSON format is also supported)
type: record
name: User
namespace: com.company
doc: User information
fields:
- name: displayName
type: string
- name: email
type: string
- name: age
type: int
`
const { document } = await parser.parse(asyncapiWithAvro);
const { Parser } = require('@asyncapi/parser');
const { AvroSchemaParser } = require('@asyncapi/raml-dt-schema-parser');
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload: # The following is an Avro schema in YAML format (JSON format is also supported)
type: record
name: User
namespace: com.company
doc: User information
fields:
- name: displayName
type: string
- name: email
type: string
- name: age
type: int
import { Parser } from '@asyncapi/parser';
import { AvroSchemaParser } from '@asyncapi/avro-schema-parser';
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload:
$ref: 'https://schemas.example.com/user'
`
const { document } = await parser.parse(asyncapiWithAvro);
const { Parser } = require('@asyncapi/parser');
const { AvroSchemaParser } = require('@asyncapi/raml-dt-schema-parser');
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload:
$ref: 'https://schemas.example.com/user'
`
const { document } = await parser.parse(asyncapiWithAvro);
import { Parser } from '@asyncapi/parser';
import { AvroSchemaParser } from '@asyncapi/avro-schema-parser';
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload:
$ref: 'local/path/to/file/user'
`
const { document } = await parser.parse(asyncapiWithAvro);
const { Parser } = require('@asyncapi/parser');
const { AvroSchemaParser } = require('@asyncapi/raml-dt-schema-parser');
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload:
$ref: 'local/path/to/file/user'
`
const { document } = await parser.parse(asyncapiWithAvro);
import { Parser } from '@asyncapi/parser';
import { AvroSchemaParser } from '@asyncapi/avro-schema-parser';
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload:
$ref: 'https://LY422RBU2HN6JQ5T:+f8wz9a0iM06AX7xfwbzSM9YPw/JIkr22Cvl5EKT5Hb1d/nz5nOpbXV/vZC+Iz5c@example.europe-west3.gcp.confluent.cloud/subjects/test/versions/1/schema'
`
const { document } = await parser.parse(asyncapiWithAvro);
const { Parser } = require('@asyncapi/parser');
const { AvroSchemaParser } = require('@asyncapi/raml-dt-schema-parser');
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload:
$ref: 'https://LY422RBU2HN6JQ5T:+f8wz9a0iM06AX7xfwbzSM9YPw/JIkr22Cvl5EKT5Hb1d/nz5nOpbXV/vZC+Iz5c@example.europe-west3.gcp.confluent.cloud/subjects/test/versions/1/schema'
`
const { document } = await parser.parse(asyncapiWithAvro);
Avro schemas included in parsed AsyncAPI documents are validated using avsc. The parser.validate(...)
function returns all validation issues.
import { Parser } from '@asyncapi/parser';
import { AvroSchemaParser } from '@asyncapi/avro-schema-parser';
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithInvalidAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload:
type: notAValidAvroType
`;
const diagnostics = await parser.validate(doc);
// Custom schema issues are stored by the code "asyncapi-schemas-v2"
const avroDiagnostics = diagnostics.filter(d => d.code === 'asyncapi-schemas-v2');
console.log(avroDiagnostics);
const { Parser } = require('@asyncapi/parser');
const { AvroSchemaParser } = require('@asyncapi/raml-dt-schema-parser');
const parser = new Parser();
parser.registerSchemaParser(AvroSchemaParser());
const asyncapiWithInvalidAvro = `
asyncapi: 2.0.0
info:
title: Example with Avro
version: 0.1.0
channels:
example:
publish:
message:
schemaFormat: 'application/vnd.apache.avro;version=1.9.0'
payload:
type: notAValidAvroType
`;
const diagnostics = await parser.validate(doc);
// Custom schema issues are stored by the code "asyncapi-schemas-v2"
const avroDiagnostics = diagnostics.filter(d => d.code === 'asyncapi-schemas-v2');
console.log(avroDiagnostics);
Note
parser.parse(...)
function also returnsdiagnostics
data with all the validation issues.
Required fields are fields with no default value and without the "null"
union element.
Additional attributes not defined in the Avro Specification are permitted and are treated as a metadata by the specification. To improve human readability of generated AsyncAPI documentation and to leverage more features from the JSON schema we included support for the extra attributes that can be added into Avro document.
example
- Can be used to define the example value from the business domain of given field. Value will be propagated into examples attribute of JSON schema and therefore will be picked for the generated "Example of payload" when using some AsyncAPI documentation generator.For Number instances:
multipleOf
- Can be used to define the multipleOf value of a numeric instance. The multipleOf
MUST be a number, strictly greater than 0.maximum
- Can be used to define the maximum value of a numeric instance.exclusiveMaximum
- Can be used to define the exclusiveMaximum value of a numeric instance.minimum
- Can be used to define the minimum value of a numeric instance.exclusiveMinimum
- Can be used to define the exclusiveMinimum value of a numeric instance.For String instances:
maxLength
- Can be used to define the maxLength value of a string instance. The value of this keyword MUST be a non-negative integer.minLength
- Can be used to define the minLength value of a string instance. The value of this keyword MUST be a non-negative integer.pattern
- Can be used to define the pattern value of a string instance.For Array instances:
maxItems
- Can be used to define the maxItems value of a string instance. The value of this keyword MUST be a non-negative integer.minItems
- Can be used to define the minItems value of a string instance. The value of this keyword MUST be a non-negative integer.uniqueItems
- Can be used to define the uniqueItems value of a string instance. The value of this keyword MUST be a boolean.If, at the top level of the Avro schema, the 'name' attribute is defined, it will be copied to the corresponding JSON schema's 'x-parser-schema-id' attribute. If the Avro schema also has the 'namespace' attribute defined, then that schema's fully qualified name will be put into that attribute. The fully qualified name is defined by the namespace, followed by a dot, followed by the name.
If there are two schemas that resolve to the same fully qualified name, only the last one will be returned by the parser. Make sure names of your schemas are unique.
If no name attribute is present, the 'x-parser-schema-id' will have a generated unique id with a name like 'anonymous-schema-1' generated by the main parser. 'x-parser-schema-id' is one of the custom extensions supported by the parser.
JSON numbers (RFC 4627, section 2.4) don't define any limit to the scale and/or precision of numbers. That said, we can enforce limits on int
and long
but we can't enforce them on float
and double
because they can't accurately be represented on JSON Schema.
Since we support extra attributes on field, you can set
minimum
andmaximum
attribute on float and double types to display number limits.
This is not a limitation of this package per se but of the JSON Reference RFC. So far, you can only hardcode the values for key
and secret
on the $ref
URL.
Thanks goes to these wonderful people (emoji key):
Fran Méndez 💻 🚧 👀 🤔 | Lukasz Gornicki 🚧 👀 🚇 | Ludovic Dussart 💻 🚧 👀 | Dale Lane 💻 🚧 👀 | Jonathan 💻 | Radim Loskot 💻 | Michael Davis 💻 |
Germán Schnyder 💻 |
This project follows the all-contributors specification. Contributions of any kind welcome!
FAQs
An AsyncAPI schema parser for Avro 1.x schemas.
The npm package @asyncapi/avro-schema-parser receives a total of 114,208 weekly downloads. As such, @asyncapi/avro-schema-parser popularity was classified as popular.
We found that @asyncapi/avro-schema-parser demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.