pkgsrc/net/irrtoolset-nox11/patches/patch-dq
spz e9602106e1 - update DESCR to match reality
- add patch to src/gnug++/int.defs.h for Solaris compatibility
  (by Ian Dickinson, iand@eng.pipex.net)
- move Errors manpage to a less general name (suggested by Ian Dickinson)
- add patch to src/RtConfig/f_cisco.cc by Hagen Boehm <hboehm@NIC.DTAG.DE>
  (fixes up the string that gets output instead of a copy of said string)
- improve src/Makefile.in some more
2008-03-08 11:00:34 +00:00

622 lines
21 KiB
Text

$NetBSD: patch-dq,v 1.1 2008/03/08 11:00:35 spz Exp $
--- man/man1/IRRToolSet-Errors.1.orig 2008-03-08 10:03:21.000000000 +0100
+++ man/man1/IRRToolSet-Errors.1
@@ -0,0 +1,617 @@
+.\"// Copyright (c) 2001,2002 RIPE NCC
+.\"//
+.\"// All Rights Reserved
+.\"//
+.\"// Permission to use, copy, modify, and distribute this software and its
+.\"// documentation for any purpose and without fee is hereby granted,
+.\"// provided that the above copyright notice appear in all copies and that
+.\"// both that copyright notice and this permission notice appear in
+.\"// supporting documentation, and that the name of the author not be
+.\"// used in advertising or publicity pertaining to distribution of the
+.\"// software without specific, written prior permission.
+.\"//
+.\"// THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
+.\"// ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS; IN NO EVENT SHALL
+.\"// AUTHOR BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY
+.\"// DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
+.\"// AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+.\"// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+.\"//
+.\"//
+.\"// Copyright (c) 1994 by the University of Southern California
+.\"// and/or the International Business Machines Corporation.
+.\"// All rights reserved.
+.\"//
+.\"// Permission to use, copy, modify, and distribute this software and
+.\"// its documentation in source and binary forms for lawful
+.\"// non-commercial purposes and without fee is hereby granted, provided
+.\"// that the above copyright notice appear in all copies and that both
+.\"// the copyright notice and this permission notice appear in supporting
+.\"// documentation, and that any documentation, advertising materials,
+.\"// and other materials related to such distribution and use acknowledge
+.\"// that the software was developed by the University of Southern
+.\"// California, Information Sciences Institute and/or the International
+.\"// Business Machines Corporation. The name of the USC or IBM may not
+.\"// be used to endorse or promote products derived from this software
+.\"// without specific prior written permission.
+.\"//
+.\"// NEITHER THE UNIVERSITY OF SOUTHERN CALIFORNIA NOR INTERNATIONAL
+.\"// BUSINESS MACHINES CORPORATION MAKES ANY REPRESENTATIONS ABOUT
+.\"// THE SUITABILITY OF THIS SOFTWARE FOR ANY PURPOSE. THIS SOFTWARE IS
+.\"// PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES,
+.\"// INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
+.\"// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, TITLE, AND
+.\"// NON-INFRINGEMENT.
+.\"//
+.\"// IN NO EVENT SHALL USC, IBM, OR ANY OTHER CONTRIBUTOR BE LIABLE FOR ANY
+.\"// SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES, WHETHER IN CONTRACT,
+.\"// TORT, OR OTHER FORM OF ACTION, ARISING OUT OF OR IN CONNECTION WITH,
+.\"// THE USE OR PERFORMANCE OF THIS SOFTWARE.
+.\"//
+.\"// Questions concerning this software should be directed to
+.\"// info-ra@isi.edu.
+.\"//
+.\"// Author(s): Cengiz Alaettinoglu <cengiz@isi.edu>
+.\"
+.\"
+.TH IRRToolSet-Errors 1 local
+.SH NAME
+IRRToolSet-Errors: error and warning messages
+.SH DESCRIPTION
+.PP
+The goal of this document is to clarify the possible errors you may encounter when using IRRToolSet. Some of these errors are listed on the manual pages for the tools. If you didn't find the error on the manual page of the tool you were using, please refer to this page. Some errors wuth obvious explanation are listed here for reference, but to not have any documentation. Still, if description is unclear or unsufficient, please report to irrtoolset@ripe.net.
+.SH IRR communication errors
+.PP
+.B Command errors
+.PP
+.PD 0
+.P
+Error: unknown irr protocol <protocol>, using irrd
+.P
+known protocols: irrd(rawhoisd), ripe(bird), ripe_perl
+.PD 1
+.RS
+.PP
+The protocol specified with "-protocol" option is unknown or not supported. Use one of the known protocols to connect to IRR server. This option is case-insensitive. This is important which protocol to use, because some client/server protocols are incompatible, and you can get wrong result. Check IRR server documentation and use the protocols which are compatible with it. Please note that there are 3 protocols supported, and the rest are aliases (rawhoisd is the same as irrd and bird is the same as ripe). ripe_perl should be used with old ripe server.
+.PP
+.RE
+.B System errors
+.PP
+Error: gethostbyname (<hostname>) failed.
+.PP
+Error: socket() failed.
+.PP
+Error: connect() failed.
+.PP
+Error: fgets() failed.
+.PP
+Error: fread() failed.
+.PP
+Error: fwrite() failed.
+.PP
+Connection to <host>\:<port>\ failed!
+.RS
+.PP
+There could be several reasons for this error: host is unreachable, or some packet filtering is on and you can't send the packets, or the server may be not responding. Check your network setup and host reachability.
+.PP
+.RE
+Warning: setsockopt SO_KEEPALIVE failed!
+.RS
+.PP
+All protocols supported by IRRToolSet are using persistent connection to the IRR server. When the socket for IRR connection is created, SO_KEEPALIVE option is set to enable persistent connection (client has to keep checking if the destination is still alive). See setsockopt(2) manual page for details about possible failures.
+.PP
+.RE
+.B IRR-specific errors
+.PP
+Error: setting source to <sources>\ failed.
+.RS
+.PP
+One (or several) sources from <sources> list are not found on IRR server. If the source setting for IRR server failed, the source list will be default one.
+Check IRR server documentation for the proper command to get the list of all available sources and default sources. This check is only implemented for irrd(rawhoisd). If you mistyped the source name, re-run the program using "-s <sources>" option.
+.PP
+.RE
+Error: current source setting is <sources>\.
+.RS
+.PP
+This is rather informational message, preceeded by error message about failed sources setting. It shows the source list which is used currently by the program for querying. If you want to modify this list, use "-s <sources>" option.
+.PP
+.RE
+Warning: irrd(rawhoisd) does not yet support rtr-set expansion.
+.RS
+.PP
+Although as-set and route-set expansion is an internal feature of irrd, rtr-set expansion is not implemented yet. In IRRToolSet it is done by external functions, but it still works. So you can safely ignore this warning, this is just a reminder to keep an eye on irrd development and update the code to use internal feature when it is implemented.
+.PP
+.RE
+Warning: key not found error for query <last_query>
+.RS
+.PP
+Object not found in the database for specified sources. <last_query> specifies the actual query to the server which returned to objects. The reason can be:
+.PD 0
+.IP \(bu 2
+object, source or host name are mistyped and therefore object cannot be found;
+.IP \(bu 2
+this is true error and you're referencing non-existent object, which is supposed to be in the database; check your objects and policy description.
+.PD 1
+.PP
+.RE
+Warning: no byte count error for query <last_query>\.
+.RS
+.PP
+irrd server returns the length of the reply for successful queries with "A<reply length in bytes including newlines>". The program is expecting it if query is successful. If it is not received, the warning is issued. This error can also indicate protocol/server incompatibility (for example, RIPE whois server with irrd protocol). Please check IRR server documentation for details.
+.PP
+.RE
+Warning: no end of data line error for query <last_query>\.
+.RS
+.PP
+After a successful query irrd server issues special "end of data" command, "C". If it is not received after <length of reply> bytes of data, the program complains. This can indicate that query was broken, or incomplete, or some other server error occured. Please check IRR server documentation for details or ask IRR server administration for help.
+.PP
+.RE
+.SH RPSL parser errors
+.B Lexer errors
+.PP
+Error: unknown class <yytext>
+.RS
+.PP
+Wrong first attribute of the object. This attribute is considered RPSL class name, and determines the object type. The rest of object's attributes can have any order, but the first one should be on the first place.
+.PP
+.RE
+Error: unknown attribute <attr> of class <class>
+.RS
+.PP
+Wrong attribute of the object. The attribute is a string followed by ":" which describes the type of data after ":". Object consists of "attribute:value" pairs. For more information on RPSL classes, see RFC 2622.
+.PP
+.RE
+Error: Non-ASCII character encountered
+.PP
+Error: unterminated string encountered
+.PP
+Error: octal escape sequence is out of bounds
+.PP
+Error: bad octal escape sequence
+.PP
+Warning: attribute <attr> of class <class> is now obsolete.
+.RS
+.PP
+This attribute is described in RPSL dictionary as valid RPSL attribute, but it is now obsoleted and should not be used any longer. See RFC 2622 for more information about RPSL attributes.
+.PP
+.RE
+.B Parser errors
+.PP
+Error: syntax error
+.RS
+.PP
+String starts with non-attribute or object is incomplete.
+.PP
+.RE
+Error: "changed: <email> <YYYYMMDD>" expected
+.RS
+.PP
+Wrong "changed" attribute. <email> is e-mail address in RFC 822 format, <YYYYMMDD> is a date.
+.PP
+.RE
+Error: argument to <name> should match <match>
+.RS
+.PP
+Syntax for some RPSL attributes is defined by regular expressions. The error indicates that attribute's value didn't match the regular expression.
+.PP
+.RE
+Error: argument to <name> should be <match>
+.RS
+.PP
+Generic RPSL attributes have fixed syntax, and exact match is expected.
+.PP
+.RE
+Error: argument to <name> should be blob sequence.
+.RS
+.PP
+Indicates a syntax error in "auth" attribute specification.
+.PP
+.RE
+Warning: unknown protocol <string>, BGP4 assumed.
+.RS
+.PP
+Unknown protocol specified in import/export policy. Defaults to BGP4. The known protocols are listed in RFC 2622, Dictionary section.
+.PP
+.RE
+Error: from <peering> expected.
+.RS
+.PP
+Syntax error in "import" attribute specification. See RFC2622 for more details about "import" attribute syntax.
+.RE
+.PP
+Error: to <peering> expected.
+.RS
+.PP
+Syntax error in "export" attribute specification.
+The syntax for "export" attribute is symmetrical for import,
+with changes: from->to, accept->announce.
+For more details see RFC2622.
+.PP
+.RE
+.PP
+Error: badly formed filter/action or keyword NETWORKS/ACTION missing.
+.RS
+.PP
+Syntax error in "default" attibute specification
+The syntax for "default" attribute is:
+.PD 0
+.P
+default: to <peering> [action <action>]
+.P
+[networks <filter>]
+.P
+For more details see RFC2622.
+.PD 1
+.PP
+.RE
+Error: TO <peer> missing.
+.RS
+.PP
+Syntax error in "default" attribute specification.
+Please see "default" attribute syntax above.
+.PP
+.RE
+.PP
+Error: badly formed filter.
+.RS
+.PP
+Syntax error in RPSL filter specification.
+RPSL filter is an expression over AS-number, prefixes, AS-sets, range operators etc. When applying to a set of routes, it returns the resulting set of routes matched by this filter. There are several types of RPSL filters - prefix filters, AS_path filters, etc. For more details, see RFC2622.
+.PP
+.RE
+.PP
+Error: in action specification.
+.RS
+.PP
+Syntax error in action specification. "Action" keyword specifies the action to be executed if the route is matched by the filter. The general "action" syntax is:
+.PD 0
+.P
+action <rp_attribute> <method> (<rp_method_arguments>);
+.P
+| action <rp_attribute> <operator> <argument>;
+.P
+For more details see RFC2622.
+.PD 1
+.RE
+.PP
+Error: integer mask length expected.
+.RS
+.PP
+The integer mask length is a number of bits taken by network number.
+.PP
+.RE
+.PP
+Error: MASKLEN <length> expected.
+.RS
+.PP
+Syntax error in "ifaddr" attribute specification.
+The syntax for "ifaddr" attribute is:
+.PD 0
+.P
+ifaddr: <ipv4-address> masklen <integer> [action <action>]
+.PD 1
+.RE
+.PP
+Error: <ip_address> MASKLEN <length> [<action>] expected.
+.RS
+.PP
+Syntax error in "ifaddr" specification. See "ifaddr" attribute syntax above.
+.PP
+.RE
+.PP
+Error: unknown protocol <protocol>.
+.RS
+.PP
+Unknown protocol in peer specification. Known protocols are:
+BGP4 (default), OSPF, RIP, IGRP, IS-IS, STATIC, RIPng, DVMRP, PIM-DM, PIM-SM, CBT, MOSPF.
+.PP
+.RE
+Error: protocol <protocol> does not have option <option>
+.RS
+.PP
+This option is not defined for this protocol in RPSL dictionary.
+For defined protocols and options, please see RPSL dictionary description in RFC2622.
+.PP
+.RE
+Error: mandatory option <option> of protocol <protocol> is missing.
+.RS
+.PP
+The mandatory option for this protocol is missing.
+For defined protocols and options, please see RPSL dictionary description in RFC2622.
+.PP
+.RE
+.PP
+Error: in peer option.
+.RS
+.PP
+Syntax error in "peer" attribute. This attribute describes router's peering.
+The syntax is:
+.PD 0
+.P
+<protocol> <ipv4-address> <options>
+.P
+| <protocol> <inet-rtr-name> <options>
+.P
+| <protocol> <rtr-set-name> <options>
+.P
+| <protocol> <peering-set-name> <options>
+.P
+Where:
+.TP 10
+<protocol>
+is any of the protocols supported by RPSL dictionary, e.g. BGP4.
+.TP 10
+<ipv4-address>
+is a valid IPv4 address in "dot" decimal notation, e.g. 1.1.1.1
+.TP 10
+<inet-rtr-name>
+is a name of "inet-rtr" object, e.g fully qualified DNS name without trailing "." (RFC1034). It should not exceed 254 characters.
+.TP 10
+<rtr-set-name>
+is a name of "rtr-set" object. Consists of letters, digits, the underscore "_" and hyphen "-". Starts with "rtrs-" prefix, and the last character of a name must be a letter or a digit.
+.TP 10
+<peering-set-name>
+is a name of "peering-set" object.It has the same syntax as "rtr-set" object's name above, but its prefix should be "prng-".
+.PD 1
+.RE
+.PP
+Error: missing peer ip_address.
+.RS
+.PP
+Peer address is missing in peer specification.
+.PD 0
+.P
+<ipv4-address> is a valid IPv4 address in "dot" decimal notation, e.g. 1.1.1.1
+.PD 1
+.RE
+.PP
+Error: missing protocol name.
+.RS
+.PP
+Protocol name is missing in peer specification. Protocol name should be a valid protocol defined in RPSL dictionary, e.g. BGP4 (see RFC2622).
+.RE
+.PP
+Error: <as-expression> expected.
+.RS
+.PP
+Syntax error in "aggr-bndry" attribute of "route" object. The syntax is:
+.PD 0
+.P
+<as-expression>.
+Where:
+.TP 10
+<as-expression>
+is an expression over AS numbers and sets. It defines the list of ASes performing the aggregation. If this attribute is missing, the origin AS is the sole aggregation boundary. See RFC2622 for more detailed description of this attribute in "route" object.
+.PD 1
+.RE
+.PP
+Error: OUTBOUND <as-expression> expected.
+.RS
+.PP
+Syntax error in "aggr-mtd" attribute of "route" object. The syntax is:
+.PD 0
+.P
+aggr-mtd: inbound
+ | outbound [<as-expression>]
+.P
+Where:
+.TP 10
+inbound, outbound
+RPSL keywords specifying the type of aggregation. See RFC2622 for more detailed description of this attribute of "route" object.
+.TP 10
+<as-expression>
+is an expression over as-sets and as-numbers.
+.P
+See RFC2622 for more detailed description of this attribute of "route" object.
+.PD 1
+.RE
+.PP
+Error: INBOUND can not be followed by anything.
+.RS
+.PP
+Syntax error in "aggr-mtd" attribute of "route" object. See the details above.
+.PP
+.RE
+.PP
+Error: keyword INBOUND or OUTBOUND expected.
+.RS
+.PP
+Syntax error in "aggr-mtd" attribute of "route" object. See the details above.
+.PP
+.RE
+Error: [at <router-exp>] [action <action>] [upon <condition>] expected.
+.RS
+.PP
+Syntax error in "inject" attribute of route object. This attribute specifies which routers perform the aggregation and when they perform it. See RFC 2622 for more details about the meaning of this attribute.
+.PD 0
+.TP 10
+<router-expr>
+is an expression over router IP addresses, inet-rtr names, and rtr-set names using operators AND, OR, and EXCEPT. The binary "EXCEPT" operator is the set subtraction operator and has the same precedence as the operator AND. EXCEPT = AND NOT.
+.TP 10
+<action>
+defines an action to execute to modify various BGP attributes. See RFC2622 for more details on action specificatin.
+.TP 10
+<condition>
+is a boolean condition. The aggregate is generated if and only if this condition is true. See RFC 2622 for more details on "condition" specification.
+.PD 1
+.RE
+.PP
+Error: [ATOMIC] [[<filter>] [PROTOCOL <protocol> <filter>] ...] expected.
+.RS
+.PP
+Syntax error in "components" attribute of the "route" object. This attribute specifies which routes are used to form the aggregate.
+.PD 0
+.TP 10
+<filter>
+is RPSL filter expression over AS-number, AS-sets, route-set, prefixes, range operations, etc.
+.TP 10
+<protocol>
+is a routing protocol name, as defined in RPSL dictionary.
+.PD 1
+See RFC 2622 for more detailed description of this attribute.
+.PP
+.RE
+Error: invalid member
+.RS
+.PP
+The member of the route-set should be a valid IPV4 prefix in "/" slash notation.
+.PP
+.RE
+.B RPSL dictionary errors
+.PP
+These errors are also RPSL parser errors. They can be encountered if you modify RPSL dictionary, recompile and try to use the parser.
+.PP
+Error: invalid rp-attribute specification
+.RS
+.PP
+Syntax error in rp-attribute specification. rp-attributes are used in RPSL dictionary specification to describe routing protocol attributes and methods. E.g. RPSL rp-attributes for BGP4 match BGP4 attributes, and their methods are actions to perform. For instance, "action aspath.prepend(AS123);" prepends the BGP AS_path attribute with AS123 for the routes matched by the filter. For more information about rp-attributes (Routing Policy attributes) and how they reflect real BGP attributes, see RFC 2622.
+.PP
+.RE
+Error: invalid method specification for <rp-attribute>
+.RS
+.PP
+Syntax error in rp-attribute specification, in method. See RFC 2622 for details about rp-attributes specification syntax.
+.PP
+.RE
+Error: invalid operator specification for <rp-attribute>
+.RS
+.PP
+Syntax error in rp-attribute specification, in operator. See RFC 2622 for details about rp-attributes specification syntax.
+.PP
+.RE
+Error: invalid operator
+.RS
+.PP
+Syntax error in rp-attribute specification, in operator. See RFC 2622 for details about rp-attributes specification syntax.
+.PP
+.RE
+Error: method specification expected
+.RS
+.PP
+Method definition in rp-attribute has wrong syntax or is incomplete. The format is <method_name>(<arguments>).
+.PP
+.RE
+Error: invalid typedef specification
+.RS
+.PP
+Error in "typedef" attribute. This attribute defines the data types for method arguments, which are then used with rp-attributes. See RFC 2622 for more information of "typedef" specification.
+.PP
+.RE
+Error: empty union specification
+.RS
+.PP
+Syntax error in union specification for type definition. The syntax is:
+typedef: union <list of types to be included in union>. This error can be encountered if the list is empty.
+.PP
+.RE
+Error: invalid type <string>
+.RS
+.PP
+Invalid string found where the type definition keyword expected.
+.PP
+.RE
+Error: invalid type <string>[<integer>,<integer>]
+.RS
+.PP
+Invalid string found where the type definition keyword expected.
+.PP
+.RE
+Error: invalid type <string>[<float>,<float>]"
+.RS
+.PP
+Invalid string found where the type definition keyword expected.
+.PP
+.RE
+Error: invalid type <string>, enum expected
+.RS
+.PP
+[ <enum_list> ] should be preceeded by "enum" keyword.
+.PP
+.RE
+Error: invalid list size
+.RS
+.PP
+Syntax error in list specification. The syntax is:
+list of <valid_type>-<valid-type> ... <valid-type>.
+.PP
+.RE
+Error: invalid protocol option
+.PP
+Error: invalid protocol name
+.PP
+Error: in attr option specification.
+.RS
+.PP
+Synatx error in attribute "attr" specification of "dictionary" class. The syntax is:
+.PD 0
+.P
+attr: <attr_name> [syntax(syntax_type),] optional/mandatory single/multiple type
+.PD 1
+.PP
+.RE
+Error: no known syntax rule for <syntax>.
+.RS
+.PP
+Syntax definition is not found (see rpsl/rpsl/rptype.cc);
+.PP
+.RE
+Error: could not compile regexp <regexp>.
+.RS
+.PP
+Requested syntax type is "regexp", but failed to compile the regular expression.
+.PP
+.RE
+Error: attr name expected.
+.RS
+.PP
+Syntax error in attribute "attr" specification, see syntax definition above.
+.PP
+.RE
+Error: argument <argument> to <rp-attribute>.operator<method> should be <type>.
+.RS
+.PP
+Wrong operatior used with this rp-attribute. Check rp-attribute specification and operators/methods (RFC 2622).
+.PP
+.RE
+Error: wrong number of arguments to <rp.attribute>.operator<method>.
+.RS
+.PP
+Wrong number of arguments used with rp-attribute's operator. Check rp-attribute specification and its operators/methods (RFC 2622).
+.PP
+.RE
+Error: argument <argument> to <rp-attribute>.<method> should be <type>.
+.RS
+.PP
+Wrong argument used with operator/method with this rp-attribute. Check rp-attribute's methods specification (RFC 2622).
+.PP
+.RE
+Error: wrong number of arguments to <rp-attribute>.<method>.
+.RS
+.PP
+Wrong number of arguments used with this method. Check method's specification (RFC 2622).
+.PP
+.RE
+Error: rp-attribute <rp-attribute> does not have <method> defined.
+.RS
+.PP
+Undefined method used with rp-attribute. Check rp-attribute's methods' specification (RFC 2622) for this rp-attribute.
+.PP
+.RE
+.SH REFERENCES
+.IP \(bu 2
+.B
+RFC 2622
+"Routing Policy Specification Language (RPSL)"
+ftp://ftp.ripe.net/rfc/rfc2622.txt
+.IP \(bu 2
+.B
+RFC 822
+"Standard for the format of ARPA INTERNET text messages"
+ftp://ftp.ripe.net/rfc/rfc822.txt
+.IP \(bu 2
+.B
+RFC 1034
+"Domain names - concepts and facilities"
+ftp://ftp.ripe.net/rfc/rfc1034.txt
+.SH AUTHORS
+Katie Petrusha <katie@ripe.net>