Skip to main content

Environment variable parsing library.

Project description

environparse

Environment variable parsing library, inspired by stdlib argparse.

Features:

  • Handles both optional and required environment variable.
  • Built-in various actions to handle the value parsing, such as:
    • String
    • Number (integer or float)
    • Boolean
    • Path (with optional validations)
    • File opener
  • Localization support. Currently, supports the following languages:
    • en
    • zh-CN
    • zh-SG
    • zh-HK
    • zh-TW
  • And more features that have not yet been implemented...

Install

Available on PyPI.

The release page also provided wheel package to download.

Example

environparse has a built-in HTTP server startup script to demonstrate the basic usage of environparse. To access it, run the following command to see help messages:

$ > pwd
/tmp
$ > LANGUAGE=en_SG.UTF-8 HELP= python -m environparse.examples.httpserver
Usage: [ENVS]... httpserver.py [ARGS]...

An script to start a http server, but use `environparse` to demonstrate the option parsing.

The following environment variables will be preemptively parsed and exit after performing the operation:
    HELP=[...]    Show this help message and exit.

Unless otherwise stated, all options are optional by default.
List of available environment variables [ENVS]:
    BIND_ADDRESS=[STRING]    Bind to a specified address. Leave empty to bind all interfaces.
    BIND_PORT=[INTEGER]      Bind to a specified port.                                       
                             [Default: 6282]                                                 
    ROOTDIR=[PATH]           Serve a specified directory.                                    
                             [Default: /tmp]                                                 

Do not forget the warning from `http.server` documentation:
http.server is not recommended for production. It only implements basic security checks.
$ >

environparse even support localization:

用法:[环境变量]... httpserver.py [参数]...

An script to start a http server, but use `environparse` to demonstrate the option parsing.

以下环境变量将被抢先解析,并在运行操作后退出:
    HELP=[...]    显示此帮助信息并退出。

除非另有说明,所有选项默认都是可选的。
可用的 [环境变量] 列表:
    BIND_ADDRESS=[字符串]    Bind to a specified address. Leave empty to bind all interfaces.
    BIND_PORT=[整数]         Bind to a specified port.                                       
                             [默认值:6282]                                                  
    ROOTDIR=[PATH]           Serve a specified directory.                                    
                             [默认值:/tmp]                                                  

Do not forget the warning from `http.server` documentation:
http.server is not recommended for production. It only implements basic security checks.
$ >

Now, try to test the HTTP server:

$ > ROOTDIR="$HOME/Music" BIND_ADDRESS='127.127.127.127' python -m environparse.examples.httpserver
Consumed names of environment variables:
['BIND_ADDRESS', 'ROOTDIR']
Parsed options:
{'BIND_ADDRESS': '127.127.127.127', 'BIND_PORT': 6282, 'rootdir': PosixPath('/home/user/Music')}
Starting the HTTP server...
Serving HTTP on 127.127.127.127 port 6282 (http://127.127.127.127:6282/) ...
127.0.0.1 - - [27/Jul/2024 01:35:59] "GET /Music/EXEC_HYMME_SEAMLESSECHO%3DH_D_.%20-%20stellatram.flac HTTP/1.1" 200 -
127.0.0.1 - - [27/Jul/2024 01:36:45] "GET /Music/%E3%82%B3%E3%83%BC%E3%83%89%E3%83%BB%E3%82%A8%E3%83%86%E3%82%B9%E3%82%A6%E3%82%A7%E3%82%A4%28Class__ETHES_WEI%3D_extends.COMMUNI_SAT_.%29%20-%20%E9%9C%9C%E6%9C%88%E3%81%AF%E3%82%8B%E3%81%8B.flac HTTP/1.1" 200 -
127.0.0.1 - - [27/Jul/2024 01:57:04] "GET /Music/%E7%A5%AD%E6%9E%9C%E3%81%A6%E3%81%AE%E8%8A%B1%20-%20%E4%B8%AD%E6%81%B5%E5%85%89%E5%9F%8E%E3%80%81%E9%9C%9C%E6%9C%88%E3%81%AF%E3%82%8B%E3%81%8B.flac HTTP/1.1" 200 -
^C
Keyboard interrupt received, exiting.
$ >

Changelog

All notable changes to this project will be documented in this file.

This project adheres to PyPI Version Specification.

0.2.0.post1 - 2024-07-28

  • Fixed some typos in README.md.
  • Added missing changelog of version 0.2.0.

0.2.0 - 2024-07-28

  • Added an environparse-based HTTP server start script for example purpose.

    • To access/use this script, run:

      $ > [ENVIRONS]... python -m environparse.examples.httpserver
      
  • Added some base path validators.

    • These validators are members of class PathValidators. For example, PathValidators.HasPermission can validate the path accessibility with specified mode argument.
    • To create a custom path validator, please inherit from environparse.AbstractPathValidator and implement the __call__() method.
  • Now you can finer control over display of option defaults in help messages through keyword-only argument show_default in parser initialization and option definition.

  • Protocol class DefinedOptionType is removed. Now DefinedOption (renamed from _DefinedOption) can use to annotate the return type of EnvironmentVariableParser.defineOption().

0.1.0 - 2024-07-26

The initial release.

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

environparse-0.2.0.post1.tar.gz (24.8 kB view details)

Uploaded Source

Built Distribution

environparse-0.2.0.post1-py3-none-any.whl (28.7 kB view details)

Uploaded Python 3

File details

Details for the file environparse-0.2.0.post1.tar.gz.

File metadata

  • Download URL: environparse-0.2.0.post1.tar.gz
  • Upload date:
  • Size: 24.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.1.dev0+g94f810c.d20240510 CPython/3.12.4

File hashes

Hashes for environparse-0.2.0.post1.tar.gz
Algorithm Hash digest
SHA256 2cb2b0c32fba974b6e7ec41969f9638082480e3547de681dd8ecb937fb893d02
MD5 0ab78f909a3d2d484d2d1ef927e966e5
BLAKE2b-256 5dac0ac59cff8ad172bc371f0716fbdb4094c7508328c6061677711a17c15cd1

See more details on using hashes here.

File details

Details for the file environparse-0.2.0.post1-py3-none-any.whl.

File metadata

  • Download URL: environparse-0.2.0.post1-py3-none-any.whl
  • Upload date:
  • Size: 28.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.1.dev0+g94f810c.d20240510 CPython/3.12.4

File hashes

Hashes for environparse-0.2.0.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 41ad81d55de728452fb689b9234071d16c0c75db11b898fc423428b555a7021d
MD5 a97ff82692a394e411ff82fdeeb8206b
BLAKE2b-256 2c95779d7646ae06ab6fe61e72d59fa41d59ca3a4352fb9c4e06df0c915bbcae

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