Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(feat) First cut at a developer's guide to help onboarding users. #166

Merged
merged 3 commits into from
May 20, 2024
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
50 changes: 50 additions & 0 deletions docs/developer-guide.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
# Developer's Guide to using Weaver

This is an in-progress guide for how to use Weaver to develop your own Semantic Convention registry or codegen.

TODO - Add more getting started guides.

## JQ - Tips and Tricks

While JQ is extremely powerful, it can be finicky to use. For example, fighting instances where JQ decides to repate a structure vs. nest a list can take some getting used to.

Using an explorer tool like [DevToolsDaily JQ playground](https://www.devtoolsdaily.com/jq_playground/) can dramatically improve your debugging journey in crafting the `jq` expressions you use in rendering templates.

To do so we recommend following [Creating a JSON ouput for your registry](#creating-a-json-output-for-your-registry) and then copy-paste your registry JSON as input into the JQ playground.

Check warning on line 13 in docs/developer-guide.md

View workflow job for this annotation

GitHub Actions / Spell Check with Typos

"ouput" should be "output".
jsuereth marked this conversation as resolved.
Show resolved Hide resolved

## Templates - Tips and Tricks

When designing JINJA templates, you can make use the the `debug` function to output the context of the tempalte at any point in time. Simply add `{{ debug(ctx.some_variable) }}` do your template and you'll get a

Check warning on line 17 in docs/developer-guide.md

View workflow job for this annotation

GitHub Actions / Spell Check with Typos

"tempalte" should be "template".
jsuereth marked this conversation as resolved.
Show resolved Hide resolved
JSON rendered view of whatever is passed into `debug` at that portion of the template.

## Policies - Tips and tricks

The OPA policy language REGO can be complicated to learn at first. Using an explorer tool like [The Rego Playground](https://play.openpolicyagent.org) can be a dramatic aide in live debugging policy files and
understanding the language.

To debug `before_resolution` policies, simply take the model YAML files and convert them to JSON (online tools work here) and then copy-paste this data into the "input" of the Rego playground.

To debug `after_resolution` policies, simply follow the [Creating a JSON output for your registry](#creating-a-json-output-for-your-registry) directions and then copy your registry's JSON into the "input" of
jsuereth marked this conversation as resolved.
Show resolved Hide resolved
the Rego playground.

## Creating a JSON output for your registry

Many times it's useful to have raw JSON output of your registry for debugging or tooling. To generate this
output, simply do the following:

1. Creating a new template registery `templates/registry/json`

Check warning on line 35 in docs/developer-guide.md

View workflow job for this annotation

GitHub Actions / Spell Check with Typos

"registery" should be "registry".
2. Create a `weaver.yaml` file that pulls the entire registry:

```yaml
templates:
- pattern: registry.json.j2
application_mode: single
filter: '.'
```

3. Create a `registry.json.j2` template file to render your full registry as JSON.

```
{{- template.set_file_name("registry.json") -}}
{{ ctx | tojson }}
```
Loading