gurux.dlms.secure.GXDLMSSecureServer3 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.secure;
import gurux.dlms.GXDLMSServer3;
import gurux.dlms.IGXCryptoNotifier;
import gurux.dlms.enums.InterfaceType;
import gurux.dlms.objects.GXDLMSAssociationLogicalName;
import gurux.dlms.objects.GXDLMSAssociationShortName;
import gurux.dlms.objects.GXDLMSHdlcSetup;
import gurux.dlms.objects.GXDLMSTcpUdpSetup;
/**
* Implements secured DLMS server.
*
* @author Gurux Ltd.
*/
public abstract class GXDLMSSecureServer3 extends GXDLMSServer3
implements IGXCryptoNotifier {
/**
* Ciphering settings.
*/
private GXCiphering ciphering;
/**
* Constructor.
*
* @param logicalNameReferencing
* Is logical name referencing used.
* @param type
* Interface type.
*/
public GXDLMSSecureServer3(final boolean logicalNameReferencing,
final InterfaceType type) {
super(logicalNameReferencing, type);
// System title format is FLAG ID + serial number.
byte[] st =
new byte[] { 0x47, 0x52, 0x58, 0x00, 0x00, 0x00, 0x00, 0x01 };
ciphering = new GXCiphering(st);
setCipher(ciphering);
}
/**
* Constructor.
*
* @param ln
* Association logical name.
* @param type
* Interface type.
*/
public GXDLMSSecureServer3(final GXDLMSAssociationLogicalName ln,
final InterfaceType type) {
super(ln, type);
// System title format is FLAG ID + serial number.
byte[] st =
new byte[] { 0x47, 0x52, 0x58, 0x00, 0x00, 0x00, 0x00, 0x01 };
ciphering = new GXCiphering(st);
setCipher(ciphering);
}
/**
* Constructor.
*
* @param sn
* Association short name.
* @param type
* Interface type.
*/
public GXDLMSSecureServer3(final GXDLMSAssociationShortName sn,
final InterfaceType type) {
super(sn, type);
// System title format is FLAG ID + serial number.
byte[] st =
new byte[] { 0x47, 0x52, 0x58, 0x00, 0x00, 0x00, 0x00, 0x01 };
ciphering = new GXCiphering(st);
setCipher(ciphering);
}
/**
* Constructor.
*
* @param ln
* Association logical name.
* @param hdlc
* HDLC settings.
*/
public GXDLMSSecureServer3(final GXDLMSAssociationLogicalName ln,
final GXDLMSHdlcSetup hdlc) {
super(ln, hdlc);
// System title format is FLAG ID + serial number.
byte[] st =
new byte[] { 0x47, 0x52, 0x58, 0x00, 0x00, 0x00, 0x00, 0x01 };
ciphering = new GXCiphering(st);
setCipher(ciphering);
}
/**
* Constructor.
*
* @param sn
* Association short name.
* @param hdlc
* HDLC settings.
*/
public GXDLMSSecureServer3(final GXDLMSAssociationShortName sn,
final GXDLMSHdlcSetup hdlc) {
super(sn, hdlc);
byte[] st =
new byte[] { 0x47, 0x52, 0x58, 0x00, 0x00, 0x00, 0x00, 0x01 };
ciphering = new GXCiphering(st);
setCipher(ciphering);
}
/**
* Constructor.
*
* @param ln
* Association logical name.
* @param wrapper
* Wrapper settings.
*/
public GXDLMSSecureServer3(final GXDLMSAssociationLogicalName ln,
final GXDLMSTcpUdpSetup wrapper) {
super(ln, wrapper);
byte[] st =
new byte[] { 0x47, 0x52, 0x58, 0x00, 0x00, 0x00, 0x00, 0x01 };
ciphering = new GXCiphering(st);
setCipher(ciphering);
}
/**
* Constructor.
*
* @param sn
* Association short name.
* @param wrapper
* Wrapper settings.
*/
public GXDLMSSecureServer3(final GXDLMSAssociationShortName sn,
final GXDLMSTcpUdpSetup wrapper) {
super(sn, wrapper);
byte[] st =
new byte[] { 0x47, 0x52, 0x58, 0x00, 0x00, 0x00, 0x00, 0x01 };
ciphering = new GXCiphering(st);
setCipher(ciphering);
}
public final GXCiphering getCiphering() {
return ciphering;
}
/**
* @return Key Encrypting Key, also known as Master key.
*/
public final byte[] getKek() {
return getSettings().getKek();
}
/**
* @param value
* Key Encrypting Key, also known as Master key.
*/
public final void setKek(final byte[] value) {
getSettings().setKek(value);
}
}