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

org.opencastproject.assetmanager.impl.persistence.SnapshotDto Maven / Gradle / Ivy

/*
 * Licensed to The Apereo Foundation under one or more contributor license
 * agreements. See the NOTICE file distributed with this work for additional
 * information regarding copyright ownership.
 *
 *
 * The Apereo Foundation licenses this file to you under the Educational
 * Community 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://opensource.org/licenses/ecl2.txt
 *
 * 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 org.opencastproject.assetmanager.impl.persistence;

import static org.opencastproject.util.data.functions.Functions.chuck;

import org.opencastproject.assetmanager.api.Availability;
import org.opencastproject.assetmanager.api.Snapshot;
import org.opencastproject.assetmanager.impl.SnapshotImpl;
import org.opencastproject.assetmanager.impl.VersionImpl;
import org.opencastproject.mediapackage.MediaPackage;
import org.opencastproject.mediapackage.MediaPackageElement;
import org.opencastproject.mediapackage.MediaPackageParser;

import org.eclipse.persistence.annotations.CascadeOnDelete;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.Arrays;
import java.util.Date;
import java.util.Set;
import java.util.function.Function;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EntityManager;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Index;
import javax.persistence.Lob;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.TableGenerator;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.TypedQuery;
import javax.persistence.UniqueConstraint;

/** JPA DTO. */
@Entity(name = "Snapshot")
@Table(name = "oc_assets_snapshot", indexes = {
    @Index(name = "IX_oc_assets_snapshot_archival_date", columnList = ("archival_date")),
    @Index(name = "IX_oc_assets_snapshot_mediapackage_id", columnList = ("mediapackage_id")),
    @Index(name = "IX_oc_assets_snapshot_organization_id", columnList = ("organization_id")),
    @Index(name = "IX_oc_assets_snapshot_owner", columnList = ("owner")),
    @Index(name = "IX_oc_assets_snapshot_series", columnList = ("series_id, version"))
    }, uniqueConstraints = {
    @UniqueConstraint(columnNames = {"mediapackage_id", "version"}) })
@NamedQueries({
        @NamedQuery(name = "Snapshot.countOrgEvents", query = "select count(distinct s.mediaPackageId) from Snapshot s "
                + "where s.organizationId = :organizationId"),
        @NamedQuery(name = "Snapshot.countEvents", query = "select count(distinct s.mediaPackageId) from Snapshot s"),
        @NamedQuery(name = "Snapshot.countByMediaPackage", query = "select count(s) from Snapshot s "
                + "where s.mediaPackageId = :mediaPackageId"),
        @NamedQuery(name = "Snapshot.countByMediaPackageAndOrg", query = "select count(s) from Snapshot s "
                + "where s.mediaPackageId = :mediaPackageId and s.organizationId = :organizationId")})
// Maintain own generator to support database migrations from Archive to AssetManager
// The generator's initial value has to be set after the data migration.
// Otherwise duplicate key errors will most likely happen.
@TableGenerator(name = "seq_oc_assets_snapshot", initialValue = 0, allocationSize = 50)
public class SnapshotDto {
  private static final Logger logger = LoggerFactory.getLogger(SnapshotDto.class);

  @Id
  @Column(name = "id")
  @GeneratedValue(strategy = GenerationType.TABLE, generator = "seq_oc_assets_snapshot")
  private Long id;

  @Column(name = "mediapackage_id", length = 128, nullable = false)
  private String mediaPackageId;

  @Column(name = "version", nullable = false)
  private Long version;

  @Column(name = "series_id", length = 128)
  private String seriesId;

  @Column(name = "organization_id", length = 128, nullable = false)
  private String organizationId;

  @Column(name = "archival_date", nullable = false)
  @Temporal(TemporalType.TIMESTAMP)
  private Date archivalDate;

  @Column(name = "availability", nullable = false, length = 32)
  private String availability;

  @Column(name = "storage_id", nullable = false, length = 256)
  private String storageId;

  @Column(name = "owner", nullable = false, length = 256)
  private String owner;

  @Lob
  @Column(name = "mediapackage_xml", length = 65535, nullable = false)
  private String mediaPackageXml;

  @CascadeOnDelete
  @OneToMany(targetEntity = AssetDto.class, fetch = FetchType.LAZY, cascade = CascadeType.ALL, mappedBy = "snapshot")
  private Set assets;

