io.vertx.ext.auth.impl.realms.ShiroAuthRealmImpl.java Source code

Java tutorial

Introduction

Here is the source code for io.vertx.ext.auth.impl.realms.ShiroAuthRealmImpl.java

Source

/*
 * Copyright 2014 Red Hat, Inc.
 *
 *  All rights reserved. This program and the accompanying materials
 *  are made available under the terms of the Eclipse Public License v1.0
 *  and Apache License v2.0 which accompanies this distribution.
 *
 *  The Eclipse Public License is available at
 *  http://www.eclipse.org/legal/epl-v10.html
 *
 *  The Apache License v2.0 is available at
 *  http://www.opensource.org/licenses/apache2.0.php
 *
 *  You may elect to redistribute this code under either of these licenses.
 */

package io.vertx.ext.auth.impl.realms;

import io.vertx.core.json.JsonObject;
import io.vertx.core.logging.Logger;
import io.vertx.core.logging.impl.LoggerFactory;
import io.vertx.ext.auth.AuthRealm;
import org.apache.shiro.authc.AuthenticationException;
import org.apache.shiro.authc.AuthenticationToken;
import org.apache.shiro.authc.ExcessiveAttemptsException;
import org.apache.shiro.authc.IncorrectCredentialsException;
import org.apache.shiro.authc.LockedAccountException;
import org.apache.shiro.authc.UnknownAccountException;
import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.authz.AuthorizationException;
import org.apache.shiro.mgt.DefaultSecurityManager;
import org.apache.shiro.realm.Realm;
import org.apache.shiro.subject.PrincipalCollection;
import org.apache.shiro.subject.Subject;
import org.apache.shiro.subject.SubjectContext;
import org.apache.shiro.subject.support.DefaultSubjectContext;

/**
 * @author <a href="http://tfox.org">Tim Fox</a>
 */
public class ShiroAuthRealmImpl implements AuthRealm {

    private static final Logger log = LoggerFactory.getLogger(ShiroAuthRealmImpl.class);

    protected DefaultSecurityManager securityManager;
    protected Realm realm;
    protected JsonObject config;

    protected ShiroAuthRealmImpl() {
    }

    public ShiroAuthRealmImpl(Realm realm) {
        this.realm = realm;
    }

    @Override
    public void init(JsonObject config) {
        this.securityManager = new DefaultSecurityManager(realm);
    }

    @Override
    public String login(JsonObject credentials) {
        SubjectContext subjectContext = new DefaultSubjectContext();
        Subject subject = securityManager.createSubject(subjectContext);
        String username = credentials.getString("username");
        String password = credentials.getString("password");
        AuthenticationToken token = new UsernamePasswordToken(username, password);
        try {
            subject.login(token);
            return subject.getPrincipal().toString();
        } catch (UnknownAccountException | IncorrectCredentialsException | LockedAccountException
                | ExcessiveAttemptsException e) {
            return null;
        } catch (AuthenticationException ae) {
            // Unexpected exception - log it
            log.error("Unexpected exception when logging in", ae.getCause());
            return null;
        }
    }

    @Override
    public boolean hasRole(String principal, String role) {
        SubjectContext subjectContext = new DefaultSubjectContext();
        PrincipalCollection coll = new SimplePrincipalCollection(principal);
        subjectContext.setPrincipals(coll);
        Subject subject = securityManager.createSubject(subjectContext);
        return subject.hasRole(role);
    }

    @Override
    public boolean hasPermission(String principal, String permission) {
        SubjectContext subjectContext = new DefaultSubjectContext();
        PrincipalCollection coll = new SimplePrincipalCollection(principal);
        subjectContext.setPrincipals(coll);
        Subject subject = securityManager.createSubject(subjectContext);
        try {
            subject.checkPermission(permission);
            return true;
        } catch (AuthorizationException e) {
            return false;
        }
    }

}