This file is indexed.

/usr/share/pyshared/zope.app.appsetup-3.14.0.egg-info/PKG-INFO is in python-zope.app.appsetup 3.14.0-0ubuntu4.

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
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
Metadata-Version: 1.1
Name: zope.app.appsetup
Version: 3.14.0
Summary: Zope app setup helper
Home-page: http://pypi.python.org/pypi/zope.app.appsetup
Author: Zope Corporation and Contributors
Author-email: zope-dev@zope.org
License: ZPL 2.1
Description: zope.app.appsetup README
        ========================
        
        This package provides application setup helpers for the Zope3 appserver.
        
        
        .. contents::
        
        Bootstrap helpers
        =================
        
        The bootstrap helpers provide a number of functions that help with
        bootstrapping.
        
        The bootStrapSubscriber function makes sure that there is a root
        object.  It subscribes to DatabaseOpened events:
        
            >>> from zope.app.appsetup import bootstrap
            >>> import zope.processlifetime
        
            >>> from ZODB.tests import util
            >>> db = util.DB()
            >>> bootstrap.bootStrapSubscriber(zope.processlifetime.DatabaseOpened(db))
        
        The subscriber makes sure that there is a root folder:
        
            >>> from zope.app.publication.zopepublication import ZopePublication
            >>> conn = db.open()
            >>> root = conn.root()[ZopePublication.root_name]
            >>> sm = root.getSiteManager()
            >>> conn.close()
        
        A DatabaseOpenedWithRoot is generated with the database.
        
            >>> from zope.component.eventtesting import getEvents
            >>> [event] = getEvents(zope.processlifetime.IDatabaseOpenedWithRoot)
            >>> event.database is db
            True
        
        Generally, startup code that expects the root object and site to have
        been created will want to subscribe to this event, not
        IDataBaseOpenedEvent.
        
        The subscriber generates the event whether or not the root had to be
        set up:
        
            >>> bootstrap.bootStrapSubscriber(zope.processlifetime.DatabaseOpened(db))
            >>> [e, event] = getEvents(zope.processlifetime.IDatabaseOpenedWithRoot)
            >>> event.database is db
            True
        
        
        Check the Security Policy
        -------------------------
        
        When the security policy got refactored to be really pluggable, the
        inclusion of the security policy configuration was moved to the very
        top level, to site.zcml.  This happened in r24770, after ZopeX3 3.0
        was released, but before 3.1.
        
        Now the maintainers of existing 3.0 sites need to manually update
        their site.zcml to include securitypolicy.zcml while upgrading to 3.1.
        See also http://www.zope.org/Collectors/Zope3-dev/381 .
        
            >>> from zope.testing.loggingsupport import InstalledHandler
            >>> handler = InstalledHandler('zope.app.appsetup')
        
        If the security policy is unset from the default
        ParanoidSecurityPolicy, we get a warning:
        
            >>> from zope.app.appsetup.bootstrap import checkSecurityPolicy
            >>> event = object()
            >>> checkSecurityPolicy(event)
            >>> print handler
            zope.app.appsetup WARNING
              Security policy is not configured.
            Please make sure that securitypolicy.zcml is included in site.zcml immediately
            before principals.zcml
        
        However, if any non-default security policy is installed, no warning
        is emitted:
        
            >>> from zope.security.management import setSecurityPolicy
            >>> defaultPolicy = setSecurityPolicy(object())
            >>> handler.clear()
            >>> checkSecurityPolicy(event)
            >>> print handler
            <BLANKLINE>
        
        Clean up:
        
            >>> handler.uninstall()
        
        
        Debug console
        =============
        
        The debug console lets you have a Python prompt with the full Zope
        environment loaded (which includes the ZCML configuration, as well as an open
        database connection).
        
        Let's define a helper to run the debug script and trap SystemExit exceptions
        that would otherwise hide the output
        
            >>> import sys
            >>> from zope.app.appsetup import debug
            >>> def run(*args):
            ...     sys.argv[0] = 'debug'
            ...     sys.stderr = sys.stdout
            ...     try:
            ...         debug.main(args)
            ...     except SystemExit, e:
            ...         print "(exited with status %d)" % e.code
        
        If you call the script with no arguments, it displays a brief error message
        on stderr
        
            >>> run()
            Error: please specify a configuration file
            For help, use debug -h
            (exited with status 2)
        
        We need to pass a ZConfig configuration file as an argument
        
            >>> run('-C', 'test.conf')
            The application root is known as `root`.
        
        Now you have the root object from the open database available as a global
        variable named 'root' in the __main__ module:
        
            >>> main_module = sys.modules['__main__']
            >>> main_module.root            # doctest: +ELLIPSIS
            <zope.site.folder.Folder object at ...>
        
        and we have asked Python to enter interactive mode by setting the
        PYTHONINSPECT environment variable
        
            >>> import os
            >>> os.environ.get('PYTHONINSPECT')
            'true'
        
        We have to do extra work to honor the PYTHONSTARTUP environment variable:
        
            >>> pythonstartup = os.path.join(os.path.dirname(debug.__file__),
            ...                              'testdata', 'pythonstartup')
            >>> os.environ['PYTHONSTARTUP'] = pythonstartup
            >>> run('-C', 'test.conf')
            The application root is known as `root`.
        
        You can see that our pythonstartup file was executed because it changed
        the prompt
        
            >>> sys.ps1
            'debug> '
        
        
        
        Product-specific configuration
        ==============================
        
        The ``product`` module of this package provides a very simple way to deal with
        what has traditionally been called "product configuration", where "product"
        refers to the classic Zope 2 notion of a product.
        
        The configuration schema for the application server allows named
        <product-config> sections to be added to the configuration file, and product
        code can use the API provided by the module to retrieve configuration sections
        for given names.
        
        There are two public functions in the module that should be used in normal
        operations, and additional functions and a class that can be used to help with
        testing:
        
            >>> from zope.app.appsetup import product
        
        Let's look at the helper class first, since we'll use it in describing the
        public (application) interface.  We'll follow that with the functions for
        normal operation, then the remaining test-support functions.
        
        
        Faux configuration object
        -------------------------
        
        The ``FauxConfiguration`` class constructs objects that behave like the
        ZConfig section objects to the extent needed for the product configuration
        API.  These will be used here, and may also be used to create configurations
        for testing components that consume such configuration.
        
        The constructor requires two arguments: the name of the section, and a mapping
        of keys to values that the section should provide.  Let's create a simple
        example:
        
            >>> one = product.FauxConfiguration("one", {})
            >>> one.getSectionName()
            'one'
            >>> one.mapping
            {}
        
        Providing a non-empty set of key/value pairs trivially behaves as expected:
        
            >>> two = product.FauxConfiguration("two", {"abc": "def"})
            >>> two.getSectionName()
            'two'
            >>> two.mapping
            {'abc': 'def'}
        
        
        Application API
        ---------------
        
        There are two functions in the application interface for this module.  One is
        used by the configuration provider, and the other is used by the consumer.
        
        The provider's API takes a sequence of configuration objects that conform to
        the behaviors exhibited by the default ZConfig section objects.  Since the
        ``FauxConfiguration`` class provides these behaviors, we can easily see how
        this can be used:
        
            >>> product.setProductConfigurations([one, two])
        
        Now that we've established some configuration, we want to be able to use it.
        We do this using the ``getProductConfiguration()`` function.  This function
        takes a name and returns a matching configuration section if there is one, of
        None if not:
        
            >>> product.getProductConfiguration("one")
            {}
        
            >>> product.getProductConfiguration("not-there") is None
            True
        
        Note that for a section that exists, only the internal mapping is provided,
        not the containing section object.  This is a historical wart; we'll just need
        to live with it until new APIs are introduced.
        
        Setting the configuration a second time will overwrite the prior
        configuration; sections previously available will no longer be:
        
            >>> product.setProductConfigurations([two])
            >>> product.getProductConfiguration("one") is None
            True
        
        The new sections are available, as expected:
        
            >>> product.getProductConfiguration("two")
            {'abc': 'def'}
        
        
        Test support functions
        ----------------------
        
        Additional functions are provided that make it easier to manage configuration
        state in testing.
        
        The first can be used to provide configuration for a single name.  The
        function takes a name and either a configuration mapping or ``None`` as
        arguments.  If ``None`` is provided as the second argument, any configuration
        settings for the name are removed, if present.  If the second argument is not
        ``None``, it will be used as the return value for ``getProductConfiguration``
        for the given name.
        
            >>> product.setProductConfiguration("first", None)
            >>> print product.getProductConfiguration("first")
            None
        
            >>> product.setProductConfiguration("first", {"key": "value1"})
            >>> product.getProductConfiguration("first")
            {'key': 'value1'}
        
            >>> product.setProductConfiguration("first", {"key": "value2"})
            >>> product.getProductConfiguration("first")
            {'key': 'value2'}
        
            >>> product.setProductConfiguration("first", {"alt": "another"})
            >>> product.getProductConfiguration("first")
            {'alt': 'another'}
        
            >>> product.setProductConfiguration("second", {"you": "there"})
            >>> product.getProductConfiguration("first")
            {'alt': 'another'}
            >>> product.getProductConfiguration("second")
            {'you': 'there'}
        
            >>> product.setProductConfiguration("first", None)
            >>> print product.getProductConfiguration("first")
            None
        
        The other two functions work in concert, saving and restoring the entirety of
        the configuration state.
        
        Our current configuration includes data for the "second" key, and none for the
        "first" key:
        
            >>> print product.getProductConfiguration("first")
            None
            >>> print product.getProductConfiguration("second")
            {'you': 'there'}
        
        Let's save this state:
        
            >>> state = product.saveConfiguration()
        
        Now let's replace the kitchen sink:
        
            >>> product.setProductConfigurations([
            ...     product.FauxConfiguration("x", {"a": "b"}),
            ...     product.FauxConfiguration("y", {"c": "d"}),
            ...     ])
        
            >>> print product.getProductConfiguration("first")
            None
            >>> print product.getProductConfiguration("second")
            None
        
            >>> product.getProductConfiguration("x")
            {'a': 'b'}
            >>> product.getProductConfiguration("y")
            {'c': 'd'}
        
        The saved configuration state can be restored:
        
            >>> product.restoreConfiguration(state)
        
            >>> print product.getProductConfiguration("x")
            None
            >>> print product.getProductConfiguration("y")
            None
        
            >>> print product.getProductConfiguration("first")
            None
            >>> print product.getProductConfiguration("second")
            {'you': 'there'}
        
        There's an additional function that can be used to load product configuration
        from a file object; only product configuration components are accepted.  The
        function returns a mapping of names to configuration objects suitable for
        passing to ``setProductConfiguration``.  Using this with
        ``setProductConfigurations`` would require constructing ``FauxConfiguration``
        objects.
        
        Let's create some sample configuration text:
        
            >>> product_config = '''
            ... <product-config product1>
            ...   key1 product1-value1
            ...   key2 product1-value2
            ... </product-config>
            ...
            ... <product-config product2>
            ...   key1 product2-value1
            ...   key3 product2-value2
            ... </product-config>
            ... '''
        
        We can now load the configuration using the ``loadConfiguration`` function:
        
            >>> import StringIO
            >>> import pprint
        
            >>> sio = StringIO.StringIO(product_config)
            >>> config = product.loadConfiguration(sio)
        
            >>> pprint.pprint(config, width=1)
            {'product1': {'key1': 'product1-value1',
                          'key2': 'product1-value2'},
             'product2': {'key1': 'product2-value1',
                          'key3': 'product2-value2'}}
        
        Extensions that provide product configurations can be used as well:
        
            >>> product_config = '''
            ... %import zope.app.appsetup.testproduct
            ...
            ... <testproduct foobar>
            ... </testproduct>
            ...
            ... <testproduct barfoo>
            ...   key1 value1
            ...   key2 value2
            ... </testproduct>
            ... '''
        
            >>> sio = StringIO.StringIO(product_config)
            >>> config = product.loadConfiguration(sio)
        
            >>> pprint.pprint(config, width=1)
            {'barfoo': {'key1': 'value1',
                        'key2': 'value2',
                        'product-name': 'barfoo'},
             'foobar': {'product-name': 'foobar'}}
        
        
        Changelog
        =========
        
        3.14.0 (2010-04-13)
        -------------------
        
        - make zope.testing an optional (test) dependency.
        
        - remove test dependency zope.app.testing. 
        
        
        3.13.0 (2009-12-24)
        -------------------
        
        - Import hooks functionality from zope.component after it was moved there from
          zope.site.
        
        - Import ISite from zope.component after it was moved there from
          zope.location. This lifts the dependency on zope.location.
        
        - Added missing install dependency on `zope.testing`.
        
        
        3.12.0 (2009-06-20)
        -------------------
        
        - Using ``zope.processlifetime`` interfaces and implementations
          directly instead of BBB imports from ``zope.app.appsetup``.
        
        - Got rid of depencency on ``zope.app.component``.
        
        - Got rid of test dependency on ``zope.app.security``.
        
        
        3.11 (2009-05-13)
        -----------------
        
        - Event interfaces / implementations moved to ``zope.processlifetime``,
          version 1.0.  Depend on this package, and add BBB imports.
        
        
        3.10.1 (2009-03-31)
        -------------------
        
        - Fixed a ``DeprecationWarning`` introduced in 3.10.0.
        
        - Added doctests to long description to show up at pypi.
        
        
        3.10.0 (2009-03-19)
        -------------------
        
        - Finally deprecate the "asObject" argument of helper functions in the
          ``zope.app.appsetup.bootstrap`` module. If your code uses any of these
          functions, please remove the "asObject=True" argument passing anywhere,
          because the support for that argument will be dropped soon.
        
        - Move session utility bootstrapping logic from ``zope.session`` into this
          package. This removes a dependency from zope.session to this package.
        
        - Remove one more deprecated function.
        
        
        3.9.0 (2009-01-31)
        ------------------
        
        - Use ``zope.site`` instead of ``zope.app.folder`` and
          ``zope.app.component``.
        
        - Use ``zope.container`` instead of ``zope.app.container``.
        
        - Move error log bootstrapping logic from ``zope.error`` into this
          package.  This removes a dependency from zope.error to this
          package. Also added a test for bootstrapping the error log here,
          which was missing in ``zope.error``.
        
        
        3.8.0 (2008-08-25)
        ------------------
        
        - Feature: Developed an entry point that allows you to quickly bring up an
          application instance for debugging purposes. (Implemented by Marius Gedminas
          and Stephan Richter.)
        
        
        3.7.0 (2008-08-19)
        ------------------
        
        - Added ``.product.loadConfiguration`` test-support function; loads product
          configuration (only) from a file object, allowing test code (including
          setup) to make use of the same configuration schema support used by normal
          startup.
        
        
        3.6.0 (2008-07-23)
        ------------------
        
        - Added additional test support functions to set the configuration for a
          single section, and save/restore the entire configuration.
        
        
        3.5.0 (2008-06-17)
        ------------------
        
        - Added helper class for supporting product configuration tests.
        
        - Added documentation for the product configuration API, with tests.
        
        
        3.4.1 (2007-09-27)
        ------------------
        
        - Egg was faulty, re-released.
        
        
        3.4.0 (2007-09-25)
        ------------------
        
        - Initial documented release.
        
        - Reflect changes form zope.app.error refactoring.
        
Keywords: zope3 app setup
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Web Environment
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Zope Public License
Classifier: Programming Language :: Python
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Topic :: Internet :: WWW/HTTP
Classifier: Framework :: Zope3