CdmMetadataWriter.java

  1. /* Copyright 2002-2025 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.     /** Metadata. */
  33.     private final CdmMetadata metadata;

  34.     /** Simple constructor.
  35.      * @param metadata metadata to write
  36.      */
  37.     public CdmMetadataWriter(final CdmMetadata metadata) {
  38.         super(XmlStructureKey.metadata.name(), null);
  39.         this.metadata      = metadata;
  40.     }

  41.     /** {@inheritDoc} */
  42.     @Override
  43.     protected void writeContent(final Generator generator) throws IOException {

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

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

  58.         // originator
  59.         generator.writeEntry(CdmMetadataKey.OPERATOR_CONTACT_POSITION.name(),
  60.                              metadata.getOperatorContactPosition(), null, false);
  61.         generator.writeEntry(CdmMetadataKey.OPERATOR_ORGANIZATION.name(),
  62.                              metadata.getOperatorOrganization(), null, false);
  63.         generator.writeEntry(CdmMetadataKey.OPERATOR_PHONE.name(),
  64.                              metadata.getOperatorPhone(), null, false);
  65.         generator.writeEntry(CdmMetadataKey.OPERATOR_EMAIL.name(),
  66.                              metadata.getOperatorEmail(), null, false);

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

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

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

  103.         if (metadata.getSolarRadiationPressure() != null) {
  104.             generator.writeEntry(CdmMetadataKey.SOLAR_RAD_PRESSURE.name(), metadata.getSolarRadiationPressure().name(),
  105.                             null, false);
  106.         }
  107.         if (metadata.getEarthTides() != null) {
  108.             generator.writeEntry(CdmMetadataKey.EARTH_TIDES.name(), metadata.getEarthTides().name(),
  109.                             null, false);
  110.         }
  111.         if (metadata.getIntrackThrust() != null) {
  112.             generator.writeEntry(CdmMetadataKey.INTRACK_THRUST.name(), metadata.getIntrackThrust().name(),
  113.                             null, false);
  114.         }

  115.     }

  116. }