CdmMetadataWriter.java

  1. /* Copyright 2002-2022 CS GROUP
  2.  * Licensed to CS GROUP (CS) under one or more
  3.  * contributor license agreements.  See the NOTICE file distributed with
  4.  * this work for additional information regarding copyright ownership.
  5.  * CS licenses this file to You under the Apache License, Version 2.0
  6.  * (the "License"); you may not use this file except in compliance with
  7.  * the License.  You may obtain a copy of the License at
  8.  *
  9.  *   http://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  * Unless required by applicable law or agreed to in writing, software
  12.  * distributed under the License is distributed on an "AS IS" BASIS,
  13.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  * See the License for the specific language governing permissions and
  15.  * limitations under the License.
  16.  */
  17. package org.orekit.files.ccsds.ndm.cdm;

  18. import java.io.IOException;
  19. import java.util.ArrayList;
  20. import java.util.List;

  21. import org.orekit.files.ccsds.definitions.BodyFacade;
  22. import org.orekit.files.ccsds.section.AbstractWriter;
  23. import org.orekit.files.ccsds.section.XmlStructureKey;
  24. import org.orekit.files.ccsds.utils.generation.Generator;

  25. /**
  26.  * Writer for Metadata for CCSDS Conjunction Data Messages.
  27.  *
  28.  * @author Melina Vanel
  29.  * @since 11.2
  30.  */
  31. public class CdmMetadataWriter extends AbstractWriter {

  32.     /** Constant for boolean translation. */
  33.     private static final String YES = "YES";

  34.     /** Constant for boolean translation. */
  35.     private static final String NO = "NO";

  36.     /** Metadata. */
  37.     private final CdmMetadata metadata;

  38.     /** Simple constructor.
  39.      * @param metadata metadata to write
  40.      */
  41.     public CdmMetadataWriter(final CdmMetadata metadata) {
  42.         super(XmlStructureKey.metadata.name(), null);
  43.         this.metadata      = metadata;
  44.     }

  45.     /** {@inheritDoc} */
  46.     @Override
  47.     protected void writeContent(final Generator generator) throws IOException {

  48.         generator.writeComments(metadata.getComments());

  49.         // object
  50.         generator.writeEntry(CdmMetadataKey.OBJECT.name(),
  51.                              metadata.getObject(), null, true);
  52.         generator.writeEntry(CdmMetadataKey.OBJECT_DESIGNATOR.name(),
  53.                              metadata.getObjectDesignator(), null, true);
  54.         generator.writeEntry(CdmMetadataKey.CATALOG_NAME.name(),
  55.                              metadata.getCatalogName(), null, true);
  56.         generator.writeEntry(CdmMetadataKey.OBJECT_NAME.name(),
  57.                              metadata.getObjectName(), null, true);
  58.         generator.writeEntry(CdmMetadataKey.INTERNATIONAL_DESIGNATOR.name(),
  59.                              metadata.getInternationalDes(), null, true);
  60.         generator.writeEntry(CdmMetadataKey.OBJECT_TYPE.name(),
  61.                              metadata.getObjectType(), false);

  62.         // originator
  63.         generator.writeEntry(CdmMetadataKey.OPERATOR_CONTACT_POSITION.name(),
  64.                              metadata.getOperatorContactPosition(), null, false);
  65.         generator.writeEntry(CdmMetadataKey.OPERATOR_ORGANIZATION.name(),
  66.                              metadata.getOperatorOrganization(), null, false);
  67.         generator.writeEntry(CdmMetadataKey.OPERATOR_PHONE.name(),
  68.                              metadata.getOperatorPhone(), null, false);
  69.         generator.writeEntry(CdmMetadataKey.OPERATOR_EMAIL.name(),
  70.                              metadata.getOperatorEmail(), null, false);

  71.         // other information
  72.         generator.writeEntry(CdmMetadataKey.EPHEMERIS_NAME.name(),
  73.                              metadata.getEphemName(), null, true);
  74.         generator.writeEntry(CdmMetadataKey.COVARIANCE_METHOD.name(),
  75.                              metadata.getCovarianceMethod(), true);
  76.         generator.writeEntry(CdmMetadataKey.MANEUVERABLE.name(),
  77.                              metadata.getManeuverable().getValue(), null, true);
  78.         if (metadata.getOrbitCenter() != null) {
  79.             generator.writeEntry(CdmMetadataKey.ORBIT_CENTER.name(),
  80.                                  metadata.getOrbitCenter().getName(), null, false);
  81.         }
  82.         generator.writeEntry(CdmMetadataKey.REF_FRAME.name(),
  83.                              metadata.getRefFrame().getName(), null, true);
  84.         // gravity
  85.         if (metadata.getGravityModel() != null) {
  86.             final String model =
  87.                             new StringBuilder().
  88.                             append(metadata.getGravityModel()).
  89.                             append(": ").
  90.                             append(metadata.getGravityDegree()).
  91.                             append("D ").
  92.                             append(metadata.getGravityOrder()).
  93.                             append('O').
  94.                             toString();
  95.             generator.writeEntry(CdmMetadataKey.GRAVITY_MODEL.name(), model, null, false);
  96.         }

  97.         // atmosphere
  98.         generator.writeEntry(CdmMetadataKey.ATMOSPHERIC_MODEL.name(), metadata.getAtmosphericModel(), null, false);

  99.         // N body perturbation
  100.         if (metadata.getNBodyPerturbations() != null && !metadata.getNBodyPerturbations().isEmpty()) {
  101.             final List<String> names = new ArrayList<>();
  102.             for (BodyFacade bf : metadata.getNBodyPerturbations()) {
  103.                 names.add(bf.getName());
  104.             }
  105.             generator.writeEntry(CdmMetadataKey.N_BODY_PERTURBATIONS.name(), names, false);
  106.         }

  107.         // other perturbations
  108.         generator.writeEntry(CdmMetadataKey.SOLAR_RAD_PRESSURE.name(), metadata.getSolarRadiationPressure() ? YES : NO, null, false);
  109.         generator.writeEntry(CdmMetadataKey.EARTH_TIDES.name(), metadata.getEarthTides() ? YES : NO, null, false);
  110.         generator.writeEntry(CdmMetadataKey.INTRACK_THRUST.name(), metadata.getIntrackThrust() ? YES : NO, null, false);

  111.     }

  112. }