10a7ce71fSopenharmony_ci/*
20a7ce71fSopenharmony_ci * Copyright (c) 2022 HiSilicon (Shanghai) Technologies CO., LIMITED.
30a7ce71fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
40a7ce71fSopenharmony_ci * you may not use this file except in compliance with the License.
50a7ce71fSopenharmony_ci * You may obtain a copy of the License at
60a7ce71fSopenharmony_ci *
70a7ce71fSopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
80a7ce71fSopenharmony_ci *
90a7ce71fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
100a7ce71fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
110a7ce71fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
120a7ce71fSopenharmony_ci * See the License for the specific language governing permissions and
130a7ce71fSopenharmony_ci * limitations under the License.
140a7ce71fSopenharmony_ci */
150a7ce71fSopenharmony_ci
160a7ce71fSopenharmony_ci#ifndef IOT_HMAC_H
170a7ce71fSopenharmony_ci#define IOT_HMAC_H
180a7ce71fSopenharmony_ci/**
190a7ce71fSopenharmony_ci * This function used to generate the passwd for the mqtt to connect the HW IoT platform
200a7ce71fSopenharmony_ci * @param content: This is the content for the hmac,
210a7ce71fSopenharmony_ci * and usually it is the device passwd set or get from the Iot Platform
220a7ce71fSopenharmony_ci * @param content_len: The length of the content
230a7ce71fSopenharmony_ci * @param key: This is the key for the hmac, and usually it is the time used in the client_id:
240a7ce71fSopenharmony_ci * the format is:yearmonthdatehour:like 1970010100
250a7ce71fSopenharmony_ci * @param key_len: The length of the key
260a7ce71fSopenharmony_ci * @param buf: used to storage the hmac code
270a7ce71fSopenharmony_ci * @param buf_len:the buf length
280a7ce71fSopenharmony_ci * @return:0 success while others failed
290a7ce71fSopenharmony_ci*/
300a7ce71fSopenharmony_ciint HmacGeneratePwd(const unsigned char *content, int contentLen, const unsigned char *key,
310a7ce71fSopenharmony_ci    int keyLen, unsigned char *buf);
320a7ce71fSopenharmony_ci#endif