2 * Copyright (C) 2005-2018 Team Kodi
3 * This file is part of Kodi - https://kodi.tv
5 * SPDX-License-Identifier: GPL-2.0-or-later
6 * See LICENSES/README.md for more information.
10 #include "addons/AddonManager.h"
11 #include "addons/addoninfo/AddonType.h"
12 #include "interfaces/generic/ScriptInvocationManager.h"
13 #include "utils/StringUtils.h"
14 #include "utils/log.h"
22 CService::CService(const AddonInfoPtr
& addonInfo
) : CAddon(addonInfo
, AddonType::SERVICE
)
26 CServiceAddonManager::CServiceAddonManager(CAddonMgr
& addonMgr
) :
31 CServiceAddonManager::~CServiceAddonManager()
33 m_addonMgr
.Events().Unsubscribe(this);
34 m_addonMgr
.UnloadEvents().Unsubscribe(this);
37 void CServiceAddonManager::OnEvent(const ADDON::AddonEvent
& event
)
39 if (typeid(event
) == typeid(ADDON::AddonEvents::Enabled
))
43 else if (typeid(event
) == typeid(ADDON::AddonEvents::ReInstalled
))
48 else if (typeid(event
) == typeid(ADDON::AddonEvents::Disabled
) ||
49 typeid(event
) == typeid(ADDON::AddonEvents::Unload
))
55 void CServiceAddonManager::Start()
57 m_addonMgr
.Events().Subscribe(this, &CServiceAddonManager::OnEvent
);
58 m_addonMgr
.UnloadEvents().Subscribe(this, &CServiceAddonManager::OnEvent
);
60 if (m_addonMgr
.GetAddons(addons
, AddonType::SERVICE
))
62 for (const auto& addon
: addons
)
69 void CServiceAddonManager::Start(const std::string
& addonId
)
72 if (m_addonMgr
.GetAddon(addonId
, addon
, AddonType::SERVICE
, OnlyEnabled::CHOICE_YES
))
78 void CServiceAddonManager::Start(const AddonPtr
& addon
)
80 std::unique_lock
<CCriticalSection
> lock(m_criticalSection
);
81 if (m_services
.find(addon
->ID()) != m_services
.end())
83 CLog::Log(LOGDEBUG
, "CServiceAddonManager: {} already started.", addon
->ID());
87 if (StringUtils::EndsWith(addon
->LibPath(), ".py"))
89 CLog::Log(LOGDEBUG
, "CServiceAddonManager: starting {}", addon
->ID());
90 auto handle
= CScriptInvocationManager::GetInstance().ExecuteAsync(addon
->LibPath(), addon
);
93 CLog::Log(LOGERROR
, "CServiceAddonManager: {} failed to start", addon
->ID());
96 m_services
[addon
->ID()] = handle
;
100 void CServiceAddonManager::Stop()
102 m_addonMgr
.Events().Unsubscribe(this);
103 m_addonMgr
.UnloadEvents().Unsubscribe(this);
104 std::unique_lock
<CCriticalSection
> lock(m_criticalSection
);
105 for (const auto& service
: m_services
)
112 void CServiceAddonManager::Stop(const std::string
& addonId
)
114 std::unique_lock
<CCriticalSection
> lock(m_criticalSection
);
115 auto it
= m_services
.find(addonId
);
116 if (it
!= m_services
.end())
119 m_services
.erase(it
);
123 void CServiceAddonManager::Stop(const std::map
<std::string
, int>::value_type
& service
)
125 CLog::Log(LOGDEBUG
, "CServiceAddonManager: stopping {}.", service
.first
);
126 if (!CScriptInvocationManager::GetInstance().Stop(service
.second
))
128 CLog::Log(LOGINFO
, "CServiceAddonManager: failed to stop {} (may have ended)", service
.first
);