Add initial version of code
[nonrtric/plt/rappmanager.git] / rapp-manager-sme / src / main / java / com / oransc / rappmanager / sme / service / SmeLifecycleManager.java
1 /*-
2  * ============LICENSE_START======================================================================
3  * Copyright (C) 2023 Nordix Foundation. All rights reserved.
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  * ============LICENSE_END========================================================================
17  */
18
19 package com.oransc.rappmanager.sme.service;
20
21 import com.oransc.rappmanager.sme.provider.data.APIProviderEnrolmentDetails;
22 import lombok.RequiredArgsConstructor;
23 import org.slf4j.Logger;
24 import org.slf4j.LoggerFactory;
25 import org.springframework.context.SmartLifecycle;
26 import org.springframework.stereotype.Service;
27
28 @Service
29 @RequiredArgsConstructor
30 public class SmeLifecycleManager implements SmartLifecycle {
31
32     Logger logger = LoggerFactory.getLogger(SmeLifecycleManager.class);
33
34     private final SmeDeployer smeDeployer;
35     private boolean running;
36
37     @Override
38     public void start() {
39         try {
40             logger.info("Registering Rapp Manager as AMF");
41             APIProviderEnrolmentDetails providerServiceAMF = smeDeployer.createAMF();
42             logger.info("Rapp Manager AMF Registration Id: " + providerServiceAMF.getApiProvDomId());
43             running = true;
44         }catch (Exception e){
45             logger.warn("Error in initializing AMF", e);
46             running = false;
47         }
48     }
49
50     @Override
51     public void stop() {
52         if (isRunning()) {
53             logger.info("Deleting Rapp Manager as AMF");
54             smeDeployer.deleteAMF();
55             running = false;
56         }
57     }
58
59     @Override
60     public boolean isRunning() {
61         return running;
62     }
63 }