a "url_regex" ACL More...
#include <Url.h>


| Public Types | |
| using | Parameters = ACLData< const char * > | 
| using | Pointer = RefCount< Node > | 
| Public Member Functions | |
| int | match (ACLChecklist *) override | 
| Matches the actual data in checklist against this Acl::Node.  More... | |
| bool | requiresRequest () const override | 
| whether our (i.e. shallow) match() requires checklist to have a request  More... | |
| virtual SBufList | dump () const =0 | 
| virtual bool | empty () const =0 | 
| void * | operator new (size_t) | 
| void | operator delete (void *) | 
| void | context (const SBuf &aName, const char *configuration) | 
| sets user-specified ACL name and squid.conf context  More... | |
| bool | matches (ACLChecklist *checklist) const | 
| void | parseFlags () | 
| configures Acl::Node options, throwing on configuration errors  More... | |
| virtual const char * | typeString () const =0 | 
| virtual bool | isProxyAuth () const | 
| virtual bool | valid () const | 
| int | cacheMatchAcl (dlink_list *cache, ACLChecklist *) | 
| virtual int | matchForCache (ACLChecklist *checklist) | 
| void | dumpWhole (const char *directiveName, std::ostream &) | 
| Static Public Member Functions | |
| static void | ParseNamedAcl (ConfigParser &, NamedAcls *&) | 
| parses acl directive parts that follow directive name (i.e. "acl")  More... | |
| static void | Initialize () | 
| static Acl::Node * | FindByName (const SBuf &) | 
| A configured ACL with a given name or nil.  More... | |
| Public Attributes | |
| SBuf | name | 
| char * | cfgline = nullptr | 
| Protected Member Functions | |
| void | parse () override | 
| parses node representation in squid.conf; dies on failures  More... | |
| void | prepareForUse () override | 
| SBufList | dump () const override | 
| bool | empty () const override | 
| const Acl::Options & | lineOptions () override | 
| Protected Attributes | |
| std::unique_ptr< Parameters > | data | 
| Private Member Functions | |
| virtual bool | requiresAle () const | 
| whether our (i.e. shallow) match() requires checklist to have a AccessLogEntry  More... | |
| virtual bool | requiresReply () const | 
| whether our (i.e. shallow) match() requires checklist to have a reply  More... | |
| virtual const Acl::Options & | options () | 
| Static Private Member Functions | |
| static void | ParseNamed (ConfigParser &, NamedAcls &, const SBuf &name) | 
| parses acl directive parts that follow aclname  More... | |
Detailed Description
Member Typedef Documentation
◆ Parameters
| 
 | inherited | 
Definition at line 26 of file ParameterizedNode.h.
◆ Pointer
| 
 | inherited | 
Member Function Documentation
◆ cacheMatchAcl()
| 
 | inherited | 
Definition at line 401 of file Acl.cc.
References acl_proxy_auth_match_cache::acl_data, dlink_node::data, debugs, dlinkAddTail(), dlink_list::head, acl_proxy_auth_match_cache::link, acl_proxy_auth_match_cache::matchrv, and dlink_node::next.
Referenced by ACLProxyAuth::matchProxyAuth().
◆ context()
| 
 | inherited | 
Definition at line 220 of file Acl.cc.
References safe_free, and xstrdup.
Referenced by aclParseAccessLine(), aclParseAclList(), Acl::AllOf::parse(), and ParseAclWithAction().
◆ dump() [1/2]
| 
 | pure virtualinherited | 
◆ dump() [2/2]
| 
 | inlineoverrideprotectedinherited | 
Definition at line 37 of file ParameterizedNode.h.
◆ dumpWhole()
| 
 | inherited | 
◆ empty() [1/2]
| 
 | pure virtualinherited | 
◆ empty() [2/2]
| 
 | inlineoverrideprotectedinherited | 
Definition at line 38 of file ParameterizedNode.h.
◆ FindByName()
Definition at line 159 of file Acl.cc.
References assert, Config, debugs, and SquidConfig::namedAcls.
Referenced by aclIsProxyAuth(), Acl::InnerNode::lineParse(), parse_ftp_epsv(), and TestACLMaxUserIP::testParseLine().
◆ Initialize()
| 
 | staticinherited | 
Definition at line 471 of file Acl.cc.
References Config, debugs, and SquidConfig::namedAcls.
Referenced by serverConnectionsOpen().
◆ isProxyAuth()
| 
 | virtualinherited | 
Reimplemented in ACLExternal, and ACLProxyAuth.
◆ lineOptions()
| 
 | inlineoverrideprotectedvirtualinherited | 
- Returns
- (linked) "line" Options supported by this Acl::Node
- See also
- Acl::Node::options()
Reimplemented from Acl::Node.
Definition at line 39 of file ParameterizedNode.h.
◆ match()
| 
 | overridevirtual | 
Implements Acl::Node.
Definition at line 18 of file Url.cc.
References SBuf::c_str(), Acl::ParameterizedNode< ACLData< const char * > >::data, AnyP::Uri::DecodeOrDupe(), and Filled().
◆ matches()
| 
 | inherited | 
