Skip to main content

Browser resources implementation for Zope.

Project description

zope.browserresource

Latest release Supported Python versions https://github.com/zopefoundation/zope.browserresource/actions/workflows/tests.yml/badge.svg https://coveralls.io/repos/github/zopefoundation/zope.browserresource/badge.svg?branch=master Documentation Status

This package provides an implementation of browser resources. It also provides directives for defining those resources using ZCML.

Resources are static files and directories that are served to the browser directly from the filesystem. The most common example are images, CSS style sheets, or JavaScript files.

Resources are be registered under a symbolic name and can later be referred to by that name, so their usage is independent from their physical location. Resources can also easily be internationalized.

Documentation is hosted at https://zopebrowserresource.readthedocs.io

Changes

6.0 (2025-09-12)

  • Replace pkg_resources namespace with PEP 420 native namespace.

5.2 (2025-02-14)

  • Add support for Python 3.12, 3.13.

  • Drop support for Python 3.7, 3.8.

5.1 (2023-08-28)

  • Make tests more resilient.

5.0 (2023-02-14)

  • Drop support for Python 2.7, 3.5, 3.6.

  • Add support for Python 3.9, 3.10, 3.11.

  • Drop support for python setup.py test.

4.4 (2019-12-10)

  • Make the registration of the FileETag adapter conditional on the environment as Zope 4 registers this adapter explicitly in Products.Five.browser. See #12.

  • Add support for Python 3.8.

  • Drop support for Python 3.4.

4.3 (2018-10-05)

4.2.1 (2017-09-01)

  • Fix dependencies of the zcml extra.

4.2.0 (2017-08-04)

  • Add support for Python 3.5 and 3.6.

  • Drop support for Python 2.6 and 3.3.

4.1.0 (2014-12-26)

4.0.2 (2014-11-04)

  • Return no ETag if no adapter is registered, disabling the requirement for applications that was introduced in 3.11.0 (GitHub #1)

4.0.1 (2013-04-03)

  • Fix some Python 3 string vs bytes issues.

4.0.0 (2013-02-20)

  • Replace deprecated zope.component.adapts usage with equivalent zope.component.adapter decorator.

  • Replace deprecated zope.interface.classProvides usage with equivalent zope.interface.provider decorator.

  • Replace deprecated zope.interface.implementsOnly usage with equivalent zope.interface.implementer_only decorator.

  • Replace deprecated zope.interface.implements usage with equivalent zope.interface.implementer decorator.

  • Drop support for Python 2.4 and 2.5.

  • Add support for Python 3.3.

3.12.0 (2010-12-14)

  • Add zcml extra dependencies and fixed dependencies of configure.zcml on other packages’ meta.zcml.

  • Add a test for including our own configure.zcml.

3.11.0 (2010-08-13)

  • Support the HTTP ETag header for file resources. ETag generation can be customized or disabled by providing an IETag multi-adapter on (IFileResource, your-application-skin).

3.10.3 (2010-04-30)

  • Prefer the standard libraries doctest module to the one from zope.testing.

3.10.2 (2009-11-25)

  • The previous release had a broken egg, sorry.

3.10.1 (2009-11-24)

  • Import hooks functionality from zope.component after it was moved there from zope.site. This lifts the dependency on zope.site and thereby, ZODB.

  • Import ISite and IPossibleSite from zope.component after they were moved there from zope.location.

3.10.0 (2009-09-25)

  • Add an ability to forbid publishing of some files in the resource directory, this is done by fnmatch’ing the wildcards in the forbidden_names``class attribute of ``DirectoryResource. By default, the .svn is in that attribute, so directories won’t publish subversion system directory that can contain private information.

3.9.0 (2009-08-27)

Initial release. This package was splitted off zope.app.publisher as a part of refactoring process.

Additional changes that are made during refactoring:

  • Resource class for file resources are now selected the pluggable way. The resource directory publisher and browser:resource ZCML directive now creating file resources using factory utility lookup based on the file extension, so it’s now possible to add new resource types without introducing new ZCML directives and they will work inside resource directories as well.

    NOTE: the “resource_factories” attribute from the DirectoryResource was removed, so if you were using this attribute for changing resource classes for some file extensions, you need to migrate your code to new utility-based mechanism.

    See zope.browserresource.interfaces.IResourceFactoryFactory interface.

  • The Image resource class was removed, as they are actually simple files. To migrate, simply rename the “image” argument in browser:resource and browser:i18n-resource directives to “file”, if you don’t do this, resouces will work, but you’ll get deprecation warnings.

    If you need custom behaviour for images, you can register a resource factory utility for needed file extensions.

  • The PageTemplateResource was moved into a separate package, “zope.ptresource”, which is a plugin for this package now. Because of that, the “template” argument of browser:resource directive was deprecated and you should rename it to “file” to migrate. The PageTemplateResource will be created for “pt”, “zpt” and “html” files automatically, if zope.ptresource package is included in your configuration.

  • Fix stripping the “I” from an interface name for icon title, if no title is specified.

  • When publishing a resource via Resources view, set resource parent to an ISite object, not to current site manager.

  • Clean up code and improve test coverage.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

zope_browserresource-6.0.tar.gz (36.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

zope_browserresource-6.0-py3-none-any.whl (40.0 kB view details)

Uploaded Python 3

File details

Details for the file zope_browserresource-6.0.tar.gz.

File metadata

  • Download URL: zope_browserresource-6.0.tar.gz
  • Upload date:
  • Size: 36.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.11

File hashes

Hashes for zope_browserresource-6.0.tar.gz
Algorithm Hash digest
SHA256 bd7acda7ec111ddaf325b03c777d3bc2ed193319fcf760c4d258fd19f73b434b
MD5 b2a5a049a495b4264967511ffcc41542
BLAKE2b-256 0b8ef49e76614888eb5f313bf7942f2218718194a30332ca4ec294bb19c2cf09

See more details on using hashes here.

File details

Details for the file zope_browserresource-6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for zope_browserresource-6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3687f05ab66a4d4e9a6b70b3bed895c9ce64bf43020b4765e94dd2661fb7043a
MD5 743e8dd511d9d7dfa5d2f9d8dc6e8057
BLAKE2b-256 f3ab770ec1d6490ec827505374648629b7a4b14890ed1054cd73f5d0551cb9ec

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page