Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/paypal/mocca
Mocca is a GraphQL client for JVM languages with the goal of being easy to use, flexible and modular.
https://github.com/paypal/mocca
graphql groovy java jvm kotlin scala
Last synced: 4 months ago
JSON representation
Mocca is a GraphQL client for JVM languages with the goal of being easy to use, flexible and modular.
- Host: GitHub
- URL: https://github.com/paypal/mocca
- Owner: paypal
- License: mit
- Created: 2021-06-02T18:36:35.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2023-11-28T18:09:07.000Z (about 1 year ago)
- Last Synced: 2024-09-28T15:05:32.082Z (4 months ago)
- Topics: graphql, groovy, java, jvm, kotlin, scala
- Language: Java
- Homepage:
- Size: 306 KB
- Stars: 15
- Watchers: 13
- Forks: 14
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- Contributing: docs/CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
README
[![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.paypal.mocca/mocca-client/badge.svg?style=flat)](http://search.maven.org/#search|ga|1|g:com.paypal.mocca)
[![javadoc](https://javadoc.io/badge2/com.paypal.mocca/mocca-client/javadoc.svg)](https://javadoc.io/doc/com.paypal.mocca/mocca-client)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
# Mocca
Mocca is a GraphQL client for JVM languages with the goal of being easy to use, flexible and modular. With that in mind, Mocca was designed to offer:
1. Simple and intuitive API
1. Good end user documentation
1. Pluggable HTTP clients
1. Pluggable components, relying on great open source libraries, allowing features such as code generation, resilience, parsers and observability## Features
Mocca offers support for:
1. GraphQL features
1. GraphQL queries and mutations
1. Automatic variable definition
1. Automatic selection set definition based on DTO response type
1. Annotation and String based custom input variables
1. Annotation and String based custom selection set
1. Static and dynamic HTTP request headers
1. Observability via Micrometer
1. Resilience via Resilience4J
1. Flexible API allowing various pluggable HTTP clients
1. Asynchronous support
1. CompletableFuture
1. Pluggable asynchronous HTTP clients
1. User provided executor services
1. Request parameters validation via Bean Validation## Quick start
Please read the **Quick Start** section in [Mocca documentation](docs/END_USER_DOCUMENT.md) for instructions on how to start using Mocca quickly.
## End-user documentation
Please refer to [Mocca documentation](docs/END_USER_DOCUMENT.md).
## Release notes
See [Mocca release notes](docs/RELEASE_NOTES.md).## Reporting an issue
Please open an issue using our [GitHub issues](https://github.com/paypal/mocca/issues) page.## Contributing
You are very welcome to contribute to Mocca! Read our [Contribution guidelines](docs/CONTRIBUTING.md).## License
This project is licensed under the [MIT License](LICENSE.txt).