⚡️⚡️ Apiman 4 is under active development ⚡️⚡️
Apiman is a flexible and open source API Management platform.
With just a few clicks you can get Apiman running, putting a platform at your fingertips that covers the whole API Management lifecycle. Whether you want to offer existing APIs to external consumers in a secure way, or have a centralised location to discover and govern APIs, Apiman has you covered.
But that's not all. Apiman is designed to be easy to customise, and you can implement your own functionality by writing simple Java plugins.
Did you know, we have an Apiman newsletter now! We'll inform you of the latest Apiman releases as soon as they happen, along with great Apiman-related content. The latest Apiman news, blogs, tutorials, software engineering topics, and more. No spam, no nonsense.
- Apiman Containers/Docker Images
- Apiman Plugins
- Apiman Developer Portal
- Apiman Manager
- Apiman Gateway
- Apiman Distributions (packaged binaries we ship)
- Java 11+
- To build Apiman with tests: Docker or an equivalent container engine. This is for running tests with testcontainers.
- Naturally, if you're using an Apiman container, you'll need it for runtime too!
You can look at the Apiman quickstarts on apiman.io.
Or, you can build and run our 'server-all' quickstart to try everything out immediately.
Here's what you need to do:
echo "Cloning Apiman"
git clone https://github.com/apiman/apiman.git && cd apiman
echo "Building Apiman"
./fastbuild.sh
echo "Starting a Keycloak container with a demo Apiman realm"
cd tools/server-all/target/docker
docker compose up -d
echo "Starting Apiman WildFly Quickstart" && cd ../
./wildfly-dev-server/bin/standalone.sh
Once Apiman has started up, and if all went well, you can point your browser to the API Manager via http://localhost:8080/apimanui/ and log in (either register a new user or log in as the admin):
- Username:
admin
- Password:
admin123!
You can log into the Keycloak admin console via http://localhost:8085/admin (same credentials as above).
This quickstart seeds a bunch of content into apiman. This is not strictly necessary, but it does populate the API Manager with some data so that it doesn't feel so lonely the first time you log in.
There's also a handy echo service available at http://localhost:8080/services/echo - it's useful for demos. You're welcome!
The easiest way to build quickly (without tests) is to run our fastbuild script. It's in the root of the project. If you have mvnd the build will be faster.
git clone https://github.com/apiman/apiman.git && cd apiman
./fastbuild.sh
First, build the parent pom (it's in /parent
), then you can build the main project from the top level.
echo "Building Apiman Parent..."
cd parent
../mvnw clean install
cd ..
echo "Building the main Apiman project..."
./mvnw clean install
Apiman is open source, and we welcome anybody who wants to participate and contribute!
If you want to fix a bug or make any changes, please log an issue in GitHub Issues describing the bug or new feature.
You can also join our discussion forums if you want help, or to discuss a more complex issue.
There are lots of different workflows for contributing. Feel free to use one that suits you. We're endeavouring to pull together a more detailed contribution document that we'll upload soon 🙌.
Apiman also comes with a skinnable developer portal which you can let external developers sign up to your APIs in a streamlined API marketplace experience.
Check out Apiman's support page where you can find Apiman experts to help you.