Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
CLI Command Parser ##################
|downloads| |py_version| |coverage_badge| |build_status| |Ruff|
.. |py_version| image:: https://img.shields.io/badge/python-3.9%20%7C%203.10%20%7C%203.11%20%7C%203.12%20%7C%203.13%20-blue :target: https://pypi.org/project/cli-command-parser/
.. |coverage_badge| image:: https://codecov.io/gh/dskrypa/cli_command_parser/branch/main/graph/badge.svg :target: https://codecov.io/gh/dskrypa/cli_command_parser
.. |build_status| image:: https://github.com/dskrypa/cli_command_parser/actions/workflows/run-tests.yml/badge.svg :target: https://github.com/dskrypa/cli_command_parser/actions/workflows/run-tests.yml
.. |Ruff| image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json :target: https://docs.astral.sh/ruff/
.. |downloads| image:: https://img.shields.io/pypi/dm/cli-command-parser :target: https://pypistats.org/packages/cli-command-parser
CLI Command Parser is a class-based CLI argument parser that defines parameters with descriptors. It provides the tools to quickly and easily get started with basic CLIs, and it scales well to support even very large and complex CLIs while remaining readable and easy to maintain.
The primary goals of this project:
Example Program
.. code-block:: python
from cli_command_parser import Command, Option, main
class Hello(Command, description='Simple greeting example'):
name = Option('-n', default='World', help='The person to say hello to')
count: int = Option('-c', default=1, help='Number of times to repeat the message')
def main(self):
for _ in range(self.count):
print(f'Hello {self.name}!')
if __name__ == '__main__':
main()
.. code-block:: shell-session
$ hello_world.py --name Bob -c 3
Hello Bob!
Hello Bob!
Hello Bob!
$ hello_world.py -h
usage: hello_world.py [--name NAME] [--count COUNT] [--help]
Simple greeting example
Optional arguments:
--name NAME, -n NAME The person to say hello to (default: 'World')
--count COUNT, -c COUNT Number of times to repeat the message (default: 1)
--help, -h Show this help message and exit
Installing CLI Command Parser
CLI Command Parser can be installed and updated via pip <https://pip.pypa.io/en/stable/getting-started/>
__::
$ pip install -U cli-command-parser
There are no required dependencies. Support for formatting wide characters correctly in help text descriptions can
be included by adding wcwidth <https://wcwidth.readthedocs.io>
__ to your project's requirements, and/or by installing
with optional dependencies::
$ pip install -U cli-command-parser[wcwidth]
Python versions 3.9 and above are currently supported. The last release of CLI Command Parser that supported 3.8 was
2024-09-07. Support for Python 3.8 officially ended on 2024-10-07 <https://devguide.python.org/versions/>
__.
Links
FAQs
CLI Command Parser
We found that cli-command-parser demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.