3 * SQUID Web Proxy Cache http://www.squid-cache.org/
4 * ----------------------------------------------------------
6 * Squid is the result of efforts by numerous individuals from
7 * the Internet community; see the CONTRIBUTORS file for full
8 * details. Many organizations have provided support for Squid's
9 * development; see the SPONSORS file for full details. Squid is
10 * Copyrighted (C) 2001 by the Regents of the University of
11 * California; see the COPYRIGHT file for full details. Squid
12 * incorporates software developed and/or copyrighted by other
13 * sources; see the CREDITS file for full details.
15 * This program is free software; you can redistribute it and/or modify
16 * it under the terms of the GNU General Public License as published by
17 * the Free Software Foundation; either version 2 of the License, or
18 * (at your option) any later version.
20 * This program is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 * GNU General Public License for more details.
25 * You should have received a copy of the GNU General Public License
26 * along with this program; if not, write to the Free Software
27 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
31 #ifndef SQUID_AUTH_SCHEME_H
32 #define SQUID_AUTH_SCHEME_H
36 #include "base/RefCount.h"
37 #include "base/Vector.h"
40 \defgroup AuthSchemeAPI Authentication Scheme API
51 * \ingroup AuthSchemeAPI
53 * I represent an authentication scheme. For now my children
54 * store the scheme metadata.
56 * Should we need multiple configs of a single scheme,
57 * a new class should be made, and the config specific calls on Auth::Scheme moved to it.
59 class Scheme
: public RefCountable
62 typedef RefCount
<Scheme
> Pointer
;
63 typedef Vector
<Scheme::Pointer
>::iterator iterator
;
64 typedef Vector
<Scheme::Pointer
>::const_iterator const_iterator
;
67 Scheme() : initialised (false) {};
70 static void AddScheme(Scheme::Pointer
);
73 * Final termination of all authentication components.
74 * To be used only on shutdown. All global pointers are released.
75 * After this all schemes will appear completely unsupported
76 * until a call to InitAuthModules().
77 * Release the Auth::TheConfig handles instead to disable authentication
78 * without terminiating all support.
80 static void FreeAll();
83 * Locate an authentication scheme component by Name.
85 static Scheme::Pointer
Find(const char *);
87 /* per scheme methods */
88 virtual char const *type() const = 0;
89 virtual void shutdownCleanup() = 0;
90 virtual Auth::Config
*createConfig() = 0;
93 Scheme(Scheme
const &);
94 Scheme
&operator=(Scheme
const&);
96 static Vector
<Scheme::Pointer
> &GetSchemes();
102 static Vector
<Scheme::Pointer
> *_Schemes
;
107 #endif /* USE_AUTH */
108 #endif /* SQUID_AUTH_SCHEME_H */