All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.teamscale.index.metadata.abap.AbapFileMetadata Maven / Gradle / Ivy

There is a newer version: 2025.1.0-rc2
Show newest version
package com.teamscale.index.metadata.abap;

import java.io.Serializable;

import org.checkerframework.checker.nullness.qual.Nullable;
import org.conqat.lib.commons.collections.CounterSet;
import org.conqat.lib.commons.collections.PairList;
import org.conqat.lib.commons.test.IndexValueClass;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.teamscale.index.metadata.IFileMetadata;

/**
 * Collects various information about an ABAP object, from an ABAP full or incremental export zip
 * file, that will be persisted and used for analysis in Teamscale.
 */
@IndexValueClass
public class AbapFileMetadata implements IFileMetadata {

	private static final long serialVersionUID = 1L;

	private static final String FILE_PATH_PROPERTY = "filePath";

	/**
	 * Originating system property. This id must not be changed, it is used in the .metadata files
	 * stored in the Abap git.
	 */
	public static final String ORIGINATING_SYSTEM_PROPERTY = "originatingSystem";

	/**
	 * Creation date property. This id must not be changed, it is used in the .metadata files stored in
	 * the Abap git.
	 */
	public static final String CREATION_DATE_PROPERTY = "creationDate";

	/**
	 * Last update date/time property. This id must not be changed, it is used in the .metadata files
	 * stored in the Abap git.
	 */
	public static final String LAST_UPDATE_DATE_TIME_PROPERTY = "lastUpdateDateTime";

	/**
	 * Program type property. This id must not be changed, it is used in the .metadata files stored in
	 * the Abap git.
	 */
	public static final String PROGRAM_TYPE_PROPERTY = "programType";

	/**
	 * Authorization group property. This id must not be changed, it is used in the .metadata files
	 * stored in the Abap git.
	 */
	public static final String AUTHORIZATION_GROUP_PROPERTY = "authorizationGroup";

	/**
	 * RFC Enablement property. This id must not be changed, it is used in the .metadata files stored in
	 * the Abap git.
	 */
	public static final String IS_RFC_ENABLED_PROPERTY = "isRfcEnabled";

	/**
	 * Code generation property. This id must not be changed, it is used in the .metadata files stored
	 * in the Abap git.
	 */
	public static final String IS_GENERATED_CODE_PROPERTY = "isGeneratedCode";

	/**
	 * ABAP language version property. This id must not be changed, it is used in the .metadata files
	 * stored in the Abap git.
	 */
	public static final String LANGUAGE_VERSION_PROPERTY = "languageVersion";

	/**
	 * Release contract property. This id must not be changed, it is used in the .metadata files stored
	 * in the Abap git.
	 */
	public static final String RELEASE_CONTRACT_PROPERTY = "releaseContract";

	/**
	 * Path to the file.
	 */
	@JsonProperty(FILE_PATH_PROPERTY)
	private final String filePath;

	/**
	 * The SAP system in which this ABAP object was created.
	 */
	@JsonProperty(ORIGINATING_SYSTEM_PROPERTY)
	private @Nullable String originatingSystem;

	/**
	 * The date at which this ABAP object was created.
	 */
	@JsonProperty(CREATION_DATE_PROPERTY)
	private long creationDate;

	/**
	 * The date and time at which an ABAP object was last modified.
	 */
	@JsonProperty(LAST_UPDATE_DATE_TIME_PROPERTY)
	private long lastUpdateDateTime;

	/**
	 * The type of program that must be defined at its creation e.g. Executable program, include
	 * program, e.t.c. Read docs
	 * for more information.
	 */
	@JsonProperty(PROGRAM_TYPE_PROPERTY)
	private @Nullable EAbapProgramType programType;

	/**
	 * Authorization group are objects that secure ABAP programs against unauthorized access e.g.
	 * S_PROGRAM. Read the following docs for more information.
	 * 
	 */
	@JsonProperty(AUTHORIZATION_GROUP_PROPERTY)
	private @Nullable String authorizationGroup;

	/**
	 * Stores whether an ABAP object is enabled for RFC communication.
	 */
	@JsonProperty(IS_RFC_ENABLED_PROPERTY)
	private boolean rfcIsEnabled;

	/**
	 * Stores whether an ABAP object is generated. Read
	 * docs for
	 * more information.
	 */
	@JsonProperty(IS_GENERATED_CODE_PROPERTY)
	private boolean codeIsGenerated;

	/**
	 * Stores the ABAP language version of some ABAP object. See language
	 * version for SAP NetWeaver AS ABAP Release 752 and language
	 * version for newer SAP systems.
	 */
	@JsonProperty(LANGUAGE_VERSION_PROPERTY)
	private @Nullable EAbapLanguageVersion languageVersion;

	/**
	 * Stores release contract infos for some ABAP object.
	 */
	@JsonProperty(RELEASE_CONTRACT_PROPERTY)
	private @Nullable ReleaseContract releaseContract;

