This file is indexed.

/usr/lib/python2.7/dist-packages/rfc3986-0.3.1.egg-info/PKG-INFO is in python-rfc3986 0.3.1-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
Metadata-Version: 1.1
Name: rfc3986
Version: 0.3.1
Summary: Validating URI References per RFC 3986
Home-page: https://rfc3986.readthedocs.org
Author: Ian Cordasco
Author-email: ian.cordasco@rackspace.com
License: Apache 2.0
Description: rfc3986
        =======
        
        A Python implementation of `RFC 3986`_ including validation and authority 
        parsing. Coming soon: `Reference Resolution <http://tools.ietf.org/html/rfc3986#section-5>`_.
        
        Installation
        ------------
        
        Simply use pip to install ``rfc3986`` like so::
        
            pip install rfc3986
        
        License
        -------
        
        `Apache License Version 2.0`_
        
        Example Usage
        -------------
        
        The following are the two most common use cases envisioned for ``rfc3986``.
        
        Replacing ``urlparse``
        ``````````````````````
        
        To parse a URI and receive something very similar to the standard library's
        ``urllib.parse.urlparse``
        
        .. code-block:: python
        
            from rfc3986 import urlparse
        
            ssh = urlparse('ssh://user@git.openstack.org:29418/openstack/glance.git')
            print(ssh.scheme)  # => ssh
            print(ssh.userinfo)  # => user
            print(ssh.params)  # => None
            print(ssh.port)  # => 29418
        
        To create a copy of it with new pieces you can use ``copy_with``:
        
        .. code-block:: python
        
            new_ssh = ssh.copy_with(
                scheme='https'
                userinfo='',
                port=443,
                path='/openstack/glance'
            )
            print(new_ssh.scheme)  # => https
            print(new_ssh.userinfo)  # => None
            # etc.
        
        Strictly Parsing a URI and Applying Validation
        ``````````````````````````````````````````````
        
        To parse a URI into a convenient named tuple, you can simply:
        
        .. code-block:: python
        
            from rfc3986 import uri_reference
        
            example = uri_reference('http://example.com')
            email = uri_reference('mailto:user@domain.com')
            ssh = uri_reference('ssh://user@git.openstack.org:29418/openstack/keystone.git')
        
        With a parsed URI you can access data about the components:
        
        .. code-block:: python
        
            print(example.scheme)  # => http
            print(email.path)  # => user@domain.com
            print(ssh.userinfo)  # => user
            print(ssh.host)  # => git.openstack.org
            print(ssh.port)  # => 29418
        
        It can also parse URIs with unicode present:
        
        .. code-block:: python
        
            uni = uri_reference(b'http://httpbin.org/get?utf8=\xe2\x98\x83')
            print(uni.query)  # utf8=%E2%98%83
        
        With a parsed URI you can also validate it:
        
        .. code-block:: python
        
            if ssh.is_valid():
                subprocess.call(['git', 'clone', ssh.unsplit()])
        
        You can also take a parsed URI and normalize it:
        
        .. code-block:: python
        
            mangled = uri_reference('hTTp://exAMPLe.COM')
            print(mangled.scheme)  # => hTTp
            print(mangled.authority)  # => exAMPLe.COM
        
            normal = mangled.normalize()
            print(normal.scheme)  # => http
            print(mangled.authority)  # => example.com
        
        But these two URIs are (functionally) equivalent:
        
        .. code-block:: python
        
            if normal == mangled:
                webbrowser.open(normal.unsplit())
        
        Your paths, queries, and fragments are safe with us though:
        
        .. code-block:: python
        
            mangled = uri_reference('hTTp://exAMPLe.COM/Some/reallY/biZZare/pAth')
            normal = mangled.normalize()
            assert normal == 'hTTp://exAMPLe.COM/Some/reallY/biZZare/pAth'
            assert normal == 'http://example.com/Some/reallY/biZZare/pAth'
            assert normal != 'http://example.com/some/really/bizzare/path'
        
        If you do not actually need a real reference object and just want to normalize
        your URI:
        
        .. code-block:: python
        
            from rfc3986 import normalize_uri
        
            assert (normalize_uri('hTTp://exAMPLe.COM/Some/reallY/biZZare/pAth') ==
                    'http://example.com/Some/reallY/biZZare/pAth')
        
        You can also very simply validate a URI:
        
        .. code-block:: python
        
            from rfc3986 import is_valid_uri
        
            assert is_valid_uri('hTTp://exAMPLe.COM/Some/reallY/biZZare/pAth')
        
        Requiring Components
        ~~~~~~~~~~~~~~~~~~~~
        
        You can validate that a particular string is a valid URI and require
        independent components:
        
        .. code-block:: python
        
            from rfc3986 import is_valid_uri
        
            assert is_valid_uri('http://localhost:8774/v2/resource',
                                require_scheme=True,
                                require_authority=True,
                                require_path=True)
        
            # Assert that a mailto URI is invalid if you require an authority
            # component
            assert is_valid_uri('mailto:user@example.com', require_authority=True) is False
        
        If you have an instance of a ``URIReference``, you can pass the same arguments
        to ``URIReference#is_valid``, e.g.,
        
        .. code-block:: python
        
            from rfc3986 import uri_reference
        
            http = uri_reference('http://localhost:8774/v2/resource')
            assert uri.is_valid(require_scheme=True,
                                require_authority=True,
                                require_path=True)
        
            # Assert that a mailto URI is invalid if you require an authority
            # component
            mailto = uri_reference('mailto:user@example.com')
            assert uri.is_valid(require_authority=True) is False
        
        Alternatives
        ------------
        
        - `rfc3987 <https://pypi.python.org/pypi/rfc3987/1.3.4>`_
        
          This is a direct competitor to this library, with extra features,
          licensed under the GPL.
        
        - `uritools <https://pypi.python.org/pypi/uritools/0.5.1>`_
        
          This can parse URIs in the manner of RFC 3986 but provides no validation and
          only recently added Python 3 support.
        
        - Standard library's `urlparse`/`urllib.parse`
        
          The functions in these libraries can only split a URI (valid or not) and
          provide no validation.
        
        Contributing
        ------------
        
        This project follows and enforces the Python Software Foundation's `Code of
        Conduct <https://www.python.org/psf/codeofconduct/>`_.
        
        If you would like to contribute but do not have a bug or feature in mind, feel
        free to email Ian and find out how you can help.
        
        The git repository for this project is maintained at
        https://github.com/sigmavirus24/rfc3986
        
        .. _RFC 3986: http://tools.ietf.org/html/rfc3986
        .. _Apache License Version 2.0: https://www.apache.org/licenses/LICENSE-2.0
        
        
        0.3.1 -- 2015-12-15
        -------------------
        
        - Preserve empty query strings during normalization
        
        0.3.0 -- 2015-10-20
        -------------------
        
        - Read README and HISTORY files using the appropriate codec so rfc3986 can be
          installed on systems with locale's other than utf-8 (specifically C)
        
        - Replace the standard library's urlparse behaviour
        
        0.2.2 -- 2015-05-27
        -------------------
        
        - Update the regular name regular expression to accept all of the characters
          allowed in the RFC. Closes bug #11 (Thanks Viktor Haag). Previously URIs
          similar to "http://http-bin.org" would be considered invalid.
        
        0.2.1 -- 2015-03-20
        -------------------
        
        - Check that the bytes of an IPv4 Host Address are within the valid range.
          Otherwise, URIs like "http://256.255.255.0/v1/resource" are considered
          valid.
        
        - Add 6 to the list of unreserved characters. It was previously missing.
          Closes bug #9
        
        0.2.0 -- 2014-06-30
        -------------------
        
        - Add support for requiring components during validation. This includes adding
          parameters ``require_scheme``, ``require_authority``, ``require_path``,
          ``require_path``, ``require_query``, and ``require_fragment`` to
          ``rfc3986.is_valid_uri`` and ``URIReference#is_valid``.
        
        0.1.0 -- 2014-06-27
        -------------------
        
        - Initial Release includes validation and normalization of URIs
        
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: Natural Language :: English
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2.6
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4