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

Add JSON schemas for the policy configurations #522

Merged
merged 7 commits into from
Dec 5, 2017

Conversation

davidor
Copy link
Contributor

@davidor davidor commented Dec 5, 2017

This PR adds JSON schemas for the configurations of the policies that have one. This schemas will be used by the UI to know which parameters it needs to ask the user when configuring a policy.

This PR also changes the organization a bit. Now every policy has its own directory with that contains the policy itself and its schema.

Also, in order to be able to require apicast.policy.a_policy instead of apicast.policy.a_policy.policy, I needed to change lua paths in several places. Ideas on how to make this simpler welcome :)

Apart from the code itself, each policy will, at least, have a schema
for its configuration. The idea is to have a separate directory for each
policy that will contain the policy itself and the schema.
This allows to require 'apicast.policy.somepolicy' instead of
'apicast.policy.somepolicy.policy'.
@davidor davidor requested a review from mikz December 5, 2017 10:23
@davidor davidor force-pushed the schema-policies-config branch from f723d2c to dde322b Compare December 5, 2017 10:36
@@ -42,7 +42,8 @@ http {
log_format time '[$time_local] $host:$server_port $remote_addr:$remote_port "$request" $status $body_bytes_sent ($request_time) $post_action_impact';
access_log off;

lua_package_path ";;{{prefix}}/?.lua;{{prefix}}/src/?.lua";
# src/?/policy.lua allows us to require apicast.policy.apolicy
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it is fine now. 👍 Later we can solve it with custom loader.

"type": "array",
"items": {
"type": "string",
"enum": ["GET", "HEAD", "POST", "PUT", "DELETE", "PATCH"]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To be future-proff we definitely should include OPTIONS and when we are at it I think we can include TRACE and CONNECT too. https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods

Copy link
Contributor Author

@davidor davidor Dec 5, 2017

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done.

Copy link
Contributor

@mikz mikz left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍 good start

We will have to add more descriptions to those configuration options, but that we can do as we will have some UI prototype.

@ddcesare @thomasmaas please check the JSON schema so you know how they'll look like.

I think we should address #522 (comment) before merging and add at least OPTIONS HTTP method.

👍

@davidor davidor force-pushed the schema-policies-config branch from dde322b to ffec937 Compare December 5, 2017 13:28
@davidor davidor merged commit 8cdfd62 into master Dec 5, 2017
@davidor davidor deleted the schema-policies-config branch December 5, 2017 13:46
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants