blob: 431b6779acd5931229de6662877fe40e1424475b [file] [log] [blame]
Brian Waters13d96012017-12-08 16:53:31 -06001/*
2* Copyright (c) 2017 Sprint
3*
4* Licensed under the Apache License, Version 2.0 (the "License");
5* you may not use this file except in compliance with the License.
6* You may obtain a copy of the License at
7*
8* http://www.apache.org/licenses/LICENSE-2.0
9*
10* Unless required by applicable law or agreed to in writing, software
11* distributed under the License is distributed on an "AS IS" BASIS,
12* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13* See the License for the specific language governing permissions and
14* limitations under the License.
15*/
16
17/****************
18 Generated By: fdtool enhancements to diafuzzer
19 License: same as freeDiameter
20****************/
21
22
23/*
24 * Dictionary definitions of objects specified in rfc7683_avps.
25 */
26#include <freeDiameter/extension.h>
27
28#define PROTO_VER "unspecified"
29#define GEN_DATE 1506697143.69
30
31const char *rfc7683_avps_proto_ver = PROTO_VER;
32const double rfc7683_avps_gen_date = GEN_DATE;
33
34/* The content of this file follows the same structure as dict_base_proto.c */
35
36#define CHECK_dict_new( _type, _data, _parent, _ref ) \
37{ \
38 int _ret = fd_dict_new( fd_g_config->cnf_dict, (_type), (_data), (_parent), (_ref) ); \
39 if ( _ret != 0 && _ret != EEXIST ) \
40 return _ret; \
41}
42
43#define CHECK_dict_search( _type, _criteria, _what, _result ) \
44 CHECK_FCT( fd_dict_search( fd_g_config->cnf_dict, (_type), (_criteria), (_what), (_result), ENOENT) );
45
46struct local_rules_definition {
47 struct dict_avp_request avp_vendor_plus_name;
48 enum rule_position position;
49 int min;
50 int max;
51};
52
53#define RULE_ORDER( _position ) ((((_position) == RULE_FIXED_HEAD) || ((_position) == RULE_FIXED_TAIL)) ? 1 : 0 )
54
55/* Attention! This version of the macro uses AVP_BY_NAME_AND_VENDOR, in contrast to most other copies! */
56#define PARSE_loc_rules( _rulearray, _parent) { \
57 int __ar; \
58 for (__ar=0; __ar < sizeof(_rulearray) / sizeof((_rulearray)[0]); __ar++) { \
59 struct dict_rule_data __data = { NULL, \
60 (_rulearray)[__ar].position, \
61 0, \
62 (_rulearray)[__ar].min, \
63 (_rulearray)[__ar].max}; \
64 __data.rule_order = RULE_ORDER(__data.rule_position); \
65 CHECK_FCT( fd_dict_search( \
66 fd_g_config->cnf_dict, \
67 DICT_AVP, \
68 AVP_BY_NAME_AND_VENDOR, \
69 &(_rulearray)[__ar].avp_vendor_plus_name, \
70 &__data.rule_avp, 0 ) ); \
71 if ( !__data.rule_avp ) { \
72 TRACE_DEBUG(INFO, "AVP Not found: '%s'", (_rulearray)[__ar].avp_vendor_plus_name.avp_name); \
73 return ENOENT; \
74 } \
75 { \
76 int _ret = fd_dict_new( fd_g_config->cnf_dict, DICT_RULE, &(__data), (_parent), NULL ); \
77 if ( _ret != 0 && _ret != EEXIST ) { \
78 TRACE_DEBUG(INFO, "Error on rule with AVP '%s'", \
79 (_rulearray)[__ar].avp_vendor_plus_name.avp_name); \
80 return EINVAL; \
81 } \
82 } \
83 } \
84}
85
86#define CHECK_vendor_new( _data ) { \
87 struct dict_object * vendor_found; \
88 if (fd_dict_search(fd_g_config->cnf_dict,DICT_VENDOR,VENDOR_BY_ID,&_data.vendor_id,&vendor_found,ENOENT) == ENOENT) { \
89 CHECK_FCT(fd_dict_new(fd_g_config->cnf_dict, DICT_VENDOR, &_data, NULL, NULL)); \
90 } \
91}
92
93#define enumval_def_u32( _val_, _str_ ) \
94 { _str_, { .u32 = _val_ }}
95
96#define enumval_def_os( _len_, _val_, _str_ ) \
97 { _str_, { .os = { .data = (unsigned char *)_val_, .len = _len_ }}}
98
99
100static int dict_rfc7683_avps_load_defs(char * conffile)
101{
102 TRACE_ENTRY("%p", conffile);
103
104 /* AVP section */
105 {
106 struct dict_object * Address_type;
107 struct dict_object * UTF8String_type;
108 struct dict_object * DiameterIdentity_type;
109 struct dict_object * DiameterURI_type;
110 struct dict_object * Time_type;
111 struct dict_object * IPFilterRule_type;
112
113 CHECK_dict_search( DICT_TYPE, TYPE_BY_NAME, "Address", &Address_type);
114 CHECK_dict_search( DICT_TYPE, TYPE_BY_NAME, "UTF8String", &UTF8String_type);
115 CHECK_dict_search( DICT_TYPE, TYPE_BY_NAME, "DiameterIdentity", &DiameterIdentity_type);
116 CHECK_dict_search( DICT_TYPE, TYPE_BY_NAME, "DiameterURI", &DiameterURI_type);
117 CHECK_dict_search( DICT_TYPE, TYPE_BY_NAME, "Time", &Time_type);
118 CHECK_dict_search( DICT_TYPE, TYPE_BY_NAME, "IPFilterRule", &IPFilterRule_type);
119 /* OC-Feature-Vector */
120 {
121 struct dict_avp_data data = {
122 622, /* Code */
123 0, /* Vendor */
124 "OC-Feature-Vector", /* Name */
125 AVP_FLAG_VENDOR, /* Fixed flags */
126 AVP_FLAG_VENDOR, /* Fixed flag values */
127 AVP_TYPE_UNSIGNED64 /* base type of data */
128 };
129 CHECK_dict_new( DICT_AVP, &data, NULL, NULL);
130 };
131 /* OC-Sequence-Number */
132 {
133 struct dict_avp_data data = {
134 624, /* Code */
135 0, /* Vendor */
136 "OC-Sequence-Number", /* Name */
137 AVP_FLAG_VENDOR, /* Fixed flags */
138 AVP_FLAG_VENDOR, /* Fixed flag values */
139 AVP_TYPE_UNSIGNED64 /* base type of data */
140 };
141 CHECK_dict_new( DICT_AVP, &data, NULL, NULL);
142 };
143 /* OC-Validity-Duration */
144 {
145 struct dict_avp_data data = {
146 625, /* Code */
147 0, /* Vendor */
148 "OC-Validity-Duration", /* Name */
149 AVP_FLAG_VENDOR, /* Fixed flags */
150 AVP_FLAG_VENDOR, /* Fixed flag values */
151 AVP_TYPE_UNSIGNED32 /* base type of data */
152 };
153 CHECK_dict_new( DICT_AVP, &data, NULL, NULL);
154 };
155 /* OC-Report-Type */
156 {
157 struct dict_avp_data data = {
158 626, /* Code */
159 0, /* Vendor */
160 "OC-Report-Type", /* Name */
161 AVP_FLAG_VENDOR, /* Fixed flags */
162 AVP_FLAG_VENDOR, /* Fixed flag values */
163 AVP_TYPE_INTEGER32 /* base type of data */
164 };
165 struct dict_object *type;
166 struct dict_type_data tdata = { AVP_TYPE_INTEGER32, "Enumerated(OC-Report-Type)", NULL, NULL, NULL };
167 struct dict_enumval_data t_1 = { "HOST_REPORT", { .i32=0 }};
168 struct dict_enumval_data t_2 = { "REALM_REPORT", { .i32=1 }};
169 struct dict_enumval_data t_3 = { "Texas", { .i32=75034 }};
170 struct dict_enumval_data t_4 = { "CA", { .i32=95134 }};
171 /* Create the Enumerated type, and then the AVP */
172 CHECK_dict_new( DICT_TYPE, &tdata, NULL, &type);
173 CHECK_dict_new( DICT_ENUMVAL, &t_1, type, NULL);
174 CHECK_dict_new( DICT_ENUMVAL, &t_2, type, NULL);
175 CHECK_dict_new( DICT_ENUMVAL, &t_3, type, NULL);
176 CHECK_dict_new( DICT_ENUMVAL, &t_4, type, NULL);
177 CHECK_dict_new( DICT_AVP, &data, type, NULL);
178 };
179 /* OC-Reduction-Percentage */
180 {
181 struct dict_avp_data data = {
182 627, /* Code */
183 0, /* Vendor */
184 "OC-Reduction-Percentage", /* Name */
185 AVP_FLAG_VENDOR, /* Fixed flags */
186 AVP_FLAG_VENDOR, /* Fixed flag values */
187 AVP_TYPE_UNSIGNED32 /* base type of data */
188 };
189 CHECK_dict_new( DICT_AVP, &data, NULL, NULL);
190 };
191 /* OC-Supported-Features */
192 {
193 /* Grouped */
194 struct dict_object * avp;
195 struct dict_avp_data data = {
196 621, /* Code */
197 0, /* Vendor */
198 "OC-Supported-Features", /* Name */
199 AVP_FLAG_VENDOR, /* Fixed flags */
200 AVP_FLAG_VENDOR, /* Fixed flag values */
201 AVP_TYPE_GROUPED /* base type of data */
202 };
203 CHECK_dict_new( DICT_AVP, &data , NULL, &avp);
204 }
205 /* OC-OLR */
206 {
207 /* Grouped */
208 struct dict_object * avp;
209 struct dict_avp_data data = {
210 623, /* Code */
211 0, /* Vendor */
212 "OC-OLR", /* Name */
213 AVP_FLAG_VENDOR, /* Fixed flags */
214 AVP_FLAG_VENDOR, /* Fixed flag values */
215 AVP_TYPE_GROUPED /* base type of data */
216 };
217 CHECK_dict_new( DICT_AVP, &data , NULL, &avp);
218 }
219
220
221 }
222
223 /* Commands section */
224 {
225
226 }
227
228 return 0;
229}
230
231static int dict_rfc7683_avps_load_rules(char * conffile)
232{
233 /* Grouped AVP section */
234 {
235 /* OC-Supported-Features */
236 {
237 /* Grouped */
238 struct dict_object * avp;
239 struct dict_avp_request avp_vendor_plus_name = { .avp_vendor = 0, .avp_name = "OC-Supported-Features"};
240 CHECK_dict_search(DICT_AVP, AVP_BY_NAME_AND_VENDOR, &avp_vendor_plus_name, &avp)
241 struct local_rules_definition rules[] =
242 {
243 { { .avp_vendor = 0, .avp_name = "OC-Feature-Vector"}, RULE_OPTIONAL, -1, -1 }
244 };
245 PARSE_loc_rules( rules, avp );
246 }
247 /* OC-OLR */
248 {
249 /* Grouped */
250 struct dict_object * avp;
251 struct dict_avp_request avp_vendor_plus_name = { .avp_vendor = 0, .avp_name = "OC-OLR"};
252 CHECK_dict_search(DICT_AVP, AVP_BY_NAME_AND_VENDOR, &avp_vendor_plus_name, &avp)
253 struct local_rules_definition rules[] =
254 {
255 { { .avp_vendor = 0, .avp_name = "OC-Sequence-Number"}, RULE_FIXED_HEAD, -1, -1 },
256 { { .avp_vendor = 0, .avp_name = "OC-Report-Type"}, RULE_FIXED_HEAD, -1, -1 },
257 { { .avp_vendor = 0, .avp_name = "OC-Reduction-Percentage"}, RULE_OPTIONAL, -1, -1 },
258 { { .avp_vendor = 0, .avp_name = "OC-Validity-Duration"}, RULE_OPTIONAL, -1, -1 }
259 };
260 PARSE_loc_rules( rules, avp );
261 }
262
263 }
264
265 /* Commands section */
266 {
267
268 }
269
270 LOG_D( "Extension 'Dictionary definitions for rfc7683_avps (None)' initialized");
271 return 0;
272}
273
274int dict_entry(char * conffile)
275{
276 dict_rfc7683_avps_load_defs(conffile);
277 return dict_rfc7683_avps_load_rules(conffile);
278}
279
280const char* dict_rfc7683_avps_proto_ver(char * conffile) {
281 return rfc7683_avps_proto_ver;
282}
283
284const double dict_rfc7683_avps_gen_ts(char * conffile) {
285 return rfc7683_avps_gen_date;
286}
287
288EXTENSION_ENTRY2("dict_rfc7683_avps", dict_rfc7683_avps_load_defs, dict_rfc7683_avps_load_rules);
289
290
291