blob: a6f3c5db41744509d1392083294043c2be7b5ca6 [file] [log] [blame]
paul718e3742002-12-13 20:15:29 +00001/* Route map function.
2 * Copyright (C) 1998 Kunihiro Ishiguro
3 *
4 * This file is part of GNU Zebra.
5 *
6 * GNU Zebra is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2, or (at your option) any
9 * later version.
10 *
11 * GNU Zebra is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with GNU Zebra; see the file COPYING. If not, write to the Free
18 * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
19 * 02111-1307, USA.
20 */
21
22#ifndef _ZEBRA_ROUTEMAP_H
23#define _ZEBRA_ROUTEMAP_H
24
25/* Route map's type. */
26enum route_map_type
27{
28 RMAP_PERMIT,
29 RMAP_DENY,
30 RMAP_ANY
31};
32
33typedef enum
34{
35 RMAP_MATCH,
36 RMAP_DENYMATCH,
37 RMAP_NOMATCH,
38 RMAP_ERROR,
39 RMAP_OKAY
40} route_map_result_t;
41
42typedef enum
43{
44 RMAP_RIP,
45 RMAP_RIPNG,
46 RMAP_OSPF,
47 RMAP_OSPF6,
48 RMAP_BGP
49} route_map_object_t;
50
51typedef enum
52{
53 RMAP_EXIT,
54 RMAP_GOTO,
55 RMAP_NEXT
56} route_map_end_t;
57
58typedef enum
59{
60 RMAP_EVENT_SET_ADDED,
61 RMAP_EVENT_SET_DELETED,
62 RMAP_EVENT_SET_REPLACED,
63 RMAP_EVENT_MATCH_ADDED,
64 RMAP_EVENT_MATCH_DELETED,
65 RMAP_EVENT_MATCH_REPLACED,
66 RMAP_EVENT_INDEX_ADDED,
67 RMAP_EVENT_INDEX_DELETED
68} route_map_event_t;
69
paulfee0f4c2004-09-13 05:12:46 +000070/* Depth limit in RMAP recursion using RMAP_CALL. */
71#define RMAP_RECURSION_LIMIT 10
72
paul718e3742002-12-13 20:15:29 +000073/* Route map rule structure for matching and setting. */
74struct route_map_rule_cmd
75{
76 /* Route map rule name (e.g. as-path, metric) */
hasso27a43a82004-10-08 06:29:12 +000077 const char *str;
paul718e3742002-12-13 20:15:29 +000078
79 /* Function for value set or match. */
80 route_map_result_t (*func_apply)(void *, struct prefix *,
81 route_map_object_t, void *);
82
83 /* Compile argument and return result as void *. */
84 void *(*func_compile)(char *);
85
86 /* Free allocated value by func_compile (). */
87 void (*func_free)(void *);
88};
89
90/* Route map apply error. */
91enum
92{
93 /* Route map rule is missing. */
94 RMAP_RULE_MISSING = 1,
95
96 /* Route map rule can't compile */
97 RMAP_COMPILE_ERROR
98};
99
100/* Route map rule list. */
101struct route_map_rule_list
102{
103 struct route_map_rule *head;
104 struct route_map_rule *tail;
105};
106
107/* Route map index structure. */
108struct route_map_index
109{
110 struct route_map *map;
111
112 /* Preference of this route map rule. */
113 int pref;
114
115 /* Route map type permit or deny. */
116 enum route_map_type type;
117
118 /* Do we follow old rules, or hop forward? */
119 route_map_end_t exitpolicy;
120
121 /* If we're using "GOTO", to where do we go? */
122 int nextpref;
123
paulfee0f4c2004-09-13 05:12:46 +0000124 /* If we're using "CALL", to which route-map do ew go? */
125 char *nextrm;
126
paul718e3742002-12-13 20:15:29 +0000127 /* Matching rule list. */
128 struct route_map_rule_list match_list;
129 struct route_map_rule_list set_list;
130
131 /* Make linked list. */
132 struct route_map_index *next;
133 struct route_map_index *prev;
134};
135
136/* Route map list structure. */
137struct route_map
138{
139 /* Name of route map. */
140 char *name;
141
142 /* Route map's rule. */
143 struct route_map_index *head;
144 struct route_map_index *tail;
145
146 /* Make linked list. */
147 struct route_map *next;
148 struct route_map *prev;
149};
150
151/* Prototypes. */
152void route_map_init ();
153void route_map_init_vty ();
154
155/* Add match statement to route map. */
156int
157route_map_add_match (struct route_map_index *index,
hasso27a43a82004-10-08 06:29:12 +0000158 const char *match_name,
paul718e3742002-12-13 20:15:29 +0000159 char *match_arg);
160
161/* Delete specified route match rule. */
162int
163route_map_delete_match (struct route_map_index *index,
hasso27a43a82004-10-08 06:29:12 +0000164 const char *match_name,
paul718e3742002-12-13 20:15:29 +0000165 char *match_arg);
166
167/* Add route-map set statement to the route map. */
168int
169route_map_add_set (struct route_map_index *index,
hasso27a43a82004-10-08 06:29:12 +0000170 const char *set_name,
paul718e3742002-12-13 20:15:29 +0000171 char *set_arg);
172
173/* Delete route map set rule. */
174int
hasso27a43a82004-10-08 06:29:12 +0000175route_map_delete_set (struct route_map_index *index, const char *set_name,
paul718e3742002-12-13 20:15:29 +0000176 char *set_arg);
177
178/* Install rule command to the match list. */
179void
180route_map_install_match (struct route_map_rule_cmd *cmd);
181
182/* Install rule command to the set list. */
183void
184route_map_install_set (struct route_map_rule_cmd *cmd);
185
186/* Lookup route map by name. */
187struct route_map *
188route_map_lookup_by_name (char *name);
189
190/* Apply route map to the object. */
191route_map_result_t
192route_map_apply (struct route_map *map, struct prefix *,
193 route_map_object_t object_type, void *object);
194
195void route_map_add_hook (void (*func) (char *));
196void route_map_delete_hook (void (*func) (char *));
197void route_map_event_hook (void (*func) (route_map_event_t, char *));
198
199
200#endif /* _ZEBRA_ROUTEMAP_H */