mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-24 18:55:04 +08:00
2770 lines
112 KiB
Plaintext
2770 lines
112 KiB
Plaintext
From pgsql-hackers-owner+M4219@hub.org Tue Jul 4 20:10:16 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id UAA13204
|
||
for <pgman@candle.pha.pa.us>; Tue, 4 Jul 2000 20:10:15 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e650A8S29252;
|
||
Tue, 4 Jul 2000 20:10:08 -0400 (EDT)
|
||
Received: from merganser.its.uu.se (merganser.its.uu.se [130.238.6.236])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6505pS14530
|
||
for <pgsql-hackers@postgresql.org>; Tue, 4 Jul 2000 20:05:52 -0400 (EDT)
|
||
Received: from regulus.student.UU.SE ([130.238.5.2]:37402 "EHLO
|
||
regulus.its.uu.se") by merganser.its.uu.se with ESMTP
|
||
id <S176281AbQGEAFU>; Wed, 5 Jul 2000 02:05:20 +0200
|
||
Received: from peter (helo=localhost)
|
||
by regulus.its.uu.se with local-esmtp (Exim 3.02 #2)
|
||
id 139cnr-0003QO-00
|
||
for pgsql-hackers@postgresql.org; Wed, 05 Jul 2000 02:12:35 +0200
|
||
Date: Wed, 5 Jul 2000 02:12:35 +0200 (CEST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
To: PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: [HACKERS] Repair plan for inet and cidr types
|
||
Message-ID: <Pine.LNX.4.21.0007050118110.3542-100000@localhost.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=ISO-8859-1
|
||
Content-Transfer-Encoding: 8BIT
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
As we know, the inet and cidr types are still broken in several ways,
|
||
amongst others input and output functions, operators, ordering. I've
|
||
collected the bug reports from the last year or so from the archives.
|
||
|
||
There's apparently a lack of understanding of what exactly are these types
|
||
are supposed to do. Therefore, instead of addressing each bug
|
||
individually, let me first state what I reconstructed as the specification
|
||
of these types, and then add what is currently wrong with it.
|
||
|
||
* CIDR
|
||
|
||
The cidr type stores the identity of an IP _network_. A network
|
||
specification is of the form 'x.x.x.x/y'. The documentation states that if
|
||
y is omitted then it is constructed from the old A, B, C class scheme. So
|
||
be it. In a real world network, the bits (y+1)...32 have to be zero, but
|
||
the cidr type does not currently enforce this. This has been the source of
|
||
bugs in the past, and no doubt the source of some confusion as well. I
|
||
propose that cidr _reject_ input of the form '127.0.0.5/16'. If you think
|
||
about it, this is the same as int4 rejecting 3.5 as input.
|
||
|
||
* INET
|
||
|
||
The inet type stores the identity of an IP _host_. A host specification is
|
||
of the form 'x.x.x.x'. Optionally, the inet type also stores the identity
|
||
of the network the host is in. E.g., '127.0.0.5/16' means the host
|
||
127.0.0.5 in the network 127.0/16.
|
||
|
||
* Type equivalency
|
||
|
||
This has also been a source of problems. I propose that cidr and inet are
|
||
not made equivalent types at any level. No automatic casting either. A
|
||
network and a host are not the same thing. To construct a cidr value from
|
||
an inet value, you'd have to use some sort of (to be created) network()
|
||
function, e.g., network('127.0.0.5/16') => '127.0/16'. IMO, there is no
|
||
reasonable way to construct an inet value from a cidr value.
|
||
|
||
* Operators
|
||
|
||
Because the types are equivalent, the operators have also been bunched
|
||
together in confusing ways. I propose that ordering operators (>, +, <)
|
||
between inet and cidr be eliminated, they do not make sense. The only
|
||
useful operation between cidr and inet is the << ("contains") operator.
|
||
Ordering withing cidr and inet be defined in terms of their bit
|
||
representation, as is the case now. The << family of operators should also
|
||
be removed for the inet type -- a host cannot "contain" another host. What
|
||
you probably wanted is `inet1 << network(inet2)'.
|
||
|
||
|
||
Does anyone see this differently? If not, can we agree on this
|
||
specification?
|
||
|
||
--
|
||
Peter Eisentraut Sernanders v<>g 10:115
|
||
peter_e@gmx.net 75262 Uppsala
|
||
http://yi.org/peter-e/ Sweden
|
||
|
||
|
||
From pgsql-hackers-owner+M4230@hub.org Tue Jul 4 22:13:37 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id WAA13773
|
||
for <pgman@candle.pha.pa.us>; Tue, 4 Jul 2000 22:13:37 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e652DSS19722;
|
||
Tue, 4 Jul 2000 22:13:28 -0400 (EDT)
|
||
Received: from druid.net (root@druid.net [216.126.72.98])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e652D9S19504
|
||
for <pgsql-hackers@postgresql.org>; Tue, 4 Jul 2000 22:13:09 -0400 (EDT)
|
||
Received: from localhost (4223 bytes) by druid.net
|
||
via sendmail with P:stdio/R:bind_hosts/T:inet_zone_bind_smtp
|
||
(sender: <darcy>) (ident <darcy> using unix)
|
||
id <m139egU-000AXpC@druid.net>
|
||
for <pgsql-hackers@postgresql.org>; Tue, 4 Jul 2000 22:13:06 -0400 (EDT)
|
||
(Smail-3.2.0.109 1999-Oct-27 #3 built 2000-Jun-28)
|
||
Message-Id: <m139egU-000AXpC@druid.net>
|
||
From: darcy@druid.net (D'Arcy J.M. Cain)
|
||
Subject: Re: [HACKERS] Repair plan for inet and cidr types
|
||
In-Reply-To: <Pine.LNX.4.21.0007050118110.3542-100000@localhost.localdomain>
|
||
"from Peter Eisentraut at Jul 5, 2000 02:12:35 am"
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
Date: Tue, 4 Jul 2000 22:13:06 -0400 (EDT)
|
||
CC: PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
X-Mailer: ELM [version 2.4ME+ PL78 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Thus spake Peter Eisentraut
|
||
> There's apparently a lack of understanding of what exactly are these types
|
||
> are supposed to do. Therefore, instead of addressing each bug
|
||
> individually, let me first state what I reconstructed as the specification
|
||
> of these types, and then add what is currently wrong with it.
|
||
|
||
I have been browsing through the old messages on the topic. There was, in
|
||
fact some very good work defining the type before anyone actually started
|
||
to code. There was a surprising amount of controversy over the actual
|
||
definitions but I think in the end we hammered it out at least to the
|
||
point that everyone could work with it.
|
||
|
||
> * CIDR
|
||
>
|
||
> The cidr type stores the identity of an IP _network_. A network
|
||
> specification is of the form 'x.x.x.x/y'. The documentation states that if
|
||
> y is omitted then it is constructed from the old A, B, C class scheme. So
|
||
> be it. In a real world network, the bits (y+1)...32 have to be zero, but
|
||
> the cidr type does not currently enforce this. This has been the source of
|
||
> bugs in the past, and no doubt the source of some confusion as well. I
|
||
> propose that cidr _reject_ input of the form '127.0.0.5/16'. If you think
|
||
> about it, this is the same as int4 rejecting 3.5 as input.
|
||
|
||
There is also the option of accepting it but masking out the host bits
|
||
before storing it. That gives us automatic conversion if we store an
|
||
inet into a cidr if our intent is to store the network part.
|
||
|
||
What sort of bugs do you think it caused btw?
|
||
|
||
> * INET
|
||
>
|
||
> The inet type stores the identity of an IP _host_. A host specification is
|
||
> of the form 'x.x.x.x'. Optionally, the inet type also stores the identity
|
||
> of the network the host is in. E.g., '127.0.0.5/16' means the host
|
||
> 127.0.0.5 in the network 127.0/16.
|
||
|
||
That sounds right. We also allowed for hosts to be stored implicitely by
|
||
simply making the netmask /32.
|
||
|
||
> * Type equivalency
|
||
>
|
||
> This has also been a source of problems. I propose that cidr and inet are
|
||
> not made equivalent types at any level. No automatic casting either. A
|
||
> network and a host are not the same thing. To construct a cidr value from
|
||
> an inet value, you'd have to use some sort of (to be created) network()
|
||
> function, e.g., network('127.0.0.5/16') => '127.0/16'. IMO, there is no
|
||
> reasonable way to construct an inet value from a cidr value.
|
||
|
||
I'm not sure I understand why this is necessary. I can see not allowing
|
||
cidr ==> inet conversions but inet ==> cidr can be done as it is a matter
|
||
of dropping information - the host part.
|
||
|
||
|
||
> * Operators
|
||
>
|
||
> Because the types are equivalent, the operators have also been bunched
|
||
> together in confusing ways. I propose that ordering operators (>, +, <)
|
||
> between inet and cidr be eliminated, they do not make sense. The only
|
||
> useful operation between cidr and inet is the << ("contains") operator.
|
||
> Ordering withing cidr and inet be defined in terms of their bit
|
||
> representation, as is the case now. The << family of operators should also
|
||
> be removed for the inet type -- a host cannot "contain" another host. What
|
||
> you probably wanted is `inet1 << network(inet2)'.
|
||
|
||
Then let's define that as the meaning of "inet1 << inet2" i.e. define
|
||
the << operator between inet types as meaning "tell me if inet1 is in
|
||
the same network as inet2." In fact, if we define << as only allowed
|
||
between inet and cidr (or cidr and cidr?) then the implied cast will
|
||
deal with it if that cast causes the host bits to drop as suggested
|
||
above.
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M4232@hub.org Tue Jul 4 22:20:30 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id WAA13808
|
||
for <pgman@candle.pha.pa.us>; Tue, 4 Jul 2000 22:20:29 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e652KDS33988;
|
||
Tue, 4 Jul 2000 22:20:13 -0400 (EDT)
|
||
Received: from druid.net (root@druid.net [216.126.72.98])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e652JuS33839
|
||
for <pgsql-hackers@postgresql.org>; Tue, 4 Jul 2000 22:19:57 -0400 (EDT)
|
||
Received: from localhost (1460 bytes) by druid.net
|
||
via sendmail with P:stdio/R:bind_hosts/T:inet_zone_bind_smtp
|
||
(sender: <darcy>) (ident <darcy> using unix)
|
||
id <m139emz-000AXrC@druid.net>
|
||
for <pgsql-hackers@postgresql.org>; Tue, 4 Jul 2000 22:19:49 -0400 (EDT)
|
||
(Smail-3.2.0.109 1999-Oct-27 #3 built 2000-Jun-28)
|
||
Message-Id: <m139emz-000AXrC@druid.net>
|
||
From: darcy@druid.net (D'Arcy J.M. Cain)
|
||
Subject: Re: [HACKERS] Repair plan for inet and cidr types
|
||
In-Reply-To: <Pine.LNX.4.21.0007050118110.3542-100000@localhost.localdomain>
|
||
"from Peter Eisentraut at Jul 5, 2000 02:12:35 am"
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
Date: Tue, 4 Jul 2000 22:19:49 -0400 (EDT)
|
||
CC: PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
X-Mailer: ELM [version 2.4ME+ PL78 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Thus spake Peter Eisentraut
|
||
> network and a host are not the same thing. To construct a cidr value from
|
||
> an inet value, you'd have to use some sort of (to be created) network()
|
||
> function, e.g., network('127.0.0.5/16') => '127.0/16'. IMO, there is no
|
||
|
||
Oh, I forgot to mention:
|
||
|
||
darcy=> select network('127.1.2.3/24'::inet);
|
||
network
|
||
----------
|
||
127.1.2/24
|
||
(1 row)
|
||
|
||
There is also a host and netmask function and note:
|
||
|
||
darcy=> select host('127.1.2.3/24'::cidr);
|
||
ERROR: CIDR type has no host part
|
||
|
||
But I still see no reason why that can't be implicit if we assign the
|
||
"'127.1.2.3/24'::inet" value to a cidr. In other words let "select
|
||
('127.1.2.3/24'::inet)::cidr" give the same output.
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M4234@hub.org Tue Jul 4 22:31:46 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id WAA13855
|
||
for <pgman@candle.pha.pa.us>; Tue, 4 Jul 2000 22:31:46 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e652VdS74063;
|
||
Tue, 4 Jul 2000 22:31:39 -0400 (EDT)
|
||
Received: from sss2.sss.pgh.pa.us (sss.pgh.pa.us [209.114.166.2])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e652VSS73985
|
||
for <pgsql-hackers@postgresql.org>; Tue, 4 Jul 2000 22:31:28 -0400 (EDT)
|
||
Received: from sss2.sss.pgh.pa.us (tgl@localhost [127.0.0.1])
|
||
by sss2.sss.pgh.pa.us (8.9.3/8.9.3) with ESMTP id WAA29694;
|
||
Tue, 4 Jul 2000 22:31:26 -0400 (EDT)
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
cc: PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] Repair plan for inet and cidr types
|
||
In-reply-to: <Pine.LNX.4.21.0007050118110.3542-100000@localhost.localdomain>
|
||
References: <Pine.LNX.4.21.0007050118110.3542-100000@localhost.localdomain>
|
||
Comments: In-reply-to Peter Eisentraut <peter_e@gmx.net>
|
||
message dated "Wed, 05 Jul 2000 02:12:35 +0200"
|
||
Date: Tue, 04 Jul 2000 22:31:25 -0400
|
||
Message-ID: <29691.962764285@sss.pgh.pa.us>
|
||
From: Tom Lane <tgl@sss.pgh.pa.us>
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Peter Eisentraut <peter_e@gmx.net> writes:
|
||
> There's apparently a lack of understanding of what exactly are these types
|
||
> are supposed to do. Therefore, instead of addressing each bug
|
||
> individually, let me first state what I reconstructed as the specification
|
||
> of these types, and then add what is currently wrong with it.
|
||
|
||
This sounds good offhand, but then I never paid a whole lot of attention
|
||
to the details originally. Did you go through the original inet/cidr
|
||
design discussions (the threads where Paul Vixie was participating)?
|
||
|
||
I don't believe Paul is subscribed here anymore, but I'd feel a lot
|
||
happier if you can contact him and get him to sign off on the clarified
|
||
design. Maybe this is what he had in mind all along, or maybe not.
|
||
|
||
regards, tom lane
|
||
|
||
PS: You do know who Paul Vixie is, I assume ;-). I can think of few
|
||
better-qualified experts in this domain...
|
||
|
||
From pgsql-hackers-owner+M4312@hub.org Wed Jul 5 10:48:17 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id KAA02483
|
||
for <pgman@candle.pha.pa.us>; Wed, 5 Jul 2000 10:48:16 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e65EllS08607;
|
||
Wed, 5 Jul 2000 10:47:47 -0400 (EDT)
|
||
Received: from elektron.elka.pw.edu.pl (root@elektron.elka.pw.edu.pl [148.81.63.249])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e65CiPS89307
|
||
for <pgsql-hackers@PostgreSQL.org>; Wed, 5 Jul 2000 08:44:55 -0400 (EDT)
|
||
Received: from elektron.elka.pw.edu.pl ([148.81.63.249]:41059 "EHLO
|
||
elektron.elka.pw.edu.pl") by elektron.elka.pw.edu.pl with ESMTP
|
||
id <S225388AbQGEMoB>; Wed, 5 Jul 2000 14:44:01 +0200
|
||
Date: Wed, 5 Jul 2000 14:43:49 +0200 (MET DST)
|
||
From: Jakub Bartosz Bielecki <J.B.Bielecki@elka.pw.edu.pl>
|
||
To: Sevo Stille <sevo@ip23.net>
|
||
cc: Jakub Bartosz Bielecki <J.B.Bielecki@elka.pw.edu.pl>,
|
||
pgsql-hackers@PostgreSQL.org
|
||
Subject: Re: [HACKERS] Re: postgres - development of inet/cidr
|
||
In-Reply-To: <3960A5FE.E626BAE1@ip23.net>
|
||
Message-ID: <Pine.SOL.4.21.0007051410330.1267-100000@elektron.elka.pw.edu.pl>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
|
||
|
||
On Mon, 3 Jul 2000, Sevo Stille wrote:
|
||
>
|
||
> This would be proper behaviour for the cidr datatype, which describes a
|
||
> network. "select '10.0.0.1/27'::cidr='10.0.0.2/27'::cidr;" has to return
|
||
> true, as both define the same network, the mask putting the 1 vs. 2
|
||
> outside the comparison scope.
|
||
>
|
||
> On inet, I consider the above broken - going by the documentation,
|
||
> having a netmask on a inet datatype does not define a network address
|
||
> but rather supplies additional information on the cidr network the host
|
||
> as specified by the address is in. Accordingly, it should only truncate
|
||
> if the comparison casts to cidr.
|
||
|
||
OK. After some inspection in list's archives I found the following
|
||
statement (http://www.postgresql.org/mhonarc/pgsql-hackers/1998-07):
|
||
> It does not work that way. /24 is
|
||
> not a shorthand for specifying a netmask -- in CIDR, it's a "prefix
|
||
> length".
|
||
> That means "192.7.34.21/24" is either (a) a syntax error or
|
||
> (b) equivilent to "192.7.34/24".
|
||
|
||
Everybody seemed to agree with the above opinion at that time.
|
||
|
||
This is obviously _not_ the way that CIDR is handled at this moment.
|
||
"select '1.2.3.4/24'" returns "1.2.3/24" only because the _output_ routine
|
||
silently cuts host bits. Input routine stores it exactly as '1.2.3.4/24'.
|
||
|
||
Since IMHO it's wrong I prepared a patch (I'm sending it to pgsql-patch).
|
||
It fixes the CIDR input routine to zero host bits (ie beyond-prefix bits).
|
||
Please note that I didn't change the INET input routine.
|
||
|
||
Eventually I had to change a bit comparison functions.
|
||
To this moment they worked in a CIDR way (didn't compare host bits at all)
|
||
although they were used by both INET and CIDR.
|
||
Since CIDR is zero-padded now, whole 32 bits are compared by > = <
|
||
operators.
|
||
Subnet operators <<, >> are still the same, don't compare host bits.
|
||
|
||
> The big question is whether comparisons that only work on a cidr data
|
||
> type (contains/contained) or have a cidr type on one side can safely
|
||
> cast the inet type to cidr implicitly. For:
|
||
> "select '10.0.0.1/27'::inet = '10.0.0.2/27'::inet;" FALSE
|
||
> "select '10.0.0.1/27'::cidr = '10.0.0.2/27'::cidr;" TRUE
|
||
> "select '10.0.0.1/27'::cidr = '10.0.0.2/27'::inet;" FALSE
|
||
> "select '10.0.0.1/27'::cidr >> '10.0.0.2/27'::inet;" TRUE
|
||
OK.
|
||
> "select '10.0.0.1/27'::cidr << '10.0.0.2/27'::inet;" ERROR
|
||
|
||
Currently it's not an error... There is no way (and no reason) to
|
||
distinguish between INET and CIDR. Above example is exactly
|
||
equivalent to:
|
||
select '10.0.0.0/27'::inet << '10.0.0.2/27'::inet; -- FALSE
|
||
but:
|
||
select '10.0.0.0/27'::inet <<= '10.0.0.2/27'::inet; -- TRUE
|
||
|
||
> But we need to reach an agreement on the proper
|
||
> behaviour on greater/smaller comparisons. Should:
|
||
>
|
||
> "select '10.0.0.1/27'::inet > '10.0.0.2/27'::cidr;"
|
||
>
|
||
> be true or false? Casting to cidr prior to comparison would make it
|
||
> equivalent to "select '10.0.0.0/27'::cidr > '10.0.0.0/27'::cidr;", which
|
||
> is false, both networks being equal.
|
||
|
||
It should be (and is!) true... Since second argument is
|
||
really '10.0.0.0/27'.
|
||
|
||
|
||
From pgsql-patches-owner+M284@hub.org Wed Jul 5 09:03:39 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id JAA27744
|
||
for <pgman@candle.pha.pa.us>; Wed, 5 Jul 2000 09:03:38 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e65D3OS38516;
|
||
Wed, 5 Jul 2000 09:03:24 -0400 (EDT)
|
||
Received: from elektron.elka.pw.edu.pl (root@elektron.elka.pw.edu.pl [148.81.63.249])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e65Cr5S11483
|
||
for <pgsql-patches@postgresql.org>; Wed, 5 Jul 2000 08:53:06 -0400 (EDT)
|
||
Received: from elektron.elka.pw.edu.pl ([148.81.63.249]:42221 "EHLO
|
||
elektron.elka.pw.edu.pl") by elektron.elka.pw.edu.pl with ESMTP
|
||
id <S225089AbQGEMwn>; Wed, 5 Jul 2000 14:52:43 +0200
|
||
Date: Wed, 5 Jul 2000 14:52:33 +0200 (MET DST)
|
||
From: Jakub Bartosz Bielecki <J.B.Bielecki@elka.pw.edu.pl>
|
||
To: pgsql-patches@postgresql.org
|
||
Subject: [PATCHES] Re: [HACKERS] Re: postgres - development of inet/cidr
|
||
Message-ID: <Pine.SOL.4.21.0007051446090.1267-200000@elektron.elka.pw.edu.pl>
|
||
MIME-Version: 1.0
|
||
Content-Type: MULTIPART/MIXED; BOUNDARY="-559023410-959030623-962801553=:1267"
|
||
X-Mailing-List: pgsql-patches@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-patches-owner@hub.org
|
||
Status: OR
|
||
|
||
This message is in MIME format. The first part should be readable text,
|
||
while the remaining parts are likely unreadable without MIME-aware tools.
|
||
Send mail to mime@docserver.cac.washington.edu for more info.
|
||
|
||
---559023410-959030623-962801553=:1267
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
|
||
|
||
1. Fixed obvious bug with strcpy() called on text type in network.c
|
||
2. Fixed CIDR input routine to cut 'host' bits in inet_net_pton.c
|
||
3. Changed network_{lt,gt,eq} to compare all bits of INET/CIDR in network.c
|
||
|
||
Jakub
|
||
|
||
---559023410-959030623-962801553=:1267
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII; name=inet-patch
|
||
Content-Transfer-Encoding: BASE64
|
||
Content-ID: <Pine.SOL.4.21.0007051452330.1267@elektron.elka.pw.edu.pl>
|
||
Content-Description: inet-patch
|
||
Content-Disposition: attachment; filename=inet-patch
|
||
|
||
KioqIC4vYmFja2VuZC91dGlscy9hZHQvaW5ldF9uZXRfcHRvbi5jLm9yaWcJ
|
||
VHVlIEp1bCAgNCAyMzowMDowNiAyMDAwDQotLS0gLi9iYWNrZW5kL3V0aWxz
|
||
L2FkdC9pbmV0X25ldF9wdG9uLmMJV2VkIEp1bCAgNSAxMToxMTozMiAyMDAw
|
||
DQoqKioqKioqKioqKioqKioNCioqKiAxMDEsMTA3ICoqKioNCiAgCQkJCXRt
|
||
cCwNCiAgCQkJCWRpcnR5LA0KICAJCQkJYml0czsNCiEgCWNvbnN0IHVfY2hh
|
||
ciAqb2RzdCA9IGRzdDsNCiAgDQogIAljaCA9ICpzcmMrKzsNCiAgCWlmIChj
|
||
aCA9PSAnMCcgJiYgKHNyY1swXSA9PSAneCcgfHwgc3JjWzBdID09ICdYJykN
|
||
Ci0tLSAxMDEsMTA3IC0tLS0NCiAgCQkJCXRtcCwNCiAgCQkJCWRpcnR5LA0K
|
||
ICAJCQkJYml0czsNCiEgCXVfY2hhciAqb2RzdCA9IGRzdDsNCiAgDQogIAlj
|
||
aCA9ICpzcmMrKzsNCiAgCWlmIChjaCA9PSAnMCcgJiYgKHNyY1swXSA9PSAn
|
||
eCcgfHwgc3JjWzBdID09ICdYJykNCioqKioqKioqKioqKioqKg0KKioqIDIx
|
||
MywyMTggKioqKg0KLS0tIDIxMywyMjYgLS0tLQ0KICAJCS8qIElmIGltcHV0
|
||
ZWQgbWFzayBpcyBuYXJyb3dlciB0aGFuIHNwZWNpZmllZCBvY3RldHMsIHdp
|
||
ZGVuLiAqLw0KICAJCWlmIChiaXRzID49IDggJiYgYml0cyA8ICgoZHN0IC0g
|
||
b2RzdCkgKiA4KSkNCiAgCQkJYml0cyA9IChkc3QgLSBvZHN0KSAqIDg7DQor
|
||
IAl9DQorIAkvKiBaZXJvIGhvc3QgYml0cyBpZiBhbnkgKi8NCisgCW4gPSBi
|
||
aXRzLzg7DQorIAlpZiggbiA8IChkc3QgLSBvZHN0KSApDQorIAl7DQorIAkJ
|
||
b2RzdFtuKytdICY9IFVDSEFSX01BWDw8KDggLSAoYml0cyAlIDgpKTsNCisg
|
||
CQlmb3IgKDtuIDwgKGRzdCAtIG9kc3QpOyBuKyspDQorIAkJCW9kc3Rbbl09
|
||
J1wwJzsNCiAgCX0NCiAgCS8qIEV4dGVuZCBuZXR3b3JrIHRvIGNvdmVyIHRo
|
||
ZSBhY3R1YWwgbWFzay4gKi8NCiAgCXdoaWxlIChiaXRzID4gKChkc3QgLSBv
|
||
ZHN0KSAqIDgpKQ0KKioqIC4vYmFja2VuZC91dGlscy9hZHQvbmV0d29yay5j
|
||
Lm9yaWcJVHVlIEp1bCAgNCAyMzowMjowMSAyMDAwDQotLS0gLi9iYWNrZW5k
|
||
L3V0aWxzL2FkdC9uZXR3b3JrLmMJVHVlIEp1bCAgNCAyMzozNToyMSAyMDAw
|
||
DQoqKioqKioqKioqKioqKioNCioqKiAxOCwyMyAqKioqDQotLS0gMTgsMjQg
|
||
LS0tLQ0KICAjaW5jbHVkZSAicG9zdGdyZXMuaCINCiAgI2luY2x1ZGUgInV0
|
||
aWxzL2J1aWx0aW5zLmgiDQogIA0KKyBzdGF0aWMgaW50CXY0Yml0Y21wKHVu
|
||
c2lnbmVkIGludCBhMSwgdW5zaWduZWQgaW50IGEyKTsNCiAgc3RhdGljIGlu
|
||
dAl2NGJpdG5jbXAodW5zaWduZWQgaW50IGExLCB1bnNpZ25lZCBpbnQgYTIs
|
||
IGludCBiaXRzKTsNCiAgDQogIC8qDQoqKioqKioqKioqKioqKioNCioqKiAx
|
||
MzcsMTQzICoqKioNCiAgCQlyZXR1cm4gRkFMU0U7DQogIAlpZiAoKGlwX2Zh
|
||
bWlseShhMSkgPT0gQUZfSU5FVCkgJiYgKGlwX2ZhbWlseShhMikgPT0gQUZf
|
||
SU5FVCkpDQogIAl7DQohIAkJaW50CQkJb3JkZXIgPSB2NGJpdG5jbXAoaXBf
|
||
djRhZGRyKGExKSwgaXBfdjRhZGRyKGEyKSwgaXBfYml0cyhhMikpOw0KICAN
|
||
CiAgCQlyZXR1cm4gKChvcmRlciA8IDApIHx8ICgob3JkZXIgPT0gMCkgJiYg
|
||
KGlwX2JpdHMoYTEpIDwgaXBfYml0cyhhMikpKSk7DQogIAl9DQotLS0gMTM4
|
||
LDE0NCAtLS0tDQogIAkJcmV0dXJuIEZBTFNFOw0KICAJaWYgKChpcF9mYW1p
|
||
bHkoYTEpID09IEFGX0lORVQpICYmIChpcF9mYW1pbHkoYTIpID09IEFGX0lO
|
||
RVQpKQ0KICAJew0KISAJCWludAkJCW9yZGVyID0gdjRiaXRjbXAoaXBfdjRh
|
||
ZGRyKGExKSwgaXBfdjRhZGRyKGEyKSk7DQogIA0KICAJCXJldHVybiAoKG9y
|
||
ZGVyIDwgMCkgfHwgKChvcmRlciA9PSAwKSAmJiAoaXBfYml0cyhhMSkgPCBp
|
||
cF9iaXRzKGEyKSkpKTsNCiAgCX0NCioqKioqKioqKioqKioqKg0KKioqIDE2
|
||
NiwxNzIgKioqKg0KICAJaWYgKChpcF9mYW1pbHkoYTEpID09IEFGX0lORVQp
|
||
ICYmIChpcF9mYW1pbHkoYTIpID09IEFGX0lORVQpKQ0KICAJew0KICAJCXJl
|
||
dHVybiAoKGlwX2JpdHMoYTEpID09IGlwX2JpdHMoYTIpKQ0KISAJCSAmJiAo
|
||
djRiaXRuY21wKGlwX3Y0YWRkcihhMSksIGlwX3Y0YWRkcihhMiksIGlwX2Jp
|
||
dHMoYTEpKSA9PSAwKSk7DQogIAl9DQogIAllbHNlDQogIAl7DQotLS0gMTY3
|
||
LDE3MyAtLS0tDQogIAlpZiAoKGlwX2ZhbWlseShhMSkgPT0gQUZfSU5FVCkg
|
||
JiYgKGlwX2ZhbWlseShhMikgPT0gQUZfSU5FVCkpDQogIAl7DQogIAkJcmV0
|
||
dXJuICgoaXBfYml0cyhhMSkgPT0gaXBfYml0cyhhMikpDQohIAkJICYmICh2
|
||
NGJpdGNtcChpcF92NGFkZHIoYTEpLCBpcF92NGFkZHIoYTIpKSA9PSAwKSk7
|
||
DQogIAl9DQogIAllbHNlDQogIAl7DQoqKioqKioqKioqKioqKioNCioqKiAx
|
||
OTIsMTk4ICoqKioNCiAgCQlyZXR1cm4gRkFMU0U7DQogIAlpZiAoKGlwX2Zh
|
||
bWlseShhMSkgPT0gQUZfSU5FVCkgJiYgKGlwX2ZhbWlseShhMikgPT0gQUZf
|
||
SU5FVCkpDQogIAl7DQohIAkJaW50CQkJb3JkZXIgPSB2NGJpdG5jbXAoaXBf
|
||
djRhZGRyKGExKSwgaXBfdjRhZGRyKGEyKSwgaXBfYml0cyhhMikpOw0KICAN
|
||
CiAgCQlyZXR1cm4gKChvcmRlciA+IDApIHx8ICgob3JkZXIgPT0gMCkgJiYg
|
||
KGlwX2JpdHMoYTEpID4gaXBfYml0cyhhMikpKSk7DQogIAl9DQotLS0gMTkz
|
||
LDE5OSAtLS0tDQogIAkJcmV0dXJuIEZBTFNFOw0KICAJaWYgKChpcF9mYW1p
|
||
bHkoYTEpID09IEFGX0lORVQpICYmIChpcF9mYW1pbHkoYTIpID09IEFGX0lO
|
||
RVQpKQ0KICAJew0KISAJCWludAkJCW9yZGVyID0gdjRiaXRjbXAoaXBfdjRh
|
||
ZGRyKGExKSwgaXBfdjRhZGRyKGEyKSk7DQogIA0KICAJCXJldHVybiAoKG9y
|
||
ZGVyID4gMCkgfHwgKChvcmRlciA9PSAwKSAmJiAoaXBfYml0cyhhMSkgPiBp
|
||
cF9iaXRzKGEyKSkpKTsNCiAgCX0NCioqKioqKioqKioqKioqKg0KKioqIDM0
|
||
MSwzNTMgKioqKg0KICANCiAgCWlmICgocHRyID0gc3RyY2hyKHRtcCwgJy8n
|
||
KSkgIT0gTlVMTCkNCiAgCQkqcHRyID0gMDsNCiEgCWxlbiA9IFZBUkhEUlNa
|
||
ICsgc3RybGVuKHRtcCkgKyAxOw0KICAJcmV0ID0gcGFsbG9jKGxlbik7DQog
|
||
IAlpZiAocmV0ID09IE5VTEwpDQogIAkJZWxvZyhFUlJPUiwgInVuYWJsZSB0
|
||
byBhbGxvY2F0ZSBtZW1vcnkgaW4gbmV0d29ya19ob3N0KCkiKTsNCiAgDQog
|
||
IAlWQVJTSVpFKHJldCkgPSBsZW47DQohIAlzdHJjcHkoVkFSREFUQShyZXQp
|
||
LCB0bXApOw0KICAJcmV0dXJuIChyZXQpOw0KICB9DQogIA0KLS0tIDM0Miwz
|
||
NTQgLS0tLQ0KICANCiAgCWlmICgocHRyID0gc3RyY2hyKHRtcCwgJy8nKSkg
|
||
IT0gTlVMTCkNCiAgCQkqcHRyID0gMDsNCiEgCWxlbiA9IFZBUkhEUlNaICsg
|
||
c3RybGVuKHRtcCk7DQogIAlyZXQgPSBwYWxsb2MobGVuKTsNCiAgCWlmIChy
|
||
ZXQgPT0gTlVMTCkNCiAgCQllbG9nKEVSUk9SLCAidW5hYmxlIHRvIGFsbG9j
|
||
YXRlIG1lbW9yeSBpbiBuZXR3b3JrX2hvc3QoKSIpOw0KICANCiAgCVZBUlNJ
|
||
WkUocmV0KSA9IGxlbjsNCiEgCW1lbWNweShWQVJEQVRBKHJldCksIHRtcCwg
|
||
bGVuLVZBUkhEUlNaKTsNCiAgCXJldHVybiAocmV0KTsNCiAgfQ0KICANCioq
|
||
KioqKioqKioqKioqKg0KKioqIDM5MSw0MDMgKioqKg0KICANCiAgCWlmICgo
|
||
cHRyID0gc3RyY2hyKHRtcCwgJy8nKSkgIT0gTlVMTCkNCiAgCQkqcHRyID0g
|
||
MDsNCiEgCWxlbiA9IFZBUkhEUlNaICsgc3RybGVuKHRtcCkgKyAxOw0KICAJ
|
||
cmV0ID0gcGFsbG9jKGxlbik7DQogIAlpZiAocmV0ID09IE5VTEwpDQogIAkJ
|
||
ZWxvZyhFUlJPUiwgInVuYWJsZSB0byBhbGxvY2F0ZSBtZW1vcnkgaW4gbmV0
|
||
d29ya19icm9hZGNhc3QoKSIpOw0KICANCiAgCVZBUlNJWkUocmV0KSA9IGxl
|
||
bjsNCiEgCXN0cmNweShWQVJEQVRBKHJldCksIHRtcCk7DQogIAlyZXR1cm4g
|
||
KHJldCk7DQogIH0NCiAgDQotLS0gMzkyLDQwNCAtLS0tDQogIA0KICAJaWYg
|
||
KChwdHIgPSBzdHJjaHIodG1wLCAnLycpKSAhPSBOVUxMKQ0KICAJCSpwdHIg
|
||
PSAwOw0KISAJbGVuID0gVkFSSERSU1ogKyBzdHJsZW4odG1wKTsNCiAgCXJl
|
||
dCA9IHBhbGxvYyhsZW4pOw0KICAJaWYgKHJldCA9PSBOVUxMKQ0KICAJCWVs
|
||
b2coRVJST1IsICJ1bmFibGUgdG8gYWxsb2NhdGUgbWVtb3J5IGluIG5ldHdv
|
||
cmtfYnJvYWRjYXN0KCkiKTsNCiAgDQogIAlWQVJTSVpFKHJldCkgPSBsZW47
|
||
DQohIAltZW1jcHkoVkFSREFUQShyZXQpLCB0bXAsIGxlbi1WQVJIRFJTWik7
|
||
DQogIAlyZXR1cm4gKHJldCk7DQogIH0NCiAgDQoqKioqKioqKioqKioqKioN
|
||
CioqKiA0MjQsNDM2ICoqKioNCiAgCQkvKiBHbyBmb3IgYW4gSVBWNiBhZGRy
|
||
ZXNzIGhlcmUsIGJlZm9yZSBmYXVsdGluZyBvdXQ6ICovDQogIAkJZWxvZyhF
|
||
UlJPUiwgInVua25vd24gYWRkcmVzcyBmYW1pbHkgKCVkKSIsIGlwX2ZhbWls
|
||
eShpcCkpOw0KICANCiEgCWxlbiA9IFZBUkhEUlNaICsgc3RybGVuKHRtcCkg
|
||
KyAxOw0KICAJcmV0ID0gcGFsbG9jKGxlbik7DQogIAlpZiAocmV0ID09IE5V
|
||
TEwpDQogIAkJZWxvZyhFUlJPUiwgInVuYWJsZSB0byBhbGxvY2F0ZSBtZW1v
|
||
cnkgaW4gbmV0d29ya19uZXR3b3JrKCkiKTsNCiAgDQogIAlWQVJTSVpFKHJl
|
||
dCkgPSBsZW47DQohIAlzdHJjcHkoVkFSREFUQShyZXQpLCB0bXApOw0KICAJ
|
||
cmV0dXJuIChyZXQpOw0KICB9DQogIA0KLS0tIDQyNSw0MzcgLS0tLQ0KICAJ
|
||
CS8qIEdvIGZvciBhbiBJUFY2IGFkZHJlc3MgaGVyZSwgYmVmb3JlIGZhdWx0
|
||
aW5nIG91dDogKi8NCiAgCQllbG9nKEVSUk9SLCAidW5rbm93biBhZGRyZXNz
|
||
IGZhbWlseSAoJWQpIiwgaXBfZmFtaWx5KGlwKSk7DQogIA0KISAJbGVuID0g
|
||
VkFSSERSU1ogKyBzdHJsZW4odG1wKTsNCiAgCXJldCA9IHBhbGxvYyhsZW4p
|
||
Ow0KICAJaWYgKHJldCA9PSBOVUxMKQ0KICAJCWVsb2coRVJST1IsICJ1bmFi
|
||
bGUgdG8gYWxsb2NhdGUgbWVtb3J5IGluIG5ldHdvcmtfbmV0d29yaygpIik7
|
||
DQogIA0KICAJVkFSU0laRShyZXQpID0gbGVuOw0KISAJbWVtY3B5KFZBUkRB
|
||
VEEocmV0KSwgdG1wLCBsZW4tVkFSSERSU1opOw0KICAJcmV0dXJuIChyZXQp
|
||
Ow0KICB9DQogIA0KKioqKioqKioqKioqKioqDQoqKiogNDYxLDQ3OSAqKioq
|
||
DQogIA0KICAJaWYgKChwdHIgPSBzdHJjaHIodG1wLCAnLycpKSAhPSBOVUxM
|
||
KQ0KICAJCSpwdHIgPSAwOw0KISAJbGVuID0gVkFSSERSU1ogKyBzdHJsZW4o
|
||
dG1wKSArIDE7DQogIAlyZXQgPSBwYWxsb2MobGVuKTsNCiAgCWlmIChyZXQg
|
||
PT0gTlVMTCkNCiAgCQllbG9nKEVSUk9SLCAidW5hYmxlIHRvIGFsbG9jYXRl
|
||
IG1lbW9yeSBpbiBuZXR3b3JrX25ldG1hc2soKSIpOw0KICANCiAgCVZBUlNJ
|
||
WkUocmV0KSA9IGxlbjsNCiEgCXN0cmNweShWQVJEQVRBKHJldCksIHRtcCk7
|
||
DQogIAlyZXR1cm4gKHJldCk7DQogIH0NCiAgDQogIC8qDQogICAqCUJpdHdp
|
||
c2UgY29tcGFyaXNvbiBmb3IgVjQgYWRkcmVzc2VzLiAgQWRkIFY2IGltcGxl
|
||
bWVudGF0aW9uIQ0KICAgKi8NCiAgDQogIHN0YXRpYyBpbnQNCiAgdjRiaXRu
|
||
Y21wKHVuc2lnbmVkIGludCBhMSwgdW5zaWduZWQgaW50IGEyLCBpbnQgYml0
|
||
cykNCi0tLSA0NjIsNDkxIC0tLS0NCiAgDQogIAlpZiAoKHB0ciA9IHN0cmNo
|
||
cih0bXAsICcvJykpICE9IE5VTEwpDQogIAkJKnB0ciA9IDA7DQohIAlsZW4g
|
||
PSBWQVJIRFJTWiArIHN0cmxlbih0bXApOw0KICAJcmV0ID0gcGFsbG9jKGxl
|
||
bik7DQogIAlpZiAocmV0ID09IE5VTEwpDQogIAkJZWxvZyhFUlJPUiwgInVu
|
||
YWJsZSB0byBhbGxvY2F0ZSBtZW1vcnkgaW4gbmV0d29ya19uZXRtYXNrKCki
|
||
KTsNCiAgDQogIAlWQVJTSVpFKHJldCkgPSBsZW47DQohIAltZW1jcHkoVkFS
|
||
REFUQShyZXQpLCB0bXAsIGxlbi1WQVJIRFJTWik7DQogIAlyZXR1cm4gKHJl
|
||
dCk7DQogIH0NCiAgDQogIC8qDQogICAqCUJpdHdpc2UgY29tcGFyaXNvbiBm
|
||
b3IgVjQgYWRkcmVzc2VzLiAgQWRkIFY2IGltcGxlbWVudGF0aW9uIQ0KICAg
|
||
Ki8NCisgDQorIHN0YXRpYyBpbnQNCisgdjRiaXRjbXAodW5zaWduZWQgaW50
|
||
IGExLCB1bnNpZ25lZCBpbnQgYTIpDQorIHsNCisgCWExID0gbnRvaGwoYTEp
|
||
Ow0KKyAJYTIgPSBudG9obChhMik7DQorIAlpZiAoYTEgPCBhMikNCisgCQly
|
||
ZXR1cm4gKC0xKTsNCisgCWVsc2UgDQorIAkJcmV0dXJuIChhMSA+IGEyKTsN
|
||
CisgfQ0KICANCiAgc3RhdGljIGludA0KICB2NGJpdG5jbXAodW5zaWduZWQg
|
||
aW50IGExLCB1bnNpZ25lZCBpbnQgYTIsIGludCBiaXRzKQ0K
|
||
|
||
---559023410-959030623-962801553=:1267--
|
||
|
||
From pgsql-hackers-owner+M4284@hub.org Wed Jul 5 09:04:09 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id JAA27751
|
||
for <pgman@candle.pha.pa.us>; Wed, 5 Jul 2000 09:04:08 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e65D44S42069;
|
||
Wed, 5 Jul 2000 09:04:04 -0400 (EDT)
|
||
Received: from turing.csis.gvsu.edu (IDENT:qmailr@csis.gvsu.edu [148.61.162.182])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e65D2HS35607
|
||
for <pgsql-hackers@postgresql.org>; Wed, 5 Jul 2000 09:02:17 -0400 (EDT)
|
||
Received: (qmail 4436 invoked by uid 0); 5 Jul 2000 13:02:17 -0000
|
||
Received: from eos05.csis.gvsu.edu (eisentrp@148.61.162.105)
|
||
by turing.csis.gvsu.edu with QMQP; 5 Jul 2000 13:02:17 -0000
|
||
From: eisentrp@csis.gvsu.edu
|
||
Date: Wed, 5 Jul 2000 09:02:17 -0400 (EDT)
|
||
Reply-To: Peter Eisentraut <peter_e@gmx.net>
|
||
To: "D'Arcy J.M. Cain" <darcy@druid.net>
|
||
cc: PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] Repair plan for inet and cidr types
|
||
In-Reply-To: <m139egU-000AXpC@druid.net>
|
||
Message-ID: <Pine.LNX.4.21.0007050842080.10677-100000@eos05.csis.gvsu.edu>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
On Tue, 4 Jul 2000, D'Arcy J.M. Cain wrote:
|
||
|
||
> I'm not sure I understand why this is necessary. I can see not allowing
|
||
> cidr ==> inet conversions but inet ==> cidr can be done as it is a matter
|
||
> of dropping information - the host part.
|
||
|
||
Automatic casts should not lose information. How would you feel if floats
|
||
were automatically rounded when you store them into int fields? I think
|
||
this is an important principle in any type system.
|
||
|
||
> Then let's define that as the meaning of "inet1 << inet2" i.e. define
|
||
> the << operator between inet types as meaning "tell me if inet1 is in
|
||
> the same network as inet2."
|
||
|
||
Again, let the user say what he wants: inet1 << network(inet2).
|
||
|
||
Also note that "is inet1 in the same network as inet2" is different from
|
||
"is inet1 contained in the network of inet2" (which is what it does now).
|
||
The operator you defined is symmetric (if inet1 is in the same network as
|
||
inet2, then inet2 is also in the same network as inet1), whereas the << is
|
||
antisymmetric. In fact, AFAICT, the operator you defined doesn't exist
|
||
yet, although it perhaps should.
|
||
|
||
|
||
--
|
||
Peter Eisentraut Sernanders vaeg 10:115
|
||
peter_e@gmx.net 75262 Uppsala
|
||
http://yi.org/peter-e/ Sweden
|
||
|
||
|
||
From pgsql-hackers-owner+M4293@hub.org Wed Jul 5 09:50:15 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id JAA28183
|
||
for <pgman@candle.pha.pa.us>; Wed, 5 Jul 2000 09:50:14 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e65Do1S55862;
|
||
Wed, 5 Jul 2000 09:50:01 -0400 (EDT)
|
||
Received: from andie.ip23.net (andie.ip23.net [212.83.32.23])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e65DmGS51928
|
||
for <pgsql-hackers@PostgreSQL.org>; Wed, 5 Jul 2000 09:48:16 -0400 (EDT)
|
||
Received: from imap1.ip23.net (imap1.ip23.net [212.83.32.35])
|
||
by andie.ip23.net (8.9.3/8.9.3) with ESMTP id PAA33008;
|
||
Wed, 5 Jul 2000 15:48:10 +0200 (CEST)
|
||
Received: from ip23.net (spc.ip23.net [212.83.32.122])
|
||
by imap1.ip23.net (8.9.3/8.9.3) with ESMTP id QAA00989;
|
||
Wed, 5 Jul 2000 16:01:01 +0200 (CEST)
|
||
Message-ID: <39633C99.DD58D11F@ip23.net>
|
||
Date: Wed, 05 Jul 2000 15:48:09 +0200
|
||
From: Sevo Stille <sevo@ip23.net>
|
||
Organization: IP23
|
||
X-Mailer: Mozilla 4.61 [en] (X11; I; Linux 2.2.10 i686)
|
||
X-Accept-Language: en, de
|
||
MIME-Version: 1.0
|
||
To: Jakub Bartosz Bielecki <J.B.Bielecki@elka.pw.edu.pl>
|
||
CC: pgsql-hackers@PostgreSQL.org
|
||
Subject: Re: [HACKERS] Re: postgres - development of inet/cidr
|
||
References: <Pine.SOL.4.21.0007051410330.1267-100000@elektron.elka.pw.edu.pl>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Jakub Bartosz Bielecki wrote:
|
||
|
||
> > "select '10.0.0.1/27'::cidr << '10.0.0.2/27'::inet;" ERROR
|
||
>
|
||
> Currently it's not an error... There is no way (and no reason) to
|
||
> distinguish between INET and CIDR.
|
||
|
||
Yes, there is. CIDR is defined as the network 10.0.0.1 & /27, while INET
|
||
is defined as host 10.0.0.1 within network 10.0.0.1 & /27. You can do
|
||
almost every network and host calculation both in CIDR and INET, but
|
||
you need implicit knowledge for it. Two columns are necessary to define
|
||
a host and its network in CIDR, and a network cannot be specified
|
||
without a host using INET - except for ugly in-band hacks like using
|
||
10.0.0.0/27 for the network which would prevent you from specifying a
|
||
base address.
|
||
|
||
> Above example is exactly
|
||
> equivalent to:
|
||
> select '10.0.0.0/27'::inet << '10.0.0.2/27'::inet; -- FALSE
|
||
|
||
Nope. If the right hand side is automatically propagated to a network,
|
||
it is true. If not, the above IMHO should better raise an error, as a
|
||
host can never contain a host.
|
||
|
||
> but:
|
||
> select '10.0.0.0/27'::inet <<= '10.0.0.2/27'::inet; -- TRUE
|
||
|
||
Well, you might argue that a host could contain-or-equal a host, but as
|
||
only the equals part could ever be true, that is a redundant operator
|
||
without any meaning beyond equals, and accordingly it should not be
|
||
valid for that case.
|
||
|
||
> > But we need to reach an agreement on the proper
|
||
> > behaviour on greater/smaller comparisons. Should:
|
||
> >
|
||
> > "select '10.0.0.1/27'::inet > '10.0.0.2/27'::cidr;"
|
||
> >
|
||
> > be true or false? Casting to cidr prior to comparison would make it
|
||
> > equivalent to "select '10.0.0.0/27'::cidr > '10.0.0.0/27'::cidr;", which
|
||
> > is false, both networks being equal.
|
||
>
|
||
> It should be (and is!) true... Since second argument is
|
||
> really '10.0.0.0/27'.
|
||
|
||
Yes, but that does not make it any truer. CIDR 10.0.0.0/27 is
|
||
definitively not 10.0.0.0 but [10.0.0.0 .. 10.0.0.31]. A CIDR address is
|
||
never synonymous to a plain host address. You'll see the problem if you
|
||
try to calculate the inverse - any zeroed CIDR address in the entire
|
||
range from 10.0/8 to 10.0.0.0/32 would mask to 10.0.0.0. Accordingly,
|
||
there is no simple answer to a "host bigger/smaller than network"
|
||
question. For many applications, it may be useful to define that to mean
|
||
that the host is smaller than the network bottom address respectively
|
||
bigger than the top address, but any of the other possible views would
|
||
be perfectly legal as well.
|
||
|
||
Sevo
|
||
|
||
--
|
||
sevo@ip23.net
|
||
|
||
From pgsql-hackers-owner+M4354@hub.org Wed Jul 5 16:49:21 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id QAA17585
|
||
for <pgman@candle.pha.pa.us>; Wed, 5 Jul 2000 16:49:20 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e65KmdS82556;
|
||
Wed, 5 Jul 2000 16:48:39 -0400 (EDT)
|
||
Received: from druid.net (root@druid.net [216.126.72.98])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e65KkqS77601
|
||
for <pgsql-hackers@postgresql.org>; Wed, 5 Jul 2000 16:46:52 -0400 (EDT)
|
||
Received: from localhost (2500 bytes) by druid.net
|
||
via sendmail with P:stdio/R:bind_hosts/T:inet_zone_bind_smtp
|
||
(sender: <darcy>) (ident <darcy> using unix)
|
||
id <m139w4G-000AXpC@druid.net>
|
||
for <pgsql-hackers@postgresql.org>; Wed, 5 Jul 2000 16:46:48 -0400 (EDT)
|
||
(Smail-3.2.0.109 1999-Oct-27 #3 built 2000-Jun-28)
|
||
Message-Id: <m139w4G-000AXpC@druid.net>
|
||
From: darcy@druid.net (D'Arcy J.M. Cain)
|
||
Subject: Re: [HACKERS] Repair plan for inet and cidr types
|
||
In-Reply-To: <Pine.LNX.4.21.0007050842080.10677-100000@eos05.csis.gvsu.edu>
|
||
"from eisentrp@csis.gvsu.edu at Jul 5, 2000 09:02:17 am"
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
Date: Wed, 5 Jul 2000 16:46:48 -0400 (EDT)
|
||
CC: PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
X-Mailer: ELM [version 2.4ME+ PL78 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Thus spake eisentrp@csis.gvsu.edu
|
||
> On Tue, 4 Jul 2000, D'Arcy J.M. Cain wrote:
|
||
> > I'm not sure I understand why this is necessary. I can see not allowing
|
||
> > cidr ==> inet conversions but inet ==> cidr can be done as it is a matter
|
||
> > of dropping information - the host part.
|
||
>
|
||
> Automatic casts should not lose information. How would you feel if floats
|
||
> were automatically rounded when you store them into int fields? I think
|
||
> this is an important principle in any type system.
|
||
|
||
If it was defined well I would have no problem with it.
|
||
|
||
> > Then let's define that as the meaning of "inet1 << inet2" i.e. define
|
||
> > the << operator between inet types as meaning "tell me if inet1 is in
|
||
> > the same network as inet2."
|
||
>
|
||
> Again, let the user say what he wants: inet1 << network(inet2).
|
||
|
||
I think that's what I meant. I'm just saying that inet::cidr should be
|
||
the same as network(inet). Allowing that cast makes a lot of operations
|
||
work intuitively.
|
||
|
||
> Also note that "is inet1 in the same network as inet2" is different from
|
||
> "is inet1 contained in the network of inet2" (which is what it does now).
|
||
|
||
Hmm. It is a subtle difference and I did miss it.
|
||
|
||
> The operator you defined is symmetric (if inet1 is in the same network as
|
||
> inet2, then inet2 is also in the same network as inet1), whereas the << is
|
||
> antisymmetric. In fact, AFAICT, the operator you defined doesn't exist
|
||
> yet, although it perhaps should.
|
||
|
||
I guess what I was really getting at was this.
|
||
|
||
host OP cidr
|
||
|
||
where inet would cast to host on one side and cidr on the other. What
|
||
we have now is
|
||
|
||
cidr OP cidr
|
||
|
||
with both sides casting to cidr. Of course there is no such thing as a host
|
||
type so I don't know how we would cast such a thing.
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M4421@hub.org Thu Jul 6 08:54:47 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id IAA06169
|
||
for <pgman@candle.pha.pa.us>; Thu, 6 Jul 2000 08:54:46 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e66CrgS44851;
|
||
Thu, 6 Jul 2000 08:53:42 -0400 (EDT)
|
||
Received: from elektron.elka.pw.edu.pl (root@elektron.elka.pw.edu.pl [148.81.63.249])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e66Cr5S44024
|
||
for <pgsql-hackers@PostgreSQL.org>; Thu, 6 Jul 2000 08:53:05 -0400 (EDT)
|
||
Received: from elektron.elka.pw.edu.pl ([148.81.63.249]:64907 "EHLO
|
||
elektron.elka.pw.edu.pl") by elektron.elka.pw.edu.pl with ESMTP
|
||
id <S225243AbQGFMw2>; Thu, 6 Jul 2000 14:52:28 +0200
|
||
Date: Thu, 6 Jul 2000 14:52:17 +0200 (MET DST)
|
||
From: Jakub Bartosz Bielecki <J.B.Bielecki@elka.pw.edu.pl>
|
||
To: Sevo Stille <sevo@ip23.net>
|
||
cc: Jakub Bartosz Bielecki <J.B.Bielecki@elka.pw.edu.pl>,
|
||
pgsql-hackers@PostgreSQL.org
|
||
Subject: Re: [HACKERS] Re: postgres - development of inet/cidr
|
||
In-Reply-To: <39633C99.DD58D11F@ip23.net>
|
||
Message-ID: <Pine.SOL.4.21.0007061354040.20142-100000@elektron.elka.pw.edu.pl>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
|
||
|
||
On Wed, 5 Jul 2000, Sevo Stille wrote:
|
||
>
|
||
> > > "select '10.0.0.1/27'::cidr << '10.0.0.2/27'::inet;" ERROR
|
||
> >
|
||
> > Currently it's not an error... There is no way (and no reason) to
|
||
> > distinguish between INET and CIDR.
|
||
>
|
||
> Yes, there is. CIDR is defined as the network 10.0.0.1 & /27, while INET
|
||
> is defined as host 10.0.0.1 within network 10.0.0.1 & /27. You can do
|
||
> almost every network and host calculation both in CIDR and INET, but
|
||
> you need implicit knowledge for it.
|
||
|
||
I was talking about *current* implementation of INET/CIDR (which IMHO
|
||
is very ill).
|
||
There is INET for users that want simply to store IP's and don't care
|
||
about all the technical jargon.
|
||
There is CIDR for advanced users who want to store network data.
|
||
|
||
Currently these 2 types are handled by 1 implementation, moreover despite
|
||
INET netmask and CIDR prefix-length are something completely different,
|
||
both are stored in the same field of inet structure (yuck).
|
||
|
||
At the moment it works fine. But that's only a hack.
|
||
I guess the purpose was to prevent duplication of code... Blah...
|
||
|
||
> > select '10.0.0.0/27'::inet << '10.0.0.2/27'::inet; -- FALSE
|
||
>
|
||
> Nope. If the right hand side is automatically propagated to a network,
|
||
> it is true. If not, the above IMHO should better raise an error, as a
|
||
> host can never contain a host.
|
||
>
|
||
> > select '10.0.0.0/27'::inet <<= '10.0.0.2/27'::inet; -- TRUE
|
||
>
|
||
> Well, you might argue that a host could contain-or-equal a host, but as
|
||
> only the equals part could ever be true, that is a redundant operator
|
||
> without any meaning beyond equals, and accordingly it should not be
|
||
> valid for that case.
|
||
>
|
||
> > > "select '10.0.0.1/27'::inet > '10.0.0.2/27'::cidr;"
|
||
> > It should be (and is!) true... Since second argument is
|
||
> > really '10.0.0.0/27'.
|
||
>
|
||
> Yes, but that does not make it any truer. CIDR 10.0.0.0/27 is
|
||
> definitively not 10.0.0.0 but [10.0.0.0 .. 10.0.0.31].
|
||
|
||
Same as above... You are perfectly right.
|
||
|
||
Everything works until user starts messing with _both_ INET and CIDR
|
||
at the same time.
|
||
|
||
The possible solution is:
|
||
- inhibit cidr-to-inet cast (and maybe also inet-to-cidr, because
|
||
it would throw away netmask),
|
||
- CIDR operators: > = < << >>
|
||
- INET operators: > = < (and why not & | if it would be useful???)
|
||
functions: cidr network(inet); // '10.0.0.0/27'
|
||
text host(inet); // '10.0.0.1'
|
||
int masklen(inet); // 27
|
||
- write an usable manual.
|
||
|
||
Comments?
|
||
I *might* work on it if I find some spare time. But it's unlikely :(
|
||
|
||
|
||
From pgsql-hackers-owner+M4503@hub.org Fri Jul 7 12:11:37 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id MAA26802
|
||
for <pgman@candle.pha.pa.us>; Fri, 7 Jul 2000 12:11:36 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e67GAgW67823;
|
||
Fri, 7 Jul 2000 12:10:42 -0400 (EDT)
|
||
Received: from merganser.its.uu.se (merganser.its.uu.se [130.238.6.236])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e67G9qW66262
|
||
for <pgsql-hackers@postgresql.org>; Fri, 7 Jul 2000 12:09:52 -0400 (EDT)
|
||
Received: from regulus.student.UU.SE ([130.238.5.2]:53522 "EHLO
|
||
regulus.its.uu.se") by merganser.its.uu.se with ESMTP
|
||
id <S493726AbQGGQJO>; Fri, 7 Jul 2000 18:09:14 +0200
|
||
Received: from peter (helo=localhost)
|
||
by regulus.its.uu.se with local-esmtp (Exim 3.02 #2)
|
||
id 13Aani-0003A6-00; Fri, 07 Jul 2000 18:16:26 +0200
|
||
Date: Fri, 7 Jul 2000 18:16:26 +0200 (CEST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
To: "D'Arcy J.M. Cain" <darcy@druid.net>
|
||
cc: PostgreSQL Development <pgsql-hackers@postgresql.org>
|
||
Subject: Re: [HACKERS] Repair plan for inet and cidr types
|
||
In-Reply-To: <m139w4G-000AXpC@druid.net>
|
||
Message-ID: <Pine.LNX.4.21.0007070156410.4191-100000@localhost.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=ISO-8859-1
|
||
Content-Transfer-Encoding: 8BIT
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
D'Arcy J.M. Cain writes:
|
||
|
||
> > Automatic casts should not lose information. How would you feel if floats
|
||
> > were automatically rounded when you store them into int fields? I think
|
||
> > this is an important principle in any type system.
|
||
>
|
||
> If it was defined well I would have no problem with it.
|
||
|
||
That is certainly not how type systems operate anywhere.
|
||
|
||
> I guess what I was really getting at was this.
|
||
>
|
||
> host OP cidr
|
||
>
|
||
> where inet would cast to host on one side and cidr on the other. What
|
||
> we have now is
|
||
>
|
||
> cidr OP cidr
|
||
>
|
||
> with both sides casting to cidr. Of course there is no such thing as a host
|
||
> type so I don't know how we would cast such a thing.
|
||
|
||
I think that while the implicit casting could sometimes be convenient,
|
||
it's also a source of confusion. Consider the statement
|
||
|
||
select '10.0.0.3'::cidr < '10.0.0.2'::inet; => f
|
||
|
||
This cannot possibly make sense on closer inspection. Firstly, it's
|
||
semantic nonsense, you cannot order a network and a host. Secondly, it's
|
||
also wrong. According to the documentation, the '10.0.0.3'::cidr should be
|
||
converted to '10/8' internally. Then one of two things could have happened
|
||
here: 1) cidr was implicitly converted to inet and '10.0.0.3' is taken to
|
||
be a host, which is completely wrong. Or 2) inet was converted to cidr.
|
||
But then we're looking at '10/8' < '10.0.0.2/32', which should be true.
|
||
|
||
See also
|
||
|
||
select '10.0.0.2'::cidr = '10.0.0.2'::inet; => t
|
||
|
||
which is wrong for similar reasons.
|
||
|
||
|
||
Then let's look at the << family of operators.
|
||
|
||
select '10.0.0.2'::cidr >> '10.0.0.2'::inet; => f
|
||
|
||
Again, there are two ways this could currently be resolved:
|
||
|
||
'10/8'::cidr >> '10.0.0.2/32'::cidr which does return true
|
||
or
|
||
'10.0.0.2'::inet >> '10.0.0.2'::inet
|
||
which doesn't make any sense.
|
||
|
||
On closer inspection, the inet << cidr case is completely misbehaving:
|
||
|
||
select '10.0.0.5/8'::inet << '10.0.0.0/16'::cidr; => f
|
||
select '10.0.0.5/24'::inet << '10.0.0.0/16'::cidr; => t
|
||
|
||
This is not what I'd expect.
|
||
|
||
Concretely, the cases
|
||
inet << cidr
|
||
cidr << cidr
|
||
are not the same:
|
||
|
||
'10.0.0.5/8'::inet << '10.0.0.0/16'::cidr
|
||
should be true
|
||
|
||
'10.0.0.5/8'::cidr << '10.0.0.0/16'::cidr
|
||
should be false, if you allow the left-side value in at all, which I
|
||
wouldn't.
|
||
|
||
What this tells me is that the cast from inet to cidr is not well-defined
|
||
in the mathematical sense, and therefore no implicit casting should be
|
||
allowed.
|
||
|
||
So the bottom line here is that these two types are, while from a related
|
||
domain, different, and the user should be the one that controls when and
|
||
how they are mixed together.
|
||
|
||
|
||
--
|
||
Peter Eisentraut Sernanders v<>g 10:115
|
||
peter_e@gmx.net 75262 Uppsala
|
||
http://yi.org/peter-e/ Sweden
|
||
|
||
|
||
From pgsql-hackers-owner+M5242@hub.org Sun Jul 23 10:01:45 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id KAA21261
|
||
for <pgman@candle.pha.pa.us>; Sun, 23 Jul 2000 10:01:44 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6NE1Th91342;
|
||
Sun, 23 Jul 2000 10:01:29 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6NE10h91172
|
||
for <pgsql-hackers@hub.org>; Sun, 23 Jul 2000 10:01:00 -0400 (EDT)
|
||
Received: (from ler@localhost)
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) id e6NE0w219946
|
||
for pgsql-hackers@hub.org; Sun, 23 Jul 2000 09:00:58 -0500 (CDT)
|
||
From: Larry Rosenman <ler@lerctr.org>
|
||
Message-Id: <200007231400.e6NE0w219946@lerami.lerctr.org>
|
||
Subject: [HACKERS] INET/CIDR types
|
||
To: pgsql-hackers@hub.org
|
||
Date: Sun, 23 Jul 2000 09:00:57 -0500 (CDT)
|
||
X-Mailer: ELM [version 2.4ME+ PL79 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
I noticed a discussion on this list about a re-do of the INET/CIDR
|
||
types. I was wondering if there was ANY way at all to add
|
||
an output function that ALWAYS returns all 4 octets of an INET or CIDR
|
||
type with and without the /netmask?
|
||
|
||
I'm writing a IP Allocation/Tracking app for the ISP I work for, and
|
||
find the current output format causes confusion for the less
|
||
technical types.
|
||
|
||
Larry Rosenman
|
||
--
|
||
Larry Rosenman http://www.lerctr.org/~ler
|
||
Phone: +1 972-414-9812 (voice) Internet: ler@lerctr.org
|
||
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749
|
||
|
||
From pgsql-hackers-owner+M5264@hub.org Mon Jul 24 10:34:39 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id KAA09676
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 10:34:38 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OEXZh83378;
|
||
Mon, 24 Jul 2000 10:33:35 -0400 (EDT)
|
||
Received: from druid.net (root@druid.net [216.126.72.98])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OEXGh83201
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 10:33:16 -0400 (EDT)
|
||
Received: from localhost (1444 bytes) by druid.net
|
||
via sendmail with P:stdio/R:bind_hosts/T:inet_zone_bind_smtp
|
||
(sender: <darcy>) (ident <darcy> using unix)
|
||
id <m13GjIB-000AXgC@druid.net>
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 10:33:15 -0400 (EDT)
|
||
(Smail-3.2.0.109 1999-Oct-27 #3 built 2000-Jun-28)
|
||
Message-Id: <m13GjIB-000AXgC@druid.net>
|
||
From: darcy@druid.net (D'Arcy J.M. Cain)
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <200007231400.e6NE0w219946@lerami.lerctr.org> "from Larry Rosenman
|
||
at Jul 23, 2000 09:00:57 am"
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
Date: Mon, 24 Jul 2000 10:33:14 -0400 (EDT)
|
||
CC: pgsql-hackers@hub.org
|
||
Reply-To: pgsql-hackers@hub.org
|
||
X-Mailer: ELM [version 2.4ME+ PL78 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Thus spake Larry Rosenman
|
||
> I noticed a discussion on this list about a re-do of the INET/CIDR
|
||
> types. I was wondering if there was ANY way at all to add
|
||
> an output function that ALWAYS returns all 4 octets of an INET or CIDR
|
||
> type with and without the /netmask?
|
||
>
|
||
> I'm writing a IP Allocation/Tracking app for the ISP I work for, and
|
||
> find the current output format causes confusion for the less
|
||
> technical types.
|
||
|
||
The host() function does this for the INET type. It doesn't work for
|
||
the CIDR type (it throws an error) because CIDR doesn't have a host
|
||
part per se.
|
||
|
||
darcy=> select '1.2.0.0/23'::inet;
|
||
?column?
|
||
--------
|
||
1.2.0/23
|
||
(1 row)
|
||
|
||
darcy=> select host('1.2.0.0/23'::inet);
|
||
host
|
||
-------
|
||
1.2.0.0
|
||
(1 row)
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M5265@hub.org Mon Jul 24 10:43:14 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id KAA09722
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 10:43:13 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OEfLh86364;
|
||
Mon, 24 Jul 2000 10:41:21 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OEf6h86190
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 10:41:06 -0400 (EDT)
|
||
Received: (from ler@localhost)
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) id e6OEf5D12433;
|
||
Mon, 24 Jul 2000 09:41:05 -0500 (CDT)
|
||
From: Larry Rosenman <ler@lerctr.org>
|
||
Message-Id: <200007241441.e6OEf5D12433@lerami.lerctr.org>
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <m13GjIB-000AXgC@druid.net> "from darcy@druid.net at Jul 24, 2000
|
||
10:33:14 am"
|
||
To: pgsql-hackers@hub.org
|
||
Date: Mon, 24 Jul 2000 09:41:05 -0500 (CDT)
|
||
CC: Larry Rosenman <ler@lerctr.org>
|
||
X-Mailer: ELM [version 2.4ME+ PL79 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
The bad news is that I'm tracking CIDR blocks.
|
||
|
||
If I could get a network() function to return essentially
|
||
host()::inet for CIDR's that would work.
|
||
|
||
Larry
|
||
> Thus spake Larry Rosenman
|
||
> > I noticed a discussion on this list about a re-do of the INET/CIDR
|
||
> > types. I was wondering if there was ANY way at all to add
|
||
> > an output function that ALWAYS returns all 4 octets of an INET or CIDR
|
||
> > type with and without the /netmask?
|
||
> >
|
||
> > I'm writing a IP Allocation/Tracking app for the ISP I work for, and
|
||
> > find the current output format causes confusion for the less
|
||
> > technical types.
|
||
>
|
||
> The host() function does this for the INET type. It doesn't work for
|
||
> the CIDR type (it throws an error) because CIDR doesn't have a host
|
||
> part per se.
|
||
>
|
||
> darcy=> select '1.2.0.0/23'::inet;
|
||
> ?column?
|
||
> --------
|
||
> 1.2.0/23
|
||
> (1 row)
|
||
>
|
||
> darcy=> select host('1.2.0.0/23'::inet);
|
||
> host
|
||
> -------
|
||
> 1.2.0.0
|
||
> (1 row)
|
||
>
|
||
> --
|
||
> D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
> http://www.druid.net/darcy/ | and a sheep voting on
|
||
> +1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
|
||
--
|
||
Larry Rosenman http://www.lerctr.org/~ler
|
||
Phone: +1 972-414-9812 (voice) Internet: ler@lerctr.org
|
||
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749
|
||
|
||
From pgsql-hackers-owner+M5270@hub.org Mon Jul 24 15:17:30 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id PAA11467
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 15:17:29 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OJHEh72992;
|
||
Mon, 24 Jul 2000 15:17:14 -0400 (EDT)
|
||
Received: from druid.net (root@druid.net [216.126.72.98])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OJF3h71969
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 15:15:04 -0400 (EDT)
|
||
Received: from localhost (1687 bytes) by druid.net
|
||
via sendmail with P:stdio/R:bind_hosts/T:inet_zone_bind_smtp
|
||
(sender: <darcy>) (ident <darcy> using unix)
|
||
id <m13Gngs-000AXeC@druid.net>
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 15:15:02 -0400 (EDT)
|
||
(Smail-3.2.0.109 1999-Oct-27 #3 built 2000-Jun-28)
|
||
Message-Id: <m13Gngs-000AXeC@druid.net>
|
||
From: darcy@druid.net (D'Arcy J.M. Cain)
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <200007241441.e6OEf5D12433@lerami.lerctr.org> "from Larry Rosenman
|
||
at Jul 24, 2000 09:41:05 am"
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
Date: Mon, 24 Jul 2000 15:15:01 -0400 (EDT)
|
||
CC: pgsql-hackers@hub.org
|
||
Reply-To: pgsql-hackers@hub.org
|
||
X-Mailer: ELM [version 2.4ME+ PL78 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Thus spake Larry Rosenman
|
||
> The bad news is that I'm tracking CIDR blocks.
|
||
|
||
Then there is no host part. I would argue that if someone is getting
|
||
confused with the current output then perhaps they shouldn't be dealing
|
||
with client networks.
|
||
|
||
> If I could get a network() function to return essentially
|
||
> host()::inet for CIDR's that would work.
|
||
|
||
There is a network function. It returns the network.
|
||
|
||
darcy=> select network('1.2.0.0/23'::cidr);
|
||
network
|
||
--------
|
||
1.2.0/23
|
||
(1 row)
|
||
|
||
A lot of work went into these types to make them correct. I don't think
|
||
we should be undermining that to allow people to work with incorrect
|
||
assumptions. If you want Micro$oft you know where to find it.
|
||
|
||
If you really must do this then store your blocks in the INET type. It
|
||
pretty much does what you want but doesn't try to pretend to be a CIDR.
|
||
|
||
|
||
Hmmm. I just noticed this.
|
||
|
||
darcy=> select '1.2.0.1/23'::cidr;
|
||
?column?
|
||
--------
|
||
1.2.0/23
|
||
(1 row)
|
||
|
||
Shouldn't that throw an error?
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M5271@hub.org Mon Jul 24 15:28:37 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id PAA11521
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 15:28:36 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OJSMh77820;
|
||
Mon, 24 Jul 2000 15:28:22 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OJQhh76867
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 15:26:43 -0400 (EDT)
|
||
Received: from lerdesk (ler-desk.iadfw.net [206.66.13.18])
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) with SMTP id e6OJQcc24312;
|
||
Mon, 24 Jul 2000 14:26:38 -0500 (CDT)
|
||
From: "Larry Rosenman" <ler@lerctr.org>
|
||
To: <pgsql-hackers@hub.org>, "Larry Rosenman" <ler@lerctr.org>
|
||
Subject: RE: [HACKERS] INET/CIDR types
|
||
Date: Mon, 24 Jul 2000 14:26:37 -0500
|
||
Message-ID: <NCBBKBDOOHHEJCJHLLPAMELAHIAA.ler@lerctr.org>
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Content-Transfer-Encoding: 7bit
|
||
X-Priority: 3 (Normal)
|
||
X-MSMail-Priority: Normal
|
||
X-Mailer: Microsoft Outlook IMO, Build 9.0.2416 (9.0.2911.0)
|
||
X-Mimeole: Produced By Microsoft MimeOLE V5.50.4133.2400
|
||
Importance: Normal
|
||
In-Reply-To: <m13Gngs-000AXeC@druid.net>
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
The problem is NON-TECHNICAL people will be getting the output,
|
||
and they expect 4 octet output.
|
||
|
||
I really think that we should have a way to coerce a CIDR to
|
||
an INET, and then allow host().
|
||
|
||
Remember that I am dealing with $10/hour clerks.
|
||
|
||
I really don't get the hostility to changing the OUTPUT format...
|
||
|
||
Larry Rosenman
|
||
|
||
-----Original Message-----
|
||
From: D'Arcy J.M. Cain [mailto:darcy@druid.net]
|
||
Sent: Monday, July 24, 2000 2:15 PM
|
||
To: Larry Rosenman
|
||
Cc: pgsql-hackers@hub.org
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
|
||
|
||
Thus spake Larry Rosenman
|
||
> The bad news is that I'm tracking CIDR blocks.
|
||
|
||
Then there is no host part. I would argue that if someone is getting
|
||
confused with the current output then perhaps they shouldn't be dealing
|
||
with client networks.
|
||
|
||
> If I could get a network() function to return essentially
|
||
> host()::inet for CIDR's that would work.
|
||
|
||
There is a network function. It returns the network.
|
||
|
||
darcy=> select network('1.2.0.0/23'::cidr);
|
||
network
|
||
--------
|
||
1.2.0/23
|
||
(1 row)
|
||
|
||
A lot of work went into these types to make them correct. I don't think
|
||
we should be undermining that to allow people to work with incorrect
|
||
assumptions. If you want Micro$oft you know where to find it.
|
||
|
||
If you really must do this then store your blocks in the INET type. It
|
||
pretty much does what you want but doesn't try to pretend to be a CIDR.
|
||
|
||
|
||
Hmmm. I just noticed this.
|
||
|
||
darcy=> select '1.2.0.1/23'::cidr;
|
||
?column?
|
||
--------
|
||
1.2.0/23
|
||
(1 row)
|
||
|
||
Shouldn't that throw an error?
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M5272@hub.org Mon Jul 24 15:35:28 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id PAA11554
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 15:35:28 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OJZFh80569;
|
||
Mon, 24 Jul 2000 15:35:16 -0400 (EDT)
|
||
Received: from smtp.pacifier.com (comet.pacifier.com [199.2.117.155])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OJXgh80113
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 15:33:42 -0400 (EDT)
|
||
Received: from desktop (dsl-dhogaza.pacifier.net [207.202.226.68])
|
||
by smtp.pacifier.com (8.9.3/8.9.3pop) with SMTP id MAA07579;
|
||
Mon, 24 Jul 2000 12:33:32 -0700 (PDT)
|
||
Message-Id: <3.0.1.32.20000724123008.01189db0@mail.pacifier.com>
|
||
X-Sender: dhogaza@mail.pacifier.com
|
||
X-Mailer: Windows Eudora Pro Version 3.0.1 (32)
|
||
Date: Mon, 24 Jul 2000 12:30:08 -0700
|
||
To: "Larry Rosenman" <ler@lerctr.org>, <pgsql-hackers@hub.org>,
|
||
"Larry Rosenman" <ler@lerctr.org>
|
||
From: Don Baccus <dhogaza@pacifier.com>
|
||
Subject: RE: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <NCBBKBDOOHHEJCJHLLPAMELAHIAA.ler@lerctr.org>
|
||
References: <m13Gngs-000AXeC@druid.net>
|
||
Mime-Version: 1.0
|
||
Content-Type: text/plain; charset="us-ascii"
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
At 02:26 PM 7/24/00 -0500, Larry Rosenman wrote:
|
||
>The problem is NON-TECHNICAL people will be getting the output,
|
||
>and they expect 4 octet output.
|
||
>
|
||
>I really think that we should have a way to coerce a CIDR to
|
||
>an INET, and then allow host().
|
||
>
|
||
>Remember that I am dealing with $10/hour clerks.
|
||
>
|
||
>I really don't get the hostility to changing the OUTPUT format...
|
||
|
||
Are these $10/hour clerks typing in SQL to psql? Strange ...
|
||
|
||
If not, formatting issues like this can easily be broken (or fixed,
|
||
according to your POV) by your application client.
|
||
|
||
|
||
|
||
- Don Baccus, Portland OR <dhogaza@pacifier.com>
|
||
Nature photos, on-line guides, Pacific Northwest
|
||
Rare Bird Alert Service and other goodies at
|
||
http://donb.photo.net.
|
||
|
||
From pgsql-hackers-owner+M5273@hub.org Mon Jul 24 15:38:46 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id PAA11571
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 15:38:45 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OJcPh81593;
|
||
Mon, 24 Jul 2000 15:38:25 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OJanh80997
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 15:36:49 -0400 (EDT)
|
||
Received: from lerdesk (ler-desk.iadfw.net [206.66.13.18])
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) with SMTP id e6OJajc24698;
|
||
Mon, 24 Jul 2000 14:36:45 -0500 (CDT)
|
||
From: "Larry Rosenman" <ler@lerctr.org>
|
||
To: "Don Baccus" <dhogaza@pacifier.com>, "Larry Rosenman" <ler@lerctr.org>,
|
||
<pgsql-hackers@hub.org>, "Larry Rosenman" <ler@lerctr.org>
|
||
Subject: RE: [HACKERS] INET/CIDR types
|
||
Date: Mon, 24 Jul 2000 14:36:44 -0500
|
||
Message-ID: <NCBBKBDOOHHEJCJHLLPACELCHIAA.ler@lerctr.org>
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Content-Transfer-Encoding: 7bit
|
||
X-Priority: 3 (Normal)
|
||
X-MSMail-Priority: Normal
|
||
X-Mailer: Microsoft Outlook IMO, Build 9.0.2416 (9.0.2911.0)
|
||
X-Mimeole: Produced By Microsoft MimeOLE V5.50.4133.2400
|
||
Importance: Normal
|
||
In-Reply-To: <3.0.1.32.20000724123008.01189db0@mail.pacifier.com>
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
I was hoping to have some niceties out of the SQL retrieve to print directly
|
||
in PHP, and not have to massage it.
|
||
|
||
Why is there such animosity to printing out all 4 octets in some function
|
||
somewhere for a CIDR block?
|
||
|
||
Larry
|
||
|
||
-----Original Message-----
|
||
From: Don Baccus [mailto:dhogaza@pacifier.com]
|
||
Sent: Monday, July 24, 2000 2:30 PM
|
||
To: Larry Rosenman; pgsql-hackers@hub.org; Larry Rosenman
|
||
Subject: RE: [HACKERS] INET/CIDR types
|
||
|
||
|
||
At 02:26 PM 7/24/00 -0500, Larry Rosenman wrote:
|
||
>The problem is NON-TECHNICAL people will be getting the output,
|
||
>and they expect 4 octet output.
|
||
>
|
||
>I really think that we should have a way to coerce a CIDR to
|
||
>an INET, and then allow host().
|
||
>
|
||
>Remember that I am dealing with $10/hour clerks.
|
||
>
|
||
>I really don't get the hostility to changing the OUTPUT format...
|
||
|
||
Are these $10/hour clerks typing in SQL to psql? Strange ...
|
||
|
||
If not, formatting issues like this can easily be broken (or fixed,
|
||
according to your POV) by your application client.
|
||
|
||
|
||
|
||
- Don Baccus, Portland OR <dhogaza@pacifier.com>
|
||
Nature photos, on-line guides, Pacific Northwest
|
||
Rare Bird Alert Service and other goodies at
|
||
http://donb.photo.net.
|
||
|
||
From pgsql-hackers-owner+M5274@hub.org Mon Jul 24 16:19:47 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id QAA11771
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 16:19:46 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OKJRh99659;
|
||
Mon, 24 Jul 2000 16:19:28 -0400 (EDT)
|
||
Received: from druid.net (root@druid.net [216.126.72.98])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OKHbh98841
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 16:17:37 -0400 (EDT)
|
||
Received: from localhost (1546 bytes) by druid.net
|
||
via sendmail with P:stdio/R:bind_hosts/T:inet_zone_bind_smtp
|
||
(sender: <darcy>) (ident <darcy> using unix)
|
||
id <m13GofQ-000AX1C@druid.net>
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 16:17:36 -0400 (EDT)
|
||
(Smail-3.2.0.109 1999-Oct-27 #3 built 2000-Jun-28)
|
||
Message-Id: <m13GofQ-000AX1C@druid.net>
|
||
From: darcy@druid.net (D'Arcy J.M. Cain)
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <NCBBKBDOOHHEJCJHLLPACELCHIAA.ler@lerctr.org> "from Larry Rosenman
|
||
at Jul 24, 2000 02:36:44 pm"
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
Date: Mon, 24 Jul 2000 16:17:36 -0400 (EDT)
|
||
CC: Don Baccus <dhogaza@pacifier.com>, pgsql-hackers@hub.org
|
||
Reply-To: pgsql-hackers@hub.org
|
||
X-Mailer: ELM [version 2.4ME+ PL78 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Thus spake Larry Rosenman
|
||
> I was hoping to have some niceties out of the SQL retrieve to print directly
|
||
> in PHP, and not have to massage it.
|
||
>
|
||
> Why is there such animosity to printing out all 4 octets in some function
|
||
> somewhere for a CIDR block?
|
||
|
||
You keep saying "hostility" as if we are ganging up against you. Believe
|
||
me, I have no animosity towards you and I am sure no one else has either.
|
||
We are resisting the change you want simply because it would violate the
|
||
RFC which we agreed to follow when we created the types.
|
||
|
||
If you think this is hostile, you will probably think that the original
|
||
discussions in the archives are nuclear war :-). If you would like to
|
||
look it over make sure to set aside a lot of time. We spent a long time
|
||
hashing this out.
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M5275@hub.org Mon Jul 24 16:29:30 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id QAA11819
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 16:29:28 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OKT6h02534;
|
||
Mon, 24 Jul 2000 16:29:06 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OKRUh02012
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 16:27:30 -0400 (EDT)
|
||
Received: from lerdesk (ler-desk.iadfw.net [206.66.13.18])
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) with SMTP id e6OKRPc26861;
|
||
Mon, 24 Jul 2000 15:27:25 -0500 (CDT)
|
||
From: "Larry Rosenman" <ler@lerctr.org>
|
||
To: <pgsql-hackers@hub.org>, "Larry Rosenman" <ler@lerctr.org>
|
||
Cc: "Don Baccus" <dhogaza@pacifier.com>
|
||
Subject: RE: [HACKERS] INET/CIDR types
|
||
Date: Mon, 24 Jul 2000 15:27:24 -0500
|
||
Message-ID: <NCBBKBDOOHHEJCJHLLPAAELHHIAA.ler@lerctr.org>
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Content-Transfer-Encoding: 7bit
|
||
X-Priority: 3 (Normal)
|
||
X-MSMail-Priority: Normal
|
||
X-Mailer: Microsoft Outlook IMO, Build 9.0.2416 (9.0.2911.0)
|
||
X-Mimeole: Produced By Microsoft MimeOLE V5.50.4133.2400
|
||
Importance: Normal
|
||
In-Reply-To: <m13GofQ-000AX1C@druid.net>
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
What RFC says you can't print all 4 octets of a CIDR Netnumber?
|
||
|
||
Why does network(cidr) return the whole cidr output just like
|
||
select cidr?
|
||
|
||
I'm just trying to figure out the logic here.
|
||
|
||
Here is what my Cisco Router that speaks BGP says:
|
||
big-bro#term ip netmask-format bit-count
|
||
big-bro#sh ip bg 206.66.0.0/20
|
||
BGP routing table entry for 206.66.0.0/20, version 150832
|
||
Paths: (5 available, best #4)
|
||
Advertised to non peer-group peers:
|
||
157.130.140.109 166.63.135.33 206.66.12.3 206.66.12.4 206.66.12.7
|
||
206.66.12.
|
||
8
|
||
Local, (aggregated by 4278 206.66.12.3), (received & used)
|
||
206.66.12.3 from 206.66.12.3 (206.66.12.3)
|
||
Origin IGP, localpref 0, valid, internal, atomic-aggregate
|
||
Local, (aggregated by 4278 206.66.12.7), (received & used)
|
||
206.66.12.7 from 206.66.12.7 (206.66.12.7)
|
||
Origin IGP, localpref 0, valid, internal, atomic-aggregate
|
||
Local, (aggregated by 4278 206.66.12.8), (received & used)
|
||
206.66.12.8 from 206.66.12.8 (206.66.12.8)
|
||
Origin IGP, localpref 0, valid, internal, atomic-aggregate
|
||
Local, (aggregated by 4278 206.66.12.1)
|
||
0.0.0.0 from 0.0.0.0 (206.66.12.1)
|
||
Origin IGP, localpref 100, weight 32768, valid, aggregated, local,
|
||
atomic-
|
||
aggregate, best
|
||
Local, (received & used)
|
||
206.66.12.4 from 206.66.12.4 (206.66.12.4)
|
||
Origin IGP, metric 0, localpref 100, valid, internal
|
||
big-bro#
|
||
|
||
I am just asking for the same type output.
|
||
|
||
Why is this so hard?
|
||
|
||
The info is in the type, and the print routine wouldn't be so hard.
|
||
|
||
I can probably write the function in less than 1 hour, but getting it
|
||
integrated is
|
||
my stumbling block.
|
||
|
||
|
||
|
||
-----Original Message-----
|
||
From: D'Arcy J.M. Cain [mailto:darcy@druid.net]
|
||
Sent: Monday, July 24, 2000 3:18 PM
|
||
To: Larry Rosenman
|
||
Cc: Don Baccus; pgsql-hackers@hub.org
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
|
||
|
||
Thus spake Larry Rosenman
|
||
> I was hoping to have some niceties out of the SQL retrieve to print
|
||
directly
|
||
> in PHP, and not have to massage it.
|
||
>
|
||
> Why is there such animosity to printing out all 4 octets in some function
|
||
> somewhere for a CIDR block?
|
||
|
||
You keep saying "hostility" as if we are ganging up against you. Believe
|
||
me, I have no animosity towards you and I am sure no one else has either.
|
||
We are resisting the change you want simply because it would violate the
|
||
RFC which we agreed to follow when we created the types.
|
||
|
||
If you think this is hostile, you will probably think that the original
|
||
discussions in the archives are nuclear war :-). If you would like to
|
||
look it over make sure to set aside a lot of time. We spent a long time
|
||
hashing this out.
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
|
||
From pgsql-hackers-owner+M5276@hub.org Mon Jul 24 16:54:14 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id QAA11929
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 16:54:13 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OKruh24719;
|
||
Mon, 24 Jul 2000 16:53:56 -0400 (EDT)
|
||
Received: from druid.net (root@druid.net [216.126.72.98])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OKrPh24294
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 16:53:25 -0400 (EDT)
|
||
Received: from localhost (1495 bytes) by druid.net
|
||
via sendmail with P:stdio/R:bind_hosts/T:inet_zone_bind_smtp
|
||
(sender: <darcy>) (ident <darcy> using unix)
|
||
id <m13GpE4-000AX0C@druid.net>
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 16:53:24 -0400 (EDT)
|
||
(Smail-3.2.0.109 1999-Oct-27 #3 built 2000-Jun-28)
|
||
Message-Id: <m13GpE4-000AX0C@druid.net>
|
||
From: darcy@druid.net (D'Arcy J.M. Cain)
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <NCBBKBDOOHHEJCJHLLPAAELHHIAA.ler@lerctr.org> "from Larry Rosenman
|
||
at Jul 24, 2000 03:27:24 pm"
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
Date: Mon, 24 Jul 2000 16:53:24 -0400 (EDT)
|
||
CC: pgsql-hackers@hub.org, Don Baccus <dhogaza@pacifier.com>
|
||
Reply-To: pgsql-hackers@hub.org
|
||
X-Mailer: ELM [version 2.4ME+ PL78 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Thus spake Larry Rosenman
|
||
> What RFC says you can't print all 4 octets of a CIDR Netnumber?
|
||
|
||
Can't recall. It was Paul Vixie who made the claim and since he was
|
||
probably the one who wrote it I tend to believe him.
|
||
|
||
In fact it may be that it suggested rather than required but someone
|
||
would have to dig out the RFC before we considered changing it I think.
|
||
|
||
> Why does network(cidr) return the whole cidr output just like
|
||
> select cidr?
|
||
|
||
Yah, it's redundant. "network(cidr)" is just a long way to say "cidr."
|
||
The only reason it is there is because of the way the code was written
|
||
for the two types. Not having it would have required a special test to
|
||
look for it and technically it is correct so we didn't bother.
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M5277@hub.org Mon Jul 24 17:12:12 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id RAA12251
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 17:12:11 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OLBth32813;
|
||
Mon, 24 Jul 2000 17:11:55 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OLBah32716
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 17:11:36 -0400 (EDT)
|
||
Received: from lerdesk (ler-desk.iadfw.net [206.66.13.18])
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) with SMTP id e6OLBZc28924;
|
||
Mon, 24 Jul 2000 16:11:35 -0500 (CDT)
|
||
From: "Larry Rosenman" <ler@lerctr.org>
|
||
To: <pgsql-hackers@hub.org>, "Larry Rosenman" <ler@lerctr.org>
|
||
Cc: "Don Baccus" <dhogaza@pacifier.com>
|
||
Subject: RE: [HACKERS] INET/CIDR types
|
||
Date: Mon, 24 Jul 2000 16:11:34 -0500
|
||
Message-ID: <NCBBKBDOOHHEJCJHLLPAIELMHIAA.ler@lerctr.org>
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain;
|
||
charset="iso-8859-1"
|
||
Content-Transfer-Encoding: 7bit
|
||
X-Priority: 3 (Normal)
|
||
X-MSMail-Priority: Normal
|
||
X-Mailer: Microsoft Outlook IMO, Build 9.0.2416 (9.0.2911.0)
|
||
X-Mimeole: Produced By Microsoft MimeOLE V5.50.4133.2400
|
||
Importance: Normal
|
||
In-Reply-To: <m13GpE4-000AX0C@druid.net>
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Can we dig up the RFC?
|
||
|
||
Larry
|
||
|
||
-----Original Message-----
|
||
From: pgsql-hackers-owner@hub.org [mailto:pgsql-hackers-owner@hub.org]On
|
||
Behalf Of D'Arcy J.M. Cain
|
||
Sent: Monday, July 24, 2000 3:53 PM
|
||
To: Larry Rosenman
|
||
Cc: pgsql-hackers@hub.org; Don Baccus
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
|
||
|
||
Thus spake Larry Rosenman
|
||
> What RFC says you can't print all 4 octets of a CIDR Netnumber?
|
||
|
||
Can't recall. It was Paul Vixie who made the claim and since he was
|
||
probably the one who wrote it I tend to believe him.
|
||
|
||
In fact it may be that it suggested rather than required but someone
|
||
would have to dig out the RFC before we considered changing it I think.
|
||
|
||
> Why does network(cidr) return the whole cidr output just like
|
||
> select cidr?
|
||
|
||
Yah, it's redundant. "network(cidr)" is just a long way to say "cidr."
|
||
The only reason it is there is because of the way the code was written
|
||
for the two types. Not having it would have required a special test to
|
||
look for it and technically it is correct so we didn't bother.
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|
||
From pgsql-hackers-owner+M5278@hub.org Mon Jul 24 18:31:03 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id SAA12804
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 18:31:03 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OMUmh59689;
|
||
Mon, 24 Jul 2000 18:30:48 -0400 (EDT)
|
||
Received: from anubis (anubis.ip23.net [212.83.32.60])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OMTxh58656
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 18:29:59 -0400 (EDT)
|
||
Received: from ip23.net (umbriel [212.83.32.61]) by anubis (980427.SGI.8.8.8/980728.SGI.AUTOCF) via ESMTP id AAA96097; Tue, 25 Jul 2000 00:29:42 +0200 (CEST)
|
||
Message-ID: <397CC356.7C78A018@ip23.net>
|
||
Date: Tue, 25 Jul 2000 00:29:42 +0200
|
||
From: Sevo Stille <sevo@ip23.net>
|
||
Reply-To: sevo@ip23.net
|
||
Organization: IP23
|
||
X-Mailer: Mozilla 4.7 [en] (WinNT; U)
|
||
X-Accept-Language: en-GB,en,de,en-US
|
||
MIME-Version: 1.0
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
CC: pgsql-hackers@hub.org
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
References: <NCBBKBDOOHHEJCJHLLPAMELAHIAA.ler@lerctr.org>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Larry Rosenman wrote:
|
||
>
|
||
> The problem is NON-TECHNICAL people will be getting the output,
|
||
> and they expect 4 octet output.
|
||
|
||
Well, but what are they going to do if they see, say, that 196.100.0.0
|
||
is already allocated? Any CIDR net starting off on the .0 will have
|
||
exactly the same 4 octet notation. That is, the above entry would only
|
||
tell that there is some indeterminable number of addresses starting off
|
||
196.100.0.0 allocated, which could be anything between a measly /31 and
|
||
a whopping big /16. To repeat: CIDR having no implicit netmask encoded
|
||
in the class, there is no way of figuring out your allocation if you
|
||
lose the explicit mask. Which presumably will cause considerable
|
||
problems in a network allocation and tracking application!
|
||
|
||
> I really think that we should have a way to coerce a CIDR to
|
||
> an INET, and then allow host().
|
||
|
||
There is no unique mapping of a CIDR network to a INET host address,
|
||
except for the special case of /32.
|
||
|
||
> Remember that I am dealing with $10/hour clerks.
|
||
|
||
Then given them a interface which makes the concept of CIDR obvious to
|
||
them. Faking a classed notation is no way to go! IP v.4 being what it
|
||
is, and registries being on the move to enforce CIDR more and more, they
|
||
will inevitably encounter CIDR sooner or later, probably in a business
|
||
critical way.
|
||
|
||
> I really don't get the hostility to changing the OUTPUT format...
|
||
|
||
Anything broken that is added will sooner or later be used by somebody.
|
||
Which means that it can't be fixed without breaking some applications.
|
||
That alone should be a good enough reason not to introduce any broken
|
||
notions intentionally.
|
||
|
||
Sevo
|
||
|
||
--
|
||
Sevo Stille
|
||
sevo@ip23.net
|
||
|
||
From pgsql-hackers-owner+M5279@hub.org Mon Jul 24 18:31:24 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id SAA12809
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 18:31:23 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OMVBh60018;
|
||
Mon, 24 Jul 2000 18:31:11 -0400 (EDT)
|
||
Received: from paprika.michvhf.com (paprika.michvhf.com [209.103.136.12])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OMUrh59759
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 18:30:53 -0400 (EDT)
|
||
Received: (qmail 39846 invoked by uid 1001); 24 Jul 2000 22:30:59 -0000
|
||
Date: Mon, 24 Jul 2000 18:30:59 -0400 (EDT)
|
||
From: Vince Vielhaber <vev@michvhf.com>
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
cc: pgsql-hackers@hub.org
|
||
Subject: RE: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <NCBBKBDOOHHEJCJHLLPAIELMHIAA.ler@lerctr.org>
|
||
Message-ID: <Pine.BSF.4.21.0007241828230.36999-100000@paprika.michvhf.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
On Mon, 24 Jul 2000, Larry Rosenman wrote:
|
||
|
||
> Can we dig up the RFC?
|
||
|
||
Feel free. You can start your research with RFC1467 and look back at
|
||
what it touches on, then on to 1517, 1518 and 1519 then to 1817 and
|
||
then to 2317. If, after reading these, you don't understand why and/or
|
||
why not you can check with Paul himself at www.vix.com, 'cuze if you
|
||
don't understand then he's your only hope.
|
||
|
||
Vince.
|
||
--
|
||
==========================================================================
|
||
Vince Vielhaber -- KA8CSH email: vev@michvhf.com http://www.pop4.net
|
||
128K ISDN from $22.00/mo - 56K Dialup from $16.00/mo at Pop4 Networking
|
||
Online Campground Directory http://www.camping-usa.com
|
||
Online Giftshop Superstore http://www.cloudninegifts.com
|
||
==========================================================================
|
||
|
||
|
||
|
||
|
||
From pgsql-hackers-owner+M5280@hub.org Mon Jul 24 18:53:56 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id SAA12905
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 18:53:55 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6OMrjh74011;
|
||
Mon, 24 Jul 2000 18:53:45 -0400 (EDT)
|
||
Received: from anubis (anubis.ip23.net [212.83.32.60])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6OMrNh73763
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 18:53:24 -0400 (EDT)
|
||
Received: from ip23.net (umbriel [212.83.32.61]) by anubis (980427.SGI.8.8.8/980728.SGI.AUTOCF) via ESMTP id AAA95973; Tue, 25 Jul 2000 00:52:30 +0200 (CEST)
|
||
Message-ID: <397CC8AE.FC342360@ip23.net>
|
||
Date: Tue, 25 Jul 2000 00:52:30 +0200
|
||
From: Sevo Stille <sevo@ip23.net>
|
||
Reply-To: sevo@ip23.net
|
||
Organization: IP23
|
||
X-Mailer: Mozilla 4.7 [en] (WinNT; U)
|
||
X-Accept-Language: en-GB,en,de,en-US
|
||
MIME-Version: 1.0
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
CC: pgsql-hackers@hub.org, Don Baccus <dhogaza@pacifier.com>
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
References: <NCBBKBDOOHHEJCJHLLPAAELHHIAA.ler@lerctr.org>
|
||
Content-Type: text/plain; charset=us-ascii
|
||
Content-Transfer-Encoding: 7bit
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Larry Rosenman wrote:
|
||
>
|
||
> What RFC says you can't print all 4 octets of a CIDR Netnumber?
|
||
|
||
Implicitly in 1518, for example:
|
||
---------8<----------------------8<----------------------8<------------
|
||
For the purposes of this paper, an IP prefix is an IP address and
|
||
some indication of the leftmost contiguous significant bits within
|
||
this address.
|
||
---------8<----------------------8<----------------------8<------------
|
||
|
||
As I already explained, the use of variable-length masks implies that
|
||
they have to be explicitly stated. This was not neccessary in classed
|
||
networks, as the MSB's encoded the class (mask).
|
||
|
||
> Why does network(cidr) return the whole cidr output just like
|
||
> select cidr?
|
||
|
||
Because a cast to network is a cast to CIDR - casting to the same type
|
||
obviously won't change a thing.
|
||
|
||
> I'm just trying to figure out the logic here.
|
||
|
||
As a matter of fact, it is the side effect of the current
|
||
implementations shortcomings - we have common code for INET and CIDR,
|
||
otherwise, network would not have to be a valid operator for CIDR.
|
||
|
||
> Here is what my Cisco Router that speaks BGP says:
|
||
> big-bro#term ip netmask-format bit-count
|
||
> big-bro#sh ip bg 206.66.0.0/20
|
||
> BGP routing table entry for 206.66.0.0/20, version 150832
|
||
> Paths: (5 available, best #4)
|
||
> Advertised to non peer-group peers:
|
||
> 157.130.140.109 166.63.135.33 206.66.12.3 206.66.12.4 206.66.12.7
|
||
> 206.66.12.
|
||
> ...
|
||
> I am just asking for the same type output.
|
||
|
||
Huh? The only *network* I see in there IS in /bits notation.
|
||
|
||
Sevo
|
||
|
||
--
|
||
Sevo Stille
|
||
sevo@ip23.net
|
||
|
||
From pgsql-hackers-owner+M5282@hub.org Mon Jul 24 19:05:38 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id TAA13152
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 19:05:37 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6ON5Mh82281;
|
||
Mon, 24 Jul 2000 19:05:22 -0400 (EDT)
|
||
Received: from smtp.pacifier.com (comet.pacifier.com [199.2.117.155])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6ON4qh81966
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 19:04:52 -0400 (EDT)
|
||
Received: from desktop (dsl-dhogaza.pacifier.net [207.202.226.68])
|
||
by smtp.pacifier.com (8.9.3/8.9.3pop) with SMTP id QAA16750;
|
||
Mon, 24 Jul 2000 16:04:27 -0700 (PDT)
|
||
Message-Id: <3.0.1.32.20000724160016.01192100@mail.pacifier.com>
|
||
X-Sender: dhogaza@mail.pacifier.com
|
||
X-Mailer: Windows Eudora Pro Version 3.0.1 (32)
|
||
Date: Mon, 24 Jul 2000 16:00:16 -0700
|
||
To: Vince Vielhaber <vev@michvhf.com>, Larry Rosenman <ler@lerctr.org>
|
||
From: Don Baccus <dhogaza@pacifier.com>
|
||
Subject: RE: [HACKERS] INET/CIDR types
|
||
Cc: pgsql-hackers@hub.org
|
||
In-Reply-To: <Pine.BSF.4.21.0007241828230.36999-100000@paprika.michvhf.c
|
||
om>
|
||
References: <NCBBKBDOOHHEJCJHLLPAIELMHIAA.ler@lerctr.org>
|
||
Mime-Version: 1.0
|
||
Content-Type: text/plain; charset="us-ascii"
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
At 06:30 PM 7/24/00 -0400, Vince Vielhaber wrote:
|
||
>On Mon, 24 Jul 2000, Larry Rosenman wrote:
|
||
>
|
||
>> Can we dig up the RFC?
|
||
>
|
||
>Feel free. You can start your research with RFC1467 and look back at
|
||
>what it touches on, then on to 1517, 1518 and 1519 then to 1817 and
|
||
>then to 2317. If, after reading these, you don't understand why and/or
|
||
>why not you can check with Paul himself at www.vix.com, 'cuze if you
|
||
>don't understand then he's your only hope.
|
||
|
||
I bet just hacking your PHP script to format it in the way you want
|
||
would involve a heck of a lot less effort ...
|
||
|
||
|
||
|
||
- Don Baccus, Portland OR <dhogaza@pacifier.com>
|
||
Nature photos, on-line guides, Pacific Northwest
|
||
Rare Bird Alert Service and other goodies at
|
||
http://donb.photo.net.
|
||
|
||
From pgsql-hackers-owner+M5281@hub.org Mon Jul 24 19:01:25 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id TAA12969
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 19:01:25 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6ON1Dh79863;
|
||
Mon, 24 Jul 2000 19:01:13 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6ON0rh79630
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 19:00:53 -0400 (EDT)
|
||
Received: (from ler@localhost)
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) id e6ON0lO03554;
|
||
Mon, 24 Jul 2000 18:00:47 -0500 (CDT)
|
||
From: Larry Rosenman <ler@lerctr.org>
|
||
Message-Id: <200007242300.e6ON0lO03554@lerami.lerctr.org>
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <397CC8AE.FC342360@ip23.net> "from Sevo Stille at Jul 25, 2000 00:52:30
|
||
am"
|
||
To: sevo@ip23.net
|
||
Date: Mon, 24 Jul 2000 18:00:46 -0500 (CDT)
|
||
CC: Larry Rosenman <ler@lerctr.org>, pgsql-hackers@hub.org,
|
||
Don Baccus <dhogaza@pacifier.com>
|
||
X-Mailer: ELM [version 2.4ME+ PL79 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
> Larry Rosenman wrote:
|
||
> >
|
||
> > What RFC says you can't print all 4 octets of a CIDR Netnumber?
|
||
>
|
||
> Implicitly in 1518, for example:
|
||
> ---------8<----------------------8<----------------------8<------------
|
||
> For the purposes of this paper, an IP prefix is an IP address and
|
||
> some indication of the leftmost contiguous significant bits within
|
||
> this address.
|
||
> ---------8<----------------------8<----------------------8<------------
|
||
This doesn't prohibit listing all 4 octets, which is my argument...
|
||
>
|
||
> As I already explained, the use of variable-length masks implies that
|
||
> they have to be explicitly stated. This was not neccessary in classed
|
||
> networks, as the MSB's encoded the class (mask).
|
||
I know this...
|
||
>
|
||
> > Why does network(cidr) return the whole cidr output just like
|
||
> > select cidr?
|
||
>
|
||
> Because a cast to network is a cast to CIDR - casting to the same type
|
||
> obviously won't change a thing.
|
||
>
|
||
> > I'm just trying to figure out the logic here.
|
||
>
|
||
> As a matter of fact, it is the side effect of the current
|
||
> implementations shortcomings - we have common code for INET and CIDR,
|
||
> otherwise, network would not have to be a valid operator for CIDR.
|
||
|
||
I just want something equivalent to host(inet) that
|
||
prints all 4 octets of a CIDR type with no mask.
|
||
|
||
Is that hard?
|
||
>
|
||
> > Here is what my Cisco Router that speaks BGP says:
|
||
> > big-bro#term ip netmask-format bit-count
|
||
> > big-bro#sh ip bg 206.66.0.0/20
|
||
> > BGP routing table entry for 206.66.0.0/20, version 150832
|
||
> > Paths: (5 available, best #4)
|
||
> > Advertised to non peer-group peers:
|
||
> > 157.130.140.109 166.63.135.33 206.66.12.3 206.66.12.4 206.66.12.7
|
||
> > 206.66.12.
|
||
> > ...
|
||
> > I am just asking for the same type output.
|
||
>
|
||
> Huh? The only *network* I see in there IS in /bits notation.
|
||
Yes, but with all 4 octets, which is all I'm looking for....
|
||
|
||
|
||
>
|
||
> Sevo
|
||
>
|
||
> --
|
||
> Sevo Stille
|
||
> sevo@ip23.net
|
||
|
||
|
||
--
|
||
Larry Rosenman http://www.lerctr.org/~ler
|
||
Phone: +1 972-414-9812 (voice) Internet: ler@lerctr.org
|
||
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749
|
||
|
||
From pgsql-hackers-owner+M5285@hub.org Mon Jul 24 22:17:47 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id WAA22852
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 22:17:46 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6P2CVh51074;
|
||
Mon, 24 Jul 2000 22:12:31 -0400 (EDT)
|
||
Received: from spider.pilosoft.com (p55-222.acedsl.com [160.79.55.222])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6P2Boh50884
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 22:11:50 -0400 (EDT)
|
||
Received: from localhost (alexmail@localhost)
|
||
by spider.pilosoft.com (8.9.3/8.9.3) with ESMTP id WAA03783;
|
||
Mon, 24 Jul 2000 22:13:58 -0400 (EDT)
|
||
Date: Mon, 24 Jul 2000 22:13:57 -0400 (EDT)
|
||
From: Alex Pilosov <alex@pilosoft.com>
|
||
To: Sevo Stille <sevo@ip23.net>
|
||
cc: Larry Rosenman <ler@lerctr.org>, pgsql-hackers@hub.org
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <397CC356.7C78A018@ip23.net>
|
||
Message-ID: <Pine.BSO.4.10.10007242208480.4362-100000@spider.pilosoft.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
This whole discussion is quite silly guys.
|
||
|
||
It is quite reasonable to have ability to split CIDR net into two pieces:
|
||
the network and the bitshift. Second one is already possible, the first
|
||
one can be accomplished by having functions to convert a cidr/inet to int8
|
||
(not int4 because of sign thing), and back.
|
||
|
||
Its also very easy to implement ;)
|
||
|
||
This will actually come very useful for many applications. Something I'm
|
||
working on now (allocation of 'most appropriate' block) requires ability
|
||
to split a netblock into two, which could be most easily accomplished
|
||
using int8 math. (net::int8+2^(netmask(net)-1)).
|
||
|
||
Now, patch anyone? :)
|
||
-alex
|
||
On Tue, 25 Jul 2000, Sevo Stille wrote:
|
||
|
||
> Larry Rosenman wrote:
|
||
> >
|
||
> > The problem is NON-TECHNICAL people will be getting the output,
|
||
> > and they expect 4 octet output.
|
||
>
|
||
> Well, but what are they going to do if they see, say, that 196.100.0.0
|
||
> is already allocated? Any CIDR net starting off on the .0 will have
|
||
> exactly the same 4 octet notation. That is, the above entry would only
|
||
> tell that there is some indeterminable number of addresses starting off
|
||
> 196.100.0.0 allocated, which could be anything between a measly /31 and
|
||
> a whopping big /16. To repeat: CIDR having no implicit netmask encoded
|
||
> in the class, there is no way of figuring out your allocation if you
|
||
> lose the explicit mask. Which presumably will cause considerable
|
||
> problems in a network allocation and tracking application!
|
||
>
|
||
> > I really think that we should have a way to coerce a CIDR to
|
||
> > an INET, and then allow host().
|
||
>
|
||
> There is no unique mapping of a CIDR network to a INET host address,
|
||
> except for the special case of /32.
|
||
>
|
||
> > Remember that I am dealing with $10/hour clerks.
|
||
>
|
||
> Then given them a interface which makes the concept of CIDR obvious to
|
||
> them. Faking a classed notation is no way to go! IP v.4 being what it
|
||
> is, and registries being on the move to enforce CIDR more and more, they
|
||
> will inevitably encounter CIDR sooner or later, probably in a business
|
||
> critical way.
|
||
>
|
||
> > I really don't get the hostility to changing the OUTPUT format...
|
||
>
|
||
> Anything broken that is added will sooner or later be used by somebody.
|
||
> Which means that it can't be fixed without breaking some applications.
|
||
> That alone should be a good enough reason not to introduce any broken
|
||
> notions intentionally.
|
||
>
|
||
> Sevo
|
||
>
|
||
>
|
||
|
||
|
||
From pgsql-hackers-owner+M5287@hub.org Mon Jul 24 22:48:05 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id WAA23082
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 22:48:04 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6P2hrh58014;
|
||
Mon, 24 Jul 2000 22:43:53 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6P2hbh57922
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 22:43:37 -0400 (EDT)
|
||
Received: (from ler@localhost)
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) id e6P2eVl12604;
|
||
Mon, 24 Jul 2000 21:40:31 -0500 (CDT)
|
||
From: Larry Rosenman <ler@lerctr.org>
|
||
Message-Id: <200007250240.e6P2eVl12604@lerami.lerctr.org>
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <Pine.BSO.4.10.10007242208480.4362-100000@spider.pilosoft.com>
|
||
"from Alex Pilosov at Jul 24, 2000 10:13:57 pm"
|
||
To: Alex Pilosov <alex@pilosoft.com>
|
||
Date: Mon, 24 Jul 2000 21:40:31 -0500 (CDT)
|
||
CC: Sevo Stille <sevo@ip23.net>, Larry Rosenman <ler@lerctr.org>,
|
||
pgsql-hackers@hub.org
|
||
X-Mailer: ELM [version 2.4ME+ PL79 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
> This whole discussion is quite silly guys.
|
||
>
|
||
> It is quite reasonable to have ability to split CIDR net into two pieces:
|
||
> the network and the bitshift. Second one is already possible, the first
|
||
> one can be accomplished by having functions to convert a cidr/inet to int8
|
||
> (not int4 because of sign thing), and back.
|
||
>
|
||
> Its also very easy to implement ;)
|
||
>
|
||
> This will actually come very useful for many applications. Something I'm
|
||
> working on now (allocation of 'most appropriate' block) requires ability
|
||
> to split a netblock into two, which could be most easily accomplished
|
||
> using int8 math. (net::int8+2^(netmask(net)-1)).
|
||
All I'm looking for is to be able to print all 4 octets of an IP address
|
||
out so that joe user can take the 4 numbers and type it into the
|
||
4 boxes on a Windows 98 box, and use them.
|
||
|
||
Is that really that abhorrent?
|
||
|
||
They also need the 4 octet netmask which I can get now.
|
||
|
||
All we are missing is a way to print ALL 4 NUMBERS ALL THE TIME
|
||
for the output. It's not asking for classful, and for sure
|
||
we use CIDR all over the place, but for the final output that my
|
||
users see, why can't I have the database just print all 4 octets?
|
||
|
||
Why is this discussion so hard?
|
||
|
||
Larry
|
||
>
|
||
> Now, patch anyone? :)
|
||
> -alex
|
||
> On Tue, 25 Jul 2000, Sevo Stille wrote:
|
||
>
|
||
> > Larry Rosenman wrote:
|
||
> > >
|
||
> > > The problem is NON-TECHNICAL people will be getting the output,
|
||
> > > and they expect 4 octet output.
|
||
> >
|
||
> > Well, but what are they going to do if they see, say, that 196.100.0.0
|
||
> > is already allocated? Any CIDR net starting off on the .0 will have
|
||
> > exactly the same 4 octet notation. That is, the above entry would only
|
||
> > tell that there is some indeterminable number of addresses starting off
|
||
> > 196.100.0.0 allocated, which could be anything between a measly /31 and
|
||
> > a whopping big /16. To repeat: CIDR having no implicit netmask encoded
|
||
> > in the class, there is no way of figuring out your allocation if you
|
||
> > lose the explicit mask. Which presumably will cause considerable
|
||
> > problems in a network allocation and tracking application!
|
||
> >
|
||
> > > I really think that we should have a way to coerce a CIDR to
|
||
> > > an INET, and then allow host().
|
||
> >
|
||
> > There is no unique mapping of a CIDR network to a INET host address,
|
||
> > except for the special case of /32.
|
||
> >
|
||
> > > Remember that I am dealing with $10/hour clerks.
|
||
> >
|
||
> > Then given them a interface which makes the concept of CIDR obvious to
|
||
> > them. Faking a classed notation is no way to go! IP v.4 being what it
|
||
> > is, and registries being on the move to enforce CIDR more and more, they
|
||
> > will inevitably encounter CIDR sooner or later, probably in a business
|
||
> > critical way.
|
||
> >
|
||
> > > I really don't get the hostility to changing the OUTPUT format...
|
||
> >
|
||
> > Anything broken that is added will sooner or later be used by somebody.
|
||
> > Which means that it can't be fixed without breaking some applications.
|
||
> > That alone should be a good enough reason not to introduce any broken
|
||
> > notions intentionally.
|
||
> >
|
||
> > Sevo
|
||
> >
|
||
> >
|
||
>
|
||
|
||
|
||
--
|
||
Larry Rosenman http://www.lerctr.org/~ler
|
||
Phone: +1 972-414-9812 (voice) Internet: ler@lerctr.org
|
||
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749
|
||
|
||
From pgsql-hackers-owner+M5288@hub.org Mon Jul 24 22:51:31 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id WAA23098
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 22:51:30 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6P2omh59374;
|
||
Mon, 24 Jul 2000 22:50:48 -0400 (EDT)
|
||
Received: from spider.pilosoft.com (p55-222.acedsl.com [160.79.55.222])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6P2oah59301
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 22:50:36 -0400 (EDT)
|
||
Received: from localhost (alexmail@localhost)
|
||
by spider.pilosoft.com (8.9.3/8.9.3) with ESMTP id WAA03944;
|
||
Mon, 24 Jul 2000 22:53:20 -0400 (EDT)
|
||
Date: Mon, 24 Jul 2000 22:53:20 -0400 (EDT)
|
||
From: Alex Pilosov <alex@pilosoft.com>
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
cc: Sevo Stille <sevo@ip23.net>, pgsql-hackers@hub.org
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <200007250240.e6P2eVl12604@lerami.lerctr.org>
|
||
Message-ID: <Pine.BSO.4.10.10007242252290.4362-100000@spider.pilosoft.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
On Mon, 24 Jul 2000, Larry Rosenman wrote:
|
||
|
||
> > This whole discussion is quite silly guys.
|
||
> >
|
||
> > It is quite reasonable to have ability to split CIDR net into two pieces:
|
||
> > the network and the bitshift. Second one is already possible, the first
|
||
> > one can be accomplished by having functions to convert a cidr/inet to int8
|
||
> > (not int4 because of sign thing), and back.
|
||
> >
|
||
> > Its also very easy to implement ;)
|
||
> >
|
||
> > This will actually come very useful for many applications. Something I'm
|
||
> > working on now (allocation of 'most appropriate' block) requires ability
|
||
> > to split a netblock into two, which could be most easily accomplished
|
||
> > using int8 math. (net::int8+2^(netmask(net)-1)).
|
||
> All I'm looking for is to be able to print all 4 octets of an IP address
|
||
> out so that joe user can take the 4 numbers and type it into the
|
||
> 4 boxes on a Windows 98 box, and use them.
|
||
>
|
||
> Is that really that abhorrent?
|
||
>
|
||
> They also need the 4 octet netmask which I can get now.
|
||
>
|
||
> All we are missing is a way to print ALL 4 NUMBERS ALL THE TIME
|
||
> for the output. It's not asking for classful, and for sure
|
||
> we use CIDR all over the place, but for the final output that my
|
||
> users see, why can't I have the database just print all 4 octets?
|
||
|
||
Larry,
|
||
With my suggestion, you can do it as follows:
|
||
|
||
net::int8::inet
|
||
|
||
(net being of cidr type)
|
||
-alex
|
||
|
||
|
||
From pgsql-hackers-owner+M5290@hub.org Mon Jul 24 23:10:44 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id XAA23371
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 23:10:44 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6P3ATh64149;
|
||
Mon, 24 Jul 2000 23:10:29 -0400 (EDT)
|
||
Received: from lerami.lerctr.org (lerami.lerctr.org [207.158.72.11])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6P3AAh64000
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 23:10:10 -0400 (EDT)
|
||
Received: (from ler@localhost)
|
||
by lerami.lerctr.org (8.10.1/8.10.1/20000715) id e6P3A1v13825;
|
||
Mon, 24 Jul 2000 22:10:01 -0500 (CDT)
|
||
From: Larry Rosenman <ler@lerctr.org>
|
||
Message-Id: <200007250310.e6P3A1v13825@lerami.lerctr.org>
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <Pine.BSO.4.10.10007242252290.4362-100000@spider.pilosoft.com>
|
||
"from Alex Pilosov at Jul 24, 2000 10:53:20 pm"
|
||
To: Alex Pilosov <alex@pilosoft.com>
|
||
Date: Mon, 24 Jul 2000 22:10:01 -0500 (CDT)
|
||
CC: Larry Rosenman <ler@lerctr.org>, Sevo Stille <sevo@ip23.net>,
|
||
pgsql-hackers@hub.org
|
||
X-Mailer: ELM [version 2.4ME+ PL79 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
The bad news is it doesn't work now...
|
||
|
||
|
||
ler=# select host(netblock::int8::inet) from networks;
|
||
ERROR: Cannot cast type 'cidr' to 'int8'
|
||
ler=# \d networks
|
||
Table "networks"
|
||
Attribute | Type | Modifier
|
||
---------------+--------------+----------
|
||
netblock | cidr |
|
||
router | integer |
|
||
interface | varchar(64) |
|
||
dest_ip | inet |
|
||
net_name | varchar(64) |
|
||
owner | integer |
|
||
origin | varchar(256) |
|
||
assigned_date | date |
|
||
assigned_by | varchar(64) |
|
||
asn | smallint |
|
||
|
||
ler=#
|
||
|
||
> On Mon, 24 Jul 2000, Larry Rosenman wrote:
|
||
>
|
||
> > > This whole discussion is quite silly guys.
|
||
> > >
|
||
> > > It is quite reasonable to have ability to split CIDR net into two pieces:
|
||
> > > the network and the bitshift. Second one is already possible, the first
|
||
> > > one can be accomplished by having functions to convert a cidr/inet to int8
|
||
> > > (not int4 because of sign thing), and back.
|
||
> > >
|
||
> > > Its also very easy to implement ;)
|
||
> > >
|
||
> > > This will actually come very useful for many applications. Something I'm
|
||
> > > working on now (allocation of 'most appropriate' block) requires ability
|
||
> > > to split a netblock into two, which could be most easily accomplished
|
||
> > > using int8 math. (net::int8+2^(netmask(net)-1)).
|
||
> > All I'm looking for is to be able to print all 4 octets of an IP address
|
||
> > out so that joe user can take the 4 numbers and type it into the
|
||
> > 4 boxes on a Windows 98 box, and use them.
|
||
> >
|
||
> > Is that really that abhorrent?
|
||
> >
|
||
> > They also need the 4 octet netmask which I can get now.
|
||
> >
|
||
> > All we are missing is a way to print ALL 4 NUMBERS ALL THE TIME
|
||
> > for the output. It's not asking for classful, and for sure
|
||
> > we use CIDR all over the place, but for the final output that my
|
||
> > users see, why can't I have the database just print all 4 octets?
|
||
>
|
||
> Larry,
|
||
> With my suggestion, you can do it as follows:
|
||
>
|
||
> net::int8::inet
|
||
>
|
||
> (net being of cidr type)
|
||
> -alex
|
||
>
|
||
|
||
|
||
--
|
||
Larry Rosenman http://www.lerctr.org/~ler
|
||
Phone: +1 972-414-9812 (voice) Internet: ler@lerctr.org
|
||
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749
|
||
|
||
From pgsql-hackers-owner+M5291@hub.org Mon Jul 24 23:24:11 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id XAA23433
|
||
for <pgman@candle.pha.pa.us>; Mon, 24 Jul 2000 23:24:10 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6P3Nfh69885;
|
||
Mon, 24 Jul 2000 23:23:41 -0400 (EDT)
|
||
Received: from spider.pilosoft.com (p55-222.acedsl.com [160.79.55.222])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6P3Mvh69635
|
||
for <pgsql-hackers@hub.org>; Mon, 24 Jul 2000 23:22:57 -0400 (EDT)
|
||
Received: from localhost (alexmail@localhost)
|
||
by spider.pilosoft.com (8.9.3/8.9.3) with ESMTP id XAA27580;
|
||
Mon, 24 Jul 2000 23:25:41 -0400 (EDT)
|
||
Date: Mon, 24 Jul 2000 23:25:41 -0400 (EDT)
|
||
From: Alex Pilosov <alex@pilosoft.com>
|
||
To: Larry Rosenman <ler@lerctr.org>
|
||
cc: Sevo Stille <sevo@ip23.net>, pgsql-hackers@hub.org
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <200007250310.e6P3A1v13825@lerami.lerctr.org>
|
||
Message-ID: <Pine.BSO.4.10.10007242314200.4362-100000@spider.pilosoft.com>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Yes, I know.
|
||
I didn't say it existed, I proposed to create a simple conversion function
|
||
that would do that, which is why I asked for a patch.
|
||
|
||
I'd do it myself but it'll take some time. Should be really simple,
|
||
something to the effect of return a.s_addr (where a is struct in_addr),
|
||
however, I'm not sure what's POSIXly correct way to do that.
|
||
|
||
|
||
|
||
On Mon, 24 Jul 2000, Larry Rosenman wrote:
|
||
|
||
> The bad news is it doesn't work now...
|
||
>
|
||
>
|
||
> ler=# select host(netblock::int8::inet) from networks;
|
||
> ERROR: Cannot cast type 'cidr' to 'int8'
|
||
> ler=# \d networks
|
||
> Table "networks"
|
||
> Attribute | Type | Modifier
|
||
> ---------------+--------------+----------
|
||
> netblock | cidr |
|
||
> router | integer |
|
||
> interface | varchar(64) |
|
||
> dest_ip | inet |
|
||
> net_name | varchar(64) |
|
||
> owner | integer |
|
||
> origin | varchar(256) |
|
||
> assigned_date | date |
|
||
> assigned_by | varchar(64) |
|
||
> asn | smallint |
|
||
>
|
||
> ler=#
|
||
>
|
||
> > On Mon, 24 Jul 2000, Larry Rosenman wrote:
|
||
> >
|
||
> > > > This whole discussion is quite silly guys.
|
||
> > > >
|
||
> > > > It is quite reasonable to have ability to split CIDR net into two pieces:
|
||
> > > > the network and the bitshift. Second one is already possible, the first
|
||
> > > > one can be accomplished by having functions to convert a cidr/inet to int8
|
||
> > > > (not int4 because of sign thing), and back.
|
||
> > > >
|
||
> > > > Its also very easy to implement ;)
|
||
> > > >
|
||
> > > > This will actually come very useful for many applications. Something I'm
|
||
> > > > working on now (allocation of 'most appropriate' block) requires ability
|
||
> > > > to split a netblock into two, which could be most easily accomplished
|
||
> > > > using int8 math. (net::int8+2^(netmask(net)-1)).
|
||
> > > All I'm looking for is to be able to print all 4 octets of an IP address
|
||
> > > out so that joe user can take the 4 numbers and type it into the
|
||
> > > 4 boxes on a Windows 98 box, and use them.
|
||
> > >
|
||
> > > Is that really that abhorrent?
|
||
> > >
|
||
> > > They also need the 4 octet netmask which I can get now.
|
||
> > >
|
||
> > > All we are missing is a way to print ALL 4 NUMBERS ALL THE TIME
|
||
> > > for the output. It's not asking for classful, and for sure
|
||
> > > we use CIDR all over the place, but for the final output that my
|
||
> > > users see, why can't I have the database just print all 4 octets?
|
||
> >
|
||
> > Larry,
|
||
> > With my suggestion, you can do it as follows:
|
||
> >
|
||
> > net::int8::inet
|
||
> >
|
||
> > (net being of cidr type)
|
||
> > -alex
|
||
> >
|
||
>
|
||
>
|
||
>
|
||
|
||
|
||
From pgsql-hackers-owner+M5292@hub.org Tue Jul 25 01:27:56 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id BAA25020
|
||
for <pgman@candle.pha.pa.us>; Tue, 25 Jul 2000 01:27:56 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6P5RWh12976;
|
||
Tue, 25 Jul 2000 01:27:32 -0400 (EDT)
|
||
Received: from smtp.pacifier.com (comet.pacifier.com [199.2.117.155])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6P5PHh12429
|
||
for <pgsql-hackers@hub.org>; Tue, 25 Jul 2000 01:25:17 -0400 (EDT)
|
||
Received: from desktop (dsl-dhogaza.pacifier.net [207.202.226.68])
|
||
by smtp.pacifier.com (8.9.3/8.9.3pop) with SMTP id WAA04370;
|
||
Mon, 24 Jul 2000 22:25:00 -0700 (PDT)
|
||
Message-Id: <3.0.1.32.20000724221204.01198400@mail.pacifier.com>
|
||
X-Sender: dhogaza@mail.pacifier.com
|
||
X-Mailer: Windows Eudora Pro Version 3.0.1 (32)
|
||
Date: Mon, 24 Jul 2000 22:12:04 -0700
|
||
To: Larry Rosenman <ler@lerctr.org>, Alex Pilosov <alex@pilosoft.com>
|
||
From: Don Baccus <dhogaza@pacifier.com>
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
Cc: Sevo Stille <sevo@ip23.net>, Larry Rosenman <ler@lerctr.org>,
|
||
pgsql-hackers@hub.org
|
||
In-Reply-To: <200007250240.e6P2eVl12604@lerami.lerctr.org>
|
||
References: <Pine.BSO.4.10.10007242208480.4362-100000@spider.pilosoft.com>
|
||
Mime-Version: 1.0
|
||
Content-Type: text/plain; charset="us-ascii"
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
At 09:40 PM 7/24/00 -0500, Larry Rosenman wrote:
|
||
|
||
>Why is this discussion so hard?
|
||
|
||
Because it's an output format you could easily solve yourself. Could've
|
||
solved yourself long ago.
|
||
|
||
If you care so much, change the sources and run your own custom version.
|
||
The beauty of open source, you get to break it in whatever manner you
|
||
choose.
|
||
|
||
Or hack your PHP script.
|
||
|
||
If you need help hacking your script you can probably get help, here. I'm
|
||
sure people are tired enough of this thread to write it for you, if that's
|
||
necessary.
|
||
|
||
Next I suppose you'll ask that Unix "ls" output switch "/" to
|
||
"\" so your $10 clerks can understand the output?
|
||
|
||
|
||
|
||
- Don Baccus, Portland OR <dhogaza@pacifier.com>
|
||
Nature photos, on-line guides, Pacific Northwest
|
||
Rare Bird Alert Service and other goodies at
|
||
http://donb.photo.net.
|
||
|
||
From pgsql-hackers-owner+M5321@hub.org Tue Jul 25 16:45:35 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id QAA19032
|
||
for <pgman@candle.pha.pa.us>; Tue, 25 Jul 2000 16:45:34 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6PKieh98955;
|
||
Tue, 25 Jul 2000 16:44:40 -0400 (EDT)
|
||
Received: from merganser.its.uu.se (merganser.its.uu.se [130.238.6.236])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6PKenh96652
|
||
for <pgsql-hackers@hub.org>; Tue, 25 Jul 2000 16:40:49 -0400 (EDT)
|
||
Received: from regulus.student.UU.SE ([130.238.5.2]:40690 "EHLO
|
||
regulus.its.uu.se") by merganser.its.uu.se with ESMTP
|
||
id <S291004AbQGYUkH>; Tue, 25 Jul 2000 22:40:07 +0200
|
||
Received: from peter (helo=localhost)
|
||
by regulus.its.uu.se with local-esmtp (Exim 3.02 #2)
|
||
id 13HBVx-0001cn-00; Tue, 25 Jul 2000 22:41:21 +0200
|
||
Date: Tue, 25 Jul 2000 22:41:21 +0200 (CEST)
|
||
From: Peter Eisentraut <peter_e@gmx.net>
|
||
To: pgsql-hackers@hub.org
|
||
cc: Larry Rosenman <ler@lerctr.org>
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <m13Gngs-000AXeC@druid.net>
|
||
Message-ID: <Pine.LNX.4.21.0007251905480.546-100000@localhost.localdomain>
|
||
MIME-Version: 1.0
|
||
Content-Type: TEXT/PLAIN; charset=ISO-8859-1
|
||
Content-Transfer-Encoding: 8BIT
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
D'Arcy J.M. Cain writes:
|
||
|
||
> Hmmm. I just noticed this.
|
||
>
|
||
> darcy=> select '1.2.0.1/23'::cidr;
|
||
> ?column?
|
||
> --------
|
||
> 1.2.0/23
|
||
> (1 row)
|
||
>
|
||
> Shouldn't that throw an error?
|
||
|
||
Isn't that what I've been saying all along?
|
||
|
||
|
||
--
|
||
Peter Eisentraut Sernanders v<>g 10:115
|
||
peter_e@gmx.net 75262 Uppsala
|
||
http://yi.org/peter-e/ Sweden
|
||
|
||
|
||
From pgsql-hackers-owner+M5370@hub.org Thu Jul 27 06:17:36 2000
|
||
Received: from hub.org (root@hub.org [216.126.84.1])
|
||
by candle.pha.pa.us (8.9.0/8.9.0) with ESMTP id GAA24699
|
||
for <pgman@candle.pha.pa.us>; Thu, 27 Jul 2000 06:17:35 -0400 (EDT)
|
||
Received: from hub.org (majordom@localhost [127.0.0.1])
|
||
by hub.org (8.10.1/8.10.1) with SMTP id e6RAHRA44622;
|
||
Thu, 27 Jul 2000 06:17:27 -0400 (EDT)
|
||
Received: from druid.net (root@druid.net [216.126.72.98])
|
||
by hub.org (8.10.1/8.10.1) with ESMTP id e6RAH2A44416
|
||
for <pgsql-hackers@hub.org>; Thu, 27 Jul 2000 06:17:02 -0400 (EDT)
|
||
Received: from localhost (1387 bytes) by druid.net
|
||
via sendmail with P:stdio/R:bind_hosts/T:inet_zone_bind_smtp
|
||
(sender: <darcy>) (ident <darcy> using unix)
|
||
id <m13Hkik-000AX9C@druid.net>
|
||
for <pgsql-hackers@hub.org>; Thu, 27 Jul 2000 06:16:54 -0400 (EDT)
|
||
(Smail-3.2.0.109 1999-Oct-27 #3 built 2000-Jun-28)
|
||
Message-Id: <m13Hkik-000AX9C@druid.net>
|
||
From: darcy@druid.net (D'Arcy J.M. Cain)
|
||
Subject: Re: [HACKERS] INET/CIDR types
|
||
In-Reply-To: <Pine.LNX.4.21.0007251905480.546-100000@localhost.localdomain>
|
||
"from Peter Eisentraut at Jul 25, 2000 10:41:21 pm"
|
||
To: Peter Eisentraut <peter_e@gmx.net>
|
||
Date: Thu, 27 Jul 2000 06:16:54 -0400 (EDT)
|
||
CC: pgsql-hackers@hub.org, Larry Rosenman <ler@lerctr.org>
|
||
Reply-To: pgsql-hackers@hub.org
|
||
X-Mailer: ELM [version 2.4ME+ PL78 (25)]
|
||
MIME-Version: 1.0
|
||
Content-Transfer-Encoding: 7bit
|
||
Content-Type: text/plain; charset=US-ASCII
|
||
X-Mailing-List: pgsql-hackers@postgresql.org
|
||
Precedence: bulk
|
||
Sender: pgsql-hackers-owner@hub.org
|
||
Status: OR
|
||
|
||
Thus spake Peter Eisentraut
|
||
> > Hmmm. I just noticed this.
|
||
> >
|
||
> > darcy=> select '1.2.0.1/23'::cidr;
|
||
> > ?column?
|
||
> > --------
|
||
> > 1.2.0/23
|
||
> > (1 row)
|
||
> >
|
||
> > Shouldn't that throw an error?
|
||
>
|
||
> Isn't that what I've been saying all along?
|
||
|
||
Well, yes but I thought that it was now and that you were arguing to keep
|
||
that behaviour. This seems to be the behaviour that I was suggesting
|
||
although you have half convinced me that this should throw an error.
|
||
|
||
So, it looks like the status quo is for inet::cidr to be a different
|
||
spelling for network(inet). Is this the way we want to keep it?
|
||
|
||
--
|
||
D'Arcy J.M. Cain <darcy@{druid|vex}.net> | Democracy is three wolves
|
||
http://www.druid.net/darcy/ | and a sheep voting on
|
||
+1 416 425 1212 (DoD#0082) (eNTP) | what's for dinner.
|
||
|