Mercurial > libavformat.hg
view httpauth.h @ 6275:287072e5227b libavformat
Add MD5 protocol
This is a write-only protocol which computes the md5sum of data written,
and on close writes this to the designated output or stdout if none
is specified. It can be used to test muxers without writing an actual
file.
author | mru |
---|---|
date | Sun, 18 Jul 2010 20:19:08 +0000 |
parents | a1a309c4a751 |
children |
line wrap: on
line source
/* * HTTP authentication * Copyright (c) 2010 Martin Storsjo * * This file is part of FFmpeg. * * FFmpeg is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * FFmpeg is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with FFmpeg; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ #ifndef AVFORMAT_HTTPAUTH_H #define AVFORMAT_HTTPAUTH_H /** * Authentication types, ordered from weakest to strongest. */ typedef enum HTTPAuthType { HTTP_AUTH_NONE = 0, /**< No authentication specified */ HTTP_AUTH_BASIC, /**< HTTP 1.0 Basic auth from RFC 1945 * (also in RFC 2617) */ HTTP_AUTH_DIGEST, /**< HTTP 1.1 Digest auth from RFC 2617 */ } HTTPAuthType; typedef struct { char nonce[300]; /**< Server specified nonce */ char algorithm[10]; /**< Server specified digest algorithm */ char qop[30]; /**< Quality of protection, containing the one * that we've chosen to use, from the * alternatives that the server offered. */ char opaque[300]; /**< A server-specified string that should be * included in authentication responses, not * included in the actual digest calculation. */ int nc; /**< Nonce count, the number of earlier replies * where this particular nonce has been used. */ } DigestParams; /** * HTTP Authentication state structure. Must be zero-initialized * before used with the functions below. */ typedef struct { /** * The currently chosen auth type. */ HTTPAuthType auth_type; /** * Authentication realm */ char realm[200]; /** * The parameters specifiec to digest authentication. */ DigestParams digest_params; } HTTPAuthState; void ff_http_auth_handle_header(HTTPAuthState *state, const char *key, const char *value); char *ff_http_auth_create_response(HTTPAuthState *state, const char *auth, const char *path, const char *method); #endif /* AVFORMAT_HTTPAUTH_H */