gurux.dlms.objects.enums.SecurityPolicy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gurux.dlms Show documentation
Show all versions of gurux.dlms Show documentation
gurux.dlms.java package is used to communicate with DLMS devices.
//
// --------------------------------------------------------------------------
// Gurux Ltd
//
//
//
// Filename: $HeadURL$
//
// Version: $Revision$,
// $Date$
// $Author$
//
// Copyright (c) Gurux Ltd
//
//---------------------------------------------------------------------------
//
// DESCRIPTION
//
// This file is a part of Gurux Device Framework.
//
// Gurux Device Framework is Open Source software; you can redistribute it
// and/or modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; version 2 of the License.
// Gurux Device Framework is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
// See the GNU General Public License for more details.
//
// More information of Gurux products: https://www.gurux.org
//
// This code is licensed under the GNU General Public License v2.
// Full text may be retrieved at http://www.gnu.org/licenses/gpl-2.0.txt
//---------------------------------------------------------------------------
package gurux.dlms.objects.enums;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Set;
/**
* Security policy Enforces authentication and/or encryption algorithm provided
* with security suite. This enumeration is used for version 1.
*/
public enum SecurityPolicy {
/**
* All messages are authenticated using Security Suite 0.
*/
AUTHENTICATED(1),
/**
* All messages are encrypted using Security Suite 0.
*/
ENCRYPTED(2),
/**
* Request is authenticated.
*/
AUTHENTICATED_REQUEST(0x4),
/**
* Request is encrypted.
*/
ENCRYPTED_REQUEST(0x8),
/**
* Request is digitally signed.
*/
DIGITALLY_SIGNED_REQUEST(0x10),
/**
* Response authenticated.
*/
AUTHENTICATED_RESPONSE(0x20),
/**
* Response encrypted.
*/
ENCRYPTED_RESPONSE(0x40),
/**
* Response is digitally signed.
*/
DIGITALLY_SIGNED_RESPONSE(0x80);
/**
* Integer value of enumeration.
*/
private int intValue;
/**
* Collection of integer and enumeration values.
*/
private static java.util.HashMap mappings;
/**
* Get mappings.
*
* @return Hash map of enumeration and integer values.
*/
private static HashMap getMappings() {
synchronized (SecurityPolicy.class) {
if (mappings == null) {
mappings = new HashMap();
}
}
return mappings;
}
/**
* Constructor.
*
* @param value
* Integer value for enumerator.
*/
SecurityPolicy(final int forValue) {
intValue = forValue;
synchronized (SecurityPolicy.class) {
getMappings().put(forValue, this);
}
}
/**
* Get enemerator's integer value.
*
* @return Integer value of enumerator.
*/
public int getValue() {
return intValue;
}
/**
* @return Get enumeration constant values.
*/
private static SecurityPolicy[] getEnumConstants() {
return new SecurityPolicy[] { AUTHENTICATED, ENCRYPTED,
AUTHENTICATED_REQUEST, ENCRYPTED_REQUEST,
DIGITALLY_SIGNED_REQUEST, AUTHENTICATED_RESPONSE,
ENCRYPTED_RESPONSE, DIGITALLY_SIGNED_RESPONSE };
}
/**
* Get enumerator from integer value.
*
* @param value
* integer value.
* @return Enumerator value.
*/
public static java.util.Set forValue(final int value) {
Set values = new HashSet();
// Version 1.
SecurityPolicy[] enums = getEnumConstants();
for (int pos = 0; pos != enums.length; ++pos) {
if ((enums[pos].intValue & value) == enums[pos].intValue) {
values.add(enums[pos]);
}
}
return values;
}
/**
* Converts the enumerated value to integer value.
*
* @param forValue
* The enumerated value.
* @return The integer value.
*/
public static int toInteger(final java.util.Set forValue) {
int tmp = 0;
for (SecurityPolicy it : forValue) {
tmp |= it.getValue();
}
return tmp;
}
}