	/**
	 * Constructor to help create JSON objects.
	 */
	@JsonCreator
	public AbapFileMetadata(@JsonProperty(FILE_PATH_PROPERTY) String filePath,
			@JsonProperty(CREATION_DATE_PROPERTY) long creationDate,
			@JsonProperty(LAST_UPDATE_DATE_TIME_PROPERTY) long lastUpdateDateTime,
			@JsonProperty(ORIGINATING_SYSTEM_PROPERTY) @Nullable String originatingSystem,
			@JsonProperty(PROGRAM_TYPE_PROPERTY) @Nullable EAbapProgramType programType,
			@JsonProperty(AUTHORIZATION_GROUP_PROPERTY) @Nullable String authorizationGroup,
			@JsonProperty(LANGUAGE_VERSION_PROPERTY) @Nullable EAbapLanguageVersion languageVersion,
			@JsonProperty(RELEASE_CONTRACT_PROPERTY) @Nullable ReleaseContract releaseContract,
			@JsonProperty(IS_RFC_ENABLED_PROPERTY) boolean rfcIsEnabled,
			@JsonProperty(IS_GENERATED_CODE_PROPERTY) boolean codeIsGenerated) {
		this.filePath = filePath;
		this.creationDate = creationDate;
		this.lastUpdateDateTime = lastUpdateDateTime;
		this.originatingSystem = originatingSystem;
		this.programType = programType;
		this.authorizationGroup = authorizationGroup;
		this.languageVersion = languageVersion;
		this.releaseContract = releaseContract;
		this.rfcIsEnabled = rfcIsEnabled;
		this.codeIsGenerated = codeIsGenerated;
	}

	@Override
	public PairList getMetrics() {
		PairList metrics = new PairList<>();
		metrics.add(CREATION_DATE_PROPERTY, creationDate);
		metrics.add(LAST_UPDATE_DATE_TIME_PROPERTY, lastUpdateDateTime);
		metrics.add(ORIGINATING_SYSTEM_PROPERTY, toMetric(originatingSystem));
		metrics.add(PROGRAM_TYPE_PROPERTY, EAbapProgramType.toMetric(programType));
		metrics.add(LANGUAGE_VERSION_PROPERTY, EAbapLanguageVersion.toMetric(languageVersion));
		metrics.add(AUTHORIZATION_GROUP_PROPERTY, toMetric(authorizationGroup));
		return metrics;
	}

	/**
	 * Transforms the string value into a matching {@link CounterSet}.
	 * 

* We are using {@link CounterSet counter sets} because we don't lose the amount of files with the * specific string on aggregation in a folder. */ private CounterSet toMetric(@Nullable String value) { if (value == null) { // CounterSets are not allowed to have null as key value return CounterSet.empty(); } else { return new CounterSet<>(value, 1); } } /** Returns the {@link #filePath}. */ public String getFilePath() { return filePath; } /** Returns the {@link #originatingSystem}. */ public String getOriginatingSystem() { return originatingSystem; } /** Returns the creation date. */ public long getCreationDate() { return creationDate; } /** Returns the last update date and time. */ public long getLastUpdateDateTime() { return lastUpdateDateTime; } /** @see #originatingSystem */ public void setOriginatingSystem(String originatingSystem) { this.originatingSystem = originatingSystem; } /** @see #lastUpdateDateTime */ public void setLastUpdateDateTime(long lastUpdateDateTime) { this.lastUpdateDateTime = lastUpdateDateTime; } /** @see #creationDate */ public void setCreationDate(long creationDate) { this.creationDate = creationDate; } /** @see #rfcIsEnabled */ public boolean isRfcEnabled() { return rfcIsEnabled; } /** @see #rfcIsEnabled */ public void setRfcEnabled(boolean rfcIsEnabled) { this.rfcIsEnabled = rfcIsEnabled; } /** @see #programType */ public void setProgramType(EAbapProgramType programType) { this.programType = programType; } /** @see #languageVersion */ public void setLanguageVersion(EAbapLanguageVersion languageVersion) { this.languageVersion = languageVersion; } /** @see #authorizationGroup */ public void setAuthorizationGroup(String authorizationGroup) { this.authorizationGroup = authorizationGroup; } /** @see #releaseContract */ public void setReleaseContract(ReleaseContract releaseContract) { this.releaseContract = releaseContract; } /** @see #codeIsGenerated */ public void setCodeIsGenerated(boolean codeIsGenerated) { this.codeIsGenerated = codeIsGenerated; } /** @see #programType */ public EAbapProgramType getProgramType() { return programType; } /** @see #languageVersion */ public EAbapLanguageVersion getLanguageVersion() { return languageVersion; } /** @see #authorizationGroup */ public String getAuthorizationGroup() { return authorizationGroup; } /** @see #releaseContract */ public ReleaseContract getReleaseContract() { return releaseContract; } /** @see #codeIsGenerated */ public boolean isCodeGenerated() { return codeIsGenerated; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy