/* * Copyright (c) 2021 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 HILOG_PLUGIN_H #define HILOG_PLUGIN_H #include "file_cache.h" #include "hilog_plugin_config.pb.h" #include "hilog_plugin_result.pb.h" #include "logging.h" #include "plugin_module_api.h" #include #include #include #include class HilogPlugin { public: HilogPlugin(); ~HilogPlugin(); int Start(const uint8_t* configData, uint32_t configSize); int Stop(); int SetWriter(WriterStruct* writer); void Run(void); private: std::string GetPidCmd(); std::string GetlevelCmd(); bool InitHilogCmd(); std::string ClearHilog(); bool OpenLogFile(); int GetDateTime(char* psDateTime, uint32_t size); void ParseLogLineInfo(const char* data, size_t len, HilogLine* info); bool SetHilogLineDetails(const char* data, HilogLine* info); bool TimeStringToNS(const char* data, struct timespec *ts); bool FindFirstNum(char** p); bool RemoveSpaces(char** p); bool FindFirstSpace(char** p); static FILE* CustomPopen(const char* command, const char* type); static int CustomPclose(FILE* fp); bool StringToL(const char* word, long& value); // for ut void SetConfig(HilogConfig& config) { protoConfig_ = config; return; } std::string GetFullCmd() { return fullCmd_; } private: HilogConfig protoConfig_; std::vector protoBuffer_; std::vector dataBuffer_; WriterStruct* resultWriter_ = nullptr; std::mutex mutex_; std::thread workThread_; std::atomic running_ = true; std::string fullCmd_; std::unique_ptr fp_; std::unique_ptr fileCache_ = nullptr; }; #endif // !HILOG_PLUGIN_H