Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sap/openapi-specification
The SAP's extension to OpenAPI Specification defines a standard for describing HTTP APIs at SAP.
https://github.com/sap/openapi-specification
api documentation extension openapi
Last synced: about 1 month ago
JSON representation
The SAP's extension to OpenAPI Specification defines a standard for describing HTTP APIs at SAP.
- Host: GitHub
- URL: https://github.com/sap/openapi-specification
- Owner: SAP
- License: apache-2.0
- Created: 2022-11-29T15:06:36.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-09-16T07:42:05.000Z (2 months ago)
- Last Synced: 2024-09-21T00:05:04.353Z (about 2 months ago)
- Topics: api, documentation, extension, openapi
- Language: TypeScript
- Size: 114 KB
- Stars: 8
- Watchers: 4
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
[![REUSE status](https://api.reuse.software/badge/github.com/SAP/openapi-specification)](https://api.reuse.software/info/github.com/SAP/openapi-specification)
# OpenAPI Specification for SAP Ecosystem
This repository contains extensions to the original [OpenAPI Specification](https://github.com/OAI/OpenAPI-Specification) which are relevant for SAP Ecosystem and corresponding tooling. Additionally, it provides a compiled "ready to use" version of schema files which includes the original schemas with SAP-specific changes on top.
The following versions of OpenAPI Specification are supported:
- [OpenAPI Specification v2.0 for SAP Ecosystem](./sap-schemas/v2.0) (based on [OpenAPI v2.0](https://spec.openapis.org/oas/v2.0), also known as Swagger 2.0)
- [OpenAPI Specification v3.0 for SAP Ecosystem](./sap-schemas/v3.0) (based on [OpenAPI v3.0.3](https://spec.openapis.org/oas/v3.0.3))Every OpenAPI Specification for SAP Ecosystem document is also a valid OpenAPI document of a corresponding version.
The goal of these specification is to describe SAP's extensions to OpenAPI Specifications in a standardized way. The specification are used by [SAP API Business Hub](https://api.sap.com) and other tooling in SAP Ecosystem.
## Requirements
Each schema in this repository is described using JSON format.
No specific tools are needed to use these schema files.
Contributors to this repository will need to run the generator, which requires Node.js to be installed.
## Known Issues
No known issues.
## Primitive Type Mapping
OpenAPI is based on the JSON type system and uses the `format` keyword for differentiating JSON types, and in some cases additional keywords:
| [ABAP][abap] | [CAP][cap] | Java | [OData][odata] | [SQL][hana] | OpenAPI type | [OpenAPI format][formats] | OpenAPI keywords | JSON example |
| --------------------------- | ------------------- | -------------------- | ------------------ | ---------------------------------------- | --------------- | ------------------------- | ---------------------------------- | -------------------------------------------- |
| RAW16, CHAR32 | UUID | java.lang.String | Edm.Guid | VARBINARY(16), VARCHAR(32), NVARCHAR(36) | string | uuid | - | `"1e4c3ce2-452b-4a0f-9ce4-985edc35b4d7"` |
| ABAP_BOOL | Boolean | boolean | Edm.Boolean | BOOLEAN | boolean | - | - | `true` |
| b | UInt8 | short | Edm.Byte | TINYINT | integer | uint8 | - | `255` |
| - | - | short | Edm.SByte | TINYINT | integer | int8 | - | `-128` |
| s | Int16 | short | Edm.Int16 | SMALLINT | integer | int16 | - | `32767` |
| i | Int32, Integer | int | Edm.Int32 | INTEGER | integer | int32 | - | `2147483647` |
| int8 | Int64, Integer64 | long | Edm.Int64 | BIGINT | string, integer | int64 | - | `"9223372036854775807"` |
| decfloat34 | Decimal | java.math.BigDecimal | Edm.Decimal | DECIMAL | string, number | decimal128 | - | `"9.999999999999999999999999999999999e6144"` |
| p | Decimal(p,s) | java.math.BigDecimal | Edm.Decimal | DECIMAL(p,s) | string, number | decimal | [x-sap-precision, x-sap-scale][ps] | `"12556.33"` |
| f | Double | double | Edm.Double | DOUBLE | number | double | | `3.141592653589793` |
| d | Date | java.time.LocalDate | Edm.Date | DATE | string | date | - | `"2024-12-31"` |
| /IWBEP/V4_EDM_TYPE_DURATION | - | java.time.Duration | Edm.Duration | - | string | duration | - | `"27DT7H43M40.8S"` |
| t | Time | java.time.LocalTime | Edm.TimeOfDay | TIME | string | (time) | - | `"23:59:59"` |
| utclong | DateTime, Timestamp | java.time.Instant | Edm.DateTimeOffset | TIMESTAMP | string | date-time | - | `"1969-07-20T20:17:00Z"` |
| string | String | java.lang.String | Edm.String | NVARCHAR | string | - | - | `"Hello\nWorld"` |
| c, n | String(m) | java.lang.String | Edm.String | NVARCHAR(m) | string | - | maxLength: m | `"Hôtel de Ville"` |
| xstring | Binary | byte[] | Edm.Binary | VARBINARY | string | base64url | - | `"T0RhdGE"` |
| x | Binary(m) | byte[] | Edm.Binary | VARBINARY(m) | string | base64url | maxLength: m | `"T3BlbkFQSQ=="` |
| xstring | LargeBinary | byte[] | Edm.Binary | BLOB | string | base64url | - | `"R3JhcGhRTA=="` |
| string | LargeString | java.lang.String | Edm.String | NCLOB | string | - | - | `"Once upon a time..."` |[abap]: https://help.sap.com/doc/abapdocu_cp_index_htm/CLOUD/en-US/index.htm?file=abendata_types.htm
[cap]: https://cap.cloud.sap/docs/cds/types
[hana]: https://help.sap.com/docs/SAP_HANA_PLATFORM/4fe29514fd584807ac9f2a04f6754767/20a1569875191014b507cf392724b7eb.html
[odata]: https://docs.oasis-open.org/odata/odata-csdl-json/v4.01/odata-csdl-json-v4.01.html#sec_PrimitiveTypes
[formats]: https://spec.openapis.org/registry/format/index.html
[ps]: https://github.com/SAP/openapi-specification/tree/main/sap-schemas/v3.0#x-sap-precision## How to obtain support
See [CONTRIBUTING.md](CONTRIBUTING.md).
## Contributing
See [CONTRIBUTING.md](CONTRIBUTING.md).
## Code of Conduct
We as members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone. By participating in this project, you agree to abide by its [Code of Conduct](CODE_OF_CONDUCT.md) at all times.
## Licensing
Please see our [LICENSE](LICENSE) for copyright and license information. Detailed information including third-party components and their licensing/copyright information is available [via the REUSE tool](https://api.reuse.software/info/github.com/SAP/openapi-specification).