  public static SnapshotDto mk(
          MediaPackage mediaPackage,
          VersionImpl version,
          String organization,
          Date archivalDate,
          Availability availability,
          String storageId,
          String owner) {
    try {
      final SnapshotDto dto = new SnapshotDto();
      dto.mediaPackageId = mediaPackage.getIdentifier().toString();
      dto.version = version.value();
      dto.seriesId = mediaPackage.getSeries();
      dto.organizationId = organization;
      dto.archivalDate = archivalDate;
      dto.mediaPackageXml = MediaPackageParser.getAsXml(mediaPackage);
      dto.availability = availability.name();
      dto.storageId = storageId;
      dto.owner = owner;
      return dto;
    } catch (Exception e) {
      return chuck(e);
    }
  }

  public static SnapshotDto mk(Snapshot snapshot) {
    try {
      return mk(snapshot.getMediaPackage(),
              VersionImpl.mk(Long.parseLong(snapshot.getVersion().toString())),
              snapshot.getOrganizationId(),
              snapshot.getArchivalDate(),
              snapshot.getAvailability(),
              snapshot.getStorageId(),
              snapshot.getOwner());
    } catch (Exception e) {
      return chuck(e);
    }
  }

  public Long getId() {
    return Database.insidePersistenceContextCheck(id);
  }

  public VersionImpl getVersion() {
    return Conversions.toVersion(version);
  }

  public String getMediaPackageId() {
    return mediaPackageId;
  }

  public String getStorageId() {
    return storageId;
  }

  void setAvailability(Availability a) {
    this.availability = a.name();
  }

  void setStorageId(String id) {
    this.storageId = id;
  }

  public boolean addAsset(AssetDto asset) {
    return this.assets.add(asset);
  }

  public boolean removeAsset(AssetDto asset) {
    return this.assets.remove(asset);
  }

  public Snapshot toSnapshot() {
    MediaPackage mediaPackage = Conversions.toMediaPackage(mediaPackageXml);
    // ensure elements are tagged `archive`
    for (MediaPackageElement element: mediaPackage.getElements()) {
      if (!Arrays.asList(element.getTags()).contains("archive")) {
        logger.debug("Adding additional tag `archive` to element {} retrieved from asset manager", element);
        element.addTag("archive");
      }
    }
    return new SnapshotImpl(
            id,
            Conversions.toVersion(version),
            organizationId,
            archivalDate,
            Availability.valueOf(availability),
            storageId,
            owner,
            mediaPackage);
  }

  /**
   * Check if any snapshot with the given media package exists.
   *
   * @param mediaPackageId
   *          The media package identifier to check for
   * @return If a snapshot exists for the given media package
   */
  public static Function existsQuery(final String mediaPackageId) {
    return existsQuery(mediaPackageId, null);
  }

  /**
   * Check if any snapshot with the given media package exists.
   *
   * @param mediaPackageId
   *          The media package identifier to check for
   * @param organization
   *          An organization to limit the check for
   * @return If a snapshot exists for the given media package
   */
  public static Function existsQuery(final String mediaPackageId, final String organization) {
    return em -> {
      TypedQuery query;
      if (organization == null) {
        query = em.createNamedQuery("Snapshot.countByMediaPackage", Long.class)
            .setParameter("mediaPackageId", mediaPackageId);
      } else {
        query = em.createNamedQuery("Snapshot.countByMediaPackageAndOrg", Long.class)
            .setParameter("mediaPackageId", mediaPackageId)
            .setParameter("organizationId", organization);
      }
      logger.debug("Executing query {}", query);
      return query.getSingleResult() > 0;
    };
  }

  /**
   * Count events with snapshots in the asset manager
   *
   * @param organization
   *          An organization to count in
   * @return Number of events
   */
  public static Function countEventsQuery(final String organization) {
    return em -> {
      TypedQuery query;
      if (null != organization) {
        query = em.createNamedQuery("Snapshot.countOrgEvents", Long.class)
            .setParameter("organizationId", organization);
      } else {
        query = em.createNamedQuery("Snapshot.countEvents", Long.class);
      }
      logger.debug("Executing query {}", query);
      return query.getSingleResult();
    };
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy