Skip to content

folio-org/okapi

Repository files navigation

Okapi — a multitenant API Gateway

Copyright (C) 2015-2020 The Open Library Foundation

This software is distributed under the terms of the Apache License, Version 2.0. See the file "LICENSE" for more information.

System requirements

The Okapi software has the following compile-time dependencies:

  • Java 11

  • Apache Maven 3.3.x or higher

In addition, the test suite must be able to bind to ports 9230-9239 to succeed.

Note: If tests fail, the API Gateway may be unable in some cases to shut down microservices that it has spawned, and they may need to be terminated manually.

Quick start

To build and run:

$ mvn install
$ mvn exec:exec

Okapi listens on port 9130.

Developers

When running unit tests, property testStorage controls what storage to use. It has a default value of inmemory,postgres,mongo. Tests will complete faster by specifying one storage type only.

For example:

$ mvn -DtestStorage=inmemory install

When filing bug reports with unit test output, always use Maven option -B to avoid control characters in output.

Docker image

At Docker Hub:

See Automation/Docker Hub for details.

Docker images are the primary distribution model for FOLIO modules. To run the images you will need the Docker Engine or Docker Desktop runtime.

Ubuntu package

Import the FOLIO signing key and add the FOLIO apt repository for Ubuntu 20.04 LTS (Focal Fossa):

wget -q -O - https://repository.folio.org/packages/debian/folio-apt-archive-key.asc | sudo apt-key add -
sudo add-apt-repository "deb https://repository.folio.org/packages/ubuntu/ focal/"

Documentation