EDI API Server Installation
Overview
The API server installation involves “pulling” and running its docker container from our Docker registry.
The API server consists of only one container, it does not need a database. The container is completely stateless, you don’t need to create and manage volumes.
This makes it easy to run multiple instances of the API Server and scale it up/down depending on your workload.
If you prefer not to use Docker, you can install the API Server as a service directly. The API Server is a Java/SpringBoot application, so you will need to install Java and configure running the API Server as a service.
Installing and Running API Server with Docker
On Linux you may need to run
sudo
for all docker commands.
We recommend using docker compose
to run the EDI converter container; you can also run it without docker compose as explained below.
- Create a new folder (e.g., “edi”), download
docker-compose.yml
file from this link and copy it into this folder - Navigate to the folder where you saved the
docker-compose.yml
- Create the
etc
folder. Copy the license file toetc
. You can request your trial license here. - Run
docker compose pull
. This will ensure that you have the latest image. - Run
docker compose up -d
.
On Linux/macOS:
mkdir edi
cd edi
mkdir etc
# Copy the license file from the location you downloaded it to
cp edi-license.bin etc
wget https://datainsight.health/edi-convert/docker-compose.yml
docker compose pull
docker compose up -d
docker compose logs
You can also specify your license as an environment variable; in this case, you don’t need the
etc
volume.
The default port for the container is 5080, you can change it in docker-compose.yml.
To stop the service, run docker compose down
.
To view the logs, run docker compose logs -f
If you prefer not to use docker compose, you can run the container directly using the steps below.
Create the etc
folder and copy your license file into this folder. After that run the following commands:
docker pull repo.datainsight.health/ediconvert:2.10
docker create --name ediconvert -p "5080:5080" -v ./etc:/app/etc repo.datainsight.health/ediconvert:2.10
To start/stop the container:
docker start ediconvert
docker stop ediconvert
To view logs:
docker logs ediconvert
Installation without Docker
The API server is a Java application. You can install it on any server using the steps below:
- Download and install Java. Java 17 or higher is required. We recommend using the latest long-term support release of Java. You can also install Java using sdkman or a package manager on Linux or macOS. Once you install Java, verify the Java’s version by running
java -version
command from the terminal/command line window. - Create a folder/directory where you’re going to install the API back-end, e.g.,
edi
- Create the
etc
folder inside the newly created folder. Copy the license file toetc
. You can request your trial license here. - Download the distribution’s zip file from this link
- Unzip the zip file into the installation folder/directory (e.g., into
edi
) - Open the terminal/command line window and navigate to the installation folder/directory (
cd edi
) - Run
java -jar ediconvert.war
You need to keep this terminal/command line window open. To install the API server as a daemon/service, follow the instructions here.
License Key as Environment Variable
You can specify your license key using the LICENSE_KEY
environment variable instead of using the license key file. This obviates the need for persistent volumes and makes deployment to Kubernetes easier to manage.
Let us know by emailing to ediconvert@datainsight.health that this is your preferred license format.
Initial Tests to Verify the Installation
To verify that the server is running, open http://localhost:5080/api/about or run this command:
curl http://localhost:5080/api/about
You may also want to convert a test EDI file. You can many sample files in our GitHub repo.
Download any of the files and run:
curl -H "Content-Type: text/plain" --data-binary @<your file> http://localhost:5080/api/edi/json