mirror of
https://github.com/Unidata/netcdf-c.git
synced 2025-01-24 16:04:40 +08:00
49737888ca
## Improvements to S3 Documentation * Create a new document *quickstart_paths.md* that give a summary of the legal path formats used by netcdf-c. This includes both file paths and URL paths. * Modify *nczarr.md* to remove most of the S3 related text. * Move the S3 text from *nczarr.md* to a new document *cloud.md*. * Add some S3-related text to the *byterange.md* document. Hopefully, this will make it easier for users to find the information they want. ## Rebuild NCZarr Testing In order to avoid problems with running make check in parallel, two changes were made: 1. The *nczarr_test* test system was rebuilt. Now, for each test. any generated files are kept in a test-specific directory, isolated from all other test executions. 2. Similarly, since the S3 test bucket is shared, any generated S3 objects are isolated using a test-specific key path. ## Other S3 Related Changes * Add code to ensure that files created on S3 are reclaimed at end of testing. * Used the bash "trap" command to ensure S3 cleanup even if the test fails. * Cleanup the S3 related configure.ac flag set since S3 is used in several places. So now one should use the option *--enable-s3* instead of *--enable-nczarr-s3*, although the latter is still kept as a deprecated alias for the former. * Get some of the github actions yml to work with S3; required fixing various test scripts adding a secret to access the Unidata S3 bucket. * Cleanup S3 portion of libnetcdf.settings.in and netcdf_meta.h.in and test_common.in. * Merge partial S3 support into dhttp.c. * Create an experimental s3 access library especially for use with Windows. It is enabled by using the options *--enable-s3-internal* (automake) or *-DENABLE_S3_INTERNAL=ON* (CMake). Also add a unit-test for it. * Move some definitions from ncrc.h to ncs3sdk.h ## Other Changes * Provide a default implementation of strlcpy and move this and similar defaults into *dmissing.c*.
81 lines
3.1 KiB
C
81 lines
3.1 KiB
C
#ifndef HEADER_CURL_HMAC_H
|
|
#define HEADER_CURL_HMAC_H
|
|
/*********************************************************************
|
|
* Copyright 2018, UCAR/Unidata
|
|
* See netcdf/COPYRIGHT file for copying and redistribution conditions.
|
|
* ********************************************************************/
|
|
/***************************************************************************
|
|
* _ _ ____ _
|
|
* Project ___| | | | _ \| |
|
|
* / __| | | | |_) | |
|
|
* | (__| |_| | _ <| |___
|
|
* \___|\___/|_| \_\_____|
|
|
*
|
|
* Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
*
|
|
* This software is licensed as described in the file COPYING, which
|
|
* you should have received as part of this distribution. The terms
|
|
* are also available at https://curl.se/docs/copyright.html.
|
|
*
|
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
* copies of the Software, and permit persons to whom the Software is
|
|
* furnished to do so, under the terms of the COPYING file.
|
|
*
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
* KIND, either express or implied.
|
|
*
|
|
* SPDX-License-Identifier: curl
|
|
*
|
|
***************************************************************************/
|
|
|
|
#ifndef CURL_DISABLE_CRYPTO_AUTH
|
|
|
|
#include <curl/curl.h>
|
|
|
|
#define HMAC_MD5_LENGTH 16
|
|
|
|
typedef CURLcode (* HMAC_hinit_func)(void *context);
|
|
typedef void (* HMAC_hupdate_func)(void *context,
|
|
const unsigned char *data,
|
|
unsigned int len);
|
|
typedef void (* HMAC_hfinal_func)(unsigned char *result, void *context);
|
|
|
|
|
|
/* Per-hash function HMAC parameters. */
|
|
struct HMAC_params {
|
|
HMAC_hinit_func
|
|
hmac_hinit; /* Initialize context procedure. */
|
|
HMAC_hupdate_func hmac_hupdate; /* Update context with data. */
|
|
HMAC_hfinal_func hmac_hfinal; /* Get final result procedure. */
|
|
unsigned int hmac_ctxtsize; /* Context structure size. */
|
|
unsigned int hmac_maxkeylen; /* Maximum key length (bytes). */
|
|
unsigned int hmac_resultlen; /* Result length (bytes). */
|
|
};
|
|
|
|
|
|
/* HMAC computation context. */
|
|
struct HMAC_context {
|
|
const struct HMAC_params *hmac_hash; /* Hash function definition. */
|
|
void *hmac_hashctxt1; /* Hash function context 1. */
|
|
void *hmac_hashctxt2; /* Hash function context 2. */
|
|
};
|
|
|
|
|
|
/* Prototypes. */
|
|
struct HMAC_context *Curl_HMAC_init(const struct HMAC_params *hashparams,
|
|
const unsigned char *key,
|
|
unsigned int keylen);
|
|
int Curl_HMAC_update(struct HMAC_context *context,
|
|
const unsigned char *data,
|
|
unsigned int len);
|
|
int Curl_HMAC_final(struct HMAC_context *context, unsigned char *result);
|
|
|
|
extern CURLcode Curl_hmacit(const struct HMAC_params *hashparams,
|
|
const unsigned char *key, const size_t keylen,
|
|
const unsigned char *data, const size_t datalen,
|
|
unsigned char *output);
|
|
|
|
#endif
|
|
|
|
#endif /* HEADER_CURL_HMAC_H */
|