Introduce a script that configures a local testing environment
with ipa default.conf, krb5.conf, and ca.crt from a server hostname.
The lite server configuration allows easy and convenient testing of
IPA server and client code. It uses an existing 389-DS and KRB5 KDC
server on another machine:
    $ contrib/lite-setup.py master.ipa.example
    $ source ~/.ipa/activate.sh
    (ipaenv) $ kinit username
    (ipaenv) $ make lite-server
IPA server UI is available on http://localhost:8888/ipa/
Signed-off-by: Christian Heimes <cheimes@redhat.com>
Reviewed-By: Rob Crittenden <rcritten@redhat.com>
		
	
In-tree development debugging and testing
lite-server and lite-client enable fast development, debugging, and performance analysis of server or client code from an in-tree source directory. The lite-server runs a local web server that uses a remote LDAP and KRB5 server.
Prerequisites
Remote IPA server
Lite-server and lite-client require a running IPA server. The server should have a similar LDAP schema and IPA version as the in-tree sources. Some features may not work if the differences are too great.
The lite-server only needs a working LDAP server and KRB5 server. For KdcProxy or CA-related features the Apache HTTPd and pki-tomcatd service must be running, too.
If the lite-client is configured for remote-server instead of lite-server, then the lite-client uses the HTTP API of the remote server.
Local setup
- Configure and build FreeIPA according to BUILD.txt, TL;DR
$ sudo dnf builddep -b --spec freeipa.spec.in --best --allowerasing --setopt=install_weak_deps=False
$ ./autogen.sh
$ make
- Install additional dependencies for the lite-server
sudo dnf install -y python3-werkzeug python3-watchdog
- 
The FQDN of the remote IPA server must be resolvable. In case the server does not have a valid DNS entry, it is possible to add the hostname and IP address to /etc/hosts.
- 
Create configuration files in ~/.ipa. The lite-server requires an IPA configuration, CA certificate file, KRB5 configuration, Kerberos TGT and a file based credential cache. The scriptcontrib/lite-setup.pycan create a all necessary files for you and sets updefault.conf,krb5.conf,ca.crt, and evenldap.conf:
$ contrib/lite-setup.py master.ipa.example
- Setup environment variables: the lite-setup script also creates a
shell source file that activates a virtualenv like environment. The
source files sets several environment variables for PATH, KRB5, LDAP,
IPA, and Python. The env allows you to run the lite server, ipaclient commands, or OpenLDAP commands:
$ source ~/.ipa/activate.sh
- Acquire a TGT
(ipaenv) $ kinit username
- Run the lite-server
(ipaenv) $ make lite-server
- Run ipaclient commands in another shell session. The lite-setup scripts provides a wrapper that uses the development sources, too.
$ source ~/.ipa/activate.sh
(ipaenv) $ which ipa
~/.ipa/ipa
(ipaenv) $ ipa ping
- Deactivate the environment
(ipaenv) $ deactivate_ipaenv
Limitations
The lite-server does not have access to the ra-agent certificate. Therefore most CA and KRA (vault) operations are not supported.
Tricks and tips
The lite-server has a functional Web UI at http://localhost:8888/ipa/xml. The session is already authenticated with the current TGT.
The lite-setup script has additional options
- --kdcproxyconfigures- krb5.conffor Kerberos over HTTPS
- --debugenables IPA and KRB5 debugging
- --remote-serverlets you run local client commands without a local lite-server.
The make lite-server command supports arguments like
PYTHON=/path/to/custom/interpreter or
LITESERVER_ARGS='--enable-profiler=-'.
By default the dev server supports HTTP only. To switch to HTTPS, you can put a PEM file at ~/.ipa/lite.pem. The PEM file must contain a server certificate, its unencrypted private key and intermediate chain certs (if applicable).