/* * Copyright (c) 2023 Huawei Device Co., Ltd. * 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 PRINT_HTTP_REQUEST_PROCESS_H_ #define PRINT_HTTP_REQUEST_PROCESS_H_ #ifdef IPPOVERUSB_ENABLE #include #include #include #include "singleton.h" #include "httplib.h" #include "print_usb_manager.h" namespace OHOS::Print { template class DoubleBufQue { public: void push(T& val) { std::lock_guard mtx_locker(mutexSwap); writeQueue.emplace(val); } bool pop(T& val) { if (readQueue.empty()) { std::lock_guard mtx_locker(mutexSwap); if (writeQueue.empty()) { return false; } readQueue.swap(writeQueue); } val = readQueue.front(); readQueue.pop(); return true; } private: std::queue writeQueue; std::queue readQueue; std::mutex mutexSwap; }; class PrintHttpRequestProcess { public: PrintHttpRequestProcess(); virtual ~PrintHttpRequestProcess(); uint32_t ProcessRequest(const httplib::Request &requestData, httplib::Response &responseData, const httplib::ContentReader &content_reader); void SetDeviceName(std::string name); std::string GetDeviceName(); void Stop(); private: std::string PrintOperation(Operation operation); size_t NeedOffset(const std::vector &readTempBuffer); void RecordBufByOperation(Operation operation, size_t requestId, const std::vector &tmVector); void GetContentLength(const std::vector &readTempBuffer, size_t index, bool &findContentLength, size_t &contentLength); void DumpRespIdCode(const std::vector &readTempBuffer, Operation operation, size_t begin, size_t maxSize); bool ProcessDataFromDevice(Operation operation); void StartWriteDataToPrinterLooper(); void StartReadSendDocDataFromPrinterLooper(); void ProcessHttpResponse(httplib::Response &responseData, size_t requestId); void ProcessHttpResponseGetAttr(httplib::Response &responseData, size_t requestId); void ProcessHttpResponseSendDoc(httplib::Response &responseData, size_t requestId); bool DealRequestHeader(const httplib::Request &requestData, std::string &sHeadersAndBody); void CalcReqIdOperaId(const char *data, size_t dataLength, size_t &requestId); void ProcessOtherRequest(const char *data, size_t data_length, std::string &sHeadersAndBody, size_t requestId); void DumpReqIdOperaId(const char *data, size_t data_length); std::string CreateChunk(const char *data, size_t data_length); void CreatWriteDataTask(); void CreatReadSendDocTask(); bool CheckLineEnd(std::vector &readTempBuffer, size_t index); size_t CalculateRequestId(std::vector &readTempBuffer, size_t index, Operation operation); size_t CalculateFileDataBeginIndex(size_t index, Operation operation); int32_t WriteDataSync(const std::string &dataStr); int32_t BulkTransferWriteData(const std::string &dataStr); void ProcessHttpResp(size_t requestId, httplib::Response &responseData, const std::string &sHeadersAndBody); void GetAttrAgain(Operation operation, std::vector &tmVector); private: bool needWriteData = false; bool needReadSendDoc = false; bool needWriteSendDoc = false; bool deviceOpen = true; std::map reqIdOperaIdMap; // requestId + operationId std::map> readBufMap; // requestId + buffer std::map> readSendDocBufMap; // requestId + buffer std::map> readGetAttrBufMap; // requestId + buffer std::string devName; std::mutex mutexCommon; std::mutex mutexGetAttr; std::mutex mutexSendDoc; DoubleBufQue sendDocDataQue; DoubleBufQue ippDataQue; size_t sendDocTotalLen = 0; }; } #endif // PRINT_HTTP_REQUEST_PROCESS_H_ #endif // IPPOVERUSB_ENABLE