261 lines
No EOL
15 KiB
PHTML
261 lines
No EOL
15 KiB
PHTML
<?php
|
|
$new = $this->getParam('new', false);
|
|
$events = $this->getParam('events', []);
|
|
$patterns = [
|
|
'documents',
|
|
'documents.create',
|
|
'documents.update',
|
|
'documents.delete',
|
|
];
|
|
|
|
foreach ($events as $name => $event) {
|
|
$patterns[] = $name;
|
|
foreach ($event as $key => $value) {
|
|
if (!\str_starts_with($key, '$')) {
|
|
if (!($value['$resource'] ?? false)) {
|
|
$patterns[] = "{$name}.{$key}";
|
|
} else {
|
|
$patterns[] = $key;
|
|
foreach ($value as $key2 => $value2) {
|
|
if (!\str_starts_with($key2, '$')) {
|
|
if (!($value2['$resource'] ?? false)) {
|
|
$patterns[] = "{$key}.{$key2}";
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
sort($patterns);
|
|
|
|
?>
|
|
<div
|
|
data-service="projects.getWebhook"
|
|
data-name="project-webhook"
|
|
data-scope="console"
|
|
data-event="load,projects.createWebhook,projects.deleteWebhook,projects.updateWebhook,projects.updateWebhookSignature"
|
|
data-param-project-id="{{router.params.project}}"
|
|
data-param-webhook-id="{{router.params.id}}"
|
|
data-success="trigger"
|
|
data-success-param-trigger-events="projects.getWebhook">
|
|
|
|
<div class="cover">
|
|
<h1 class="zone xl margin-bottom-large">
|
|
<a data-ls-attrs="href=/console/webhooks?project={{router.params.project}}" class="back text-size-small link-return-animation--start"><i class="icon-left-open"></i> Webhooks</a>
|
|
<br />
|
|
|
|
<?php if ($new) : ?>
|
|
<span>Add Webhook</span>
|
|
<? else : ?>
|
|
<span data-ls-bind="{{project-webhook.name}} "> </span>
|
|
<?php endif; ?>
|
|
</h1>
|
|
</div>
|
|
|
|
<div class="zone xl" x-data="events">
|
|
<h2 class="margin-top">Settings</h2>
|
|
<div class="row responsive">
|
|
<div class="col span-8 margin-bottom">
|
|
<label> </label>
|
|
|
|
<div class="box margin-bottom-large">
|
|
<form
|
|
data-analytics
|
|
data-analytics-activity
|
|
data-analytics-event="submit"
|
|
data-analytics-category="console"
|
|
<?php if ($new) : ?>
|
|
data-success="alert,trigger,redirect"
|
|
data-analytics-label="Create Project Webhook"
|
|
data-service="projects.createWebhook"
|
|
data-success-param-alert-text="Created webhook successfully"
|
|
data-success-param-trigger-events="projects.createWebhook"
|
|
data-failure-param-alert-text="Failed to create webhook"
|
|
data-success-param-redirect-url="/console/webhooks?project={{router.params.project}}"
|
|
<?php else : ?>
|
|
data-success="alert,trigger"
|
|
data-analytics-label="Update Project Webhook"
|
|
data-service="projects.updateWebhook"
|
|
data-success-param-alert-text="Updated webhook successfully"
|
|
data-success-param-trigger-events="projects.updateWebhook"
|
|
data-failure-param-alert-text="Failed to update webhook"
|
|
<?php endif; ?>
|
|
data-scope="console"
|
|
data-event="submit"
|
|
data-failure="alert"
|
|
data-failure-param-alert-classname="error">
|
|
|
|
<input type="hidden" name="projectId" data-ls-bind="{{router.params.project}}" />
|
|
<?php if (!$new) : ?><input type="hidden" name="webhookId" data-ls-bind="{{project-webhook.$id}}" /><?php endif; ?>
|
|
|
|
<label data-ls-attrs="for=name-{{webhook.$id}}">Name</label>
|
|
<input type="text" class="full-width" data-ls-attrs="id=name-{{project-webhook.$id}}" name="name" required autocomplete="off" data-ls-bind="{{project-webhook.name}}" maxlength="128" />
|
|
|
|
<label data-ls-attrs="for=url-{{webhook.$id}}">POST URL</label>
|
|
<input type="url" class="full-width" data-ls-attrs="id=url-{{project-webhook.$id}}" name="url" required autocomplete="off" placeholder="https://example.com/callback" data-ls-bind="{{project-webhook.url}}" />
|
|
|
|
<section class="margin-bottom-small" data-ls-attrs="x-init=load({{project-webhook.events}})">
|
|
<label class="margin-bottom-small">Events <span class="tooltip small" data-tooltip="Set events that will trigger your webhook."><i class="icon-info-circled"></i></span></label>
|
|
<div>
|
|
<template x-for="event in Array.from(events)">
|
|
<div class="row events responsive thin margin-bottom-small">
|
|
<div class="col span-12 margin-bottom-small">
|
|
<span class="text" x-text="event"></span>
|
|
<span class="action" @click="removeEvent(event)">
|
|
<i class="icon-trash"></i>
|
|
</span>
|
|
</div>
|
|
<input name="events" data-cast-to="array" type="hidden" :value="event"></input>
|
|
</div>
|
|
</template>
|
|
</div>
|
|
<button class="margin-end margin-bottom-small reverse" type="button" @click="showModal($refs.modal_webhook)">Add Event</button>
|
|
</section>
|
|
|
|
<div class="margin-bottom toggle" data-ls-ui-open data-button-aria="Advanced Options">
|
|
<i class="icon-plus pull-end margin-top-tiny"></i>
|
|
<i class="icon-minus pull-end margin-top-tiny"></i>
|
|
|
|
<h2 class="margin-bottom">
|
|
Advanced Options
|
|
<small class="text-size-small">(optional)</small>
|
|
</h2>
|
|
|
|
<label data-ls-attrs="for=security-{{project-webhook.$id}}" class="margin-bottom-small">
|
|
<div class="margin-bottom-small">SSL / TLS (Certificate verification)</div>
|
|
|
|
<input <?php if ($new): ?>checked<?php else: ?>data-ls-bind="{{project-webhook.security}}"<?php endif; ?> name="security" type="radio" required data-ls-attrs="id=secure-yes-{{project-webhook.$id}}" value="true" data-cast-to="boolean" /> <span>Enabled</span>
|
|
<input name="security" type="radio" required data-ls-attrs="id=secure-no-{{project-webhook.$id}}" data-ls-bind="{{project-webhook.security}}" value="false" data-cast-to="boolean" /> <span>Disabled</span>
|
|
</label>
|
|
|
|
<p class="margin-bottom text-size-small text-fade"><span class="text-red">Warning</span>: Untrusted or self-signed certificates may not be secure.
|
|
<a href="https://en.wikipedia.org/wiki/Self-signed_certificate" target="_blank" rel="noopener">Learn more<i class="icon-link-ext"></i></a>
|
|
</p>
|
|
|
|
<label>HTTP Authentication <span class="tooltip" data-tooltip="Use to secure your endpoint from untrusted sources"><i class="icon-question"></i></span> <small>(optional)</small></label>
|
|
|
|
<div class="row responsive thin">
|
|
<div class="col span-6 margin-bottom">
|
|
<label data-ls-attrs="for=httpUser-{{project-webhook.$id}}">User</label>
|
|
<input type="text" class="full-width margin-bottom-no" data-ls-attrs="id=httpUser-{{project-webhook.$id}}" name="httpUser" autocomplete="off" data-ls-bind="{{project-webhook.httpUser}}" />
|
|
</div>
|
|
<div class="col span-6 margin-bottom">
|
|
<label data-ls-attrs="for=httpPass-{{project-webhook.$id}}">Password</label>
|
|
<input type="password" data-forms-show-secret class="full-width margin-bottom-no" data-ls-attrs="id=httpPass-{{project-webhook.$id}}" name="httpPass" autocomplete="off" data-ls-bind="{{project-webhook.httpPass}}" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<footer>
|
|
<button type="submit">Update</button>
|
|
</footer>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
<?php if (!$new) : ?>
|
|
<div class="col span-4 sticky-top margin-bottom">
|
|
<label>Webhook ID</label>
|
|
<div class="input-copy margin-bottom">
|
|
<input id="uid" type="text" autocomplete="off" placeholder="" data-ls-bind="{{project-webhook.$id}}" disabled data-forms-copy>
|
|
</div>
|
|
|
|
<label>Signature Key <span class="tooltip small" data-tooltip="Can be used to validate your Webhooks."><i class="icon-info-circled"></i></span></label>
|
|
<div class="input-copy margin-bottom">
|
|
<input id="signatureKey" type="text" autocomplete="off" placeholder="" data-ls-bind="{{project-webhook.signatureKey}}" disabled data-forms-copy>
|
|
</div>
|
|
|
|
<form
|
|
class="margin-bottom"
|
|
data-analytics
|
|
data-analytics-activity
|
|
data-analytics-event="submit"
|
|
data-analytics-category="console"
|
|
data-analytics-label="Update Project Webhook Signature"
|
|
data-service="projects.updateWebhookSignature"
|
|
data-scope="console"
|
|
data-event="submit"
|
|
data-confirm="Are you sure you want to generate a new Signature Key?"
|
|
data-success="trigger"
|
|
data-success-param-alert-text="Updated webhook signature key successfully"
|
|
data-success-param-trigger-events="projects.updateWebhookSignature"
|
|
data-failure="alert"
|
|
data-failure-param-alert-text="Failed to update webhook signature key"
|
|
data-failure-param-alert-classname="error">
|
|
|
|
<input type="hidden" name="projectId" data-ls-bind="{{router.params.project}}" />
|
|
<input type="hidden" name="webhookId" data-ls-bind="{{project-webhook.$id}}" />
|
|
|
|
<button class="fill">Update Signature Key</button>
|
|
</form>
|
|
|
|
<form
|
|
class="margin-bottom"
|
|
data-analytics
|
|
data-analytics-activity
|
|
data-analytics-event="submit"
|
|
data-analytics-category="console"
|
|
data-analytics-label="Delete Project Webhook"
|
|
data-service="projects.deleteWebhook"
|
|
data-scope="console"
|
|
data-event="submit"
|
|
data-confirm="Are you sure you want to delete this webhook?"
|
|
data-success="alert,redirect"
|
|
data-success-param-redirect-url="/console/webhooks?project={{router.params.project}}"
|
|
data-success-param-alert-text="Deleted webhook successfully"
|
|
data-success-param-trigger-events="projects.deleteWebhook"
|
|
data-failure="alert"
|
|
data-failure-param-alert-text="Failed to delete webhook"
|
|
data-failure-param-alert-classname="error">
|
|
|
|
<input type="hidden" name="projectId" data-ls-bind="{{router.params.project}}" />
|
|
<input type="hidden" name="webhookId" data-ls-bind="{{project-webhook.$id}}" />
|
|
|
|
<button class="danger fill">Delete Webhook</button>
|
|
</form>
|
|
</div>
|
|
<?php endif; ?>
|
|
<div x-ref="modal_webhook" data-ui-modal class="modal box close width-small height-small" data-button-hide="on">
|
|
<div>
|
|
<form @submit.prevent="addEvent($refs.modal_webhook)">
|
|
<label for="event">
|
|
Event
|
|
</label>
|
|
<select id="event" x-model="selected" @change="setEvent()">
|
|
<option value="" selected>Select event</option>
|
|
<?php foreach ($patterns as $event) : ?>
|
|
<option value="<?php echo $event; ?>"><?php echo $event; ?></option>
|
|
<?php endforeach; ?>
|
|
</select>
|
|
<div x-show="hasResource">
|
|
<label x-text="resourceName + ' (optional)'" for="resource"></label>
|
|
<input id="resource" type="text" :placeholder="resourceName" x-model="resource" maxlength="36" pattern="^[a-zA-Z0-9][a-zA-Z0-9_-]{0,35}$">
|
|
<div class="text-fade text-size-xs margin-top-negative-small margin-bottom">Leave empty for wildcard</div>
|
|
</div>
|
|
<div x-show="hasSubResource">
|
|
<label x-text="subResourceName + ' (optional)'" for="subResource"></label>
|
|
<input id="subResource" type="text" :placeholder="subResourceName" x-model="subResource" maxlength="36" pattern="^[a-zA-Z0-9][a-zA-Z0-9_-]{0,35}$">
|
|
<div class="text-fade text-size-xs margin-top-negative-small margin-bottom">Leave empty for wildcard</div>
|
|
</div>
|
|
<div x-show="hasSubSubResource">
|
|
<label x-text="subSubResourceName + ' (optional)'" for="subSubResource"></label>
|
|
<input id="subSubResource" type="text" :placeholder="subSubResourceName" x-model="subSubResource" maxlength="36" pattern="^[a-zA-Z0-9][a-zA-Z0-9_-]{0,35}$">
|
|
<div class="text-fade text-size-xs margin-top-negative-small margin-bottom">Leave empty for wildcard</div>
|
|
</div>
|
|
<div x-show="hasAttribute">
|
|
<label for="attribute">Add Attribute (optional)</label>
|
|
<select id="attribute" x-model="attribute">
|
|
<option value="*">Select attribute</option>
|
|
<template x-for="attr in attributes">
|
|
<option :value="attr" x-text="attr"></option>
|
|
</template>
|
|
</select>
|
|
</div>
|
|
<button x-show="selected" type="submit">Add Event</button> <button data-ui-modal-close="" type="button" class="reverse">Cancel</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|