• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2021 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.android.ims.rcs.uce.request;
18 
19 import com.android.ims.rcs.uce.request.UceRequestManager.RequestManagerCallback;
20 
21 import java.util.HashMap;
22 import java.util.Map;
23 
24 /**
25  * This class is responsible for storing the capabilities request.
26  */
27 public class UceRequestRepository {
28 
29     // Dispatch the UceRequest to be executed.
30     private final UceRequestDispatcher mDispatcher;
31 
32     // Store all the capabilities requests
33     private final Map<Long, UceRequestCoordinator> mRequestCoordinators;
34 
35     private volatile boolean mDestroyed = false;
36 
UceRequestRepository(int subId, RequestManagerCallback callback)37     public UceRequestRepository(int subId, RequestManagerCallback callback) {
38         mRequestCoordinators = new HashMap<>();
39         mDispatcher = new UceRequestDispatcher(subId, callback);
40     }
41 
42     /**
43      * Clear the collection when the instance is destroyed.
44      */
onDestroy()45     public synchronized void onDestroy() {
46         mDestroyed = true;
47         mDispatcher.onDestroy();
48         mRequestCoordinators.forEach((taskId, requestCoord) -> requestCoord.onFinish());
49         mRequestCoordinators.clear();
50     }
51 
52     /**
53      * Add new UceRequestCoordinator and notify the RequestDispatcher to check whether the given
54      * requests can be executed or not.
55      */
addRequestCoordinator(UceRequestCoordinator coordinator)56     public synchronized void addRequestCoordinator(UceRequestCoordinator coordinator) {
57         if (mDestroyed) return;
58         mRequestCoordinators.put(coordinator.getCoordinatorId(), coordinator);
59         mDispatcher.addRequest(coordinator.getCoordinatorId(),
60                 coordinator.getActivatedRequestTaskIds());
61     }
62 
63     /**
64      * Remove the RequestCoordinator from the RequestCoordinator collection.
65      */
removeRequestCoordinator(Long coordinatorId)66     public synchronized UceRequestCoordinator removeRequestCoordinator(Long coordinatorId) {
67         return mRequestCoordinators.remove(coordinatorId);
68 
69     }
70 
71     /**
72      * Retrieve the RequestCoordinator associated with the given coordinatorId.
73      */
getRequestCoordinator(Long coordinatorId)74     public synchronized UceRequestCoordinator getRequestCoordinator(Long coordinatorId) {
75         return mRequestCoordinators.get(coordinatorId);
76     }
77 
getUceRequest(Long taskId)78     public synchronized UceRequest getUceRequest(Long taskId) {
79         for (UceRequestCoordinator coordinator : mRequestCoordinators.values()) {
80             UceRequest request = coordinator.getUceRequest(taskId);
81             if (request != null) {
82                 return request;
83             }
84         }
85         return null;
86     }
87 
88     // Notify that the task is finished.
notifyRequestFinished(Long taskId)89     public synchronized void notifyRequestFinished(Long taskId) {
90         mDispatcher.onRequestFinished(taskId);
91     }
92 }
93