Skip to main content

Library and command line interface to interact with Drink Management System of Fachschaft TF Uni Freiburg.

Project description

Python3 library with command line interface to interact with the Drink Management System (DMS) of the student council TF Uni Freiburg.

Example use case: Order product from the command line.

$ dms order spezi -u johann
(1) Johannes Mustermann
(2) Johanna  Musterfrau
(3) Johann   Mustermensch
Please enter a number between 1 and 3: 1
Order 1 NetteMarke Spezi (0.70€) for Johannes Mustermann? [YES/no] y
Order successful.

Getting Started

Prerequisites

You need python 3.5 or newer and pip. For development you also need git installed on your machine.

Installation

Install the dmsclient library and command line interface simply from PyPi:

pip3 install dmsclient

For developers it’s recommended to install from source vie develop. Then all changes in code are automatically available in the library and command line without reinstallation.

git clone git@<git url>:<user>/dmsclient.git
cd dmsclient

python3 setup.py develop

Command Line

The installation of dmsclient provides a command line interface dms. For authentication you have to generate a token key in your dms profile settings. Add your token to a .dmsrc file in your home folder.

[DEFAULT]
Token = XxxxxXXXxxxxxXXXXxxxxxxxXXX

Then you can start using dms. You’ll find all available commands via

dms --help

User and product names don’t have to be added exactly, but are estimated from what you type. E.g.:

$ dms buy apfel -u must
Buy Apfelschorle (0.70€) for Max Mustermann? [Y/n]

Library

For communication with the DMS via REST you can use the DmsClient class provided by this library. Authentication is provided via a token key which you can generate in the DMS profile settings. Usually the token is stored in an RC file readable with DmsConfig.

import os
from random import sample

from dmsclient import DmsClient, DmsConfig


rcfile = os.path.expanduser('~/.dmsrc')
cfg = DmsConfig()
cfg.read(rcfile)

API functions of DmsClient usually return coroutines for asynchronous access.

import asyncio


async def async_order_random_stuff_for_last_customer(loop, cfg):
    async with DmsClient(cfg.token, cfg.api) as dms:
       # register tasks which can run in parallel
       products_task = loop.create_task(dms.products)
       sales_task = loop.create_task(dms.sale_history(num_days=1))

       # execute tasks to fetch data in parallel
       available_products = [p for p in await products_task
                             if p.quantity > 0]
       random_product = sample(available_products, 1)[0]
       last_sale = (await sales_task)[0]

       # order random product
       await dms.add_order(random_product.id, last_sale['profile'])

loop = asyncio.get_event_loop()
loop.run_until_complete(async_order_random_stuff_for_last_customer(loop, cfg))

Still, you can use the library also in a synchronous fashion

from syncer import sync


@sync
async def order_random_stuff_for_last_customer(cfg):
    async with DmsClient(cfg.token, cfg.api) as dms:
        # synchronous fetch data
        products = await dms.products
        sales = await dms.sale_history(num_days=1)

        available_products = [p for p in products
                              if p.quantity > 0]
        random_product = sample(available_products, 1)[0]
        last_sale = sales[0]

        # order random product
        await dms.add_order(random_product.id, last_sale['profile'])


order_random_stuff_for_last_customer(cfg)

Alternative:

loop = asyncio.get_event_loop()

# Connect synchronously
client = dms.DmsClient(cfg.token, cfg.api)
client.connect()

# Read products
products = loop.run_until_complete(client.products)

Authors

Initiated by David-Elias Künstle <kuenstld[at]tf.uni-freiburg> / Github but see contributors for a full list of contributions.

License

dmsclient is available under the MIT License

Acknowledgements

Big thanks to the DMS and DMS-API developers!

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

dmsclient-1.5.2.tar.gz (10.8 kB view details)

Uploaded Source

Built Distribution

dmsclient-1.5.2-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file dmsclient-1.5.2.tar.gz.

File metadata

  • Download URL: dmsclient-1.5.2.tar.gz
  • Upload date:
  • Size: 10.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for dmsclient-1.5.2.tar.gz
Algorithm Hash digest
SHA256 c6589f792b797c345abb2695fc746ca3a6dcfb8405275fecd5501c0bc4f656e5
MD5 d48828903a1ff6faabcf22facf49f885
BLAKE2b-256 3b22a65a62699a08498177f9ac223b1a4922bbd3dedede6527ea8a5bdf7e2d79

See more details on using hashes here.

File details

Details for the file dmsclient-1.5.2-py3-none-any.whl.

File metadata

  • Download URL: dmsclient-1.5.2-py3-none-any.whl
  • Upload date:
  • Size: 11.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1

File hashes

Hashes for dmsclient-1.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7a24105e683aea52f400c8517ba53dc8806e305a673def06074b4fb4682a2719
MD5 5f52e05681ec507660dc49d44b794fb2
BLAKE2b-256 f58e7e5c695699ca18a74ee99a4f4ae889331aea61829d5eec28c94e888852e0

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