001/*
002 * #%L
003 * HAPI FHIR JPA Server
004 * %%
005 * Copyright (C) 2014 - 2025 Smile CDR, Inc.
006 * %%
007 * Licensed under the Apache License, Version 2.0 (the "License");
008 * you may not use this file except in compliance with the License.
009 * You may obtain a copy of the License at
010 *
011 * http://www.apache.org/licenses/LICENSE-2.0
012 *
013 * Unless required by applicable law or agreed to in writing, software
014 * distributed under the License is distributed on an "AS IS" BASIS,
015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
016 * See the License for the specific language governing permissions and
017 * limitations under the License.
018 * #L%
019 */
020package ca.uhn.fhir.jpa.dao.data;
021
022import ca.uhn.fhir.context.FhirVersionEnum;
023import ca.uhn.fhir.jpa.model.entity.NpmPackageVersionResourceEntity;
024import org.springframework.data.domain.Pageable;
025import org.springframework.data.domain.Slice;
026import org.springframework.data.jpa.repository.JpaRepository;
027import org.springframework.data.jpa.repository.Query;
028import org.springframework.data.repository.query.Param;
029
030public interface INpmPackageVersionResourceDao
031                extends JpaRepository<NpmPackageVersionResourceEntity, Long>, IHapiFhirJpaRepository {
032
033        @Query(
034                        "SELECT e FROM NpmPackageVersionResourceEntity e WHERE e.myResourceType = :resourceType AND e.myFhirVersion = :fhirVersion AND e.myPackageVersion.myCurrentVersion = true")
035        Slice<NpmPackageVersionResourceEntity> findCurrentVersionByResourceType(
036                        Pageable thePage,
037                        @Param("fhirVersion") FhirVersionEnum theFhirVersion,
038                        @Param("resourceType") String theResourceType);
039
040        @Query(
041                        "SELECT e FROM NpmPackageVersionResourceEntity e WHERE e.myCanonicalUrl = :url AND e.myFhirVersion = :fhirVersion AND e.myPackageVersion.myCurrentVersion = true")
042        Slice<NpmPackageVersionResourceEntity> findCurrentVersionByCanonicalUrl(
043                        Pageable thePage,
044                        @Param("fhirVersion") FhirVersionEnum theFhirVersion,
045                        @Param("url") String theCanonicalUrl);
046
047        @Query(
048                        "SELECT e FROM NpmPackageVersionResourceEntity e WHERE e.myCanonicalUrl = :url AND e.myCanonicalVersion = :version AND e.myFhirVersion = :fhirVersion AND e.myPackageVersion.myCurrentVersion = true")
049        Slice<NpmPackageVersionResourceEntity> findCurrentVersionByCanonicalUrlAndVersion(
050                        Pageable theOf,
051                        @Param("fhirVersion") FhirVersionEnum theFhirVersion,
052                        @Param("url") String theCanonicalUrl,
053                        @Param("version") String theCanonicalVersion);
054
055        @Query(
056                        "SELECT e FROM NpmPackageVersionResourceEntity e WHERE e.myCanonicalUrl = :url AND e.myFhirVersion = :fhirVersion AND e.myPackageVersion.myCurrentVersion = true AND e.myPackageVersion.myPackageId = :packageId")
057        Slice<NpmPackageVersionResourceEntity> findCurrentVersionByCanonicalUrlAndPackageId(
058                        Pageable theOf,
059                        @Param("fhirVersion") FhirVersionEnum theFhirVersion,
060                        @Param("url") String theCanonicalUrl,
061                        @Param("packageId") String thePackageId);
062
063        @Query(
064                        "SELECT e FROM NpmPackageVersionResourceEntity e WHERE e.myCanonicalUrl = :url AND e.myFhirVersion = :fhirVersion AND e.myPackageVersion.myCurrentVersion = true AND e.myPackageVersion.myPackageId = :packageId AND e.myPackageVersion.myVersionId = :versionId")
065        Slice<NpmPackageVersionResourceEntity> findCurrentVersionByCanonicalUrlAndPackageIdAndVersion(
066                        Pageable theOf,
067                        @Param("fhirVersion") FhirVersionEnum theFhirVersion,
068                        @Param("url") String theCanonicalUrl,
069                        @Param("packageId") String thePackageId,
070                        @Param("versionId") String theVersionId);
071
072        @Query(
073                        "SELECT e FROM NpmPackageVersionResourceEntity e WHERE e.myCanonicalUrl = :url AND e.myCanonicalVersion = :version AND e.myFhirVersion = :fhirVersion AND e.myPackageVersion.myCurrentVersion = true AND e.myPackageVersion.myPackageId = :packageId")
074        Slice<NpmPackageVersionResourceEntity> findCurrentVersionByCanonicalUrlAndVersionAndPackageId(
075                        Pageable theOf,
076                        @Param("fhirVersion") FhirVersionEnum theFhirVersion,
077                        @Param("url") String theCanonicalUrl,
078                        @Param("version") String theCanonicalVersion,
079                        @Param("packageId") String thePackageId);
080
081        @Query(
082                        "SELECT e FROM NpmPackageVersionResourceEntity e WHERE e.myCanonicalUrl = :url AND e.myCanonicalVersion = :version AND e.myFhirVersion = :fhirVersion AND e.myPackageVersion.myCurrentVersion = true AND e.myPackageVersion.myPackageId = :packageId AND e.myPackageVersion.myVersionId = :versionId")
083        Slice<NpmPackageVersionResourceEntity> findCurrentVersionByCanonicalUrlAndVersionAndPackageIdAndVersion(
084                        Pageable theOf,
085                        @Param("fhirVersion") FhirVersionEnum theFhirVersion,
086                        @Param("url") String theCanonicalUrl,
087                        @Param("version") String theCanonicalVersion,
088                        @Param("packageId") String thePackageId,
089                        @Param("versionId") String theVersionId);
090}