Skip to main content

A generic web-based browser of ZODB databases.

Project description

Overview

Eye provides a browser-based UI to browse the contents of a ZODB database.

https://github.com/davisagli/eye/raw/master/screenshot.png

It can browse “broken” ZODB objects, so you don’t have to have your application code present in the Python environment to use the tool.

It can also be used as a generic Python object browser.

Installation

At this point Eye has been tested on Python 2.6.

Eye has a few dependencies. Therefore it’s recommended to install it in a virtualenv or buildout to keep it isolated from other software on your system.

Assuming you have virtualenv installed, the following commands will install Eye:

$ virtualenv --no-site-packages eye
$ cd eye
$ bin/pip install eye

This creates a new virtualenv in the eye directory, and installs the eye console script into the bin subdirectory.

Basic usage

Inspect a ZODB filestorage

$ bin/eye [path to Data.fs]

Then open your browser to http://localhost:8080/

Persistent objects are shown in blue; other objects included in the pickles of persistent objects are shown in black.

Inspect an arbitrary object

>>> from datetime import datetime
>>> foo = datetime.now()
>>> import eye; eye.eye(foo)

Similar tools

  • zope2.zodbbrowser: Runs in Zope 2; provides a bit more app-specific info.

  • zodbbrowser: Based on the Zope 3.4.0 KGS; displays historical object revisions.

  • z3c.zodbbrowser: An apparently unfinished GSOC project; based on wxPython.

Credits

Thanks to:

  • Roberto Allende and menttes. The initial inspiration and code is from their zope2.zodbbrowser.

  • Jim Fulton for creating the ZODB.

  • The creators of the WSGI tools used by Eye.

  • The creators of the JQuery, JQuery UI, and Dynatree libraries.

  • Elizabeth Leddy

  • Hanno Schlichting

Changelog

1.0 - 2011-11-05

  • Only serve on local network interface. [davisagli]

  • Remove non-functional paste.app_factory entry point. [davisagli]

  • Do our own traversal and rendering rather than depending on Pyramid. [davisagli]

  • Provide better representation of persistent BTree structures. [hannosch]

1.0b2 - 2011-03-19

  • Work around issue with traversing objects with slashes in their key. [davisagli]

  • Handle case where objects providing interfaces not present in the Python environment can’t be unpickled even into Broken objects. [davisagli]

  • Cast non-string dict keys into strings for the sake of traversal. [davisagli]

  • Handle case where inspect.getmembers hits an AttributeError. [davisagli]

  • Handle case where ZODB state is not a mapping. [davisagli]

  • Make it possible to browse ZODB BTrees (as long as they’re not too big, anyway). [davisagli]

1.0b1 - 2011-03-19

  • Initial release. [davisagli]

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

eye-1.0.zip (216.7 kB view details)

Uploaded Source

File details

Details for the file eye-1.0.zip.

File metadata

  • Download URL: eye-1.0.zip
  • Upload date:
  • Size: 216.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for eye-1.0.zip
Algorithm Hash digest
SHA256 1ca76b3da69d45dd7a78b55e77bffb7cb93e507de90667ffc781f4aca2c14da9
MD5 81d8e3bcd41c09d04489e006ea719b3a
BLAKE2b-256 498960990af1bc2a279a5a3ed9d6beaab29e13d52c9d805bf5ef86b03937b93b

See more details on using hashes here.

Supported by

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