Skip to main content

Easily manage data storage and logging across repos

Project description

cabinet

A Python library to easily store data across multiple projects in one or more JSON files.

Supports email and event logging.

Features

  • Read and write data in the JSON files of your choice
  • Log to a file/directory of your choice without having to configure logger each time
  • Send/receive mail using cabinet.Cabinet().mail()

Structure

  • Data is stored in a settings.json file in the location of your choice
  • Logs are written to {/path/to/cabinet}/log/LOG_DAILY_YYYY-MM-DD by default
    • this can be changed on a per-log basis

Installation and Setup

  python3 -m pip install cabinet

  cabinet config

Configuration

  • Upon first launch, will prompt you to choose a location for settings.json. You can change this at any time with cabinet config.

edit() shortcuts

  • see example below to enable something like cabinet edit shopping from the terminal
    • or cabinet.Cabinet().edit("shopping"), rather than cabinet.Cabinet().edit("/home/{username}/path/to/shopping.md")
# example only; these commands will be unique to your setup

{
  "path": {
    "edit": {
      "shopping": {
        "value": "/home/{username}/path/to/shopping.md",
      },
      "todo": {
        "value": "/home/{username}/path/to/todo.md",
      }
    }
  }
}

mail

  • It is NEVER a good idea to store your password in plaintext; for this reason, I strongly recommend a "throwaway" account that is only used for sending emails
  • Gmail (as of May 2022) and most other mainstream email providers won't work with this; for support, search for sending mail from your email provider with smtplib.
  • In settings.json, add the email object to make your settings file look like this example:
{
    "email": {
        "from": "throwaway@example.com",
        "from_pw": "example",
        "from_name": "Raspberry Pi",
        "to": "destination@protonmail.com",
        "smtp_server": "example.com",
        "imap_server": "example.com",
        "port": 123
    }
}

Examples

set

from cabinet import Cabinet

cab = Cabinet()

cab.set("employee", "Tyler", "salary", 7.25)

results in this structure in settings.json:

{
    "employee": {
        "Tyler": {
            "salary": 7.25
        }
    }
}

get

from cabinet import Cabinet

cab = Cabinet()

print(cab.get("employee", "Tyler", "salary"))
> python3 test.py
> 7.25

edit

from cabinet import Cabinet

cab = Cabinet()

# if set("path", "edit", "shopping", "/path/to/shopping.md") has been called, this will edit the file assigned to that shortcut.

# opens file in Vim, saves upon exit
cab.edit("shopping")

# or you can edit a file directly...
cab.edit("/path/to/shopping.md")

mail


from cabinet import mail

mail.send('Test Subject', 'Test Body')

log


from cabinet import Cabinet

cab = Cabinet()

# writes to a file named LOG_DAILY_YYYY-MM-DD in the default log folder (or cab.get('path', 'log')) inside a YYYY-MM-DD folder

cab.log("Connection timed out") # defaults to 'info' if no level is set
cab.log("This function hit a breakpoint", level="debug")
cab.log("Looks like the server is on fire", level="critical")
cab.log("This is fine", level="info")

# writes to a file named LOG_TEMPERATURE

cab.log("30", logName="LOG_TEMPERATURE")

# writes to a file named LOG_TEMPERATURE in /home/{username}/weather

cab.log("30", logName="LOG_TEMPERATURE", filePath="/home/{username}/weather")

    # format
    # 2021-12-29 19:29:27,896 — INFO — 30

Dependencies

  • Python >= 3.6
  • smtplib

Disclaimers

  • Although I've done quite a bit of testing, I can't guarantee everything that works on my machine will work on yours. Always back up your data to multiple places to avoid data loss.
  • If you find any issues, please contact me... or get your hands dirty and raise a PR!

Author

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

cabinet-2023.4.9.1.tar.gz (15.0 kB view hashes)

Uploaded Source

Built Distribution

cabinet-2023.4.9.1-py3-none-any.whl (14.4 kB view hashes)

Uploaded Python 3

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