diff options
author | Michal Kubecek <mkubecek@suse.cz> | 2015-04-13 09:21:39 +0200 |
---|---|---|
committer | Michal Kubecek <mkubecek@suse.cz> | 2015-04-13 09:21:39 +0200 |
commit | e2bc6f4153813cc570ae814c8ddb74628009b488 (patch) | |
tree | a40b171be1d859c2232ccc94f758010f9ae54d3c /src/parser/credentials.h | |
download | twinkle-e2bc6f4153813cc570ae814c8ddb74628009b488.tar twinkle-e2bc6f4153813cc570ae814c8ddb74628009b488.tar.gz twinkle-e2bc6f4153813cc570ae814c8ddb74628009b488.tar.lz twinkle-e2bc6f4153813cc570ae814c8ddb74628009b488.tar.xz twinkle-e2bc6f4153813cc570ae814c8ddb74628009b488.zip |
initial checkin
Check in contents of upstream 1.4.2 tarball, exclude generated files.
Diffstat (limited to 'src/parser/credentials.h')
-rw-r--r-- | src/parser/credentials.h | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/src/parser/credentials.h b/src/parser/credentials.h new file mode 100644 index 0000000..15fa881 --- /dev/null +++ b/src/parser/credentials.h @@ -0,0 +1,69 @@ +/* + Copyright (C) 2005-2009 Michel de Boer <michel@twinklephone.com> + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program 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 General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +*/ + +// Credentials are used in Proxy-Authorization and +// Authorization headers + +#ifndef _CREDENTIALS_H +#define _CREDENTIALS_H + +#include <list> +#include <string> +#include "parameter.h" +#include "sockets/url.h" + +using namespace std; + +class t_digest_response { +public: + string username; + string realm; + string nonce; + t_url digest_uri; + string dresponse; + string algorithm; + string cnonce; + string opaque; + string message_qop; + unsigned long nonce_count; + list<t_parameter> auth_params; + + t_digest_response(); + + // Set one of the attributes to a value. The parameter p + // indicated wich attribute (p.name) should be set to + // which value (p.value). + // Returns false if p does not contain a valid attribute + // setting. + bool set_attr(const t_parameter &p); + + string encode(void) const; +}; + +class t_credentials { +public: + string auth_scheme; + t_digest_response digest_response; + + // auth_params is used when auth_scheme is not Digest. + list<t_parameter> auth_params; + + string encode(void) const; +}; + +#endif |