Orchestrates matching checklist against the Acl::Node using match(), after checking preconditions and while providing debugging.
- Returns
- true if and only if there was a successful match. Updates the checklist state on match, async, and failure.
Definition at line 189 of file Acl.cc.
References ACLChecklist::asyncInProgress(), DBG_IMPORTANT, debugs, ACLChecklist::hasAle(), ACLChecklist::hasReply(), ACLChecklist::hasRequest(), ACLChecklist::setLastCheckedName(), and ACLChecklist::verifyAle().
Referenced by ACLChecklist::matchAndFinish().
◆ matchForCache()
| 
 | virtualinherited | 
◆ operator delete()
| 
 | inherited | 
◆ operator new()
| 
 | inherited | 
◆ options()
| 
 | inlineprivatevirtualinherited | 
- Returns
- (linked) 'global' Options supported by this Acl::Node
Reimplemented in Acl::ServerNameCheck, Acl::DestinationDomainCheck, Acl::AnnotationCheck, ACLMaxUserIP, and ACLDestinationIP.
Definition at line 98 of file Node.h.
References Acl::NoOptions().
◆ parse()
| 
 | inlineoverrideprotectedvirtualinherited | 
Implements Acl::Node.
Definition at line 35 of file ParameterizedNode.h.
◆ parseFlags()
| 
 | inherited | 
Definition at line 360 of file Acl.cc.
References Acl::ParseFlags().
◆ ParseNamed()
| 
 | staticprivateinherited | 
Definition at line 253 of file Acl.cc.
References Assure, SBuf::cmp(), config_input_line, DBG_CRITICAL, DBG_IMPORTANT, DBG_PARSE_NOTE, debugs, ConfigParser::destruct(), fatalf(), HttpPortList, Acl::Make(), and ConfigParser::NextToken().
◆ ParseNamedAcl()
| 
 | staticinherited | 
Definition at line 229 of file Acl.cc.
References CallParser(), DBG_CRITICAL, debugs, ConfigParser::destruct(), RefCount< C >::Make(), and ConfigParser::NextToken().
Referenced by parse_acl(), and TestACLMaxUserIP::testParseLine().
◆ prepareForUse()
| 
 | inlineoverrideprotectedvirtualinherited | 
Reimplemented from Acl::Node.
Definition at line 36 of file ParameterizedNode.h.
◆ requiresAle()
| 
 | privatevirtualinherited | 
Reimplemented in ACLExternal.
◆ requiresReply()
| 
 | privatevirtualinherited | 
Reimplemented in ACLHTTPStatus, Acl::ReplyHeaderCheck< header >, and Acl::HttpRepHeaderCheck.
◆ requiresRequest()
| 
 | inlineoverridevirtual | 
◆ typeString()
| 
 | pure virtualinherited | 
Implemented in ACLIP, Acl::OrNode, Acl::AndNode, ACLHTTPStatus, Acl::NotNode, ACLProxyAuth, ACLExternal, Acl::ConnMark, ACLExtUser, Acl::TransactionInitiator, Acl::AllOf, ACLARP, Acl::ConnectionsEncrypted, ACLEui64, Acl::AnyOf, ACLMaxUserIP, ACLDestinationIP, ACLMaxConnection, ACLRandom, ACLLocalIP, and ACLSourceIP.
◆ valid()
| 
 | virtualinherited | 
Reimplemented in ACLExternal, ACLProxyAuth, Acl::ServerNameCheck, ACLMaxUserIP, ACLMaxConnection, and ACLRandom.
Member Data Documentation
◆ cfgline
◆ data
| 
 | protectedinherited | 
Points to items this ACL is configured to match. A derived class ensures that this pointer is never nil after object construction ends.
Definition at line 43 of file ParameterizedNode.h.
◆ name
| 
 | inherited | 
Either aclname parameter from the explicitly configured acl directive or a label generated for an internal ACL tree node. All Node objects corresponding to one Squid configuration have unique names. See also: context() and FindByName().
Definition at line 81 of file Node.h.
Referenced by aclDestroyAccessList(), Acl::AnnotateClientCheck::match(), Acl::AnnotateTransactionCheck::match(), ACLRandom::match(), Acl::SourceDomainCheck::match(), ACLDestinationIP::match(), Acl::NotNode::NotNode(), ACLExternal::parse(), and ACLMaxConnection::prepareForUse().
The documentation for this class was generated from the following files:
Introduction
- About Squid
- Why Squid?
- Squid Developers
- How to Donate
- How to Help Out
- Getting Squid
- Squid Source Packages
- Squid Deployment Case-Studies
- Squid Software Foundation
Documentation
- Quick Setup
- Configuration:
- FAQ and Wiki
- Guide Books:
- Non-English
- More...
Support
- Security Advisories
- Bugzilla Database
- Mailing lists
- Contacting us
- Commercial services
- Project Sponsors
- Squid-based products
