1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/include/vfs_util.h
2022-05-17 11:30:51 +02:00

110 lines
2.9 KiB
C

/*
* Copyright (C) 2021 ML!PA Consulting GmbH
*
* This file is subject to the terms and conditions of the GNU Lesser General
* Public License v2.1. See the file LICENSE in the top level directory for more
* details.
*/
/**
* @defgroup sys_vfs_util VFS helper functions
* @ingroup sys_vfs
* @{
*
* @file
* @brief VFS helper functions
*
* @author Benjamin Valentin <benjamin.valentin@ml-pa.com>
*/
#ifndef VFS_UTIL_H
#define VFS_UTIL_H
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Writes the content of a buffer to a file
* If the file already exists, it will be overwritten.
*
* @param[in] file Destination file path
* @param[in] buf Source buffer
* @param[in] len Buffer size
*
* @return 0 on success
* @return negative error from @ref vfs_open, @ref vfs_write
*/
int vfs_file_from_buffer(const char *file, const void *buf, size_t len);
/**
* @brief Reads the content of a file to a buffer
*
* @param[in] file Source file path
* @param[out] buf Destination buffer
* @param[in] len Buffer size
*
* @return number of bytes read on success
* @return -ENOSPC if the file was read successfully but is larger than
* the provided buffer. Only the first @p len bytes were read.
* @return negative error from @ref vfs_open, @ref vfs_read
*/
int vfs_file_to_buffer(const char* file, void* buf, size_t len);
#if MODULE_HASHES || DOXYGEN
/**
* @brief Compute the MD5 message digest of a file
*
* Requires the `hashes` module.
*
* @param[in] file Source file path
* @param[out] digest Destination buffer, must fit @ref MD5_DIGEST_LENGTH bytes
* @param[out] work_buf Work buffer
* @param[in] work_buf_len Size of the work buffer
*
* @return 0 on success
* @return negative error
*/
int vfs_file_md5(const char* file, void *digest,
void *work_buf, size_t work_buf_len);
/**
* @brief Compute the SHA1 message digest of a file
*
* Requires the `hashes` module.
*
* @param[in] file Source file path
* @param[out] digest Destination buffer, must fit @ref SHA1_DIGEST_LENGTH bytes
* @param[out] work_buf Work buffer
* @param[in] work_buf_len Size of the work buffer
*
* @return 0 on success
* @return negative error
*/
int vfs_file_sha1(const char* file, void *digest,
void *work_buf, size_t work_buf_len);
/**
* @brief Compute the SHA256 message digest of a file
*
* Requires the `hashes` module.
*
* @param[in] file Source file path
* @param[out] digest Destination buffer, must fit @ref SHA256_DIGEST_LENGTH bytes
* @param[out] work_buf Work buffer
* @param[in] work_buf_len Size of the work buffer
*
* @return 0 on success
* @return negative error
*/
int vfs_file_sha256(const char* file, void *digest,
void *work_buf, size_t work_buf_len);
#endif
#ifdef __cplusplus
}
#endif
#endif /* VFS_UTIL_H */
/** @} */