~clint-fewbar/ubuntu/precise/squid3/ignore-sighup-early

« back to all changes in this revision

Viewing changes to src/AuthConfig.h

  • Committer: Bazaar Package Importer
  • Author(s): Luigi Gangitano
  • Date: 2009-09-24 14:51:06 UTC
  • mfrom: (1.1.12 upstream)
  • mto: (20.2.1 sid)
  • mto: This revision was merged to the branch mainline in revision 21.
  • Revision ID: james.westby@ubuntu.com-20090924145106-38jgrzmj0d73pha5
Tags: 3.1.0.13-1
* Upload to experimental

* New upstream release
  - Fixes Follow-X-Forwarded-For support (Closes: #523943)
  - Adds IPv6 support (Closes: #432351)

* debian/rules
  - Removed obsolete configuration options
  - Enable db and radius basic authentication modules

* debian/patches/01-cf.data.debian
  - Adapted to new upstream version

* debian/patches/02-makefile-defaults
  - Adapted to new upstream version

* debian/{squid.postinst,squid.rc,README.Debian,watch}
  - Updated references to squid 3.1

* debian/squid3.install
  - Install CSS file for error pages
  - Install manual pages for new authentication modules

* debian/squid3-common.install
  - Install documented version of configuration file in /usr/share/doc/squid3

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
 
2
 
/*
3
 
 * $Id: AuthConfig.h,v 1.4 2007/05/09 07:45:58 wessels Exp $
4
 
 *
5
 
 *
6
 
 * SQUID Web Proxy Cache          http://www.squid-cache.org/
7
 
 * ----------------------------------------------------------
8
 
 *
9
 
 *  Squid is the result of efforts by numerous individuals from
10
 
 *  the Internet community; see the CONTRIBUTORS file for full
11
 
 *  details.   Many organizations have provided support for Squid's
12
 
 *  development; see the SPONSORS file for full details.  Squid is
13
 
 *  Copyrighted (C) 2001 by the Regents of the University of
14
 
 *  California; see the COPYRIGHT file for full details.  Squid
15
 
 *  incorporates software developed and/or copyrighted by other
16
 
 *  sources; see the CREDITS file for full details.
17
 
 *
18
 
 *  This program is free software; you can redistribute it and/or modify
19
 
 *  it under the terms of the GNU General Public License as published by
20
 
 *  the Free Software Foundation; either version 2 of the License, or
21
 
 *  (at your option) any later version.
22
 
 *  
23
 
 *  This program is distributed in the hope that it will be useful,
24
 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
25
 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
26
 
 *  GNU General Public License for more details.
27
 
 *  
28
 
 *  You should have received a copy of the GNU General Public License
29
 
 *  along with this program; if not, write to the Free Software
30
 
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
31
 
 *
32
 
 */
33
 
 
34
 
#ifndef SQUID_AUTHCONFIG_H
35
 
#define SQUID_AUTHCONFIG_H
36
 
 
37
 
/*
38
 
 * I am the configuration for an auth scheme.
39
 
 * Currently each scheme has only one instance of me,
40
 
 * but this may change.
41
 
 */
42
 
 
43
 
/* This class is treated like a ref counted class.
44
 
 * If the children ever stop being singletons, implement the
45
 
 * ref counting...
46
 
 */
47
 
 
48
 
class AuthUserRequest;
49
 
class AuthConfig
50
 
{
51
 
 
52
 
public:
53
 
    static AuthUserRequest *CreateAuthUser (const char *proxy_auth);
54
 
 
55
 
    static AuthConfig *Find(const char *proxy_auth);
56
 
    AuthConfig() {}
57
 
 
58
 
    virtual ~AuthConfig(){}
59
 
 
60
 
    /* Is this configuration active? (helpers running etc etc */
61
 
    virtual bool active() const = 0;
62
 
    /* new decode API: virtual factory pattern */
63
 
    virtual AuthUserRequest *decode(char const *proxy_auth) = 0;
64
 
    /* squid is finished with this config, release any unneeded resources.
65
 
     * If a singleton, delete will not occur. if not a singleton (future),
66
 
     * delete will occur when no references are held.
67
 
     * TODO: we need a 'done for reconfigure' and a 'done permanently' concept.
68
 
     */
69
 
    virtual void done() = 0;
70
 
    /* is this config complete enough to run */
71
 
    virtual bool configured() const = 0;
72
 
    /* output the parameters */
73
 
    virtual void dump(StoreEntry *, const char *, AuthConfig *) = 0;
74
 
    /* add headers as needed when challenging for auth */
75
 
    virtual void fixHeader(AuthUserRequest *, HttpReply *, http_hdr_type, HttpRequest *) = 0;
76
 
    /* prepare to handle requests */
77
 
    virtual void init(AuthConfig *) = 0;
78
 
    /* expose any/all statistics to a CacheManager */
79
 
    virtual void registerWithCacheManager(CacheManager & manager);
80
 
    /* parse config options */
81
 
    virtual void parse(AuthConfig *, int, char *) = 0;
82
 
    /* the http string id */
83
 
    virtual const char * type() const = 0;
84
 
};
85
 
 
86
 
#endif /* SQUID_AUTHCONFIG_H */