/******************************************************************************* * Mission Control Technologies, Copyright (c) 2009-2012, United States Government * as represented by the Administrator of the National Aeronautics and Space * Administration. All rights reserved. * * The MCT platform is 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. * * MCT includes source code licensed under additional open source licenses. See * the MCT Open Source Licenses file included with this distribution or the About * MCT Licenses dialog available at runtime from the MCT Help menu for additional * information. *******************************************************************************/ package org.acme.example.telemetry; import gov.nasa.arc.mct.components.AbstractComponent; import gov.nasa.arc.mct.components.FeedProvider; import gov.nasa.arc.mct.components.JAXBModelStatePersistence; import gov.nasa.arc.mct.components.ModelStatePersistence; import gov.nasa.arc.mct.services.activity.TimeService; import java.util.Map; import java.util.concurrent.atomic.AtomicReference; /** * The <code>TelemetryComponent</code> class defines a simple component * representing a single piece of telemetry. In this case, * <code>BaseComponent</code> provides all the functionality required (the * default implementation assumes this component can contain an arbitrary * component). The no argument constructor is required by the MCT platform. This * component will participate in object sharing and persistence like other MCT * components. * */ public class TelemetryComponent extends AbstractComponent implements FeedProvider { public static final String TelemetryPrefix = "example:"; private AtomicReference<TelemetryModel> model = new AtomicReference<TelemetryModel> (new TelemetryModel()); public TelemetryComponent() { super(); } @Override public boolean isLeaf() { return true; } @Override protected <T> T handleGetCapability(Class<T> capability) { if (FeedProvider.class.isAssignableFrom(capability)) { return capability.cast(this); } if (ModelStatePersistence.class.isAssignableFrom(capability)) { JAXBModelStatePersistence<TelemetryModel> persistence = new JAXBModelStatePersistence<TelemetryModel>() { @Override protected TelemetryModel getStateToPersist() { return model.get(); } @Override protected void setPersistentState(TelemetryModel modelState) { model.set(modelState); } @Override protected Class<TelemetryModel> getJAXBClass() { return TelemetryModel.class; } }; return capability.cast(persistence); } return null; } @Override public String getLegendText() { return getDisplayName() + "\n" + getExternalKey(); } @Override public int getMaximumSampleRate() { // This should be based on metadata return 1; } @Override public String getSubscriptionId() { return TelemetryPrefix+getComponentId(); } public TelemetryModel getModel() { return model.get(); } @Override public TimeService getTimeService() { return TimeServiceImpl.getInstance(); } @Override public FeedType getFeedType() { return FeedType.FLOATING_POINT; } @Override public String getCanonicalName() { return getDisplayName(); } @Override public RenderingInfo getRenderingInfo(Map<String, String> data) { String riAsString = data.get(FeedProvider.NORMALIZED_RENDERING_INFO); RenderingInfo ri = null; assert data.get(FeedProvider.NORMALIZED_VALUE_KEY) != null : "The VALUE key is required for a valid status."; assert data.get(FeedProvider.NORMALIZED_TIME_KEY) != null : "The TIME key is required for a valid status."; ri = FeedProvider.RenderingInfo.valueOf(riAsString); return ri; } @Override public long getValidDataExtent() { return System.currentTimeMillis(); } @Override public boolean isPrediction() { return false; } @Override public boolean isNonCODDataBuffer() { // TODO Auto-generated method stub return false; } }