[Release] wrt_0.8.251
[platform/framework/web/wrt.git] / src / api_new / core_module.cpp
1 /*
2  * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
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  * @file    core_module.cpp
18  * @author  Przemyslaw Ciezkowski (p.ciezkowski@samsung.com)
19  * @author  Andrzej Surdej (a.surdej@samsung.com)
20  * @version 1.0
21  * @brief   File contains definitions of wrt core module.
22  */
23
24 #include "core_module.h"
25 #include "runnable_widget_object.h"
26 #include <string>
27 #include <main_thread.h>
28 #include <dpl/log/log.h>
29 #include <dpl/assert.h>
30 #include <dpl/exception.h>
31 #include <dpl/singleton_impl.h>
32 #include <dpl/optional_typedefs.h>
33 #include "localization_setting.h"
34 #include <dpl/wrt-dao-ro/global_config.h>
35 #include <profiling_util.h>
36 #include <widget_deserialize_model.h>
37 #include <dpl/wrt-dao-ro/widget_dao_read_only.h>
38 #include <dpl/wrt-dao-ro/global_dao_read_only.h>
39
40 IMPLEMENT_SINGLETON(WRT::CoreModule)
41
42 namespace {
43 const char* const TEXT_DOMAIN = "wrt";
44 const char* const TEXT_LOCALE_PATH = "/usr/share/wrt-engine/locale";
45
46 std::string cutOffFileName(const std::string& path)
47 {
48     size_t found = path.find_last_of("/");
49     if (found == std::string::npos) {
50         return path;
51     } else {
52         return path.substr(0, found);
53     }
54 }
55
56 bool isDir(const std::string& path)
57 {
58     struct stat st;
59     if (0 == stat(path.c_str(), &st) && S_ISDIR(st.st_mode)) {
60         return true;
61     }
62     LogError("Cannot access directory [ " << path << " ]");
63     return false;
64 }
65
66 bool checkPaths()
67 {
68     using namespace WrtDB;
69     using namespace WrtDB::GlobalConfig;
70
71     bool if_ok = true;
72     if_ok &= (isDir(cutOffFileName(GetWrtDatabaseFilePath())));
73     if_ok &= (isDir(GetDevicePluginPath()));
74     if_ok &= (isDir(GetUserInstalledWidgetPath()));
75     return if_ok;
76 }
77 } // namespace anonymous
78
79 namespace WRT {
80 class CoreModuleImpl
81 {
82   public:
83
84     CoreModuleImpl() : m_initialized(false)
85     {
86         LogDebug("enter");
87     }
88
89     ~CoreModuleImpl()
90     {
91         LogDebug("Core module implementation destroyed");
92     }
93
94     bool Init()
95     {
96         if (!m_initialized) {
97             ADD_PROFILING_POINT("CoreModule::Init", "point");
98             DPL::Log::LogSystemSingleton::Instance().SetTag("WRT");
99             LogDebug("Initialize");
100             if (!checkPaths()) {
101                 LogError("Required path does not exist");
102                 return false;
103             }
104             Try
105             {
106                 ADD_PROFILING_POINT("attach databases", "start");
107                 MainThreadSingleton::Instance().AttachDatabases();
108                 ADD_PROFILING_POINT("attach databases", "stop");
109                 LogDebug("Initialize finished");
110             } catch (const DPL::Exception& ex) {
111                 LogError("Internal Error during screen preparation:");
112                 DPL::Exception::DisplayKnownException(ex);
113                 /* TODO:
114                  * Do deinitialization: check on which step exception occured
115                  * and deinitialize only initialized parts.
116                  */
117                 return false;
118             }
119             bindtextdomain(TEXT_DOMAIN, TEXT_LOCALE_PATH);
120             m_initialized = true;
121         }
122         return true;
123     }
124
125     void Terminate()
126     {
127         MainThreadSingleton::Instance().DetachDatabases();
128         m_initialized = false;
129     }
130
131     RunnableWidgetObjectPtr getRunnableWidgetObject(
132         const std::string& tizenId,
133         DPL::OptionalUInt appControlIndex)
134     {
135         try {
136             RunnableWidgetObjectPtr runnable;
137             WidgetModelPtr model =
138                 Domain::deserializeWidgetModel(tizenId, appControlIndex);
139             if (!!model) {
140                 runnable.reset(new RunnableWidgetObject(model));
141             }
142             return runnable;
143         } catch (WrtDB::WidgetDAOReadOnly::Exception::WidgetNotExist) {
144             LogDebug("Widget not found.");
145             return RunnableWidgetObjectPtr();
146         }
147     }
148
149     CoreModule::NetworkAccessMode homeNetworkAccess()
150     {
151         switch (WrtDB::GlobalDAOReadOnly::GetHomeNetworkDataUsage()) {
152         case WrtDB::GlobalDAOReadOnly::NEVER_CONNECT:
153             return CoreModule::NEVER_CONNECT;
154         case WrtDB::GlobalDAOReadOnly::ALWAYS_ASK:
155             return CoreModule::ALWAYS_ASK;
156         case WrtDB::GlobalDAOReadOnly::CONNECT_AUTOMATICALLY:
157             return CoreModule::CONNECT_AUTOMATICALLY;
158         default:
159             break;
160         }
161         LogWarning("using default value");
162         return CoreModule::ALWAYS_ASK;
163     }
164
165     CoreModule::NetworkAccessMode roamingNetworkAccess()
166     {
167         switch (WrtDB::GlobalDAOReadOnly::GetRoamingDataUsage()) {
168         case WrtDB::GlobalDAOReadOnly::NEVER_CONNECT:
169             return CoreModule::NEVER_CONNECT;
170         case WrtDB::GlobalDAOReadOnly::ALWAYS_ASK:
171             return CoreModule::ALWAYS_ASK;
172         case WrtDB::GlobalDAOReadOnly::CONNECT_AUTOMATICALLY:
173             return CoreModule::CONNECT_AUTOMATICALLY;
174         default:
175             break;
176         }
177         LogWarning("using default value");
178         return CoreModule::ALWAYS_ASK;
179     }
180
181   private:
182     bool m_initialized;
183 };
184
185 CoreModule::CoreModule() : m_impl(new CoreModuleImpl())
186 {}
187
188 CoreModule::~CoreModule()
189 {}
190
191 bool CoreModule::Init()
192 {
193     return m_impl->Init();
194 }
195
196 void CoreModule::Terminate()
197 {
198     return m_impl->Terminate();
199 }
200
201 RunnableWidgetObjectPtr CoreModule::getRunnableWidgetObject(
202     const std::string& tizenId,
203     DPL::OptionalUInt appControlIndex)
204 {
205     return m_impl->getRunnableWidgetObject(tizenId, appControlIndex);
206 }
207
208 CoreModule::NetworkAccessMode CoreModule::homeNetworkAccess()
209 {
210     return m_impl->homeNetworkAccess();
211 }
212
213 CoreModule::NetworkAccessMode CoreModule::roamingNetworkAccess()
214 {
215     return m_impl->roamingNetworkAccess();
216 }
217
218 } /* namespace WRT */