embedded-framework/middleware/AppManager/src/Protocol/SixFrame/SixFrameHandle.h
2024-03-01 22:41:22 -08:00

56 lines
2.0 KiB
C++

/*
* Copyright (c) 2023 Fancy Code.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef SIX_FRAME_HANDLE_H
#define SIX_FRAME_HANDLE_H
#include "IAppProtocolHandle.h"
#include "StatusCode.h"
#include <cJSON.h>
#include <functional>
#include <iostream>
#include <map>
#include <memory>
#include <vector>
using ResquesHandleFunc = std::function<void(std::multimap<std::string, std::string> &, ResponseHandle, void *)>;
enum class ResposeResult
{
SUCCESSFUL = 0,
FAILED,
END
};
class SixFrameHandle : public IAppProtocolHandle
{
public:
SixFrameHandle();
virtual ~SixFrameHandle() = default;
// virtual void Init(void) {}
// virtual void UnInit(void) {}
void RequestHandle(const char *url, const unsigned int urlLength, ResponseHandle responseHandle,
void *context) override;
private:
void ExtractParamsFromUrl(const std::string &url, std::multimap<std::string, std::string> &paramsMap);
void RequestHandle2(const std::string command, std::multimap<std::string, std::string> &paramsMap,
ResponseHandle responseHandle, void *context);
void DoNothing(std::multimap<std::string, std::string> &paramsMap, ResponseHandle responseHandle, void *context);
void RequestGetProductInfo(std::multimap<std::string, std::string> &paramsMap, ResponseHandle responseHandle,
void *context);
private:
cJSON *MakeResponseResult(const ResposeResult result);
private:
std::map<std::string, ResquesHandleFunc> mResquesHandleFunc;
};
#endif