Skip to main content

Web based management to catalog things including state and location etc. using Python/Django.

Project description

PyInventory

Web based management to catalog things including state and location etc. using Python/Django. Store information in WYSIWYG-HTML-Editor field and tag them and add Files, Images and Links to them.

tests codecov PyInventory @ PyPi Python Versions License GPL-3.0-or-later

Install PyInventory with YunoHost

pyinventory_ynh allows you to install PyInventory quickly and simply on a YunoHost server. If you don't have YunoHost, please consult the guide to learn how to install it.

Pull requests welcome!

about

The focus of this project is on the management of retro computing hardware.

Current features:

  • Web-based
  • Multiuser ready (Every user see and manage only his own entries)
  • Chaotic warehousing
    • Grouped "Items" e.g.: Graphics card Foo is in computer Bar
  • Data structure kept as general as possible
  • Manage information to every item:
    • Description: free WYSIWYG-HTML-Editor field
    • Storage location
    • State
    • Images, Files and Web-Links
    • receiving and delivering (when, from whom, at what price, etc.)
  • Manage "Memos" (Information independent of item/location):
    • A free WYSIWYG-HTML-Editor field
    • Tags
    • Images, Files and Web-Links

Future ideas:

  • Information: Publicly visible yes/no
    • A public list of existing items (think about it, you can set in your profile if you want to)
    • administration a wish & exchange list

any many more... ;)

Screenshots

More screenshots are here: jedie.github.io/tree/master/screenshots/PyInventory

PyInventory v0.2.0 screenshot 1.png


PyInventory v0.11.0 screenshot memo 1.png


PyInventory v0.1.0 screenshot 2.png


PyInventory v0.1.0 screenshot 3.png


Multi user support

PyInventory supports multiple users. The idea:

  • Every normal user sees only his own created database entries
  • All users used the Django admin

Note: All created Tags are shared for all existing users!

So setup a normal user:

  • Set "Staff status"
  • Unset "Superuser status"
  • Add user to "normal_user" group
  • Don't add any additional permissions

e.g.:

normal user example

More screenshots are here: jedie.github.io/tree/master/screenshots/PyInventory

local development installation

e.g.:

# Clone project (Use your fork SSH url!):
~$ git clone https://github.com/jedie/PyInventory.git
~$ cd PyInventory
~/PyInventory$ ./manage.py

Helpful for writing and debugging unittests is to run a local test server. e.g.:

~/PyInventory$ ./manage.py run_dev_server

The web page is available via: http://127.0.0.1:8000/

You can also pass a other port number or ipaddr:port combination. See: ./manage.py run_dev_server --help

Run tests, e.g.:

~/PyInventory$ ./manage.py test
~/PyInventory$ ./manage.py coverage
~/PyInventory$ ./manage.py tox

Install Playwright browsers, e.g.:

~/PyInventory$ .venv/bin/playwright install

Run only Playwright tests with the Playwright Inspector, e.g.:

~/PyInventory$ PWDEBUG=1 ./manage.py test --tag playwright

Backwards-incompatible changes

v0.19.0

  • Remove "/development/" (unmaintained "docker-compose" installation), please use YunoHost ;)
  • Removed django-processinfo and django-axes in test project.
  • Remove poetry, pytest and devshell
  • Use pip-tools, unittests and manage_django_project

history

links

Homepage http://github.com/jedie/PyInventory
PyPi https://pypi-hypernode.com/project/PyInventory/

Discuss here:

donation

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

PyInventory-0.19.0.tar.gz (123.6 kB view details)

Uploaded Source

Built Distribution

PyInventory-0.19.0-py3-none-any.whl (118.6 kB view details)

Uploaded Python 3

File details

Details for the file PyInventory-0.19.0.tar.gz.

File metadata

  • Download URL: PyInventory-0.19.0.tar.gz
  • Upload date:
  • Size: 123.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for PyInventory-0.19.0.tar.gz
Algorithm Hash digest
SHA256 83f34cac0199296778ef9d36e62d859acc1bcc900af16ba9375679e4fb10c067
MD5 2b3f4484dae683ae4967b17abfa18071
BLAKE2b-256 e6c9cae7c1f416a213b3fd1c5b78de950a79e23c151395f69f6e7f5d68d5a38b

See more details on using hashes here.

File details

Details for the file PyInventory-0.19.0-py3-none-any.whl.

File metadata

  • Download URL: PyInventory-0.19.0-py3-none-any.whl
  • Upload date:
  • Size: 118.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for PyInventory-0.19.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2caef5d8ce8683870a12a85a8cc0bedb5c7d4b8803fc67292960d74c4af31571
MD5 2fdfe26174323bdd1541108eae48a998
BLAKE2b-256 d59dec3e2120f846359e585f701c6f9716d20e203ba21317ca6a3b0670b1e1e8

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