aboutsummaryrefslogtreecommitdiff
path: root/xbmc/filesystem/EventsDirectory.cpp
blob: bc8cfdf0af4d3b8c79ba6a1712b4b2f1fdfddf27 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/*
 *  Copyright (C) 2015-2018 Team Kodi
 *  This file is part of Kodi - https://kodi.tv
 *
 *  SPDX-License-Identifier: GPL-2.0-or-later
 *  See LICENSES/README.md for more information.
 */


#include "EventsDirectory.h"

#include "FileItem.h"
#include "FileItemList.h"
#include "ServiceBroker.h"
#include "URL.h"
#include "events/EventLog.h"
#include "utils/StringUtils.h"

using namespace XFILE;

bool CEventsDirectory::GetDirectory(const CURL& url, CFileItemList &items)
{
  items.ClearProperties();
  items.SetContent("events");

  auto log = CServiceBroker::GetEventLog();
  Events events;

  std::string hostname = url.GetHostName();
  if (hostname.empty())
    events = log->Get();
  else
  {
    bool includeHigherLevels = false;
    // check if we should only retrieve events from a specific level or
    // also from all higher levels
    if (StringUtils::EndsWith(hostname, "+"))
    {
      includeHigherLevels = true;

      // remove the "+" from the end of the hostname
      hostname.pop_back();
    }

    EventLevel level = CEventLog::EventLevelFromString(hostname);

    // get the events of the specified level(s)
    events = log->Get(level, includeHigherLevels);
  }

  for (const auto& eventItem : events)
    items.Add(EventToFileItem(eventItem));

  return true;
}

std::shared_ptr<CFileItem> CEventsDirectory::EventToFileItem(
    const std::shared_ptr<const IEvent>& eventItem)
{
  if (!eventItem)
    return CFileItemPtr();

  CFileItemPtr item(new CFileItem(eventItem));

  item->SetProperty(PROPERTY_EVENT_IDENTIFIER, eventItem->GetIdentifier());
  item->SetProperty(PROPERTY_EVENT_LEVEL, CEventLog::EventLevelToString(eventItem->GetLevel()));
  item->SetProperty(PROPERTY_EVENT_DESCRIPTION, eventItem->GetDescription());

  return item;
}