README.org 11 KB

Forms based nginx login and pluggable shiro auth in karaf

    This project contains a set of [[https://karaf.apache.org/manual/latest/#_feature_and_resolver][apache karaf features]] that fills two purposes
  1. Providing a forms based login mechanism for nginx (Note: the webapp provides only authentication. No authorization of individual URLs. All authenticated users get in)
  2. Providing a "poor man's single sign-on" for web applications running in the same apache karaf instance

Status of the project

file:https://travis-ci.org/steinarb/authservice.svg?branch=master file:https://coveralls.io/repos/steinarb/authservice/badge.svg file:https://sonarcloud.io/api/project_badges/measure?project=no.priv.bang.authservice%3Aauthservice&metric=alert_status#.svg file:https://maven-badges.herokuapp.com/maven-central/no.priv.bang.authservice/authservice/badge.svg file:https://www.javadoc.io/badge/no.priv.bang.authservice/authservice.svg

SonarCloud

file:https://sonarcloud.io/api/project_badges/measure?project=no.priv.bang.authservice%3Aauthservice&metric=ncloc#.svg file:https://sonarcloud.io/api/project_badges/measure?project=no.priv.bang.authservice%3Aauthservice&metric=bugs#.svg file:https://sonarcloud.io/api/project_badges/measure?project=no.priv.bang.authservice%3Aauthservice&metric=vulnerabilities#.svg file:https://sonarcloud.io/api/project_badges/measure?project=no.priv.bang.authservice%3Aauthservice&metric=code_smells#.svg file:https://sonarcloud.io/api/project_badges/measure?project=no.priv.bang.authservice%3Aauthservice&metric=coverage#.svg

Installing on karaf

/Note/: The instructions here don't describe a production enviroment, but they describe setting up something that will let the service be startet.

The webapp needs PostgreSQL running, with a database named "ukelonn" containing the table users, and a no-password authentication scheme.

    Instructions:
  1. In bash, clone and build the authservice app:
  2. #+BEGIN_EXAMPLE mkdir -p ~/git/ cd ~/git/ git clone https://github.com/steinarb/authservice.git cd ~/git/authservice/ mvn clean install #+END_EXAMPLE
  3. [https://karaf.apache.org/manual/latest/quick-start.html][Follow the quick start guide to downloading, unpacking and starting apache karaf]]
  4. In the karaf shell, install the authservice feature repository
  5. #+BEGIN_EXAMPLE feature:repo-add mvn:no.priv.bang.authservice/authservice/LATEST/xml/features #+END_EXAMPLE
  6. In the karaf shell, install the feature that installs the authorization service that is used by nginx (this feature installs a set of test users, roles and features)
  7. #+BEGIN_EXAMPLE feature:install authservice-with-derby-dbrealm-and-session #+END_EXAMPLE
  8. Open a browser on the URL http://localhost:8181/authservice and do a login with a valid username/password combination (e.g. "admin/admin")
  9. Open a browser on the URL http://localhost:8181/authservice/check and verify that it doesn't return a 401 HTTP code
  10. Optionally install the user administration UI (not needed for using this service with nginx, but needed for administrating the access)
  11. #+BEGIN_EXAMPLE feature:install user-admin-with-derby #+END_EXAMPLE
  12. Open a browser on the URL http://localhost:8181/authservice/useradmin and test adding/modifying users, roles and permissions

Forms based login for nginx

    The webapp installed by the above installation instructions offers two URLs for use by the [[http://nginx.org/en/docs/http/ngx_http_auth_request_module.html][NGINX auth_request module]]:
  • /auth which will just check the login state of Apache Shiro, returning the status code 401 for failure and 200 for success
  • /login which contains a login form and will authenticate against Apache Shiro

The webapp is implemented as two servlets exposed as OSGi services, that will be picked up by the pax web whiteboard extender.

Installing and configuring nginx

    Instructions:
  1. Install nginx with the auth module. On debian this is done with the command
  2. #+BEGIN_EXAMPLE apt-get update apt-get install nginx-extras #+END_EXAMPLE
  3. Add the following to the /etc/nginx/sites-available/default (adapt this to the actual server/site in use):
  4. #+BEGIN_SRC conf server { listen 80 default_server; listen [::]:80 default_server;

root /var/www/html;

# Add index.php to the list if you are using PHP index index.html index.htm index.nginx-debian.html;

server_name _;

location /authservice { auth_request off; # Necessary for REST API POST to work, shiro will handle authorization here proxy_pass http://localhost:8181/authservice; proxy_cookie_path ~^/authservice.*$ /; proxy_set_header Host $host; }

# Avoid browser attempt at fetching favicon.ico triggering a login and redirecting # a 404 Not Found when there is no favicon.ico on the site (which is perferctly OK # for both the site and the browser) location /favicon.ico { auth_request off; }

location / { # First attempt to serve request as file, then # as directory, then fall back to displaying a 404. try_files $uri $uri/ =404; }

# Auth configuration auth_request /authservice/check; error_page 401 = @error401;

Installing and configuring postgresql

Installing and configuring apache karaf

Integrating with other webapps in karaf

    # If the user is not logged in, redirect to authservice login URL, with redirect information location @error401 { add_header X-Original-URI "$scheme://$http_host$request_uri"; add_header Set-Cookie "NSREDIRECT=$scheme://$http_host$request_uri"; return 302 /authservice/login } } #+END_SRC /Note/: only command examples for debian/ubuntu/etc. are shown, but the overall steps should work on a lot of platforms
  1. Install PostgreSQL, as root do the following command:
  2. #+BEGIN_EXAMPLE apt-get install postgresql #+END_EXAMPLE
  3. Add a PostgreSQL user named "karaf", as root do the following command
  4. #+BEGIN_EXAMPLE PGPASSWORD=karaf sudo -u postgres createuser karaf #+END_EXAMPLE /Note/: Replace the password in the PGPASSWORD environment variable with something other than the example and use that password in the karaf configuration
  5. Create an empty PostgreSQL database named "authservice" owned by user "karaf"
  6. #+BEGIN_EXAMPLE sudo -u postgres createdb -O karaf authservice #+END_EXAMPLE Instructions:
  7. Install apache karaf as a service, either using the karaf installation scripts or by using apt-get and the unofficial karaf deb package
  8. SSH in to the karaf console:
  9. #+BEGIN_EXAMPLE ssh -p 8101 karaf@localhost #+END_EXAMPLE The default password is "karaf" (without the quotes). It might be a good idea to change this. See the karaf documentation for how to change the password
  10. In the karaf console, do the following:
  11. Add connection configuration for the postgresql database:
  12. #+BEGIN_EXAMPLE config:edit no.priv.bang.authservice.db.postgresql.PostgresqlDatabase config:property-set authservice.db.jdbc.url "jdbc:postgresql:///authservice" config:property-set authservice.db.jdbc.user "karaf" config:property-set authservice.db.jdbc.password "karaf" config:update #+END_EXAMPLE /Note/: use the actual password given in the PGPASSWORD environment variable when creating the karaf user
  13. Install authservice from maven central:
  14. #+BEGIN_EXAMPLE feature:repo-add mvn:no.priv.bang.authservice/authservice/LATEST/xml/features feature:install user-admin-with-postgresql #+END_EXAMPLE
  15. Open a the nginx authservice URL in a web browser, e.g. https://myserver.com/authservice/ and:
  16. Log in as user "admin" with password "admin" (without the quotes)
  17. Click on the "User administration UI" link
  18. In the administration UI:
  19. Click on "Administrate users"
  20. Change the password of user "admin"
  21. Add users that are to be able to log in to nginx
  22. /Note/: The nginx config provides only authentication for nginx, no authorization based on the combination of path and role or permission. Therefore there is no need to add roles to users that only needs to log in Users that need to administrate other users, should get the useradmin role
  23. Add some links to the selfservice URLs from your website's top page (or whereever is convenient):
  24. Change password: https://myserver.com/authservice/password/
  25. Modify real namd and email: https://myserver.com/authservice/user
    There are several ways for a webapp to interact with authservice:
  1. Install authservice separately and add OSGi service injections for shiro Realm and Session (all user administration done in the authservice webapplication)
  2. Add the features for the liquibase database setup and the shiro Realm and Session and provide the necessary tables from a different web application's database
  3. Add the features for the authservice UserManagementService implementation, as well as the features for Realm and Session and and implement a user management GUI and webservice on top of the UserManagementService

...or various permutations of the above. With ukelonn I plan to add the authservice tables to the ukelonn database, and then let the ukelonn database provide the database for authservice itself. I have made a first step in the direction of authservice integration by basing ukelonn's user management on the UserManagementService OSGi service, so that it later can be replaced by the authservice implementation of the service.

License

This software is licensed under Apache Public License v 2.0.

See the LICENSE file for the full details.