Skip to main content

generate and update Magic Module resource definitions

Project description

magic-module-scaffolder

generates or updates a Magic Module Resource definitions with the metadata of the Google Cloud APIs.

When generating the definitions, it will first use the ga interface, and supplement the definition with the beta interface, so that it can determine which fields are only available on the beta interface.

The resulting definitions are not perfect and may need some polishing. Most properties required by the magic module are derived from the free text description field. So, please do check the result.

Existing field definitions are not overwritten, so once inspected and correct you can rerun the merge operation as often as you want. Note that fields of a resource which do not exist in the API are removed.

Warning

Do not use the scaffolder to generate PR on the magic-modules without careful inspection of the generated changes. The changes are generated based on what we can derive from the field description in the discovery document, and it may not always be correct.

Use it as a way to bootstrap updates and determine whether new features have been added with respect to the existing resource definition.

example - update

To update an existing resource definition, type:

$ mm-scaffolder update --inplace --resource-file mmv1/products/compute/BackendService.yaml

 mm-scaffolder update --inplace --resource-file mmv1/products/compute/BackendService.yaml
INFO: adding serviceBindings as ga field to definition of BackendService
INFO: adding kind as ga field to definition of BackendService
INFO: adding selfLink as ga field to definition of BackendService
INFO: adding usedBy as ga field to definition of BackendService
INFO: adding metadatas as ga field to definition of BackendService
INFO: adding network as ga field to definition of BackendService
INFO: adding port as ga field to definition of BackendService
INFO: adding region as ga field to definition of BackendService
INFO: adding connectionTrackingPolicy as ga field to definition of BackendService
INFO: adding subsetting as ga field to definition of BackendService
INFO: adding failoverPolicy as ga field to definition of BackendService
INFO: adding maxStreamDuration as ga field to definition of BackendService
INFO: adding failover as ga field to definition of BackendService.backends.
INFO: adding requestCoalescing as ga field to definition of BackendService.cdnPolicy
INFO: adding signedUrlKeyNames as ga field to definition of BackendService.cdnPolicy
INFO: adding enabled as ga field to definition of BackendService.iap
WARNING: mismatch in field name BackendService.localityLbPolicies: expected "localityLbPolicyConfig" defined ""
INFO: adding awsV4Authentication as ga field to definition of BackendService.securitySettings
INFO: adding optionalMode as ga field to definition of BackendService.logConfig
INFO: adding optionalFields as ga field to definition of BackendService.logConfig
INFO: adding ipAddressSelectionPolicy as beta field to definition of BackendService
INFO: adding serviceLbPolicy as beta field to definition of BackendService
INFO: adding preference as beta field to definition of BackendService.backends.
WARNING: mismatch in field name BackendService.localityLbPolicies: expected "localityLbPolicyConfig" defined ""
INFO: adding authentication as beta field to definition of BackendService.securitySettings
INFO: adding subsetSize as beta field to definition of BackendService.subsetting

example - generate

To generate a new resource definition, type:

$ mm-scaffolder generate \
   --product-directory tests/mmv1/products/networksecurity \
   serverTlsPolicies
INFO: Writing to definition of ServerTlsPolicy to tests/mmv1/products/networksecurity/ServerTlsPolicy.yaml

install

to install, type:

pip install magic-module-scaffolder

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

magic_module_scaffolder-0.0.7.tar.gz (32.5 kB view details)

Uploaded Source

Built Distribution

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

magic_module_scaffolder-0.0.7-py3-none-any.whl (14.1 kB view details)

Uploaded Python 3

File details

Details for the file magic_module_scaffolder-0.0.7.tar.gz.

File metadata

  • Download URL: magic_module_scaffolder-0.0.7.tar.gz
  • Upload date:
  • Size: 32.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for magic_module_scaffolder-0.0.7.tar.gz
Algorithm Hash digest
SHA256 d75a19de62a8b27d27f1b4d34c70c8ce3b6bb76902a3ca1926aa33181f6ebee6
MD5 967253a0281027f65bdce648ce2d50d4
BLAKE2b-256 1c38f9391dc9913cce0307d2f13c88d1ed8727990b84ed6de039a8424564fc4a

See more details on using hashes here.

File details

Details for the file magic_module_scaffolder-0.0.7-py3-none-any.whl.

File metadata

File hashes

Hashes for magic_module_scaffolder-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 bb9c5f7552da092633c195532e0c322408b0545a50db6c7d27d0ac50b3851659
MD5 8f532f2212cc48e3c0140104ff5e926e
BLAKE2b-256 c6ce476bab4e4788f1083f01a7fae5ac3fbae9dcd80e406d49f13a9dc7805dc4

See more details on using hashes here.

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