Table of Contents
This repository is a template for building and deploying io.Manager to your own infrastructure. It provides a Docker Compose configuration for local development and testing, as well as Kubernetes configurations for deployment to a production environment.
The repository is structured to contain three primary services:
- Server: The core server implementation using NodeJS.
- Admin: A user interface for administration purposes developed in React.
- Proxy: A proxy service to manage and route incoming requests, built with nginx.
Each of these services resides under the services
directory in its own dedicated folder.
The kubernetes configurations are under the kubernetes
folder.
advanced/
│
├── kubernetes/
│
├── services/
│ ├── server/
│ ├── admin/
│ └── proxy/
│
├── docker-compose.yml
└── README.md
The NPM packages exposing io.Manager and the Admin UI are hosted in a private NPM repository. To obtain access, contact us.
Once you have access to JFROG you need to generate an .npmrc file that will authenticate you to the repository. To do so:
- Login to JFROG.
- Expand the menu in top right and click "Setup"
- Select "NPM".
- From the dropdown menu select default-npm-virtual.
- Copy the snippet.
- Create an .npmrc file with the copied contents and add it to the services/server and services/admin folders.
By default the server is configured with none authentication, which means it trust the username provided by the client and does no verifications. When connecting to the server the desktop platform will send the username of the current user. With that configuration any client can fetch data from the server, however to access the administrative UI he will need to be granted an extra role. The default set of users that have that role is hardcoded in the server.
To change the list you need to modify the file services/server/src/index.ts
and change the value of the auth_exclusive_users
var.
If you want to switch to another authentication check the Authentication section in our docs.
You can clone the repository, make modifications to any of the service implementations, and then use Docker Compose to test your changes locally.
- Docker
-
Clone the repository:
git clone https://github.com/InteropIO/manager-template cd manager-template
-
Use Docker Compose to build and start the services:
docker-compose -p io-manager up --build
You can also use the npm start
command to run the above Docker Compose command.
After running the command, the services will be started at http://localhost:8080/server
and http://localhost:8080/admin
.
If you want to experiment with the Kubernetes configurations locally, you can use minikube to deploy the application to a local cluster.
- Docker
- Minikube
kubectl
configured to communicate with your Minikube cluster
Use this article to setup minikube.
-
Setup the minikube cluster (this will build the images, load them into minikube and aplly the kubernetes configurations)
npm run setup:mini
-
Run the following to tunnel the services to your local machine:
npm run tunnel:mini
This should make the services available at http://localhost:8080/server
and http://localhost:8080/admin
.
- Use the following command to delete the cluster configurations, build new images, load the new images into minikube and apply the kubernetes configuration again
npm run reload:mini
If you plan to deploy the services to a production Kubernetes cluster on a cloud provider like Azure or AWS, you'll need to make some changes to the provided configurations:
- Volumes: Modify the volume configurations to suit your cloud provider's storage solution. Update the configurations in
kubernetes/volumes.yaml
. - Reverse Proxy Configuration: Adjust the reverse proxy settings based on your deployment environment. Modify the configurations in
kubernetes/reverse-proxy.yaml
.
After making these changes, you can then deploy to your chosen Kubernetes service. Ensure you thoroughly test all configurations in a staging environment before deploying to production to ensure optimal performance and security.
By default, this package is integrated with a MongoDB database. However, io.Manager supports a variety of databases, granting flexibility based on your requirements and deployment environment. Check the Databases section in our documentation for more information.
By default, this packages comes with none authentication. However, io.Manager supports a variety of authentication methods, including Basic, JWT, and OAuth2. Check the Authentication section in our documentation for more information.