~aleteoryx/muditaos

ref: c5e533f94f68cd4e2924e8d3d3e485612214082f muditaos/module-services/service-cellular/src/VolteHandlerImpl.cpp -rw-r--r-- 1.1 KiB
c5e533f9 — Marcin Zieliński [MOS-770] Replace VoLTE state switching mechanism 3 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
// Copyright (c) 2017-2022, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md

#include "VolteHandlerImpl.hpp"

namespace cellular::internal
{
    bool ModemResponseParserImpl::operator()(QcfgImsResult const &response, bool requestedState) const
    {
        using namespace at::response::qcfg_ims;

        if (!response) {
            throw std::runtime_error("[VoLTE] modem responded with error to QCFG_IMS");
        }

        std::pair<IMSState, VoLTEIMSState> parsed;
        if (!at::response::parseQCFG_IMS(response, parsed)) {
            throw std::runtime_error("[VoLTE] unable to parse modem's response to QCFG_IMS");
        }

        auto const &ims          = parsed.first;
        bool stateMatchesRequest = (ims != IMSState::Disable) == requestedState;
        LOG_INFO("[VoLTE] current IMS state: %s which %s expectation",
                 magic_enum::enum_name(ims).data(),
                 ((stateMatchesRequest) ? "matches" : "doesn't match"));
        return stateMatchesRequest;
    }
} // namespace cellular::internal