xref: /freebsd/sbin/setkey/token.l (revision 83418c878b75fafd5f9bfc44baf049487ce99a86)
1cf43a054SHajimu UMEMOTO /*	$KAME: token.l,v 1.43 2003/07/25 09:35:28 itojun Exp $	*/
23c62e87aSJun-ichiro itojun Hagino 
38a16b7a1SPedro F. Giffuni /*-
48a16b7a1SPedro F. Giffuni  * SPDX-License-Identifier: BSD-3-Clause
58a16b7a1SPedro F. Giffuni  *
69a4365d0SYoshinobu Inoue  * Copyright (C) 1995, 1996, 1997, 1998, and 1999 WIDE Project.
79a4365d0SYoshinobu Inoue  * All rights reserved.
89a4365d0SYoshinobu Inoue  *
99a4365d0SYoshinobu Inoue  * Redistribution and use in source and binary forms, with or without
109a4365d0SYoshinobu Inoue  * modification, are permitted provided that the following conditions
119a4365d0SYoshinobu Inoue  * are met:
129a4365d0SYoshinobu Inoue  * 1. Redistributions of source code must retain the above copyright
139a4365d0SYoshinobu Inoue  *    notice, this list of conditions and the following disclaimer.
149a4365d0SYoshinobu Inoue  * 2. Redistributions in binary form must reproduce the above copyright
159a4365d0SYoshinobu Inoue  *    notice, this list of conditions and the following disclaimer in the
169a4365d0SYoshinobu Inoue  *    documentation and/or other materials provided with the distribution.
179a4365d0SYoshinobu Inoue  * 3. Neither the name of the project nor the names of its contributors
189a4365d0SYoshinobu Inoue  *    may be used to endorse or promote products derived from this software
199a4365d0SYoshinobu Inoue  *    without specific prior written permission.
209a4365d0SYoshinobu Inoue  *
219a4365d0SYoshinobu Inoue  * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
229a4365d0SYoshinobu Inoue  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
239a4365d0SYoshinobu Inoue  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
249a4365d0SYoshinobu Inoue  * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
259a4365d0SYoshinobu Inoue  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
269a4365d0SYoshinobu Inoue  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
279a4365d0SYoshinobu Inoue  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
289a4365d0SYoshinobu Inoue  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
299a4365d0SYoshinobu Inoue  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
309a4365d0SYoshinobu Inoue  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
319a4365d0SYoshinobu Inoue  * SUCH DAMAGE.
329a4365d0SYoshinobu Inoue  */
339a4365d0SYoshinobu Inoue 
349a4365d0SYoshinobu Inoue %{
359a4365d0SYoshinobu Inoue #include <sys/types.h>
369a4365d0SYoshinobu Inoue #include <sys/param.h>
379a4365d0SYoshinobu Inoue #include <sys/socket.h>
389a4365d0SYoshinobu Inoue #include <net/route.h>
399a4365d0SYoshinobu Inoue #include <net/pfkeyv2.h>
408409aedfSGeorge V. Neville-Neil #include <netipsec/keydb.h>
418409aedfSGeorge V. Neville-Neil #include <netipsec/key_debug.h>
429a4365d0SYoshinobu Inoue #include <netinet/in.h>
438409aedfSGeorge V. Neville-Neil #include <netipsec/ipsec.h>
449a4365d0SYoshinobu Inoue 
459a4365d0SYoshinobu Inoue #include <stdlib.h>
469a4365d0SYoshinobu Inoue #include <limits.h>
479a4365d0SYoshinobu Inoue #include <string.h>
489a4365d0SYoshinobu Inoue #include <unistd.h>
499a4365d0SYoshinobu Inoue #include <errno.h>
50cf43a054SHajimu UMEMOTO #include <netdb.h>
51cf43a054SHajimu UMEMOTO 
529a4365d0SYoshinobu Inoue #include "vchar.h"
539a4365d0SYoshinobu Inoue #include "y.tab.h"
549a4365d0SYoshinobu Inoue 
559a4365d0SYoshinobu Inoue int lineno = 1;
569a4365d0SYoshinobu Inoue 
579a4365d0SYoshinobu Inoue extern u_char m_buf[BUFSIZ];
589a4365d0SYoshinobu Inoue extern u_int m_len;
599a4365d0SYoshinobu Inoue extern int f_debug;
609a4365d0SYoshinobu Inoue 
61784bddbcSKevin Lo int yylex(void);
62784bddbcSKevin Lo void yyfatal(const char *s);
63784bddbcSKevin Lo void yyerror(const char *s);
64784bddbcSKevin Lo extern void parse_init(void);
65784bddbcSKevin Lo int parse(FILE **);
66784bddbcSKevin Lo int yyparse(void);
679a4365d0SYoshinobu Inoue %}
689a4365d0SYoshinobu Inoue 
691b6c9c3fSBaptiste Daroussin %option noyywrap
701b6c9c3fSBaptiste Daroussin 
719a4365d0SYoshinobu Inoue /* common section */
729a4365d0SYoshinobu Inoue nl		\n
739a4365d0SYoshinobu Inoue ws		[ \t]+
749a4365d0SYoshinobu Inoue digit		[0-9]
759a4365d0SYoshinobu Inoue letter		[0-9A-Za-z]
769a4365d0SYoshinobu Inoue hexdigit	[0-9A-Fa-f]
779a4365d0SYoshinobu Inoue dot		\.
789a4365d0SYoshinobu Inoue hyphen		\-
799a4365d0SYoshinobu Inoue slash		\/
809a4365d0SYoshinobu Inoue blcl		\[
819a4365d0SYoshinobu Inoue elcl		\]
829a4365d0SYoshinobu Inoue semi		\;
839a4365d0SYoshinobu Inoue comment		\#.*
849a4365d0SYoshinobu Inoue quotedstring	\"[^"]*\"
859a4365d0SYoshinobu Inoue decstring	{digit}+
869a4365d0SYoshinobu Inoue hexstring	0[xX]{hexdigit}+
873c62e87aSJun-ichiro itojun Hagino ipaddress	[a-fA-F0-9:]([a-fA-F0-9:\.]*|[a-fA-F0-9:\.]*%[a-zA-Z0-9]*)
889a4365d0SYoshinobu Inoue ipaddrmask	{slash}{digit}{1,3}
899a4365d0SYoshinobu Inoue name		{letter}(({letter}|{digit}|{hyphen})*({letter}|{digit}))*
909a4365d0SYoshinobu Inoue hostname	{name}(({dot}{name})+{dot}?)?
919a4365d0SYoshinobu Inoue 
92cf43a054SHajimu UMEMOTO %s S_PL S_AUTHALG S_ENCALG
939a4365d0SYoshinobu Inoue 
949a4365d0SYoshinobu Inoue %%
959a4365d0SYoshinobu Inoue 
96cf43a054SHajimu UMEMOTO add		{ return(ADD); }
97cf43a054SHajimu UMEMOTO delete		{ return(DELETE); }
98cf43a054SHajimu UMEMOTO deleteall	{ return(DELETEALL); }
99cf43a054SHajimu UMEMOTO get		{ return(GET); }
100cf43a054SHajimu UMEMOTO flush		{ return(FLUSH); }
101cf43a054SHajimu UMEMOTO dump		{ return(DUMP); }
1029a4365d0SYoshinobu Inoue 
1039a4365d0SYoshinobu Inoue 	/* for management SPD */
104cf43a054SHajimu UMEMOTO spdadd		{ return(SPDADD); }
105cf43a054SHajimu UMEMOTO spddelete	{ return(SPDDELETE); }
106cf43a054SHajimu UMEMOTO spddump		{ return(SPDDUMP); }
107cf43a054SHajimu UMEMOTO spdflush	{ return(SPDFLUSH); }
108cf43a054SHajimu UMEMOTO tagged		{ return(TAGGED); }
109cf43a054SHajimu UMEMOTO {hyphen}P	{ BEGIN S_PL; return(F_POLICY); }
110cf43a054SHajimu UMEMOTO <S_PL>[a-zA-Z0-9:\.\-_/ \n\t][a-zA-Z0-9:\.%\-_/ \n\t]* {
1119a4365d0SYoshinobu Inoue 			yymore();
1129a4365d0SYoshinobu Inoue 
1139a4365d0SYoshinobu Inoue 			/* count up for nl */
1149a4365d0SYoshinobu Inoue 			    {
1159a4365d0SYoshinobu Inoue 				char *p;
1168153ab0eSBruce Evans 				for (p = yytext; *p != '\0'; p++)
1179a4365d0SYoshinobu Inoue 					if (*p == '\n')
1189a4365d0SYoshinobu Inoue 						lineno++;
1199a4365d0SYoshinobu Inoue 			    }
1209a4365d0SYoshinobu Inoue 
1219a4365d0SYoshinobu Inoue 			yylval.val.len = strlen(yytext);
1229a4365d0SYoshinobu Inoue 			yylval.val.buf = strdup(yytext);
123cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
124cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
1259a4365d0SYoshinobu Inoue 
1269a4365d0SYoshinobu Inoue 			return(PL_REQUESTS);
1279a4365d0SYoshinobu Inoue 		}
128cf43a054SHajimu UMEMOTO <S_PL>{semi}	{ BEGIN INITIAL; return(EOT); }
129cf43a054SHajimu UMEMOTO 
130cf43a054SHajimu UMEMOTO 	/* address resolution flags */
131cf43a054SHajimu UMEMOTO {hyphen}[n46][n46]*	{
132cf43a054SHajimu UMEMOTO 			yylval.val.len = strlen(yytext);
133cf43a054SHajimu UMEMOTO 			yylval.val.buf = strdup(yytext);
134cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
135cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
136cf43a054SHajimu UMEMOTO 			return(F_AIFLAGS);
137cf43a054SHajimu UMEMOTO 		}
1389a4365d0SYoshinobu Inoue 
1399a4365d0SYoshinobu Inoue 	/* security protocols */
140cf43a054SHajimu UMEMOTO ah		{ yylval.num = 0; return(PR_AH); }
141cf43a054SHajimu UMEMOTO esp		{ yylval.num = 0; return(PR_ESP); }
142cf43a054SHajimu UMEMOTO ah-old		{ yylval.num = 1; return(PR_AH); }
143cf43a054SHajimu UMEMOTO esp-old		{ yylval.num = 1; return(PR_ESP); }
144cf43a054SHajimu UMEMOTO ipcomp		{ yylval.num = 0; return(PR_IPCOMP); }
1451922fd12SBruce M Simpson tcp		{ yylval.num = 0; return(PR_TCP); }
1469a4365d0SYoshinobu Inoue 
1479a4365d0SYoshinobu Inoue 	/* authentication alogorithm */
148cf43a054SHajimu UMEMOTO {hyphen}A	{ BEGIN S_AUTHALG; return(F_AUTH); }
1499f8f3a8eSKristof Provost <S_AUTHALG>chacha20-poly1305 { yylval.num = SADB_X_AALG_CHACHA20POLY1305; BEGIN INITIAL; return(ALG_AUTH); }
150cf43a054SHajimu UMEMOTO <S_AUTHALG>hmac-sha1	{ yylval.num = SADB_AALG_SHA1HMAC; BEGIN INITIAL; return(ALG_AUTH); }
151cf43a054SHajimu UMEMOTO <S_AUTHALG>hmac-sha2-256 { yylval.num = SADB_X_AALG_SHA2_256; BEGIN INITIAL; return(ALG_AUTH); }
152cf43a054SHajimu UMEMOTO <S_AUTHALG>hmac-sha2-384 { yylval.num = SADB_X_AALG_SHA2_384; BEGIN INITIAL; return(ALG_AUTH); }
153cf43a054SHajimu UMEMOTO <S_AUTHALG>hmac-sha2-512 { yylval.num = SADB_X_AALG_SHA2_512; BEGIN INITIAL; return(ALG_AUTH); }
154cf43a054SHajimu UMEMOTO <S_AUTHALG>aes-xcbc-mac { yylval.num = SADB_X_AALG_AES_XCBC_MAC; BEGIN INITIAL; return(ALG_AUTH); }
1551922fd12SBruce M Simpson <S_AUTHALG>tcp-md5	{ yylval.num = SADB_X_AALG_TCP_MD5; BEGIN INITIAL; return(ALG_AUTH); }
156cf43a054SHajimu UMEMOTO <S_AUTHALG>null { yylval.num = SADB_X_AALG_NULL; BEGIN INITIAL; return(ALG_AUTH_NOKEY); }
1579a4365d0SYoshinobu Inoue 
1589a4365d0SYoshinobu Inoue 	/* encryption alogorithm */
159cf43a054SHajimu UMEMOTO {hyphen}E	{ BEGIN S_ENCALG; return(F_ENC); }
16054bf2ef8SGeorge V. Neville-Neil <S_ENCALG>null		{ yylval.num = SADB_EALG_NULL; BEGIN INITIAL; return(ALG_ENC); }
161cf43a054SHajimu UMEMOTO <S_ENCALG>simple	{ yylval.num = SADB_EALG_NULL; BEGIN INITIAL; return(ALG_ENC_OLD); }
16200a4311aSJohn Baldwin <S_ENCALG>rijndael-cbc	{ yylval.num = SADB_X_EALG_AESCBC; BEGIN INITIAL; return(ALG_ENC); }
16300a4311aSJohn Baldwin <S_ENCALG>aes-cbc	{ yylval.num = SADB_X_EALG_AESCBC; BEGIN INITIAL; return(ALG_ENC); }
164afd010c1SGeorge V. Neville-Neil <S_ENCALG>aes-ctr	{ yylval.num = SADB_X_EALG_AESCTR; BEGIN INITIAL; return(ALG_ENC_SALT); }
165afd010c1SGeorge V. Neville-Neil <S_ENCALG>aes-gcm-16	{ yylval.num = SADB_X_EALG_AESGCM16; BEGIN INITIAL; return(ALG_ENC_SALT); }
1669f8f3a8eSKristof Provost <S_ENCALG>chacha20-poly1305 { yylval.num = SADB_X_EALG_CHACHA20POLY1305; BEGIN INITIAL; return(ALG_ENC_SALT); }
1679a4365d0SYoshinobu Inoue 
1689a4365d0SYoshinobu Inoue 	/* compression algorithms */
169cf43a054SHajimu UMEMOTO {hyphen}C	{ return(F_COMP); }
170cf43a054SHajimu UMEMOTO oui		{ yylval.num = SADB_X_CALG_OUI; return(ALG_COMP); }
171cf43a054SHajimu UMEMOTO deflate		{ yylval.num = SADB_X_CALG_DEFLATE; return(ALG_COMP); }
172cf43a054SHajimu UMEMOTO lzs		{ yylval.num = SADB_X_CALG_LZS; return(ALG_COMP); }
173cf43a054SHajimu UMEMOTO {hyphen}R	{ return(F_RAWCPI); }
1749a4365d0SYoshinobu Inoue 
1759a4365d0SYoshinobu Inoue 	/* extension */
176cf43a054SHajimu UMEMOTO {hyphen}m	{ return(F_MODE); }
177cf43a054SHajimu UMEMOTO transport	{ yylval.num = IPSEC_MODE_TRANSPORT; return(MODE); }
178cf43a054SHajimu UMEMOTO tunnel		{ yylval.num = IPSEC_MODE_TUNNEL; return(MODE); }
179cf43a054SHajimu UMEMOTO {hyphen}u	{ return(F_REQID); }
180cf43a054SHajimu UMEMOTO {hyphen}f	{ return(F_EXT); }
181cf43a054SHajimu UMEMOTO random-pad	{ yylval.num = SADB_X_EXT_PRAND; return(EXTENSION); }
182cf43a054SHajimu UMEMOTO seq-pad		{ yylval.num = SADB_X_EXT_PSEQ; return(EXTENSION); }
183cf43a054SHajimu UMEMOTO zero-pad	{ yylval.num = SADB_X_EXT_PZERO; return(EXTENSION); }
184cf43a054SHajimu UMEMOTO nocyclic-seq	{ return(NOCYCLICSEQ); }
185cf43a054SHajimu UMEMOTO {hyphen}r	{ return(F_REPLAY); }
186cf43a054SHajimu UMEMOTO {hyphen}lh	{ return(F_LIFETIME_HARD); }
187cf43a054SHajimu UMEMOTO {hyphen}ls	{ return(F_LIFETIME_SOFT); }
1882fa1b861SKonstantin Belousov {hyphen}natt	{ return(F_NATT); }
1892fa1b861SKonstantin Belousov {hyphen}natt_mtu { return(F_NATT_MTU); }
1909b93b2d8SKonstantin Belousov {hyphen}esn	{ return(F_ESN); }
191*83418c87SKonstantin Belousov {hyphen}hwif	{ return(F_HWIF); }
1929a4365d0SYoshinobu Inoue 
1939a4365d0SYoshinobu Inoue 	/* ... */
194cf43a054SHajimu UMEMOTO any		{ return(ANY); }
195cf43a054SHajimu UMEMOTO {ws}		{ }
1969a4365d0SYoshinobu Inoue {nl}		{ lineno++; }
1979a4365d0SYoshinobu Inoue {comment}
198cf43a054SHajimu UMEMOTO {semi}		{ return(EOT); }
199cf43a054SHajimu UMEMOTO 
200cf43a054SHajimu UMEMOTO 	/* for address parameters: /prefix, [port] */
201cf43a054SHajimu UMEMOTO {slash}		{ return SLASH; }
202cf43a054SHajimu UMEMOTO {blcl}		{ return BLCL; }
203cf43a054SHajimu UMEMOTO {elcl}		{ return ELCL; }
2049a4365d0SYoshinobu Inoue 
2059a4365d0SYoshinobu Inoue 	/* parameter */
2069a4365d0SYoshinobu Inoue {decstring}	{
2079a4365d0SYoshinobu Inoue 			char *bp;
2089a4365d0SYoshinobu Inoue 
209cf43a054SHajimu UMEMOTO 			yylval.ulnum = strtoul(yytext, &bp, 10);
2109a4365d0SYoshinobu Inoue 			return(DECSTRING);
2119a4365d0SYoshinobu Inoue 		}
2129a4365d0SYoshinobu Inoue 
2139a4365d0SYoshinobu Inoue {hexstring}	{
2149a4365d0SYoshinobu Inoue 			yylval.val.buf = strdup(yytext + 2);
215cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
216cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
217cf43a054SHajimu UMEMOTO 			yylval.val.len = strlen(yylval.val.buf);
2189a4365d0SYoshinobu Inoue 
2199a4365d0SYoshinobu Inoue 			return(HEXSTRING);
2209a4365d0SYoshinobu Inoue 		}
2219a4365d0SYoshinobu Inoue 
2229a4365d0SYoshinobu Inoue {quotedstring}	{
2239a4365d0SYoshinobu Inoue 			char *p = yytext;
2249a4365d0SYoshinobu Inoue 			while (*++p != '"') ;
2258153ab0eSBruce Evans 			*p = '\0';
2269a4365d0SYoshinobu Inoue 			yytext++;
2279a4365d0SYoshinobu Inoue 			yylval.val.len = yyleng - 2;
2289a4365d0SYoshinobu Inoue 			yylval.val.buf = strdup(yytext);
229cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
230cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
2319a4365d0SYoshinobu Inoue 
2329a4365d0SYoshinobu Inoue 			return(QUOTEDSTRING);
2339a4365d0SYoshinobu Inoue 		}
2349a4365d0SYoshinobu Inoue 
235cf43a054SHajimu UMEMOTO [A-Za-z0-9:][A-Za-z0-9:%\.-]* {
23633841545SHajimu UMEMOTO 			yylval.val.len = yyleng;
23733841545SHajimu UMEMOTO 			yylval.val.buf = strdup(yytext);
238cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
239cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
240cf43a054SHajimu UMEMOTO 			return(STRING);
241cf43a054SHajimu UMEMOTO 		}
242cf43a054SHajimu UMEMOTO 
243cf43a054SHajimu UMEMOTO [0-9,]+ {
244cf43a054SHajimu UMEMOTO 			yylval.val.len = yyleng;
245cf43a054SHajimu UMEMOTO 			yylval.val.buf = strdup(yytext);
246cf43a054SHajimu UMEMOTO 			if (!yylval.val.buf)
247cf43a054SHajimu UMEMOTO 				yyfatal("insufficient memory");
24833841545SHajimu UMEMOTO 			return(STRING);
24933841545SHajimu UMEMOTO 		}
25033841545SHajimu UMEMOTO 
2513c62e87aSJun-ichiro itojun Hagino .		{
2523c62e87aSJun-ichiro itojun Hagino 			yyfatal("Syntax error");
2533c62e87aSJun-ichiro itojun Hagino 			/*NOTREACHED*/
2543c62e87aSJun-ichiro itojun Hagino 		}
2559a4365d0SYoshinobu Inoue 
2569a4365d0SYoshinobu Inoue %%
2579a4365d0SYoshinobu Inoue 
2589a4365d0SYoshinobu Inoue void
259bef81bc0SKonstantin Belousov yyfatal(const char *s)
2603c62e87aSJun-ichiro itojun Hagino {
2613c62e87aSJun-ichiro itojun Hagino 	yyerror(s);
2623c62e87aSJun-ichiro itojun Hagino 	exit(1);
2633c62e87aSJun-ichiro itojun Hagino }
2643c62e87aSJun-ichiro itojun Hagino 
2653c62e87aSJun-ichiro itojun Hagino void
266bef81bc0SKonstantin Belousov yyerror(const char *s)
2679a4365d0SYoshinobu Inoue {
2689a4365d0SYoshinobu Inoue 	printf("line %d: %s at [%s]\n", lineno, s, yytext);
2699a4365d0SYoshinobu Inoue }
2709a4365d0SYoshinobu Inoue 
2719a4365d0SYoshinobu Inoue int
272bef81bc0SKonstantin Belousov parse(FILE **fp)
2739a4365d0SYoshinobu Inoue {
2749a4365d0SYoshinobu Inoue 	yyin = *fp;
2759a4365d0SYoshinobu Inoue 
2769a4365d0SYoshinobu Inoue 	parse_init();
2779a4365d0SYoshinobu Inoue 
2789a4365d0SYoshinobu Inoue 	if (yyparse()) {
2799a4365d0SYoshinobu Inoue 		printf("parse failed, line %d.\n", lineno);
2809a4365d0SYoshinobu Inoue 		return(-1);
2819a4365d0SYoshinobu Inoue 	}
2829a4365d0SYoshinobu Inoue 
2839a4365d0SYoshinobu Inoue 	return(0);
2849a4365d0SYoshinobu Inoue }
285