1 /*
2  * Copyright (c) 2021-2024 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "inner_mission_info.h"
17 
18 #include "hilog_tag_wrapper.h"
19 
20 namespace OHOS {
21 namespace AAFwk {
22 namespace {
23 const std::string KEY_MISSION_NAME = "MissionName";
24 const std::string KEY_LAUNCH_MODE = "LaunchMode";
25 const std::string KEY_MISSION_ID = "MissionId";
26 const std::string KEY_RUNNING_STATE = "RunningState";
27 const std::string KEY_LOCKED_STATE = "LockedState";
28 const std::string KEY_CONTINUABLE = "Continuable";
29 const std::string KEY_TIME = "Time";
30 const std::string KEY_LABEL = "Label";
31 const std::string KEY_ICON_PATH = "IconPath";
32 const std::string KEY_WANT = "Want";
33 const std::string KEY_START_METHOD = "StartMethod";
34 const std::string KEY_BUNDLE_NAME = "BundleName";
35 const std::string KEY_UID = "Uid";
36 const std::string KEY_IS_TEMPORARY = "IsTemporary";
37 const std::string KEY_SPEC_FLAG = "SpecFlag";
38 const std::string KEY_HAS_RECONER_INFO = "hasRecoverInfo";
39 }
ToJsonStr() const40 std::string InnerMissionInfo::ToJsonStr() const
41 {
42     nlohmann::json value;
43     value[KEY_MISSION_NAME] = missionName;
44     value[KEY_LAUNCH_MODE] = launchMode;
45     value[KEY_IS_TEMPORARY] = isTemporary;
46     value[KEY_BUNDLE_NAME] = bundleName;
47     value[KEY_START_METHOD] = startMethod;
48     value[KEY_UID] = uid;
49     value[KEY_SPEC_FLAG] = specifiedFlag;
50     value[KEY_MISSION_ID] = missionInfo.id;
51     value[KEY_RUNNING_STATE] = missionInfo.runningState;
52     value[KEY_LOCKED_STATE] = missionInfo.lockedState;
53     value[KEY_CONTINUABLE] = missionInfo.continuable;
54     value[KEY_TIME] = missionInfo.time;
55     value[KEY_LABEL] = missionInfo.label;
56     value[KEY_ICON_PATH] = missionInfo.iconPath;
57     value[KEY_WANT] = missionInfo.want.ToUri();
58     value[KEY_HAS_RECONER_INFO] = hasRecoverInfo;
59 
60     return value.dump();
61 }
62 
FromJsonStr(const std::string & jsonStr)63 bool InnerMissionInfo::FromJsonStr(const std::string &jsonStr)
64 {
65     // Do not throw exceptions in nlohmann::json::parse
66     if (jsonStr.empty()) {
67         return false;
68     }
69     nlohmann::json value = nlohmann::json::parse(jsonStr, nullptr, false);
70     if (value.is_discarded()) {
71         TAG_LOGE(AAFwkTag::ABILITYMGR, "failed to parse json sting: %{private}s.", jsonStr.c_str());
72         return false;
73     }
74 
75     if (!CheckJsonNode(value, KEY_MISSION_NAME, JsonType::STRING)) {
76         return false;
77     }
78     missionName = value[KEY_MISSION_NAME].get<std::string>();
79 
80     if (!CheckJsonNode(value, KEY_LAUNCH_MODE, JsonType::NUMBER)) {
81         return false;
82     }
83     launchMode = value[KEY_LAUNCH_MODE].get<int32_t>();
84     if (!CheckJsonNode(value, KEY_IS_TEMPORARY, JsonType::BOOLEAN)) {
85         return false;
86     }
87     isTemporary = value[KEY_IS_TEMPORARY].get<bool>();
88     if (!CheckJsonNode(value, KEY_START_METHOD, JsonType::NUMBER)) {
89         return false;
90     }
91     startMethod = value[KEY_START_METHOD].get<int32_t>();
92     if (!CheckJsonNode(value, KEY_BUNDLE_NAME, JsonType::STRING)) {
93         return false;
94     }
95     bundleName = value[KEY_BUNDLE_NAME].get<std::string>();
96     if (!CheckJsonNode(value, KEY_UID, JsonType::NUMBER)) {
97         return false;
98     }
99     uid = value[KEY_UID].get<int32_t>();
100     if (!CheckJsonNode(value, KEY_SPEC_FLAG, JsonType::STRING)) {
101         return false;
102     }
103     specifiedFlag = value[KEY_SPEC_FLAG].get<std::string>();
104     if (!CheckJsonNode(value, KEY_MISSION_ID, JsonType::NUMBER)) {
105         return false;
106     }
107     missionInfo.id = value[KEY_MISSION_ID].get<int32_t>();
108     if (!CheckJsonNode(value, KEY_RUNNING_STATE, JsonType::NUMBER)) {
109         return false;
110     }
111     missionInfo.runningState = value[KEY_RUNNING_STATE].get<int32_t>();
112     if (!CheckJsonNode(value, KEY_LOCKED_STATE, JsonType::BOOLEAN)) {
113         return false;
114     }
115     missionInfo.lockedState = value[KEY_LOCKED_STATE].get<bool>();
116     if (!CheckJsonNode(value, KEY_CONTINUABLE, JsonType::BOOLEAN)) {
117         return false;
118     }
119     missionInfo.continuable = value[KEY_CONTINUABLE].get<bool>();
120     if (!CheckJsonNode(value, KEY_TIME, JsonType::STRING)) {
121         return false;
122     }
123     missionInfo.time = value[KEY_TIME].get<std::string>();
124     if (!CheckJsonNode(value, KEY_LABEL, JsonType::STRING)) {
125         return false;
126     }
127     missionInfo.label = value[KEY_LABEL].get<std::string>();
128     if (!CheckJsonNode(value, KEY_ICON_PATH, JsonType::STRING)) {
129         return false;
130     }
131     missionInfo.iconPath = value[KEY_ICON_PATH].get<std::string>();
132     if (!CheckJsonNode(value, KEY_WANT, JsonType::STRING)) {
133         return false;
134     }
135     if (!CheckJsonNode(value, KEY_HAS_RECONER_INFO, JsonType::BOOLEAN)) {
136         return false;
137     }
138     hasRecoverInfo = value[KEY_HAS_RECONER_INFO].get<bool>();
139     Want* want = Want::ParseUri(value[KEY_WANT].get<std::string>());
140     if (want) {
141         missionInfo.want = *want;
142     }
143     return true;
144 }
145 
Dump(std::vector<std::string> & info) const146 void InnerMissionInfo::Dump(std::vector<std::string> &info) const
147 {
148     std::string dumpInfo = "      Mission ID #" + std::to_string(missionInfo.id);
149     info.push_back(dumpInfo);
150     dumpInfo = "        mission name [" + missionName + "]";
151     info.push_back(dumpInfo);
152     dumpInfo = "        runningState [" + std::to_string(missionInfo.runningState) + "]";
153     info.push_back(dumpInfo);
154     dumpInfo = "        lockedState [" + std::to_string(missionInfo.lockedState) + "]";
155     info.push_back(dumpInfo);
156     dumpInfo = "        continuable [" + std::to_string(missionInfo.continuable) + "]";
157     info.push_back(dumpInfo);
158     dumpInfo = "        timeStamp [" + missionInfo.time + "]";
159     info.push_back(dumpInfo);
160     dumpInfo = "        label [" + missionInfo.label + "]";
161     info.push_back(dumpInfo);
162     dumpInfo = "        iconPath [" + missionInfo.iconPath + "]";
163     info.push_back(dumpInfo);
164     dumpInfo = "        want [" + missionInfo.want.ToUri() + "]";
165     info.push_back(dumpInfo);
166 }
167 
CheckJsonNode(nlohmann::json & value,const std::string & node,JsonType jsonType)168 bool InnerMissionInfo::CheckJsonNode(nlohmann::json &value, const std::string &node, JsonType jsonType)
169 {
170     if (value.find(node) == value.end()) {
171         TAG_LOGE(AAFwkTag::ABILITYMGR, "node %{private}s not exists.", node.c_str());
172         return false;
173     }
174 
175     if (jsonType == JsonType::NUMBER) {
176         return value[node].is_number();
177     }
178     if (jsonType == JsonType::STRING) {
179         return value[node].is_string();
180     }
181     if (jsonType == JsonType::BOOLEAN) {
182         return value[node].is_boolean();
183     }
184     return false;
185 }
186 
UpdateMissionInfo(const InnerMissionInfoDto & info)187 void InnerMissionInfo::UpdateMissionInfo(const InnerMissionInfoDto &info)
188 {
189     missionInfo = info.missionInfo;
190     missionName = info.missionName;
191     missionAffinity = info.missionAffinity;
192     launchMode = info.launchMode;
193     startMethod = info.startMethod;
194     bundleName = info.bundleName;
195     uid = info.uid;
196     isTemporary = info.isTemporary;
197     specifiedFlag = info.specifiedFlag;
198     hasRecoverInfo = info.hasRecoverInfo;
199     collaboratorType = info.collaboratorType;
200 }
201 
ConvertInnerMissionInfoDto()202 InnerMissionInfoDto InnerMissionInfo::ConvertInnerMissionInfoDto()
203 {
204     InnerMissionInfoDto info;
205     info.missionInfo = missionInfo;
206     info.missionName = missionName;
207     info.missionAffinity = missionAffinity;
208     info.launchMode = launchMode;
209     info.startMethod = startMethod;
210     info.bundleName = bundleName;
211     info.uid = uid;
212     info.isTemporary = isTemporary;
213     info.specifiedFlag = specifiedFlag;
214     info.hasRecoverInfo = hasRecoverInfo;
215     info.collaboratorType = collaboratorType;
216 
217     return info;
218 }
219 }  // namespace AAFwk
220 }  // namespace OHOS
221