a64cf9bdd50d3d7f11ab9e5befaf251c8dcf86a6
[so.git] / so-etsi-nfvo / so-etsi-nfvo-ns-lcm / so-etsi-nfvo-ns-lcm-database-service / src / main / java / org / onap / so / etsi / nfvo / ns / lcm / database / repository / NfvoNsInstRepository.java
1 /*-
2  * ============LICENSE_START=======================================================
3  *  Copyright (C) 2020 Nordix Foundation.
4  * ================================================================================
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * 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  * SPDX-License-Identifier: Apache-2.0
18  * ============LICENSE_END=========================================================
19  */
20 package org.onap.so.etsi.nfvo.ns.lcm.database.repository;
21
22 import java.util.Optional;
23 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.NfvoNsInst;
24 import org.onap.so.etsi.nfvo.ns.lcm.database.beans.State;
25 import org.springframework.data.jpa.repository.JpaRepository;
26 import org.springframework.data.jpa.repository.Modifying;
27 import org.springframework.data.jpa.repository.Query;
28 import org.springframework.data.repository.query.Param;
29
30 /**
31  * @author Waqas Ikram (waqas.ikram@est.tech)
32  *
33  */
34 public interface NfvoNsInstRepository extends JpaRepository<NfvoNsInst, String> {
35
36     Optional<NfvoNsInst> findByName(final String name);
37
38     Optional<NfvoNsInst> findByNsInstId(final String nsInstId);
39
40     boolean existsNfvoNsInstByName(final String name);
41
42     @Modifying(clearAutomatically = true)
43     @Query("UPDATE NfvoNsInst SET status = (:state) WHERE nsInstId = (:nsInstId)")
44     int updateNsInstState(@Param("nsInstId") final String nsInstId, @Param("state") final State state);
45
46 }