~aleteoryx/muditaos

ref: 140cce4c8981263fcc14fc55a37354a2d555eb33 muditaos/module-services/service-evtmgr/harness/Parser.cpp -rw-r--r-- 2.4 KiB
140cce4c — Lucjan Bryndza [EGD-4029] Prevent call handler recursively (#927) 5 years ago
                                                                                
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
71
// Copyright (c) 2017-2020, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md

#include "Parser.hpp"
#include "Events.hpp"
#include "actions/CellularCMD.hpp"
#include "events/GPIO.hpp"
#include "events/KeyPress.hpp"
#include <Service/Bus.hpp>
#include <json/json11.hpp>
#include <log/log.hpp>
#include <service-evtmgr/Constants.hpp>

namespace harness
{

    using namespace json11;

    /// super simple parser - frame is json
    /// format is explained in Events.hpp
    /// todo have them all somehow nice { from , to, what }
    auto parse(const std::string &request, sys::Service *serv) -> Error
    {

        std::string err;
        // TODO measure stack before and after..
        json11::Json el = Json::parse(request, err);
        if (err.size() != 0 || el.is_object() != true) {
            LOG_ERROR(
                "%s >> %s : %d : %d : %d", request.c_str(), err.c_str(), el.is_array(), el.is_object(), el.type());
            return Error::BadRequest;
        }
        else {
            if (el[Type].is_null()) {
                std::shared_ptr<sys::DataMessage> ptr = std::shared_ptr<sys::DataMessage>(nullptr);
                return Error::NoType;
            }
            switch (el[Type].int_value()) {
            case (int)Events::KeyPress: {
                auto evt = events::KeyPress(el);
                if (evt && evt.msg) {
                    sys::Bus::SendUnicast(evt.msg, service::name::evt_manager, serv);
                }
            } break;
            case static_cast<int>(Events::GSMCmd): {
                bool ret = action::gsm_send(serv, el[Data].string_value());
                if (!ret) {
                    return Error::ParserFailed;
                }
            } break;
            case (int)Events::GPIO: {
                auto evt = events::GPIO(el);
                if (!evt) {
                    LOG_DEBUG("GPIO processing request failed");
                }
                else if (evt.msg) {
                    sys::Bus::SendUnicast(evt.msg, service::name::evt_manager, serv);
                }
                else {
                    LOG_DEBUG("> evt: %s", evt.encode().c_str());
                }
            } break;
            default:
                break;
            };
            return Error::Success;
        }
        return Error::Generic;
    }

}; // namespace harness