Skip to main content

No project description provided

Project description

cuddly_dicts

Turn a KDL document like this:

landtable version=1 {
    // Minimum compatible Landtable version
    ensure_landtable_version "0.0.1"
    
    provisioning {
        // Whether to allow runtime provisioning
        // (whether you can add/remove fields via the API or the web)
        allow_runtime_provisioning true
        
        // A provisioning strategy defines how a new database can be
        // created.
        strategy "Nest Postgres" {
            primary {
                using "postgres_provisioning_plugin"
                hostname "hackclub.app"
                
                authentication "userpass" {
                    username "sarah"
                    password "i_l0ve_hC!"
                }
                
                // or:
                
                authentication "vault-pg" {
                    path "database/creds/landtable"
                }
            }
        }
    }
}

Into a dict like this:

{
    "landtable": {
        "version": 1,
        "ensure_landtable_version": "0.0.1",
        "provisioning": {
            "allow_runtime_provisioning": True,
            "strategy": {
                "Nest Postgres": {
                    "primary": {
                        "using": "postgres_provisioning_plugin",
                        "hostname": "hackclub.app",
                        "authentication": {
                            "userpass": {
                                "username": "sarah",
                                "password": "i_l0ve_hC!"
                            }
                        }
                    }
                }
            }
        }
    }
}

Motivation

  • Keep using Landtable's existing validation library (Pydantic)
  • Support multiple configuration languages (TOML, JSON, YAML, whatever!) by making them all compile down to the same representation that can be validated

Conversion rules

  • KDL node -> dict result
  • landtable {} -> {"landtable": {}}.
    • Repeated landtable nodes will create a list.
  • version 1 -> {"version": 1}
    • Repeated version nodes will create a list.
      alias "High Seas"
      alias "hs"
      
      Will turn into {"alias": ["High Seas", "hs"]}
  • landtable version=1 {} -> {"landtable": {"version": 1}}
  • strategy "Nest Postgres" {} -> {"strategy": {"Nest Postgres": {}}}
    • Repeated strategy nodes will add another entry to the dict.

License

MIT or WTFPL, depending on how much of a prude you are

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

cuddly_dicts-2.0.0.tar.gz (4.8 kB view details)

Uploaded Source

Built Distribution

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

cuddly_dicts-2.0.0-py3-none-any.whl (4.8 kB view details)

Uploaded Python 3

File details

Details for the file cuddly_dicts-2.0.0.tar.gz.

File metadata

  • Download URL: cuddly_dicts-2.0.0.tar.gz
  • Upload date:
  • Size: 4.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for cuddly_dicts-2.0.0.tar.gz
Algorithm Hash digest
SHA256 ffd5171f162672e511dcefba6601ff83a07cd5bff206b20249d2041ef578c182
MD5 0ebedd5023da53eb779d77909e4a71b5
BLAKE2b-256 3153683d3dd72551ca5a6f49883fc1783c77d09c525326a5cf7b54fefbc7c1d5

See more details on using hashes here.

Provenance

The following attestation bundles were made for cuddly_dicts-2.0.0.tar.gz:

Publisher: workflow.yml on iamawatermelo/cuddly-dicts

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

File details

Details for the file cuddly_dicts-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: cuddly_dicts-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 4.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for cuddly_dicts-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 09703382eb2f0cac8e6a56868e2899061b993047b19390f57359804fb6714c38
MD5 07547d67fc90bfb2b292961cd48fec80
BLAKE2b-256 ce7725f5022a3e4985de419dfd0e44cd3a8cce904c878bcdc6a6cb32d4ea921a

See more details on using hashes here.

Provenance

The following attestation bundles were made for cuddly_dicts-2.0.0-py3-none-any.whl:

Publisher: workflow.yml on iamawatermelo/cuddly-dicts

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