xref: /freebsd/sbin/setkey/token.l (revision bef81bc0aef9dd4cd772b292d81bcc0ff7151d9f)
13c62e87aSJun-ichiro itojun Hagino /*	$FreeBSD$	*/
2cf43a054SHajimu UMEMOTO /*	$KAME: token.l,v 1.43 2003/07/25 09:35:28 itojun Exp $	*/
33c62e87aSJun-ichiro itojun Hagino 
48a16b7a1SPedro F. Giffuni /*-
58a16b7a1SPedro F. Giffuni  * SPDX-License-Identifier: BSD-3-Clause
68a16b7a1SPedro F. Giffuni  *
79a4365d0SYoshinobu Inoue  * Copyright (C) 1995, 1996, 1997, 1998, and 1999 WIDE Project.
89a4365d0SYoshinobu Inoue  * All rights reserved.
99a4365d0SYoshinobu Inoue  *
109a4365d0SYoshinobu Inoue  * Redistribution and use in source and binary forms, with or without
119a4365d0SYoshinobu Inoue  * modification, are permitted provided that the following conditions
129a4365d0SYoshinobu Inoue  * are met:
139a4365d0SYoshinobu Inoue  * 1. Redistributions of source code must retain the above copyright
149a4365d0SYoshinobu Inoue  *    notice, this list of conditions and the following disclaimer.
159a4365d0SYoshinobu Inoue  * 2. Redistributions in binary form must reproduce the above copyright
169a4365d0SYoshinobu Inoue  *    notice, this list of conditions and the following disclaimer in the
179a4365d0SYoshinobu Inoue  *    documentation and/or other materials provided with the distribution.
189a4365d0SYoshinobu Inoue  * 3. Neither the name of the project nor the names of its contributors
199a4365d0SYoshinobu Inoue  *    may be used to endorse or promote products derived from this software
209a4365d0SYoshinobu Inoue  *    without specific prior written permission.
219a4365d0SYoshinobu Inoue  *
229a4365d0SYoshinobu Inoue  * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
239a4365d0SYoshinobu Inoue  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
249a4365d0SYoshinobu Inoue  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
259a4365d0SYoshinobu Inoue  * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
269a4365d0SYoshinobu Inoue  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
279a4365d0SYoshinobu Inoue  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
289a4365d0SYoshinobu Inoue  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
299a4365d0SYoshinobu Inoue  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
309a4365d0SYoshinobu Inoue  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
319a4365d0SYoshinobu Inoue  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
329a4365d0SYoshinobu Inoue  * SUCH DAMAGE.
339a4365d0SYoshinobu Inoue  */
349a4365d0SYoshinobu Inoue 
359a4365d0SYoshinobu Inoue %{
369a4365d0SYoshinobu Inoue #include <sys/types.h>
379a4365d0SYoshinobu Inoue #include <sys/param.h>
389a4365d0SYoshinobu Inoue #include <sys/socket.h>
399a4365d0SYoshinobu Inoue #include <net/route.h>
409a4365d0SYoshinobu Inoue #include <net/pfkeyv2.h>
418409aedfSGeorge V. Neville-Neil #include <netipsec/keydb.h>
428409aedfSGeorge V. Neville-Neil #include <netipsec/key_debug.h>
439a4365d0SYoshinobu Inoue #include <netinet/in.h>
448409aedfSGeorge V. Neville-Neil #include <netipsec/ipsec.h>
459a4365d0SYoshinobu Inoue 
469a4365d0SYoshinobu Inoue #include <stdlib.h>
479a4365d0SYoshinobu Inoue #include <limits.h>
489a4365d0SYoshinobu Inoue #include <string.h>
499a4365d0SYoshinobu Inoue #include <unistd.h>
509a4365d0SYoshinobu Inoue #include <errno.h>
51cf43a054SHajimu UMEMOTO #include <netdb.h>
52cf43a054SHajimu UMEMOTO 
539a4365d0SYoshinobu Inoue #include "vchar.h"
549a4365d0SYoshinobu Inoue #include "y.tab.h"
559a4365d0SYoshinobu Inoue 
569a4365d0SYoshinobu Inoue int lineno = 1;
579a4365d0SYoshinobu Inoue 
589a4365d0SYoshinobu Inoue extern u_char m_buf[BUFSIZ];
599a4365d0SYoshinobu Inoue extern u_int m_len;
609a4365d0SYoshinobu Inoue extern int f_debug;
619a4365d0SYoshinobu Inoue 
62784bddbcSKevin Lo int yylex(void);
63784bddbcSKevin Lo void yyfatal(const char *s);
64784bddbcSKevin Lo void yyerror(const char *s);
65784bddbcSKevin Lo extern void parse_init(void);
66784bddbcSKevin Lo int parse(FILE **);
67784bddbcSKevin Lo int yyparse(void);
689a4365d0SYoshinobu Inoue %}
699a4365d0SYoshinobu Inoue 
701b6c9c3fSBaptiste Daroussin %option noyywrap
711b6c9c3fSBaptiste Daroussin 
729a4365d0SYoshinobu Inoue /* common section */
739a4365d0SYoshinobu Inoue nl		\n
749a4365d0SYoshinobu Inoue ws		[ \t]+
759a4365d0SYoshinobu Inoue digit		[0-9]
769a4365d0SYoshinobu Inoue letter		[0-9A-Za-z]
779a4365d0SYoshinobu Inoue hexdigit	[0-9A-Fa-f]
789a4365d0SYoshinobu Inoue dot		\.
799a4365d0SYoshinobu Inoue hyphen		\-
809a4365d0SYoshinobu Inoue slash		\/
819a4365d0SYoshinobu Inoue blcl		\[
829a4365d0SYoshinobu Inoue elcl		\]
839a4365d0SYoshinobu Inoue semi		\;
849a4365d0SYoshinobu Inoue comment		\#.*
859a4365d0SYoshinobu Inoue quotedstring	\"[^"]*\"
869a4365d0SYoshinobu Inoue decstring	{digit}+
879a4365d0SYoshinobu Inoue hexstring	0[xX]{hexdigit}+
883c62e87aSJun-ichiro itojun Hagino ipaddress	[a-fA-F0-9:]([a-fA-F0-9:\.]*|[a-fA-F0-9:\.]*%[a-zA-Z0-9]*)
899a4365d0SYoshinobu Inoue ipaddrmask	{slash}{digit}{1,3}
909a4365d0SYoshinobu Inoue name		{letter}(({letter}|{digit}|{hyphen})*({letter}|{digit}))*
919a4365d0SYoshinobu Inoue hostname	{name}(({dot}{name})+{dot}?)?
929a4365d0SYoshinobu Inoue 
93cf43a054SHajimu UMEMOTO %s S_PL S_AUTHALG S_ENCALG
949a4365d0SYoshinobu Inoue 
959a4365d0SYoshinobu Inoue %%
969a4365d0SYoshinobu Inoue 
97cf43a054SHajimu UMEMOTO add		{ return(ADD); }
98cf43a054SHajimu UMEMOTO delete		{ return(DELETE); }
99cf43a054SHajimu UMEMOTO deleteall	{ return(DELETEALL); }
100cf43a054SHajimu UMEMOTO get		{ return(GET); }
101cf43a054SHajimu UMEMOTO flush		{ return(FLUSH); }
102cf43a054SHajimu UMEMOTO dump		{ return(DUMP); }
1039a4365d0SYoshinobu Inoue 
1049a4365d0SYoshinobu Inoue 	/* for management SPD */
105cf43a054SHajimu UMEMOTO spdadd		{ return(SPDADD); }
106cf43a054SHajimu UMEMOTO spddelete	{ return(SPDDELETE); }
107cf43a054SHajimu UMEMOTO spddump		{ return(SPDDUMP); }
108cf43a054SHajimu UMEMOTO spdflush	{ return(SPDFLUSH); }
109cf43a054SHajimu UMEMOTO tagged		{ return(TAGGED); }
110cf43a054SHajimu UMEMOTO {hyphen}P	{ BEGIN S_PL; return(F_POLICY); }
111cf43a054SHajimu UMEMOTO <S_PL>[a-zA-Z0-9:\.\-_/ \n\t][a-zA-Z0-9:\.%\-_/ \n\t]* {
1129a4365d0SYoshinobu Inoue 			yymore();
1139a4365d0SYoshinobu Inoue 
1149a4365d0SYoshinobu Inoue 			/* count up for nl */
1159a4365d0SYoshinobu Inoue 			    {
1169a4365d0SYoshinobu Inoue 				char *p;
1178153ab0eSBruce Evans 				for (p = yytext; *p != '\0'; p++)
1189a4365d0SYoshinobu Inoue 					if (*p == '\n')
1199a4365d0SYoshinobu Inoue 						lineno++;
1209a4365d0SYoshinobu Inoue 			    }
1219a4365d0SYoshinobu Inoue 
1229a4365d0SYoshinobu Inoue 			yylval.val.len = strlen(yytext);
1239a4365d0SYoshinobu Inoue 			yylval.val.buf = strdup(yytext);
124cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
125cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
1269a4365d0SYoshinobu Inoue 
1279a4365d0SYoshinobu Inoue 			return(PL_REQUESTS);
1289a4365d0SYoshinobu Inoue 		}
129cf43a054SHajimu UMEMOTO <S_PL>{semi}	{ BEGIN INITIAL; return(EOT); }
130cf43a054SHajimu UMEMOTO 
131cf43a054SHajimu UMEMOTO 	/* address resolution flags */
132cf43a054SHajimu UMEMOTO {hyphen}[n46][n46]*	{
133cf43a054SHajimu UMEMOTO 			yylval.val.len = strlen(yytext);
134cf43a054SHajimu UMEMOTO 			yylval.val.buf = strdup(yytext);
135cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
136cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
137cf43a054SHajimu UMEMOTO 			return(F_AIFLAGS);
138cf43a054SHajimu UMEMOTO 		}
1399a4365d0SYoshinobu Inoue 
1409a4365d0SYoshinobu Inoue 	/* security protocols */
141cf43a054SHajimu UMEMOTO ah		{ yylval.num = 0; return(PR_AH); }
142cf43a054SHajimu UMEMOTO esp		{ yylval.num = 0; return(PR_ESP); }
143cf43a054SHajimu UMEMOTO ah-old		{ yylval.num = 1; return(PR_AH); }
144cf43a054SHajimu UMEMOTO esp-old		{ yylval.num = 1; return(PR_ESP); }
145cf43a054SHajimu UMEMOTO ipcomp		{ yylval.num = 0; return(PR_IPCOMP); }
1461922fd12SBruce M Simpson tcp		{ yylval.num = 0; return(PR_TCP); }
1479a4365d0SYoshinobu Inoue 
1489a4365d0SYoshinobu Inoue 	/* authentication alogorithm */
149cf43a054SHajimu UMEMOTO {hyphen}A	{ BEGIN S_AUTHALG; return(F_AUTH); }
1509f8f3a8eSKristof Provost <S_AUTHALG>chacha20-poly1305 { yylval.num = SADB_X_AALG_CHACHA20POLY1305; BEGIN INITIAL; return(ALG_AUTH); }
151cf43a054SHajimu UMEMOTO <S_AUTHALG>hmac-sha1	{ yylval.num = SADB_AALG_SHA1HMAC; BEGIN INITIAL; return(ALG_AUTH); }
152cf43a054SHajimu UMEMOTO <S_AUTHALG>hmac-sha2-256 { yylval.num = SADB_X_AALG_SHA2_256; BEGIN INITIAL; return(ALG_AUTH); }
153cf43a054SHajimu UMEMOTO <S_AUTHALG>hmac-sha2-384 { yylval.num = SADB_X_AALG_SHA2_384; BEGIN INITIAL; return(ALG_AUTH); }
154cf43a054SHajimu UMEMOTO <S_AUTHALG>hmac-sha2-512 { yylval.num = SADB_X_AALG_SHA2_512; BEGIN INITIAL; return(ALG_AUTH); }
155cf43a054SHajimu UMEMOTO <S_AUTHALG>aes-xcbc-mac { yylval.num = SADB_X_AALG_AES_XCBC_MAC; BEGIN INITIAL; return(ALG_AUTH); }
1561922fd12SBruce M Simpson <S_AUTHALG>tcp-md5	{ yylval.num = SADB_X_AALG_TCP_MD5; BEGIN INITIAL; return(ALG_AUTH); }
157cf43a054SHajimu UMEMOTO <S_AUTHALG>null { yylval.num = SADB_X_AALG_NULL; BEGIN INITIAL; return(ALG_AUTH_NOKEY); }
1589a4365d0SYoshinobu Inoue 
1599a4365d0SYoshinobu Inoue 	/* encryption alogorithm */
160cf43a054SHajimu UMEMOTO {hyphen}E	{ BEGIN S_ENCALG; return(F_ENC); }
16154bf2ef8SGeorge V. Neville-Neil <S_ENCALG>null		{ yylval.num = SADB_EALG_NULL; BEGIN INITIAL; return(ALG_ENC); }
162cf43a054SHajimu UMEMOTO <S_ENCALG>simple	{ yylval.num = SADB_EALG_NULL; BEGIN INITIAL; return(ALG_ENC_OLD); }
16300a4311aSJohn Baldwin <S_ENCALG>rijndael-cbc	{ yylval.num = SADB_X_EALG_AESCBC; BEGIN INITIAL; return(ALG_ENC); }
16400a4311aSJohn Baldwin <S_ENCALG>aes-cbc	{ yylval.num = SADB_X_EALG_AESCBC; BEGIN INITIAL; return(ALG_ENC); }
165afd010c1SGeorge V. Neville-Neil <S_ENCALG>aes-ctr	{ yylval.num = SADB_X_EALG_AESCTR; BEGIN INITIAL; return(ALG_ENC_SALT); }
166afd010c1SGeorge V. Neville-Neil <S_ENCALG>aes-gcm-16	{ yylval.num = SADB_X_EALG_AESGCM16; BEGIN INITIAL; return(ALG_ENC_SALT); }
1679f8f3a8eSKristof Provost <S_ENCALG>chacha20-poly1305 { yylval.num = SADB_X_EALG_CHACHA20POLY1305; BEGIN INITIAL; return(ALG_ENC_SALT); }
1689a4365d0SYoshinobu Inoue 
1699a4365d0SYoshinobu Inoue 	/* compression algorithms */
170cf43a054SHajimu UMEMOTO {hyphen}C	{ return(F_COMP); }
171cf43a054SHajimu UMEMOTO oui		{ yylval.num = SADB_X_CALG_OUI; return(ALG_COMP); }
172cf43a054SHajimu UMEMOTO deflate		{ yylval.num = SADB_X_CALG_DEFLATE; return(ALG_COMP); }
173cf43a054SHajimu UMEMOTO lzs		{ yylval.num = SADB_X_CALG_LZS; return(ALG_COMP); }
174cf43a054SHajimu UMEMOTO {hyphen}R	{ return(F_RAWCPI); }
1759a4365d0SYoshinobu Inoue 
1769a4365d0SYoshinobu Inoue 	/* extension */
177cf43a054SHajimu UMEMOTO {hyphen}m	{ return(F_MODE); }
178cf43a054SHajimu UMEMOTO transport	{ yylval.num = IPSEC_MODE_TRANSPORT; return(MODE); }
179cf43a054SHajimu UMEMOTO tunnel		{ yylval.num = IPSEC_MODE_TUNNEL; return(MODE); }
180cf43a054SHajimu UMEMOTO {hyphen}u	{ return(F_REQID); }
181cf43a054SHajimu UMEMOTO {hyphen}f	{ return(F_EXT); }
182cf43a054SHajimu UMEMOTO random-pad	{ yylval.num = SADB_X_EXT_PRAND; return(EXTENSION); }
183cf43a054SHajimu UMEMOTO seq-pad		{ yylval.num = SADB_X_EXT_PSEQ; return(EXTENSION); }
184cf43a054SHajimu UMEMOTO zero-pad	{ yylval.num = SADB_X_EXT_PZERO; return(EXTENSION); }
185cf43a054SHajimu UMEMOTO nocyclic-seq	{ return(NOCYCLICSEQ); }
186cf43a054SHajimu UMEMOTO {hyphen}r	{ return(F_REPLAY); }
187cf43a054SHajimu UMEMOTO {hyphen}lh	{ return(F_LIFETIME_HARD); }
188cf43a054SHajimu UMEMOTO {hyphen}ls	{ return(F_LIFETIME_SOFT); }
1899a4365d0SYoshinobu Inoue 
1909a4365d0SYoshinobu Inoue 	/* ... */
191cf43a054SHajimu UMEMOTO any		{ return(ANY); }
192cf43a054SHajimu UMEMOTO {ws}		{ }
1939a4365d0SYoshinobu Inoue {nl}		{ lineno++; }
1949a4365d0SYoshinobu Inoue {comment}
195cf43a054SHajimu UMEMOTO {semi}		{ return(EOT); }
196cf43a054SHajimu UMEMOTO 
197cf43a054SHajimu UMEMOTO 	/* for address parameters: /prefix, [port] */
198cf43a054SHajimu UMEMOTO {slash}		{ return SLASH; }
199cf43a054SHajimu UMEMOTO {blcl}		{ return BLCL; }
200cf43a054SHajimu UMEMOTO {elcl}		{ return ELCL; }
2019a4365d0SYoshinobu Inoue 
2029a4365d0SYoshinobu Inoue 	/* parameter */
2039a4365d0SYoshinobu Inoue {decstring}	{
2049a4365d0SYoshinobu Inoue 			char *bp;
2059a4365d0SYoshinobu Inoue 
206cf43a054SHajimu UMEMOTO 			yylval.ulnum = strtoul(yytext, &bp, 10);
2079a4365d0SYoshinobu Inoue 			return(DECSTRING);
2089a4365d0SYoshinobu Inoue 		}
2099a4365d0SYoshinobu Inoue 
2109a4365d0SYoshinobu Inoue {hexstring}	{
2119a4365d0SYoshinobu Inoue 			yylval.val.buf = strdup(yytext + 2);
212cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
213cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
214cf43a054SHajimu UMEMOTO 			yylval.val.len = strlen(yylval.val.buf);
2159a4365d0SYoshinobu Inoue 
2169a4365d0SYoshinobu Inoue 			return(HEXSTRING);
2179a4365d0SYoshinobu Inoue 		}
2189a4365d0SYoshinobu Inoue 
2199a4365d0SYoshinobu Inoue {quotedstring}	{
2209a4365d0SYoshinobu Inoue 			char *p = yytext;
2219a4365d0SYoshinobu Inoue 			while (*++p != '"') ;
2228153ab0eSBruce Evans 			*p = '\0';
2239a4365d0SYoshinobu Inoue 			yytext++;
2249a4365d0SYoshinobu Inoue 			yylval.val.len = yyleng - 2;
2259a4365d0SYoshinobu Inoue 			yylval.val.buf = strdup(yytext);
226cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
227cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
2289a4365d0SYoshinobu Inoue 
2299a4365d0SYoshinobu Inoue 			return(QUOTEDSTRING);
2309a4365d0SYoshinobu Inoue 		}
2319a4365d0SYoshinobu Inoue 
232cf43a054SHajimu UMEMOTO [A-Za-z0-9:][A-Za-z0-9:%\.-]* {
23333841545SHajimu UMEMOTO 			yylval.val.len = yyleng;
23433841545SHajimu UMEMOTO 			yylval.val.buf = strdup(yytext);
235cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
236cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
237cf43a054SHajimu UMEMOTO 			return(STRING);
238cf43a054SHajimu UMEMOTO 		}
239cf43a054SHajimu UMEMOTO 
240cf43a054SHajimu UMEMOTO [0-9,]+ {
241cf43a054SHajimu UMEMOTO 			yylval.val.len = yyleng;
242cf43a054SHajimu UMEMOTO 			yylval.val.buf = strdup(yytext);
243cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
244cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
24533841545SHajimu UMEMOTO 			return(STRING);
24633841545SHajimu UMEMOTO 		}
24733841545SHajimu UMEMOTO 
2483c62e87aSJun-ichiro itojun Hagino .		{
2493c62e87aSJun-ichiro itojun Hagino 			yyfatal("Syntax error");
2503c62e87aSJun-ichiro itojun Hagino 			/*NOTREACHED*/
2513c62e87aSJun-ichiro itojun Hagino 		}
2529a4365d0SYoshinobu Inoue 
2539a4365d0SYoshinobu Inoue %%
2549a4365d0SYoshinobu Inoue 
2559a4365d0SYoshinobu Inoue void
256*bef81bc0SKonstantin Belousov yyfatal(const char *s)
2573c62e87aSJun-ichiro itojun Hagino {
2583c62e87aSJun-ichiro itojun Hagino 	yyerror(s);
2593c62e87aSJun-ichiro itojun Hagino 	exit(1);
2603c62e87aSJun-ichiro itojun Hagino }
2613c62e87aSJun-ichiro itojun Hagino 
2623c62e87aSJun-ichiro itojun Hagino void
263*bef81bc0SKonstantin Belousov yyerror(const char *s)
2649a4365d0SYoshinobu Inoue {
2659a4365d0SYoshinobu Inoue 	printf("line %d: %s at [%s]\n", lineno, s, yytext);
2669a4365d0SYoshinobu Inoue }
2679a4365d0SYoshinobu Inoue 
2689a4365d0SYoshinobu Inoue int
269*bef81bc0SKonstantin Belousov parse(FILE **fp)
2709a4365d0SYoshinobu Inoue {
2719a4365d0SYoshinobu Inoue 	yyin = *fp;
2729a4365d0SYoshinobu Inoue 
2739a4365d0SYoshinobu Inoue 	parse_init();
2749a4365d0SYoshinobu Inoue 
2759a4365d0SYoshinobu Inoue 	if (yyparse()) {
2769a4365d0SYoshinobu Inoue 		printf("parse failed, line %d.\n", lineno);
2779a4365d0SYoshinobu Inoue 		return(-1);
2789a4365d0SYoshinobu Inoue 	}
2799a4365d0SYoshinobu Inoue 
2809a4365d0SYoshinobu Inoue 	return(0);
2819a4365d0SYoshinobu Inoue }
282