/*
* Copyright 2013 The Generic MBean CLI Project
*
* The Generic MBean CLI Project licenses this file to you under the Apache License, version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied.
* See the License for the specific language governing permissions and limitations under the License.
*/
package com.sohail.alam.generic.mbean.cli.security;
import com.sohail.alam.generic.mbean.cli.logger.Logger;
/**
* <p/>
* The {@link DefaultAuthentication} class is responsible for doing the user authentication, which allows
* further use of the CLI.
* The {@link DefaultAuthentication} is a default implementation of the {@link Authentication} interface.
* <p/>
*
* @author Sohail Alam
* @version 1.0.0 Date: 19/5/13
* Time: 5:59 PM
* @since 1.0.0
*/
public class DefaultAuthentication implements Authentication {
/*
* Todo - JMX Authentication & Authorization
* @author sohail.alam
* @date 31/5/13
* @time 5:03 PM
*/
/**
* The Logged in variable.
*/
private boolean loggedIn = false;
/**
* Instantiates a new DefaultAuthentication.
*/
private DefaultAuthentication() {
}
/**
* Gets instance.
*
* @return the instance
*/
public static Authentication getInstance() {
Logger.logTrace("Inside constructor", Authentication.class, false);
return SingletonHolder.instance;
}
/**
* Do authentication.
*
* @param username the USERNAME
* @param password the PASSWORD
*
* @return the boolean
*/
private boolean doAuthentication(String username, String password) {
Logger.logTrace("Inside doAuthentication() method", getClass(), false);
if (USERNAME.equalsIgnoreCase(username) && PASSWORD.equalsIgnoreCase(password)) {
return true;
} else {
return false;
}
}
/**
* Is logged in.
*
* @return the boolean
*/
@Override
public boolean isLoggedIn() {
Logger.logTrace("Inside isLoggedIn() method", getClass(), false);
return loggedIn;
}
/**
* Login boolean.
*
* @param username the username
* @param password the password
*
* @return the boolean
*/
@Override
public boolean login(String username, String password) {
Logger.logTrace("Inside login() method", getClass(), false);
if (doAuthentication(username, password)) {
loggedIn = true;
} else {
loggedIn = false;
}
return loggedIn;
}
/**
* Logout boolean.
*
* @return the boolean
*/
@Override
public boolean logout() {
Logger.logTrace("Inside logout() method", getClass(), false);
loggedIn = false;
return loggedIn;
}
/**
* The type Singleton holder.
* <p/>
* Initialization on Demand Holder (IODH) idiom which requires very little code and
* has zero synchronization overhead. Zero, as in even faster than volatile.
* IODH requires the same number of lines of code as plain old synchronization, and it's faster than DCL!
* <p/>
* {@code SOURCE: http://blog.crazybob.org/2007/01/lazy-loading-singletons.html}
*/
static class SingletonHolder {
/**
* The Instance.
*/
static Authentication instance = new DefaultAuthentication();
}
}