Skip to content

Getting started

The preferred method for production environments is to use docker-compose.yml with a corresponding MongoDB and LDAP instance.

Deploying Docker Container

Getting started is made effortless and rapid by utilizing Docker for deployment, without the need for any prerequisites except for a contemporary Docker version.

Prerequisites

  • Docker
  • Docker Compose
  • Running MongoDB server
  • Running LDAP server

Installation

After downloading the docker-compose.yml file, review it and identify the service for which you want to adjust the configuration parameters.

curl -LO https://enofex.github.io/naikan/docker-compose.yml
docker-compose up -d

Version

The 'latest' tag available on Docker Hub consistently represents the most up-to-date stable release.

Configuration

The Naikan container can be configured using any of the available configuration properties:

MongoDB

Connection String URI Format

Property Default Description
NAIKAN_MONGODB_URI mongodb://localhost:27017/naikan?replicaSet=rs0 Mongo database URI.
NAIKAN_MONGODB_DATABASE naikan Database name. Override URI database.
NAIKAN_MONGODB_TRANSACTION_ENABLED true Enable transaction.

LDAP

Property Default Description
NAIKAN_LDAP_ENABLED true Enable LDAP authentication.
NAIKAN_LDAP_SERVER_URL ldap://localhost:389 LDAP URL of the server.
NAIKAN_LDAP_BASEDN dc=example,dc=com Base suffix from which all operations should originate.
NAIKAN_LDAP_BIND_USERNAME Login username of the server.
NAIKAN_LDAP_BIND_PASSWORD Login password of the server.
NAIKAN_LDAP_ANONYMOUS_READ_ONLY true Whether read-only operations should use an anonymous environment. Disabled by default unless a username is set.
NAIKAN_LDAP_USER_DN_PATTERNS Sets the pattern which will be used to supply a DN for the user. The pattern should be the name relative to the root DN.
NAIKAN_LDAP_USERS_SEARCH_BASE The base used in the user search.
NAIKAN_LDAP_USERS_SEARCH_FILTER The filter expression used in the user search.
NAIKAN_LDAP_ACTIVE_DIRECTORY_DOMAIN The domain name. Must be provided for Active Directory.

Following some example configurations that are known to work of each server implementation. This configuration depends on our schema.

 - NAIKAN_LDAP_SERVER_URL=ldaps://ldap.example.com:636/
 - NAIKAN_LDAP_BASEDN=dc=example,dc=com
 - NAIKAN_LDAP_BIND_USERNAME=user@example.com
 - NAIKAN_LDAP_BIND_PASSWORD=password 
 - NAIKAN_LDAP_USERS_SEARCH_FILTER=(&(objectClass=user)(userPrincipalName={0}))
 - NAIKAN_LDAP_ACTIVE_DIRECTORY_DOMAIN=example.com

CORS Headers

Property Default Description
NAIKAN_CORS_ENABLED true Enable CORS.
NAIKAN_CORS_ALLOW_ORIGIN * A list of origins for which cross-origin requests are allowed.
NAIKAN_CORS_ALLOW_METHODS GET, PUT, POST, PATCH, DELETE, OPTIONS The HTTP methods to allow, e.g. GET, POST, PUT...
NAIKAN_CORS_ALLOW_HEADERS * Set the list of headers that a pre-flight request can list as allowed for use during an actual request.
NAIKAN_CORS_ALLOW_CREDENTIALS true Whether user credentials are supported.
NAIKAN_CORS_MAX_AGE 1800 Configure how long, as a duration, the response from a pre-flight request can be cached by clients.

Server

Property Default Description
NAIKAN_SERVER_COOKIE_SECURE false Whether to always mark the cookie as secure.

JVM

Property Default Description
JAVA_TOOL_OPTIONS To provide more JVM arguments to the JVM,
i.e. -XX:ActiveProcessorCount=4
 - JAVA_TOOL_OPTIONS=-Dlogging.level.root=DEBUG