blob: ecb2eb49770a3b2476cd8fbeb8394e6fc7d0c82d [file] [log] [blame]
Emeric Brun107ca302010-01-04 16:16:05 +01001/*
Willy Tarreaucd3b0942012-04-27 21:52:18 +02002 * include/proto/sample.h
3 * Functions for samples management.
Emeric Brun107ca302010-01-04 16:16:05 +01004 *
5 * Copyright (C) 2009-2010 EXCELIANCE, Emeric Brun <ebrun@exceliance.fr>
Willy Tarreaucd3b0942012-04-27 21:52:18 +02006 * Copyright (C) 2012 Willy Tarreau <w@1wt.eu>
Emeric Brun107ca302010-01-04 16:16:05 +01007 *
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation, version 2.1
11 * exclusively.
12 *
13 * This library is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
17 *
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 */
22
Willy Tarreaucd3b0942012-04-27 21:52:18 +020023#ifndef _PROTO_SAMPLE_H
24#define _PROTO_SAMPLE_H
Emeric Brun107ca302010-01-04 16:16:05 +010025
Willy Tarreaucd3b0942012-04-27 21:52:18 +020026#include <types/sample.h>
Emeric Brun107ca302010-01-04 16:16:05 +010027#include <types/stick_table.h>
28
Willy Tarreau1cf8f082014-02-07 12:14:54 +010029extern const char *smp_to_type[SMP_TYPES];
30
Thierry FOURNIEReeaa9512014-02-11 14:00:19 +010031struct sample_expr *sample_parse_expr(char **str, int *idx, const char *file, int line, char **err, struct arg_list *al);
Thierry FOURNIER20f49962013-11-21 10:51:50 +010032struct sample_conv *find_sample_conv(const char *kw, int len);
Willy Tarreau192252e2015-04-04 01:47:55 +020033struct sample *sample_process(struct proxy *px, struct session *sess,
34 struct stream *strm, unsigned int opt,
35 struct sample_expr *expr, struct sample *p);
Adis Nezirovic79beb242015-07-06 15:41:02 +020036struct sample *sample_fetch_as_type(struct proxy *px, struct session *sess,
Willy Tarreau192252e2015-04-04 01:47:55 +020037 struct stream *strm, unsigned int opt,
Adis Nezirovic79beb242015-07-06 15:41:02 +020038 struct sample_expr *expr, int smp_type);
Willy Tarreau12785782012-04-27 21:37:17 +020039void sample_register_fetches(struct sample_fetch_kw_list *psl);
40void sample_register_convs(struct sample_conv_kw_list *psl);
Willy Tarreau80aca902013-01-07 15:42:20 +010041const char *sample_src_names(unsigned int use);
Willy Tarreaua91d0a52013-03-25 08:12:18 +010042const char *sample_ckp_names(unsigned int use);
Willy Tarreau8ed669b2013-01-11 15:49:37 +010043struct sample_fetch *find_sample_fetch(const char *kw, int len);
Thierry FOURNIER4d9a1d12014-12-08 14:49:19 +010044struct sample_fetch *sample_fetch_getnext(struct sample_fetch *current, int *idx);
Thierry FOURNIER8fd13762015-03-10 23:56:48 +010045struct sample_conv *sample_conv_getnext(struct sample_conv *current, int *idx);
Willy Tarreaua4312fa2013-04-02 16:34:32 +020046int smp_resolve_args(struct proxy *p);
Thierry FOURNIER348971e2013-11-21 10:50:10 +010047int smp_expr_output_type(struct sample_expr *expr);
Thierry FOURNIER0e9af552013-12-14 14:55:04 +010048int c_none(struct sample *smp);
Thierry FOURNIER7654c9f2013-12-17 00:20:33 +010049int smp_dup(struct sample *smp);
Willy Tarreaucd3b0942012-04-27 21:52:18 +020050
Thierry FOURNIERe3ded592013-12-06 15:36:54 +010051/*
52 * This function just apply a cast on sample. It returns 0 if the cast is not
53 * avalaible or if the cast fails, otherwise returns 1. It does not modify the
54 * input sample on failure.
55 */
56static inline
57int sample_convert(struct sample *sample, int req_type)
58{
Thierry FOURNIER8c542ca2015-08-19 09:00:18 +020059 if (!sample_casts[sample->data.type][req_type])
Thierry FOURNIERe3ded592013-12-06 15:36:54 +010060 return 0;
Thierry FOURNIER8c542ca2015-08-19 09:00:18 +020061 if (sample_casts[sample->data.type][req_type] == c_none)
Thierry FOURNIER0e9af552013-12-14 14:55:04 +010062 return 1;
Thierry FOURNIER8c542ca2015-08-19 09:00:18 +020063 return sample_casts[sample->data.type][req_type](sample);
Thierry FOURNIERe3ded592013-12-06 15:36:54 +010064}
65
Willy Tarreau1777ea62016-03-10 16:15:46 +010066static inline
67struct sample *smp_set_owner(struct sample *smp, struct proxy *px,
68 struct session *sess, struct stream *strm, int opt)
69{
70 smp->px = px;
71 smp->sess = sess;
72 smp->strm = strm;
73 smp->opt = opt;
74 return smp;
75}
76
Willy Tarreau2c594792016-08-09 11:37:54 +020077
78/* Returns 1 if a sample may be safely used. It performs a few checks on the
79 * string length versus size, same for the binary version, and ensures that
80 * strings are properly terminated by a zero. If this last point is not granted
81 * but the string is not const, then the \0 is appended. Otherwise it returns 0,
82 * meaning the caller may need to call smp_dup() before going further.
83 */
84static inline
85int smp_is_safe(struct sample *smp)
86{
87 switch (smp->data.type) {
88 case SMP_T_STR:
89 if ((smp->data.u.str.len < 0) ||
90 (smp->data.u.str.size && smp->data.u.str.len >= smp->data.u.str.size))
91 return 0;
92
93 if (smp->data.u.str.str[smp->data.u.str.len] == 0)
94 return 1;
95
96 if (!smp->data.u.str.size || (smp->flags & SMP_F_CONST))
97 return 0;
98
99 smp->data.u.str.str[smp->data.u.str.len] = 0;
100 return 1;
101
102 case SMP_T_BIN:
103 return (smp->data.u.str.len >= 0) &&
104 (!smp->data.u.str.size || smp->data.u.str.len <= smp->data.u.str.size);
105
106 default:
107 return 1;
108 }
109}
110
111/* checks that a sample may freely be used, or duplicates it to normalize it.
112 * Returns 1 on success, 0 if the sample must not be used. The function also
113 * checks for NULL to simplify the calling code.
114 */
115static inline
116int smp_make_safe(struct sample *smp)
117{
118 return smp && (smp_is_safe(smp) || smp_dup(smp));
119}
120
Willy Tarreau77128f52016-08-09 11:49:20 +0200121/* Returns 1 if a sample may be safely modified in place. It performs a few
122 * checks on the string length versus size, same for the binary version, and
123 * ensures that strings are properly terminated by a zero, and of course that
124 * the size is allocate and that the SMP_F_CONST flag is not set. If only the
125 * trailing zero is missing, it is appended. Otherwise it returns 0, meaning
126 * the caller may need to call smp_dup() before going further.
127 */
128static inline
129int smp_is_rw(struct sample *smp)
130{
131 if (smp->flags & SMP_F_CONST)
132 return 0;
133
134 switch (smp->data.type) {
135 case SMP_T_STR:
136 if (!smp->data.u.str.size ||
137 smp->data.u.str.len < 0 ||
138 smp->data.u.str.len >= smp->data.u.str.size)
139 return 0;
140
141 if (smp->data.u.str.str[smp->data.u.str.len] != 0)
142 smp->data.u.str.str[smp->data.u.str.len] = 0;
143 return 1;
144
145 case SMP_T_BIN:
146 return smp->data.u.str.size &&
147 smp->data.u.str.len >= 0 &&
148 smp->data.u.str.len <= smp->data.u.str.size;
149
150 default:
151 return 1;
152 }
153}
154
155/* checks that a sample may freely be modified, or duplicates it to normalize
156 * it and make it R/W. Returns 1 on success, 0 if the sample must not be used.
157 * The function also checks for NULL to simplify the calling code.
158 */
159static inline
160int smp_make_rw(struct sample *smp)
161{
162 return smp && (smp_is_rw(smp) || smp_dup(smp));
163}
164
Willy Tarreaucd3b0942012-04-27 21:52:18 +0200165#endif /* _PROTO_SAMPLE_H */