Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/FusionAuth/fusionauth-openapi
FusionAuth OpenAPI client
https://github.com/FusionAuth/fusionauth-openapi
client-library fusionauth openapi swagger
Last synced: 2 months ago
JSON representation
FusionAuth OpenAPI client
- Host: GitHub
- URL: https://github.com/FusionAuth/fusionauth-openapi
- Owner: FusionAuth
- License: apache-2.0
- Created: 2022-01-05T20:31:30.000Z (about 3 years ago)
- Default Branch: develop
- Last Pushed: 2024-11-05T14:34:55.000Z (3 months ago)
- Last Synced: 2024-11-05T15:05:57.898Z (3 months ago)
- Topics: client-library, fusionauth, openapi, swagger
- Language: Shell
- Homepage: https://fusionauth.io/docs/v1/tech/client-libraries/openapi/
- Size: 647 KB
- Stars: 8
- Watchers: 12
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- jimsghstars - FusionAuth/fusionauth-openapi - FusionAuth OpenAPI client (Shell)
README
# FusionAuth OpenAPI
This is an OpenAPI specification for the FusionAuth API.
[Here's the openapi specification YAML file](https://github.com/FusionAuth/fusionauth-openapi/blob/main/openapi.yaml).
It can be used in a variety of contexts, including generating client libraries, tracking API changes over time and testing. More here: https://openapi.tools/
Use this file to do all your OpenAPI related actions. For additional information and documentation on FusionAuth refer to [https://fusionauth.io](https://fusionauth.io).
* [Generate libraries](#generate-libraries)
* [Java](#java)
* [Ruby](#ruby)
* [Test the YAML](#test-the-yaml)
* [Postman Collection](#postman-collection)
* [Known issues](#known-issues)
* [Next steps](#next-steps)
* [Questions and support](#contributions-and-support)
* [Contributing](#contributing)
* [License](#license)## Generate libraries
Install either Swagger: https://github.com/swagger-api/swagger-codegen/ or openapi: https://github.com/OpenAPITools/openapi-generator
These instructions will be for openapi.
### Java
To build the java client libraries:
```
bin/java/build.sh
```This will produce a jar you can use.
### Ruby
To build the ruby client libraries:
```
bin/ruby/build.sh
```Read the readme in `ruby/README.md` for installation and usage instructions. To install it as a gem locally using --dev, I had to build it and then install a couple of rspec dependencies by hand.
More docs here: https://openapi-generator.tech/docs/generators/ruby
### Dart
To build the dart client libraries:
```
bin/dart/build.sh
```This will produce a dart package you can import.
## Test the YAML
```
pip3 install schemathesis # one time
schemathesis run -vvvv --checks not_a_server_error openapi.yaml --base-url http://localhost:9011 -H "Authorization: bf69486b-4733-4470-a592-f1bfce7af580"
```## Postman Collection
You can also explore around with our API in postman.
Here's our [Postman profile](https://www.postman.com/fusionauth) and [public workspace](https://www.postman.com/fusionauth/workspace).
### Import Postman Collection
* Log into the FusionAuth Postman team
* Click the `Import` button on the left hand nav, toward the top
* Import the API definition. This should also create a new collection
* Rename the API and collection with the correct API version
* Copy over the description from a previously imported API (easiest to do it in two tabs)
* Copy the new collection into the workspace.
* Go to the [FusionAuth Postman homepage](https://www.postman.com/fusionauth) and edit the new collection and put the date on it.## Known issues
While the specification is valid, the generated client libraries haven't been fully exercised.
* FusionAuth uses polymorphic responses for some API calls, particularly Identity Providers. The support for that in client library generation code is problematic, based on our testing. I'm not sure if there are workarounds, but it seems like some work is being done. See https://github.com/swagger-api/swagger-codegen/issues/10011 and https://github.com/OpenAPITools/openapi-generator/issues/10880#issuecomment-995243186 for an openapi workaround.
* This spec is built using the [fusionauth-client-builder](https://github.com/fusionauth/fusionauth-client-builder) project JSON files. This covers almost all of the API, but not everything. A few calls may be missing. If you find one that you need, please open a bug report.
* Deprecated API endpoints are not included.
* There's no information about what parameters are required or not, because that is not part of the API JSON files.
* There are certain operations, status codes and security mechanisms (JWT auth, cookies for auth) that are not currently supported because they are not included in the API JSON files.
* OAuth grant actions aren't currently supported (the /oauth2/ endpoints).
* There is an issue generating the ruby client libraries. https://github.com/OpenAPITools/openapi-generator/issues/11350 has the repro steps. The `RUBY_POST_PROCESS_FILE` environment variable is a workaround.## Next steps
We are publishing this to see how useful the FusionAuth community finds it. We welcome feedback on your usage of this spec. We'll plan to revisit this after we've received some feedback on how useful it is and determine if there are additional features we need to implement.
Please open bugs on this repository. For support in using this, please see the next section.
## Questions and support
If you have a question or support issue regarding this OpenAPI spec, we'd love to hear from you.
If you have a paid edition with support included, please [open a ticket in your account portal](https://account.fusionauth.io/account/support/). Learn more about [paid editions here](https://fusionauth.io/pricing).
Otherwise, please [post your question in the community forum](https://fusionauth.io/community/forum/).
## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/FusionAuth/go-client.
If you find an issue with syntax, etc - this is likely a bug in the generation script. Feel free to submit a PR against the Client Builder project.
- [Client Builder](https://github.com/FusionAuth/fusionauth-client-builder)
- [build-openapi-yaml.rb](https://github.com/FusionAuth/fusionauth-client-builder/blob/master/bin/build-openapi-yaml.rb)## License
The code is available as open source under the terms of the [Apache v2.0 License](https://opensource.org/licenses/Apache-2.0).