Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
Size: Mime:
ó
®‹EYc@sždZddlmZmZddlmZmZmZmZddl	m
Z
d„Zd„Zd„Z
d„Zd	„Zd
„Zdefd„ƒYZd
S(sb
Routines and classes for supporting and expressing IP address ranges using a
glob style syntax.

iÿÿÿÿ(tAddrFormatErrortAddrConversionError(tIPRanget	IPAddresst	IPNetworktiprange_to_cidrs(t_is_strcCsŠt|ƒstSt}t}|jdƒ}t|ƒdkrAtSxB|D]:}d|kr|rdtSt}|rttSy2g|jdƒD]}t|ƒ^q‡\}}Wntk
rºtSX||krËtSd|koâdknsëtSd|kodkns‚tSqH|dkr#t}qH|tkr3tS|tkrCtSy*dt|ƒkocdknsltSWqHtk
rtSXqHWtS(	s‹
    :param ipglob: An IP address range in a glob-style format.

    :return: ``True`` if IP range glob is valid, ``False`` otherwise.
    t.it-iiþiiÿt*(RtFalsetsplittlentTruetintt
ValueError(tipglobtseen_hyphent
seen_asterisktoctetstoctettitoctet1toctet2((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyt
valid_globsH

2
	"
	cCsðt|ƒstd|ƒ‚ng}g}xš|jdƒD]‰}d|kr|jdƒ}|j|dƒ|j|dƒq;|dkrª|jdƒ|jdƒq;|j|ƒ|j|ƒq;Wtdj|ƒƒtdj|ƒƒfS(	s÷
    A function that accepts a glob-style IP range and returns the component
    lower and upper bound IP address.

    :param ipglob: an IP address range in a glob-style format.

    :return: a tuple contain lower and upper bound IP objects.
    s#not a recognised IP glob range: %r!RRiiR	t0t255(RRRtappendRtjoin(Rtstart_tokenst
end_tokensRttokens((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pytglob_to_iptupleFs	

cCsçt|ƒstd|ƒ‚ng}g}xš|jdƒD]‰}d|kr|jdƒ}|j|dƒ|j|dƒq;|dkrª|jdƒ|jdƒq;|j|ƒ|j|ƒq;Wtdj|ƒdj|ƒƒS(	sÁ
    A function that accepts a glob-style IP range and returns the equivalent
    IP range.

    :param ipglob: an IP address range in a glob-style format.

    :return: an IPRange object.
    s#not a recognised IP glob range: %r!RRiiR	RR(RRRRRR(RRRRR((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pytglob_to_iprangeds	

cCsåt|ƒ}t|ƒ}|jdkrE|jdkrEtdƒ‚nd„}g}y;|||ƒ}t|ƒstdƒ‚n|j|ƒWnOtk
ràx?t||ƒD]*}||d|dƒ}|j|ƒq¯WnX|S(s
    A function that accepts an arbitrary start and end IP address or subnet
    and returns one or more glob-style IP ranges.

    :param start: the start IP address or subnet.

    :param end: the end IP address or subnet.

    :return: a list containing one or more IP globs.
    is!IP glob ranges only support IPv4!c	SsEgt|ƒjdƒD]}t|ƒ^q}gt|ƒjdƒD]}t|ƒ^qD}g}t}t}xÇtdƒD]¹}||||kr¯|jt||ƒƒq{||dkrå||dkrå|jdƒt}q{|s(|s|jd||||fƒt}q4tdƒ‚q{tdƒ‚q{Wdj|ƒS(	NRiiiÿR	s%s-%ss,only 1 hyphenated octet per IP glob allowed!s3asterisks are not allowed before hyphenated octets!(	tstrRRR
trangeRR
RR(	tlbtubt_tt1tt2RRRR((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyt_iprange_to_glob“s(.. 
		
sinvalid ip glob creatediiÿÿÿÿ(RtversionRRRR(tstarttendR)tglobsRtcidr((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pytiprange_to_globs‚s 	!
cCstt|ƒŒS(sï
    A function that accepts a glob-style IP range and returns a list of one
    or more IP CIDRs that exactly matches it.

    :param ipglob: an IP address range in a glob-style format.

    :return: a list of one or more IP objects.
    (RR (R((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyt
glob_to_cidrsÌs	cCsLt|ƒ}t|d|dƒ}t|ƒdkrDtdƒ‚n|dS(sÿ
    A function that accepts an IP subnet in a glob-style format and returns
    a list of CIDR subnets that exactly matches the specified glob.

    :param cidr: an IP object CIDR subnet.

    :return: a list of one or more IP addresses and subnets.
    iiÿÿÿÿisbad CIDR to IP glob conversion!(RR/RR(R.tipR-((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pytcidr_to_globØs
	tIPGlobcBsheZdZd
Zd„Zd„Zd„Zd„Zd„Ze	eeddƒZd„Zd	„Z
RS(s½
    Represents an IP address range using a glob-style syntax ``x.x.x-y.*``

    Individual octets can be represented using the following shortcuts :

        1. ``*`` - the asterisk octet (represents values ``0`` through ``255``)
        2. ``x-y`` - the hyphenated octet (represents values ``x`` through ``y``)

    A few basic rules also apply :

        1. ``x`` must always be greater than ``y``, therefore :

        - ``x`` can only be ``0`` through ``254``
        - ``y`` can only be ``1`` through ``255``

        2. only one hyphenated octet per IP glob is allowed
        3. only asterisks are permitted after a hyphenated octet

    Examples:

    +------------------+------------------------------+
    | IP glob          | Description                  |
    +==================+==============================+
    | ``192.0.2.1``    | a single address             |
    +------------------+------------------------------+
    | ``192.0.2.0-31`` | 32 addresses                 |
    +------------------+------------------------------+
    | ``192.0.2.*``    | 256 addresses                |
    +------------------+------------------------------+
    | ``192.0.2-3.*``  | 512 addresses                |
    +------------------+------------------------------+
    | ``192.0-1.*.*``  | 131,072 addresses            |
    +------------------+------------------------------+
    | ``*.*.*.*``      | the whole IPv4 address space |
    +------------------+------------------------------+

    .. note ::     IP glob ranges are not directly equivalent to CIDR blocks.     They can represent address ranges that do not fall on strict bit mask     boundaries. They are suitable for use in configuration files, being     more obvious and readable than their CIDR counterparts, especially for     admins and end users with little or no networking knowledge or     experience. All CIDR addresses can always be represented as IP globs     but the reverse is not always true.
    t_globcCsKt|ƒ\}}tt|ƒj||ƒt|j|jƒd|_dS(Ni(R tsuperR3t__init__R/t_startt_endtglob(tselfRR+R,((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyR6scCstt|ƒjƒS(s-:return: Pickled state of an `IPGlob` object.(R5R3t__getstate__(R:((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyR;scCs6tt|ƒj|ƒt|j|jƒd|_dS(s>:param state: data used to unpickle a pickled `IPGlob` object.iN(R5R3t__setstate__R/R7R8R9(R:tstate((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyR<#scCs|jS(N(R4(R:((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyt	_get_glob(scCs8t|ƒ\|_|_t|j|jƒd|_dS(Ni(R R7R8R/R4(R:R((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyt	_set_glob+ss-an arbitrary IP address range in glob format.cCsd|jS(s3:return: IP glob in common representational format.s%s(R9(R:((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyt__str__2scCsd|jj|jfS(s8:return: Python statement to create an equivalent objects%s('%s')(t	__class__t__name__R9(R:((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyt__repr__6s(s_globN(RBt
__module__t__doc__t	__slots__R6R;R<R>R?tpropertytNoneR9R@RC(((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyR3ês-							N(REtnetaddr.coreRRt
netaddr.ipRRRRtnetaddr.compatRRR R!R/R0R2R3(((sD/home/tvault/.virtenv/lib/python2.7/site-packages/netaddr/ip/glob.pyt<module>
s"	6			J