/* * Copyright (c) 2024 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 VERIFY_IMPL_H #define VERIFY_IMPL_H #include "ffi_remote_data.h" #include "pub_key.h" #include "signature.h" namespace OHOS { namespace CryptoFramework { class VerifyImpl : public OHOS::FFI::FFIData { DECL_TYPE(VerifyImpl, OHOS::FFI::FFIData) public: explicit VerifyImpl(HcfVerify *verify); ~VerifyImpl(); HcfVerify *GetVerify(); HcfResult Init(HcfPubKey *pubKey); HcfResult Update(HcfBlob *input); bool Verify(HcfBlob *data, HcfBlob signatureData, int32_t *errCode); HcfResult Recover(HcfBlob input, HcfBlob *output); HcfResult SetVerifySpecByNum(int32_t itemValue); HcfResult SetVerifySpecByArr(HcfBlob itemValue); HcfResult GetVerifySpecString(SignSpecItem item, char *itemValue); HcfResult GetVerifySpecNum(SignSpecItem item, int32_t *itemValue); private: HcfVerify *verify_ = nullptr; }; } } #endif