Skip to main content

A library based on `PyYAML` that promises to parse YAML documents and produce Python objects, for executing Python code within YAML documents and instantiating Python objects based on YAML arguments.

Project description

InYAML

Overview

The library based on PyYAML promises to parse YAML documents and produce Python objects, for executing Python code within YAML documents and instantiating Python objects based on YAML arguments.

Features

  • Executable YAML: This introduces Python code defined within YAML documents when the code is not wrapped in the "" or ''. It supports importing modules, executing arbitrary Python expressions directly from YAML.
  • Instantiable YAML: It is not only Executable but also supports instantiating Python objects as defined by class or function tags in YAML. This allows the YAML to not just carry data but also semantic information about how the data should be instantiated into Python objects.
  • Dynamic Import and Execution: Functionality to dynamically import Python modules and execute functions as specified in the YAML, providing flexibility and powerful integration capabilities.

Key Components

ExecutableConstructor:

  • Executes Python codes or expressions within YAML.
  • Manages import (__import__ as the default key) and run (__run__ as the default key) executions through special YAML keys.
  • Ensures that only designated code is executed.

InstantiableConstructor:

  • Inherits from ExecutableConstructor.
  • Adds the capability to instantiate objects using type specifications provided in YAML tags.
  • Supports advanced features like namespace and argument passing for constructors.

load Function:

  • Parses YAML documents and uses either ExecutableConstructor or InstantiableConstructor based on whether the is_instantiable is True or not.
  • All imported modules or classes will be stores in the imported targets attribute (__import__ as the default identifier) of the outermost Namespace.

Installation

pip install inyaml

Usage Example

import inyaml

class TestClass:
    def __init__(self, *args, **kwargs):
        print(args)
        print(kwargs)
        print('TestClass')

def test_run_function(arg=0):
    print(arg)

input_data = """
add: 1+2
string: "string"
number: 3
outer_namespace: &ref
 inner_namespace:
  first: [9+ 8,{'any_number':99}]
  second: {"any_number":333}
list: [{'any_float':99.1}, 1, 2, 3+4, *ref]
__import__ (np): numpy
dict: {"any_number_in_a_dict":444}
__run__: test_run_function()
instance: !TestClass
 string: "from"
 __args__: [1,2,3]
 __kwargs__:
  first: 1
  second: 2
 number: 12345
 np_array: &ref_2 !np.array ~([1, 20, 300])
 np_array_2: !np.array [[1, 20, 300]]
 np_array_3: *ref_2
 __run__: test_run_function(25)
"""

print(inyaml.load(input_data))

Safety Notice

While this library allows execution of Python code specified in YAML, it should be used with caution to avoid executing untrusted code, especially in applications where YAML documents could come from untrusted sources.

Although it has been processed to avoid many dangerous situations, it is possible to introduce dangerous code when setting types and functions using ![any]. Please ensure that all introduced types and functions are safe.

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

inyaml-0.0.1b2.tar.gz (13.7 kB view details)

Uploaded Source

Built Distribution

inyaml-0.0.1b2-py3-none-any.whl (14.6 kB view details)

Uploaded Python 3

File details

Details for the file inyaml-0.0.1b2.tar.gz.

File metadata

  • Download URL: inyaml-0.0.1b2.tar.gz
  • Upload date:
  • Size: 13.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.0

File hashes

Hashes for inyaml-0.0.1b2.tar.gz
Algorithm Hash digest
SHA256 0f7f6c7a8317c41efba7a2167fb97950c2c9f76e57cdf7e190e48b3582c1e2cb
MD5 05faa95d8ad6ae80d990b1ef3da5758c
BLAKE2b-256 b62fc1d4a5fec5a739aba53d9b8e4788a1ad8a2f939458951122561865f2ab00

See more details on using hashes here.

File details

Details for the file inyaml-0.0.1b2-py3-none-any.whl.

File metadata

  • Download URL: inyaml-0.0.1b2-py3-none-any.whl
  • Upload date:
  • Size: 14.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.0

File hashes

Hashes for inyaml-0.0.1b2-py3-none-any.whl
Algorithm Hash digest
SHA256 9a41875879160d58fa5effeab75bcc6d370695c9df240cb097dda5d9e3aa0b8d
MD5 0defc23801861fe01305413743736cb6
BLAKE2b-256 be5d64793d59bf1754a1cd7867691a706c234f412feef1359b3bce8c24b561f6

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