|  | #ifndef HEADER_CURL_TOOL_METALINK_H | 
|  | #define HEADER_CURL_TOOL_METALINK_H | 
|  | /*************************************************************************** | 
|  | *                                  _   _ ____  _ | 
|  | *  Project                     ___| | | |  _ \| | | 
|  | *                             / __| | | | |_) | | | 
|  | *                            | (__| |_| |  _ <| |___ | 
|  | *                             \___|\___/|_| \_\_____| | 
|  | * | 
|  | * Copyright (C) 1998 - 2014, 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.haxx.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. | 
|  | * | 
|  | ***************************************************************************/ | 
|  | #include "tool_setup.h" | 
|  |  | 
|  | struct GlobalConfig; | 
|  | struct OperationConfig; | 
|  |  | 
|  | /* returns 1 for success, 0 otherwise (we use OpenSSL *_Init fncs directly) */ | 
|  | typedef int (* Curl_digest_init_func)(void *context); | 
|  |  | 
|  | typedef void (* Curl_digest_update_func)(void *context, | 
|  | const unsigned char *data, | 
|  | unsigned int len); | 
|  | typedef void (* Curl_digest_final_func)(unsigned char *result, void *context); | 
|  |  | 
|  | typedef struct { | 
|  | Curl_digest_init_func     digest_init;   /* Initialize context procedure */ | 
|  | Curl_digest_update_func   digest_update; /* Update context with data */ | 
|  | Curl_digest_final_func    digest_final;  /* Get final result procedure */ | 
|  | unsigned int           digest_ctxtsize;  /* Context structure size */ | 
|  | unsigned int           digest_resultlen; /* Result length (bytes) */ | 
|  | } digest_params; | 
|  |  | 
|  | typedef struct { | 
|  | const digest_params   *digest_hash;      /* Hash function definition */ | 
|  | void                  *digest_hashctx;   /* Hash function context */ | 
|  | } digest_context; | 
|  |  | 
|  | digest_context * Curl_digest_init(const digest_params *dparams); | 
|  | int Curl_digest_update(digest_context *context, | 
|  | const unsigned char *data, | 
|  | unsigned int len); | 
|  | int Curl_digest_final(digest_context *context, unsigned char *result); | 
|  |  | 
|  | typedef struct { | 
|  | const char *hash_name; | 
|  | const digest_params *dparams; | 
|  | } metalink_digest_def; | 
|  |  | 
|  | typedef struct { | 
|  | const char *alias_name; | 
|  | const metalink_digest_def *digest_def; | 
|  | } metalink_digest_alias; | 
|  |  | 
|  | typedef struct metalink_checksum { | 
|  | const metalink_digest_def *digest_def; | 
|  | /* raw digest value, not ascii hex digest */ | 
|  | unsigned char *digest; | 
|  | } metalink_checksum; | 
|  |  | 
|  | typedef struct metalink_resource { | 
|  | struct metalink_resource *next; | 
|  | char *url; | 
|  | } metalink_resource; | 
|  |  | 
|  | typedef struct metalinkfile { | 
|  | struct metalinkfile *next; | 
|  | char *filename; | 
|  | metalink_checksum *checksum; | 
|  | metalink_resource *resource; | 
|  | } metalinkfile; | 
|  |  | 
|  | #ifdef USE_METALINK | 
|  |  | 
|  | /* | 
|  | * curl requires libmetalink 0.1.0 or newer | 
|  | */ | 
|  | #define CURL_REQ_LIBMETALINK_MAJOR  0 | 
|  | #define CURL_REQ_LIBMETALINK_MINOR  1 | 
|  | #define CURL_REQ_LIBMETALINK_PATCH  0 | 
|  |  | 
|  | #define CURL_REQ_LIBMETALINK_VERS  ((CURL_REQ_LIBMETALINK_MAJOR * 10000) + \ | 
|  | (CURL_REQ_LIBMETALINK_MINOR * 100) + \ | 
|  | CURL_REQ_LIBMETALINK_PATCH) | 
|  |  | 
|  | extern const digest_params MD5_DIGEST_PARAMS[1]; | 
|  | extern const digest_params SHA1_DIGEST_PARAMS[1]; | 
|  | extern const digest_params SHA256_DIGEST_PARAMS[1]; | 
|  |  | 
|  | #include <metalink/metalink.h> | 
|  |  | 
|  | /* | 
|  | * Counts the resource in the metalinkfile. | 
|  | */ | 
|  | int count_next_metalink_resource(metalinkfile *mlfile); | 
|  | void clean_metalink(struct OperationConfig *config); | 
|  |  | 
|  | /* | 
|  | * Performs final parse operation and extracts information from | 
|  | * Metalink and creates metalinkfile structs. | 
|  | * | 
|  | * This function returns 0 if it succeeds without warnings, or one of | 
|  | * the following negative error codes: | 
|  | * | 
|  | * -1: Parsing failed; or no file is found | 
|  | * -2: Parsing succeeded with some warnings. | 
|  | */ | 
|  | int parse_metalink(struct OperationConfig *config, struct OutStruct *outs, | 
|  | const char *metalink_url); | 
|  |  | 
|  | /* | 
|  | * Callback function for CURLOPT_WRITEFUNCTION | 
|  | */ | 
|  | size_t metalink_write_cb(void *buffer, size_t sz, size_t nmemb, | 
|  | void *userdata); | 
|  |  | 
|  | /* | 
|  | * Returns nonzero if content_type includes "application/metalink+xml" | 
|  | * media-type. The check is done in case-insensitive manner. | 
|  | */ | 
|  | int check_metalink_content_type(const char *content_type); | 
|  |  | 
|  | /* | 
|  | * Check checksum of file denoted by filename. | 
|  | * | 
|  | * This function returns 1 if the checksum matches or one of the | 
|  | * following integers: | 
|  | * | 
|  | * 0: | 
|  | *   Checksum didn't match. | 
|  | * -1: | 
|  | *   Could not open file; or could not read data from file. | 
|  | * -2: | 
|  | *   No checksum in Metalink supported, hash algorithm not available, or | 
|  | *   Metalink does not contain checksum. | 
|  | */ | 
|  | int metalink_check_hash(struct GlobalConfig *config, | 
|  | metalinkfile *mlfile, | 
|  | const char *filename); | 
|  |  | 
|  | /* | 
|  | * Release resources allocated at global scope. | 
|  | */ | 
|  | void metalink_cleanup(void); | 
|  |  | 
|  | #else /* USE_METALINK */ | 
|  |  | 
|  | #define count_next_metalink_resource(x)  0 | 
|  | #define clean_metalink(x)  (void)x | 
|  |  | 
|  | /* metalink_cleanup() takes no arguments */ | 
|  | #define metalink_cleanup() Curl_nop_stmt | 
|  |  | 
|  | #endif /* USE_METALINK */ | 
|  |  | 
|  | #endif /* HEADER_CURL_TOOL_METALINK_H */ |