Squid Web Cache master
Loading...
Searching...
No Matches
AnnotateTransaction.cc
Go to the documentation of this file.
1/*
2 * Copyright (C) 1996-2025 The Squid Software Foundation and contributors
3 *
4 * Squid software is distributed under GPLv2+ license and includes
5 * contributions from numerous individuals and organizations.
6 * Please see the COPYING and CONTRIBUTORS files for details.
7 */
8
9#include "squid.h"
11#include "acl/AnnotationData.h"
12#include "acl/FilledChecklist.h"
13#include "HttpRequest.h"
14
15int
17{
18 const auto checklist = Filled(ch);
19
20 if (const auto request = checklist->request) {
21 const auto tdata = dynamic_cast<ACLAnnotationData*>(data.get());
22 assert(tdata);
23 tdata->annotate(request->notes(), &delimiters.value, checklist->al);
24 } else {
25 debugs(28, DBG_IMPORTANT, "WARNING: " << name << " ACL is used in context without " <<
26 "current transaction information. Did not annotate.");
27 }
28 return 1; // this is an "always matching" ACL
29}
30
ACLFilledChecklist * Filled(ACLChecklist *checklist)
convenience and safety wrapper for dynamic_cast<ACLFilledChecklist*>
#define assert(EX)
Definition assert.h:17
int match(ACLChecklist *) override
Matches the actual data in checklist against this Acl::Node.
Acl::CharacterSetOptionValue delimiters
annotation separators
Definition Note.h:27
SBuf name
Definition Node.h:81
Value value
final value storage, possibly after conversions
Definition Options.h:120
#define DBG_IMPORTANT
Definition Stream.h:38
#define debugs(SECTION, LEVEL, CONTENT)
Definition Stream.h:192