Skip to main content

A user-preference focused configuration library for Python.

Project description

What is it? CI codecov

Prefer is a library for helping you manage application configurations while providing your users the flexibility of using whatever configuration format fits their needs.

It provides a set of interfaces which provide standard methods for reading arbitrary project configuration data. This can vary from simple cases like JSON, to more complicated examples - such as retreiving configuration data from a database.

How do I use it?

Firstly, you'll want to install the module. This can be done easily with easy_install or pip.

easy_install prefer

Prefer is fairly simple to use. A basic use case might be that you have the following JSON configuration in settings.json:

{
  "auth": {
    "username": "user",
    "password": "pass"
  }
}

You can load these settings with the following code using promises:

import prefer

configuration = await prefer.load('settings')
username = configration.get('auth.username')

You will notice that prefer only required 'settings' as the filename. It is recommended to be given without a path or extension, because prefer takes care of looking through the filesystem for configuration files. On both Unix and Windows systems, it will look in all of the standard folders, as well as some conventional places where people like to put their configurations.

Ordering matters, so having a file in ./settings.json as well as another in /etc/settings.json is still reliable. The configuration in ./settings.json will be used first. Prefer doesn't care what format your user writes your settings in, so they can also use settings.yaml if they like.

Supported configuration formats

Along with being fully configurable to support any arbitrary data source you'd like, the following types of data can immediately be used as configuration formats upon installation of prefer:

  • JSON / JSON5 (with comments, trailing commas, unquoted keys)
  • YAML
  • INI / CFG
  • XML

Why asyncronous?

In order to supply a more-simple method of getting the configuration, many configuration tools prefer to provide a blocking method of retrieving a project configuration. One goal of prefer is to ensure that we aren't limiting users to specific use-cases - and some projects require real-time, dynamic updating of their configuration. Prefer provides all it's interfaces as asyncronous functions in order to provide that possibility without the requirement that those actions are blocking.

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

prefer-0.2.1.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

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

prefer-0.2.1-py3-none-any.whl (21.4 kB view details)

Uploaded Python 3

File details

Details for the file prefer-0.2.1.tar.gz.

File metadata

  • Download URL: prefer-0.2.1.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for prefer-0.2.1.tar.gz
Algorithm Hash digest
SHA256 c44825e664396cad2708b2989f1d872d82efab3c6e6a05a90b467c04af33e279
MD5 8d4eb8ece2c6ad986ba41d8a49494f4f
BLAKE2b-256 0974f687aee32c988a70ce45c2eb47c2897a77cfe2b9ec0f04e4fab549a61d1b

See more details on using hashes here.

Provenance

The following attestation bundles were made for prefer-0.2.1.tar.gz:

Publisher: deploy.yml on LimpidTech/prefer.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file prefer-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: prefer-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 21.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for prefer-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a1acd77e812895341210c6cbdf3e799a633c65ee47f51307d29b313c74b103fa
MD5 806c881a451a7ae32d8269d0afdbe9c7
BLAKE2b-256 c3356d9a410c62897f5320d9b1ea9f21bf23441eae5417e405a353e45cd72eb9

See more details on using hashes here.

Provenance

The following attestation bundles were made for prefer-0.2.1-py3-none-any.whl:

Publisher: deploy.yml on LimpidTech/prefer.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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