{"id":15020039,"url":"https://github.com/simplify-framework/openapi","last_synced_at":"2025-10-24T22:31:54.103Z","repository":{"id":57361500,"uuid":"243234983","full_name":"simplify-framework/openapi","owner":"simplify-framework","description":"Generate Simplify Framework base projects with True-DevOps code skeleton to run on Cloud with API Gateway, AWS Lambda and other AWS Services from OpenAPI 3.0 specs. The generated code skeleton can be debug locally and can deploy on docker orchestration platform with docker-compose and Kubernetes.","archived":false,"fork":false,"pushed_at":"2020-06-06T16:40:59.000Z","size":231,"stargazers_count":3,"open_issues_count":0,"forks_count":1,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-10-03T11:17:46.356Z","etag":null,"topics":["api-gateway","aws-lambda","codegen","devops","docker","docker-compose","express","javascript","lambda-functions","nodejs","openapi-specs","python","simplify-framework"],"latest_commit_sha":null,"homepage":"","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/simplify-framework.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null},"funding":{"open_collective":"duong-dinh-cuong"}},"created_at":"2020-02-26T10:26:55.000Z","updated_at":"2022-04-27T22:16:53.000Z","dependencies_parsed_at":"2022-09-26T16:31:20.250Z","dependency_job_id":null,"html_url":"https://github.com/simplify-framework/openapi","commit_stats":null,"previous_names":["aws-simplify/codegen","simplify-framework/codegen"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/simplify-framework/openapi","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/simplify-framework%2Fopenapi","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/simplify-framework%2Fopenapi/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/simplify-framework%2Fopenapi/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/simplify-framework%2Fopenapi/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/simplify-framework","download_url":"https://codeload.github.com/simplify-framework/openapi/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/simplify-framework%2Fopenapi/sbom","scorecard":{"id":219353,"data":{"date":"2025-08-04","repo":{"name":"github.com/simplify-framework/openapi","commit":"9f139c8e801553899e7ee22bbca14025c8b21c23"},"scorecard":{"version":"v5.2.1-28-gc1d103a9","commit":"c1d103a9bb9f635ec7260bf9aa0699466fa4be0e"},"score":3.4,"checks":[{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#dangerous-workflow"}},{"name":"Code-Review","score":6,"reason":"Found 6/10 approved changesets -- score normalized to 6","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#code-review"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#binary-artifacts"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#cii-best-practices"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/coverity.yml:1","Warn: no topLevel permission defined: .github/workflows/gencode.yml:1","Warn: no topLevel permission defined: .github/workflows/pushcode.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#token-permissions"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#maintained"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#fuzzing"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#packaging"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#security-policy"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: Apache License 2.0: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#signed-releases"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/gencode.yml:20: update your workflow using https://app.stepsecurity.io/secureworkflow/simplify-framework/openapi/gencode.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/gencode.yml:22: update your workflow using https://app.stepsecurity.io/secureworkflow/simplify-framework/openapi/gencode.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/gencode.yml:32: update your workflow using https://app.stepsecurity.io/secureworkflow/simplify-framework/openapi/gencode.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/pushcode.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/simplify-framework/openapi/pushcode.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/pushcode.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/simplify-framework/openapi/pushcode.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pushcode.yml:32: update your workflow using https://app.stepsecurity.io/secureworkflow/simplify-framework/openapi/pushcode.yml/master?enable=pin","Warn: containerImage not pinned by hash: Dockerfile:1: pin your Docker image by updating node:alpine to node:alpine@sha256:e8e882c692a08878d55ec8ff6c5a4a71b3edca25eda0af4406e2a160d8a93cf2","Warn: npmCommand not pinned by hash: Dockerfile:6-11","Warn: npmCommand not pinned by hash: .github/workflows/coverity.yml:34","Warn: npmCommand not pinned by hash: .github/workflows/pushcode.yml:43","Info:   0 out of   4 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   2 third-party GitHubAction dependencies pinned","Info:   0 out of   1 containerImage dependencies pinned","Info:   0 out of   3 npmCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#pinned-dependencies"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#branch-protection"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 30 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":0,"reason":"13 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-968p-4wvh-cqc8","Warn: Project is vulnerable to: GHSA-v88g-cgmw-v5xw","Warn: Project is vulnerable to: GHSA-93q8-gq69-wqmw","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-gxpj-cx7g-858c","Warn: Project is vulnerable to: GHSA-7mg4-w3w5-x5pc","Warn: Project is vulnerable to: GHSA-6xrf-q977-5vgc","Warn: Project is vulnerable to: GHSA-v5vg-g7rq-363w","Warn: Project is vulnerable to: GHSA-282f-qqgm-c34q","Warn: Project is vulnerable to: GHSA-f8q6-p94x-37v3","Warn: Project is vulnerable to: GHSA-w7rc-rwvf-8q5r","Warn: Project is vulnerable to: GHSA-r683-j2x4-v87g","Warn: Project is vulnerable to: GHSA-c4w7-xm78-47vh"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-17T02:11:33.639Z","repository_id":57361500,"created_at":"2025-08-17T02:11:33.640Z","updated_at":"2025-08-17T02:11:33.640Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":280878369,"owners_count":26406641,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-24T02:00:06.418Z","response_time":73,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api-gateway","aws-lambda","codegen","devops","docker","docker-compose","express","javascript","lambda-functions","nodejs","openapi-specs","python","simplify-framework"],"created_at":"2024-09-24T19:54:30.261Z","updated_at":"2025-10-24T22:31:53.815Z","avatar_url":"https://github.com/simplify-framework.png","language":"JavaScript","readme":"# Simplify Framework - OpenAPI Based Serverless  \n\nThis REST API model has moved to `npm install simplify-openapi -g` from version 0.1.9.\nWith new branch of GraphQL Serverless Model at `npm install simplify-graphql -g` \n\n![Devops CI/CD](https://github.com/simplify-framework/codegen/workflows/DevOps%20CI/CD/badge.svg)\n![NPM Downloads](https://img.shields.io/npm/dw/simplify-openapi)\n![Package Version](https://img.shields.io/github/package-json/v/simplify-framework/openapi?color=green)\n![Coverity Scan](https://scan.coverity.com/projects/21173/badge.svg)\n\nInitial code based on [openapi-codegen](https://github.com/Mermade/openapi-codegen)\n\n*Node.js-based codegen for OpenAPI specs. This project was initially by tailoring from openapi-codegen to use the core code generation functionality to generate the lambda based node projects and AWS CloudFormation stack. There was many tailored code to become a powerful tool nowaday. Thanks to the initial openapi-codegen project that has saved time for developing an initial idea.*\n\n## Divided code capability:\n- `Nano` function: per individual method (/path/rc: GET) as a lambda function\n- `Micro` function: per some methods (/path/ac: POST, PUT) as a lambda function\n- `Kilo` function: per some resources (/path/rc, /path/ac) as a lambda function\n- `Mono` application: as an application running on a docker-compose service\n\n## Deployment mode capability:\n- BlueGreen deployment: run `latest` version as `Blue` stage or `stable` version as `Green` stage\n- Enforcement deployment: specify to run a custom enforcement version (e.g maintenance package mode)\n- Canary deployment: run one of [`latest`,`stable`,`enforce`] version on-request by `x-canary-selection` HTTP header\n\n## Software development facility:\n- Production ready code skeleton (sanitizer, unit tests, api tests, coverage)\n- Controllable logging verbosity (INFO, WARN, DEBUG, ERROR) using `debug` package\n- Local and independant development code run (http://localhost:3000) by node `express`\n\n## Install from published NPM packages\n- `npm install -g simplify-openapi`\n\n## Install codegen from github sourcode\n- `git clone https://github.com/simplify-framework/openapi.git`\n- `cd openapi \u0026\u0026 npm install \u0026\u0026 npm link`\n\n## Generate Open API specs sample for pets:\n- `mkdir pets-project` to create project folder for pets\n- `cd pets-project \u0026\u0026 npm link simplify-openapi` if you install from github\n- `simplify-openapi template -i petsample` to create a `petsample` OpenAPI 3.0 specs\n- `simplify-openapi template -i othername` to create a `othername` OpenAPI 3.0 specs\n\n## Generate project using command line:\n- `simplify-openapi -i openapi.yaml` to generate code in the current folder\n- `simplify-openapi -i openapi.yaml -o other-folder` to specify another folder\n\n## Running with Docker Compose at localhost:\n- `cd projectPets \u0026\u0026 docker-compose up -d`\n- List pets at http://localhost/project-pets/pets\n- Feed pets at http://localhost/project-pets/pets/1/feed/2\n- `docker-compose down` to stop running!\n\n## Setup AWS configuration profile:\n- Create a deployment user in IAM: `simplify-user`\n- Setup IAM Role Policy using: `policy-deployment.json`\n- Setup IAM Role Policy using: `policy-services.json`\n- Setup IAM Role Policy using: `policy-execute-api.json`\n- Configure your machine `aws configure --profile simplify-eu`\n(See [Pets Project](https://github.com/simplify-framework/pets-project-template) for more information)\n\n## Run as AWS Lambda functions:\n- `npm install` to install project dependancies and tools\n- `npm run stack-deploy` to provision code containers (AWS Lambda empty functions)\n- `npm run push-code` to deploy and run code as declared in .env variables (ENV_*)\n  + ENV_functionName_DEPLOYMENT_STAGE=(`latest`|`stable`|`enfoce`|`canary`) to setup running mode\n  + ENV_functionName_ENFORCEMENT_PACKAGE=specific-package-name-with-version (`enforce` mode only)\n- `npm run stack-destroy` to provision code containers (AWS Lambda empty functions)\n\n## Serverless architecture in AWS:\n+ AWS API Gateway REST API\n  + AWS Lambda function   (service #1)\n    - AWS Secret Manager  (key vault)\n    - Custom resource     (external setup)\n    - Manage Policy Arn   (access policy)\n  + AWS Lambda function   (service #2)\n    - AWS Secret Manager  (key vault)\n    - Custom resource     (external setup)\n    - Manage Policy Arn   (access policy)\n  + AWS Lambda function   (service #3)\n    - AWS Secret Manager  (key vault)\n    - Custom resource     (external setup)\n    - Manage Policy Arn   (access policy)\n\n## OpenAPI specs with Simplify definitions:\n- `info.version`: define software package version, set for initial packages\n- `info.title`: define software package description, set for initial packages\n- `x-project-name`: to define a project which contains other resources (e.g `pets-micro-services`)\n- `x-deployment-name`: to define a deployment environment (e.g `pets-demo`, `pets-prod`)\n- `x-deployment-region`: to define where to deploy resources (e.g `eu-west-1`)\n- `x-deployment-profile`: to define a profile that hold the deployment access (e.g `simplify-eu`)\n- `x-api-gateway-name`: to define an API gateway (Rest API) resource (e.g `pets-api-gateway`)\n- `x-api-authorizer-id`: provide an authorizer id that linked to API Authorizer (e.g Cognito Auhtorizer)\n- `x-api-burst-limit`: The API request burst limit, the maximum rate limit over a time ranging from one to a few seconds\n- `x-api-rate-limit`: The API request steady-state rate limit.\n- `x-api-quota-limit`: The maximum number of requests that can be made in a given time period.\n- `x-api-quota-unit`: The time period in which the limit applies. Valid values are \"DAY\", \"WEEK\" or \"MONTH\".\n  - `x-[api/event]-service-runtime`: specify service runtime to create function (e.g nodejs12.x, python3.8 )\n  - `x-[api/event]-service-lang`: specific runtime language - is one of `javascript` or `python`\n  - `x-[api/event]-service-name`: to define lambda functions that host the source code (e.g `pets-service`)\n  - `x-[api/event]-service-model-name`: to redirect the related routing paths into a service group (e.g `pets`)\n  - `x-[api/event]-service-public`: expose or dispose this service path through API gateway (public or not)\n  - `x-[api/event]-service-authorizer`: enable or disable using API Authorizer (e.g using Cognito Authorizer)\n  - `x-[api/event]-service-api-key`: enable to use API Key with `x-api-key` header to authenticate resource\n  - `x-[api/event]-service-key-vault`: enable or disable key vault service (SecretManager in AWS)\n  - `x-[api/event]-service-schedule`: if set to value (e.g `rate(10 minutes)`) will schedule every 10 mins\n  - `x-[api/event]-service-policy`: external access policy ARN (e.g Policy ARN to DynamoDB, S3, SNS...)\n  - `x-[api/event]-service-custom`: integrate custom ARN function that trigger for external resource creation/deletion\n  - `x-[api/event]-service-control`: enable or disable service fallen control using hystrix circuit breaker (valid only for docker)\n  - `x-[api/event]-service-validation`: validate request parameters using swagger request validator (parseRequest middleware)\n  - `x-[api/event]-service-passthrough`: passthrough original request from API Gateway to service model for backward compatibility\n  - `method`: define a HTTP Rest API method: (get/put/post/delete)\n    - `x-control-operation-id` or standard `operationId`: to define a friendly name for this operation method: e.g getPetByName\n    - `x-control-service-timeout`: setup circuit break operation timeout (valid only for docker)\n    - `x-control-service-duration`: setup circuit break operation close duration (valid only for docker)\n    - `x-control-service-threshold`: setup circuit break operation threshold (valid only for docker)\n\n## The generated Pets Architecture Diagram\n\n![PetsDiagram](https://mermaid.ink/img/eyJjb2RlIjoic3RhdGVEaWFncmFtXG4gIFsqXSAtLT4gYXBpR2F0ZXdheVJlc3RhcGlOYW1lXG4gICAgYXBpR2F0ZXdheVJlc3RhcGlOYW1lIC0tPiBmdW5jdGlvbkZvckJ1eVBldHNcbiAgICBhcGlHYXRld2F5UmVzdGFwaU5hbWUgLS0-IGZ1bmN0aW9uRm9yRXRyYW5nZXJQZXRzXG4gICAgYXBpR2F0ZXdheVJlc3RhcGlOYW1lIC0tPiBmdW5jdGlvbkZvclBldHNcbiAgICBhcGlHYXRld2F5UmVzdGFwaU5hbWUgLS0-IGZ1bmN0aW9uRm9yUGVvcGxlXG5cbiAgICBmdW5jdGlvbkZvckJ1eVBldHM6ICBTaWd2NCBJQU1cbiAgICBmdW5jdGlvbkZvckV0cmFuZ2VyUGV0czogIFNpZ3Y0IElBTVxuICAgIGZ1bmN0aW9uRm9yUGV0czogIFNpZ3Y0IElBTVxuICAgIGZ1bmN0aW9uRm9yUGVvcGxlOiAgU2lndjQgSUFNXG5cbiAgICBmdW5jdGlvbkZvckJ1eVBldHMgLS0-IGdldFNob3BwaW5nUGV0czogR0VUIC9zaG9wcGluZy9wZXRzXG4gICAgZnVuY3Rpb25Gb3JFdHJhbmdlclBldHMgLS0-IGdldEV0cmFuZ2VyUGV0czogR0VUIC9ldHJhbmdlci9wZXRzXG4gICAgZXZlbnRGdW5jdGlvbkZvclBldHMgLS0-IHB1dEV2ZW50c0ZlZWRQZXRzOiBQVVQgL2V2ZW50cy9mZWVkLXBldHNcbiAgICBldmVudEZ1bmN0aW9uRm9yUGV0cyAtLT4gZXZlbnRGdW5jdGlvbkZvclBldHM6IHNjaGVkdWxlZCBieSByYXRlKDEwIGRheXMpXG4gICAgZnVuY3Rpb25Gb3JQZXRzIC0tPiBnZXRQZXRzOiBHRVQgL3BldHNcbiAgICBmdW5jdGlvbkZvclBldHMgLS0-IGNyZWF0ZVBldDogUE9TVCAvcGV0c1xuICAgIGZ1bmN0aW9uRm9yUGV0cyAtLT4gdXBkYXRlUGV0OiBQVVQgL3BldHNcbiAgICBmdW5jdGlvbkZvclBldHMgLS0-IGZlZWRQZXRCeUlkOiBHRVQgL3BldHMve2lkfS9mZWVkL3tjb3VudH1cbiAgICBmdW5jdGlvbkZvclBlb3BsZSAtLT4gbGlua1BldFRvUGVyc29uOiBQT1NUIC9wZW9wbGUvcGV0cy97aWR9XG4gICAgZnVuY3Rpb25Gb3JQZW9wbGUgLS0-IGdldFBlb3BsZTogR0VUIC9wZW9wbGVcbiAgICBmdW5jdGlvbkZvclBlb3BsZSAtLT4gcHV0UGVvcGxlOiBQVVQgL3Blb3BsZVxuICAgIGZ1bmN0aW9uRm9yUGVvcGxlIC0tPiBjcmVhdGVQZW9wbGU6IFBPU1QgL3Blb3BsZVxuICAgIFxuICAgIGdldFNob3BwaW5nUGV0cyAtLT4gc2hvcHBpbmdQZXRzXG4gICAgZ2V0RXRyYW5nZXJQZXRzIC0tPiBldHJhbmdlclBldHNcbiAgICBwdXRFdmVudHNGZWVkUGV0cyAtLT4gZXZlbnRzRmVlZFBldHNcbiAgICBnZXRQZXRzIC0tPiBwZXRzXG4gICAgY3JlYXRlUGV0IC0tPiBwZXRzXG4gICAgdXBkYXRlUGV0IC0tPiBwZXRzXG4gICAgZmVlZFBldEJ5SWQgLS0-IHBldHNGb29kc1xuICAgIGxpbmtQZXRUb1BlcnNvbiAtLT4gcGVvcGxlUGV0c1xuICAgIGdldFBlb3BsZSAtLT4gcGVvcGxlXG4gICAgcHV0UGVvcGxlIC0tPiBwZW9wbGVcbiAgICBjcmVhdGVQZW9wbGUgLS0-IHBlb3BsZVxuIiwibWVybWFpZCI6eyJ0aGVtZSI6ImRlZmF1bHQifSwidXBkYXRlRWRpdG9yIjpmYWxzZX0)\n\n\n","funding_links":["https://opencollective.com/duong-dinh-cuong"],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsimplify-framework%2Fopenapi","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsimplify-framework%2Fopenapi","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsimplify-framework%2Fopenapi/lists"}