/* * Copyright 2015 Kevin Herron * * Licensed 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.digitalpetri.opcua.stack.core.types.structured; import com.digitalpetri.opcua.stack.core.Identifiers; import com.digitalpetri.opcua.stack.core.serialization.DelegateRegistry; import com.digitalpetri.opcua.stack.core.serialization.UaDecoder; import com.digitalpetri.opcua.stack.core.serialization.UaEncoder; import com.digitalpetri.opcua.stack.core.types.UaDataType; import com.digitalpetri.opcua.stack.core.types.builtin.DateTime; import com.digitalpetri.opcua.stack.core.types.builtin.NodeId; @UaDataType("AggregateFilterResult") public class AggregateFilterResult extends MonitoringFilterResult { public static final NodeId TypeId = Identifiers.AggregateFilterResult; public static final NodeId BinaryEncodingId = Identifiers.AggregateFilterResult_Encoding_DefaultBinary; public static final NodeId XmlEncodingId = Identifiers.AggregateFilterResult_Encoding_DefaultXml; protected final DateTime _revisedStartTime; protected final Double _revisedProcessingInterval; protected final AggregateConfiguration _revisedAggregateConfiguration; public AggregateFilterResult() { super(); this._revisedStartTime = null; this._revisedProcessingInterval = null; this._revisedAggregateConfiguration = null; } public AggregateFilterResult(DateTime _revisedStartTime, Double _revisedProcessingInterval, AggregateConfiguration _revisedAggregateConfiguration) { super(); this._revisedStartTime = _revisedStartTime; this._revisedProcessingInterval = _revisedProcessingInterval; this._revisedAggregateConfiguration = _revisedAggregateConfiguration; } public DateTime getRevisedStartTime() { return _revisedStartTime; } public Double getRevisedProcessingInterval() { return _revisedProcessingInterval; } public AggregateConfiguration getRevisedAggregateConfiguration() { return _revisedAggregateConfiguration; } @Override public NodeId getTypeId() { return TypeId; } @Override public NodeId getBinaryEncodingId() { return BinaryEncodingId; } @Override public NodeId getXmlEncodingId() { return XmlEncodingId; } public static void encode(AggregateFilterResult aggregateFilterResult, UaEncoder encoder) { encoder.encodeDateTime("RevisedStartTime", aggregateFilterResult._revisedStartTime); encoder.encodeDouble("RevisedProcessingInterval", aggregateFilterResult._revisedProcessingInterval); encoder.encodeSerializable("RevisedAggregateConfiguration", aggregateFilterResult._revisedAggregateConfiguration != null ? aggregateFilterResult._revisedAggregateConfiguration : new AggregateConfiguration()); } public static AggregateFilterResult decode(UaDecoder decoder) { DateTime _revisedStartTime = decoder.decodeDateTime("RevisedStartTime"); Double _revisedProcessingInterval = decoder.decodeDouble("RevisedProcessingInterval"); AggregateConfiguration _revisedAggregateConfiguration = decoder.decodeSerializable("RevisedAggregateConfiguration", AggregateConfiguration.class); return new AggregateFilterResult(_revisedStartTime, _revisedProcessingInterval, _revisedAggregateConfiguration); } static { DelegateRegistry.registerEncoder(AggregateFilterResult::encode, AggregateFilterResult.class, BinaryEncodingId, XmlEncodingId); DelegateRegistry.registerDecoder(AggregateFilterResult::decode, AggregateFilterResult.class, BinaryEncodingId, XmlEncodingId); } }