2020-05-11 18:47:53 +12:00
<?php
2020-07-15 15:38:57 +12:00
$fileLimit = $this->getParam('fileLimit', 0);
$fileLimitHuman = $this->getParam('fileLimitHuman', 0);
2020-05-11 18:47:53 +12:00
$events = array_keys($this->getParam('events', []));
2020-07-20 02:42:46 +12:00
$timeout = $this->getParam('timeout', 900);
2021-08-04 18:39:23 +12:00
$usageStatsEnabled = $this->getParam('usageStatsEnabled', true);
2020-05-11 18:47:53 +12:00
?>
2020-05-11 16:39:00 +12:00
< div
data-service="functions.get"
data-name="project-function"
2022-01-25 13:36:33 +13:00
data-event="load,functions.update,functions.createDeployment,functions.updateDeployment,functions.deleteDeployment,functions.retryBuild"
2020-05-11 16:39:00 +12:00
data-param-function-id="{{router.params.id}}"
data-success="trigger"
data-success-param-trigger-events="functions.get">
< div class = "cover" >
< h1 class = "zone xl margin-bottom-large" >
2020-06-14 10:57:34 +12:00
< a data-ls-attrs = "href=/console/functions?project={{router.params.project}}" class = "back text-size-small link-return-animation--start" > < i class = "icon-left-open" > < / i > Functions< / a >
2020-05-11 16:39:00 +12:00
< br / >
2020-05-11 18:47:53 +12:00
< span data-ls-bind = "{{project-function.name}} " > < / span >
2020-05-11 16:39:00 +12:00
< / h1 >
< / div >
< div data-ui-modal class = "modal width-large box close" data-button-hide = "on" data-open-event = "open-json" >
2021-08-04 18:39:23 +12:00
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
2020-05-11 16:39:00 +12:00
< h2 > JSON View< / h2 >
< div class = "margin-bottom" >
< input type = "hidden" data-ls-bind = "{{project-function}}" data-forms-code / >
< / div >
< button data-ui-modal-close = "" type = "button" class = "reverse" > Cancel< / button >
< / div >
< div class = "zone xl" >
< ul class = "phases clear" data-ui-phases data-selected = "{{router.params.tab}}" >
< li data-state = "/console/functions/function?id={{router.params.id}}&project={{router.params.project}}" >
2021-08-04 18:39:23 +12:00
2020-05-13 10:00:48 +12:00
< h2 > Overview< / h2 >
2021-08-04 18:39:23 +12:00
2020-05-13 10:00:48 +12:00
< div class = "row responsive margin-top-negative" >
< div class = "col span-8 margin-bottom" >
< label > < / label >
< div class = "box margin-bottom-large" >
< div class = "text-align-center" >
2021-06-24 00:15:27 +12:00
< img src = "" data-ls-attrs = "src=/images/runtimes/{{project-function.runtime|runtimeLogo}}" alt = "Function Runtime" class = "avatar huge margin-top-negative-xxl" / >
2020-05-13 10:00:48 +12:00
2021-06-24 00:15:27 +12:00
< p class = "text-fade margin-bottom-small" data-ls-bind = "{{project-function.runtime|runtimeName}} {{project-function.runtime|runtimeVersion}}" >
2020-05-13 10:00:48 +12:00
< / p >
2022-01-25 13:36:33 +13:00
< div data-ls-if = "{{project-function.deployment}} !== ''" class = "margin-top" >
2021-03-12 01:39:06 +13:00
< button data-ls-ui-trigger = "execute-now" > Execute Now< / button > < a data-ls-attrs = "href=/console/functions/function/logs?id={{router.params.id}}&project={{router.params.project}}" class = "button reverse" style = "vertical-align: top;" > View Logs< / a >
< / div >
2020-05-13 10:00:48 +12:00
< / div >
< / div >
< div class = "margin-bottom"
2022-01-25 13:36:33 +13:00
data-service="functions.listDeployments"
2020-05-13 10:00:48 +12:00
data-scope="sdk"
2022-01-25 13:36:33 +13:00
data-event="load,functions.createDeployment,functions.deleteDeployment,functions.updateDeployment,functions.retryBuild"
data-name="project-function-deployments"
2020-07-15 15:38:57 +12:00
data-param-function-id="{{router.params.id}}"
2020-07-19 09:15:02 +12:00
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-offset=""
2020-07-17 00:04:06 +12:00
data-param-order-type="DESC"
2020-05-13 10:00:48 +12:00
data-success="trigger"
2022-01-25 13:36:33 +13:00
data-success-param-trigger-events="functions.listDeployments">
2020-05-13 10:00:48 +12:00
2022-01-25 13:36:33 +13:00
< h3 > Deployments < span class = "text-fade text-size-small pull-end margin-top-small" data-ls-bind = "{{project-function-deployments.sum}} deployments found" > < / span > < / h3 >
2020-07-19 01:49:20 +12:00
2022-01-25 13:36:33 +13:00
< div data-ls-if = "0 == {{project-function-deployments.deployments.length}} || undefined == {{project-function-deployments.deployments.length}}" class = "box margin-top margin-bottom" >
< h3 class = "margin-bottom-small text-bold" > No Deployments Found< / h3 >
2020-05-13 10:00:48 +12:00
2022-01-25 13:36:33 +13:00
< p class = "margin-bottom-no" > You haven't deployed any deployments for your function yet.< / p >
2020-05-13 10:00:48 +12:00
< / div >
2022-01-25 13:36:33 +13:00
< div data-ls-if = "(0 != {{project-function-deployments.deployments.length}}) && (undefined !== {{project-function-deployments.deployments.length}})" >
2020-05-13 10:00:48 +12:00
< div class = "box margin-bottom" >
2022-01-25 13:36:33 +13:00
< ul data-ls-loop = "project-function-deployments.deployments" data-ls-as = "deployment" class = "list" >
2020-05-13 10:00:48 +12:00
< li class = "clear" >
2022-01-25 13:36:33 +13:00
< div data-ui-modal class = "modal width-large box close" data-button-hide = "on" data-open-event = "open-stderr-{{deployment.$id}}" >
2021-11-15 15:18:53 +13:00
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
< h2 > Build Error Log< / h2 >
< div class = "margin-bottom" >
2022-01-25 13:36:33 +13:00
< input type = "hidden" data-ls-bind = "{{deployment.buildStderr}}" data-forms-code = "bash" data-lang = "bash" data-lang-label = "Bash" / >
2021-11-15 15:18:53 +13:00
< / div >
< button data-ui-modal-close = "" type = "button" class = "reverse" > Cancel< / button >
< / div >
2022-01-25 13:36:33 +13:00
< div data-ui-modal class = "modal width-large box close" data-button-hide = "on" data-open-event = "open-stdout-{{deployment.$id}}" >
2021-11-15 15:18:53 +13:00
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
< h2 > Build Log< / h2 >
< div class = "margin-bottom" >
2022-01-25 13:36:33 +13:00
< input type = "hidden" data-ls-bind = "{{deployment.buildStdout}}" data-forms-code = "bash" data-lang = "bash" data-lang-label = "Bash" / >
2021-11-15 15:18:53 +13:00
< / div >
< button data-ui-modal-close = "" type = "button" class = "reverse" > Cancel< / button >
< / div >
2022-01-25 13:36:33 +13:00
< form data-ls-if = "({{deployment.$id}} !== {{project-function.deployment}} && {{deployment.status}} == 'ready')" name = "functions.updateDeployment" class = "pull-end"
2021-01-18 19:29:26 +13:00
data-analytics
data-analytics-activity
2020-07-16 07:09:46 +12:00
data-analytics-event="submit"
data-analytics-category="console"
data-analytics-label="Create Function Execution"
2022-01-25 13:36:33 +13:00
data-service="functions.updateDeployment"
2020-07-16 07:09:46 +12:00
data-event="submit"
data-param-function-id="{{router.params.id}}"
data-success="alert,trigger"
2022-01-25 13:36:33 +13:00
data-success-param-alert-text="Deployment updated successfully"
data-success-param-trigger-events="functions.updateDeployment"
2020-07-16 07:09:46 +12:00
data-failure="alert"
2022-01-25 13:36:33 +13:00
data-failure-param-alert-text="Failed to update deployment"
2020-07-16 07:09:46 +12:00
data-failure-param-alert-classname="error">
2022-02-17 09:38:58 +13:00
< input type = "hidden" name = "deploymentId" data-ls-bind = "{{deployment.$id}}" >
2020-07-18 18:16:34 +12:00
< button > Activate< / button >
2020-07-16 07:09:46 +12:00
< / form >
2022-01-25 13:36:33 +13:00
< form data-ls-if = "({{deployment.$id}} !== {{project-function.deployment}} && {{deployment.status}} == 'failed')" name = "functions.retryBuild" class = "pull-end"
2021-12-09 04:08:53 +13:00
data-analytics
data-analytics-activity
data-analytics-event="submit"
data-analytics-category="console"
data-analytics-label="Retry Build"
data-service="functions.retryBuild"
data-event="submit"
data-success="alert,trigger"
data-success-param-alert-text="Build started successfully"
data-success-param-trigger-events="functions.retryBuild"
data-failure="alert"
data-failure-param-alert-text="Failed to retry build"
data-failure-param-alert-classname="error">
2022-01-25 13:36:33 +13:00
< input type = "hidden" name = "buildId" data-ls-bind = "{{deployment.buildId}}" >
2022-02-17 09:06:22 +13:00
< input type = "hidden" name = "functionId" data-ls-bind = "{{router.params.id}}" >
< input type = "hidden" name = "deploymentId" data-ls-bind = "{{deployment.$id}}" >
2021-12-09 04:08:53 +13:00
< button > Retry Build< / button >
< / form >
2021-11-15 15:18:53 +13:00
2022-01-25 13:36:33 +13:00
< b data-ls-bind = "{{deployment.$id}}" > < / b >
< span class = "text-fade" data-ls-bind = "{{deployment.entrypoint}}" > < / span >
2020-07-19 09:49:15 +12:00
< div class = "text-size-small margin-top-small clear" >
2022-01-25 13:36:33 +13:00
< span data-ls-if = "{{deployment.status}} == 'failed'" style = "color: var(--config-color-danger)" class = "pull-start" data-ls-bind = "{{deployment.status}}" > < / span >
< span data-ls-if = "{{deployment.status}} == 'ready'" style = "color: var(--config-color-success)" class = "pull-start" data-ls-bind = "{{deployment.status}}" > < / span >
< span data-ls-if = "{{deployment.status}} == 'processing' || {{deployment.status}} == 'building'" style = "color: var(--config-color-info)" class = "pull-start" data-ls-bind = "{{deployment.status}}" > < / span >
< span class = "pull-start" data-ls-bind = " | Created {{deployment.dateCreated|timeSince}} | {{deployment.size|humanFileSize}}{{deployment.size|humanFileUnit}}" > < / span >
2020-07-19 09:49:15 +12:00
2022-01-25 13:36:33 +13:00
< span data-ls-if = "{{deployment.status}} == 'failed'" > | < button type = "button" class = "link text-size-small" data-ls-ui-trigger = "open-stderr-{{deployment.$id}}" > Logs< / button > < / span >
< span data-ls-if = "{{deployment.status}} == 'ready'" > | < button type = "button" class = "link text-size-small" data-ls-ui-trigger = "open-stdout-{{deployment.$id}}" > Logs< / button > < / span >
2021-12-07 03:12:41 +13:00
2022-01-25 13:36:33 +13:00
< form data-ls-if = "{{deployment.$id}} !== {{project-function.deployment}}" name = "functions.deleteDeployment" class = "pull-start"
2021-01-18 19:29:26 +13:00
data-analytics
data-analytics-activity
2020-07-19 09:49:15 +12:00
data-analytics-event="submit"
data-analytics-category="console"
2022-01-25 13:36:33 +13:00
data-analytics-label="Delete Function Deployment"
data-service="functions.deleteDeployment"
2020-07-19 09:49:15 +12:00
data-event="submit"
data-param-function-id="{{router.params.id}}"
2022-01-25 13:36:33 +13:00
data-confirm="Are you sure you want to delete this function deployment?"
2020-07-19 09:49:15 +12:00
data-success="alert,trigger"
2022-01-25 13:36:33 +13:00
data-success-param-alert-text="Function deployment deleted successfully"
data-success-param-trigger-events="functions.deleteDeployment"
2020-07-19 09:49:15 +12:00
data-failure="alert"
2022-01-25 13:36:33 +13:00
data-failure-param-alert-text="Failed to delete function deployment"
2020-07-19 09:49:15 +12:00
data-failure-param-alert-classname="error">
2022-01-25 13:36:33 +13:00
< input type = "hidden" name = "deploymentId" data-ls-bind = "{{deployment.$id}}" / >
2020-07-19 09:49:15 +12:00
2020-07-20 02:42:46 +12:00
| < button type = "submit" class = "link text-danger text-size-small" > Delete< / button >
2020-07-19 09:49:15 +12:00
< / form >
< / div >
2020-05-13 10:00:48 +12:00
< / li >
< / ul >
< / div >
< / div >
< / div >
< div class = "pull-start" >
2022-01-25 13:54:44 +13:00
< button data-ls-ui-trigger = "deploy-deployment" > Create Deployment< / button >
2020-05-13 10:00:48 +12:00
< / div >
< div class = "pull-end paging" >
< form
2022-01-25 13:36:33 +13:00
data-service="functions.listDeployments"
2020-05-13 10:00:48 +12:00
data-event="submit"
2020-07-19 09:15:02 +12:00
data-param-function-id="{{router.params.id}}"
2020-05-13 10:00:48 +12:00
data-param-search="{{router.params.search}}"
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-order-type="DESC"
data-scope="sdk"
2022-01-25 13:36:33 +13:00
data-name="project-function-deployments"
2020-05-13 10:00:48 +12:00
data-success="state"
data-success-param-state-keys="search,offset">
2022-01-25 13:36:33 +13:00
< button name = "offset" data-paging-back data-offset = "{{router.params.offset}}" data-sum = "{{project-function-deployments.sum}}" class = "margin-end round small" aria-label = "Back" > < i class = "icon-left-open" > < / i > < / button >
2020-05-13 10:00:48 +12:00
< / form >
2022-01-25 13:36:33 +13:00
< span data-ls-bind = "{{router.params.offset|pageCurrent}} / {{project-function-deployments.sum|pageTotal}}" > < / span >
2020-05-13 10:00:48 +12:00
< form
2022-01-25 13:36:33 +13:00
data-service="functions.listDeployments"
2020-05-13 10:00:48 +12:00
data-event="submit"
2020-07-19 09:15:02 +12:00
data-param-function-id="{{router.params.id}}"
2020-05-13 10:00:48 +12:00
data-param-search="{{router.params.search}}"
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-order-type="DESC"
data-scope="sdk"
2022-01-25 13:36:33 +13:00
data-name="project-function-deployments"
2020-05-13 10:00:48 +12:00
data-success="state"
data-success-param-state-keys="search,offset">
2022-01-25 13:36:33 +13:00
< button name = "offset" data-paging-next data-offset = "{{router.params.offset}}" data-sum = "{{project-function-deployments.sum}}" class = "margin-start round small" aria-label = "Next" > < i class = "icon-right-open" > < / i > < / button >
2020-05-13 10:00:48 +12:00
< / form >
< / div >
< / div >
< div class = "col span-4 sticky-top margin-bottom" >
< label > Function ID< / label >
< div class = "input-copy margin-bottom" >
< input id = "uid" type = "text" autocomplete = "off" placeholder = "" data-ls-bind = "{{project-function.$id}}" disabled data-forms-copy >
< / div >
< ul class = "margin-bottom-large text-fade text-size-small" >
< li class = "margin-bottom-small" > < i class = "icon-angle-circled-right margin-start-tiny margin-end-tiny" > < / i > < button data-ls-ui-trigger = "open-json" class = "link text-size-small" > View as JSON< / button > < / li >
2020-07-15 23:22:38 +12:00
< li class = "margin-bottom-small" > < i class = "icon-angle-circled-right margin-start-tiny margin-end-tiny" > < / i > Last Updated: < span data-ls-bind = "{{project-function.dateUpdated|dateText}}" > < / span > < / li >
< li class = "margin-bottom-small" > < i class = "icon-angle-circled-right margin-start-tiny margin-end-tiny" > < / i > Created: < span data-ls-bind = "{{project-function.dateCreated|dateText}}" > < / span > < / li >
2020-05-13 10:00:48 +12:00
< / ul >
< form name = "functions.delete" class = "margin-bottom"
2021-01-18 19:29:26 +13:00
data-analytics
data-analytics-activity
2020-05-13 10:00:48 +12:00
data-analytics-event="submit"
data-analytics-category="console"
data-analytics-label="Delete Function"
data-service="functions.delete"
data-event="submit"
data-param-function-id="{{router.params.id}}"
data-confirm="Are you sure you want to delete this function?"
data-success="alert,trigger,redirect"
data-success-param-alert-text="Function deleted successfully"
data-success-param-trigger-events="functions.delete"
data-success-param-redirect-url="/console/functions?project={{router.params.project}}"
data-failure="alert"
data-failure-param-alert-text="Failed to delete function"
data-failure-param-alert-classname="error">
< button type = "submit" class = "danger fill" > Delete Function< / button >
< / form >
< / div >
< / div >
2020-05-11 16:39:00 +12:00
< / li >
2021-08-04 18:39:23 +12:00
<?php if ( $usageStatsEnabled ) : ?>
2020-10-31 08:53:27 +13:00
< li data-state = "/console/functions/function/monitors?id={{router.params.id}}&project={{router.params.project}}" >
2021-08-04 18:39:23 +12:00
2020-10-31 08:53:27 +13:00
< form class = "pull-end margin-start-small margin-top-small" data-ls-if = "{{usage.range}} !== '90d'"
data-service="functions.getUsage"
data-event="submit"
data-name="usage"
data-param-function-id="{{router.params.id}}"
data-param-range="90d">
< button class = "tick" > 90d< / button >
< / form >
< button class = "tick pull-end margin-start-small margin-top-small" data-ls-if = "{{usage.range}} === '90d'" disabled > 90d< / button >
< form class = "pull-end margin-start-small margin-top-small" data-ls-if = "{{usage.range}} !== '30d'"
data-service="functions.getUsage"
data-event="submit"
data-name="usage"
data-param-function-id="{{router.params.id}}">
< button class = "tick" > 30d< / button >
< / form >
< button class = "tick pull-end margin-start-small margin-top-small" data-ls-if = "{{usage.range}} === '30d'" disabled > 30d< / button >
< form class = "pull-end margin-start-small margin-top-small" data-ls-if = "{{usage.range}} !== '24h'"
data-service="functions.getUsage"
data-event="submit"
data-name="usage"
data-param-function-id="{{router.params.id}}"
data-param-range="24h">
< button class = "tick" > 24h< / button >
< / form >
< button class = "tick pull-end margin-start-small margin-top-small" data-ls-if = "{{usage.range}} === '24h'" disabled > 24h< / button >
< h2 > Monitors< / h2 >
2021-08-04 18:39:23 +12:00
< div
2020-10-31 08:53:27 +13:00
data-service="functions.getUsage"
data-event="load"
data-name="usage"
data-param-function-id="{{router.params.id}}">
< div class = "box margin-bottom-small" >
< div class = "margin-start-negative-small margin-end-negative-small margin-top-negative-small margin-bottom-negative-small" >
2021-11-25 23:54:02 +13:00
< div class = "chart background-image-no border-no margin-bottom-no" >
2021-11-25 22:07:34 +13:00
< input type = "hidden" data-ls-bind = "{{usage}}" data-forms-chart = "Executions=functionsExecutions" data-height = "140" data-show-y-axis = "true" / >
2020-10-31 08:53:27 +13:00
< / div >
< / div >
< / div >
< ul class = "chart-notes margin-bottom-large" >
2021-10-27 02:19:28 +13:00
< li > Executions < span data-ls-bind = "({{usage.functionsExecutions|statsGetLast|statsTotal}})" > < / span > < / li >
2020-10-31 08:53:27 +13:00
< / ul >
< div class = "box margin-bottom-small" >
< div class = "margin-start-negative-small margin-end-negative-small margin-top-negative-small margin-bottom-negative-small" >
2021-11-25 23:54:02 +13:00
< div class = "chart background-image-no border-no margin-bottom-no" >
2021-12-21 04:52:24 +13:00
< input type = "hidden" data-ls-bind = "{{usage}}" data-forms-chart = "CPU Time (milliseconds)=functionsCompute" data-colors = "orange" data-height = "140" data-show-y-axis = "true" / >
2020-10-31 08:53:27 +13:00
< / div >
< / div >
< / div >
< ul class = "chart-notes margin-bottom-large" >
2021-10-27 02:19:28 +13:00
< li class = "orange" > CPU Time < span data-ls-bind = "({{usage.functionsCompute|statsGetLast|seconds2hum}})" > < / span > < / li >
2020-10-31 08:53:27 +13:00
< / ul >
2020-06-14 08:26:45 +12:00
2020-10-31 08:53:27 +13:00
< div class = "box margin-bottom-small" >
< div class = "margin-start-negative-small margin-end-negative-small margin-top-negative-small margin-bottom-negative-small" >
2021-11-25 23:54:02 +13:00
< div class = "chart background-image-no border-no margin-bottom-no" >
2021-11-25 22:07:34 +13:00
< input type = "hidden" data-ls-bind = "{{usage}}" data-forms-chart = "Failures=functionsFailures" data-colors = "red" data-height = "140" data-show-y-axis = "true" / >
2020-10-31 08:53:27 +13:00
< / div >
2020-06-14 08:26:45 +12:00
< / div >
< / div >
2020-10-31 08:53:27 +13:00
< ul class = "chart-notes margin-bottom-large" >
2021-10-27 02:19:28 +13:00
< li class = "red" > Errors < span data-ls-bind = "({{usage.functionsFailures|statsGetLast|statsTotal}})" > < / span > < / li >
2020-10-31 08:53:27 +13:00
< / ul >
2020-06-14 08:26:45 +12:00
< / div >
2020-10-31 08:53:27 +13:00
< / li >
2021-08-04 18:39:23 +12:00
<?php endif ; ?>
2020-10-31 08:53:27 +13:00
< li data-state = "/console/functions/function/logs?id={{router.params.id}}&project={{router.params.project}}" >
2020-06-14 08:26:45 +12:00
2020-10-31 08:53:27 +13:00
< div class = "text-fade text-size-small pull-end margin-top" data-ls-bind = "{{project-function-executions.sum}} executions found" > < / div >
2020-06-14 08:26:45 +12:00
2020-10-31 08:53:27 +13:00
< h2 > Logs< / h2 >
2020-06-14 08:26:45 +12:00
2020-07-17 20:14:16 +12:00
< div
2020-07-17 09:51:26 +12:00
data-service="functions.listExecutions"
data-scope="sdk"
data-event="load,functions.createExecution"
data-name="project-function-executions"
data-param-function-id="{{router.params.id}}"
2020-07-19 09:15:02 +12:00
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-offset=""
2020-07-17 09:51:26 +12:00
data-param-order-type="DESC"
data-success="trigger"
data-success-param-trigger-events="functions.listExecutions">
2020-07-17 20:14:16 +12:00
2020-07-19 09:15:02 +12:00
< div data-ls-if = "0 < {{project-function-executions.executions.length}} && undefined !== {{project-function-executions.executions}}" >
< div class = "box margin-bottom" >
< table class = "vertical small" >
< thead >
< tr >
< th width = "30" > < / th >
2020-10-31 08:53:27 +13:00
< th width = "160" > Created< / th >
2020-07-19 09:15:02 +12:00
< th width = "150" > Status< / th >
2020-10-31 08:53:27 +13:00
< th width = "120" > Trigger< / th >
< th width = "80" > Runtime< / th >
2020-07-19 09:15:02 +12:00
< th > < / th >
< / tr >
< / thead >
< tbody data-ls-loop = "project-function-executions.executions" data-ls-as = "execution" >
< tr >
< td data-title = "" >
< i class = "dot danger" data-ls-if = "{{execution.status}} === 'failed'" > < / i >
< i class = "dot info" data-ls-if = "{{execution.status}} === 'waiting'" > < / i >
< i class = "dot info" data-ls-if = "{{execution.status}} === 'processing'" > < / i >
< i class = "dot success" data-ls-if = "{{execution.status}} === 'completed'" > < / i >
< / td >
2020-10-31 08:53:27 +13:00
< td data-title = "Date: " >
< span data-ls-bind = "{{execution.dateCreated|dateTime}}" > < / span >
< / td >
2020-07-19 09:15:02 +12:00
< td data-title = "Status: " >
< span data-ls-bind = "{{execution.status}}" > < / span >
2021-12-10 23:43:56 +13:00
< span class = "text-fade text-size-small" data-ls-if = "{{execution.statusCode}} < 200 && {{execution.statusCode}} >= 300" data-ls-bind = " exit code: {{execution.statusCode}}" > < / span >
2020-07-19 09:15:02 +12:00
< / td >
2020-10-31 08:53:27 +13:00
< td data-title = "Trigger: " >
< span data-ls-bind = "{{execution.trigger}}" > < / span >
2020-07-19 09:15:02 +12:00
< / td >
< td data-title = "Runtime: " >
< span data-ls-if = "{{execution.status}} === 'completed' || {{execution.status}} === 'failed'" data-ls-bind = "{{execution.time|seconds2hum}}" > < / span >
< span data-ls-if = "{{execution.status}} === 'waiting' || {{execution.status}} === 'processing'" > -< / span >
< / td >
2020-10-31 08:53:27 +13:00
< td data-title = "" >
2020-07-19 09:15:02 +12:00
< div data-ls-if = "{{execution.status}} === 'completed' || {{execution.status}} === 'failed'" data-title = "" >
2021-08-04 18:39:23 +12:00
2020-07-19 09:15:02 +12:00
< button class = "desktops-only pull-end link margin-start text-danger" data-ls-ui-trigger = "execution-stderr-{{execution.$id}}" > Errors< / button >
< button class = "desktops-only pull-end link margin-start" data-ls-ui-trigger = "execution-stdout-{{execution.$id}}" > Output< / button >
2020-10-31 08:53:27 +13:00
< button class = "phones-only-inline tablets-only-inline link margin-end-small" data-ls-ui-trigger = "execution-stdout-{{execution.$id}}" > Output< / button >
< button class = "phones-only-inline tablets-only-inline link text-danger" data-ls-ui-trigger = "execution-stderr-{{execution.$id}}" > Errors< / button >
2020-07-19 09:15:02 +12:00
< div data-ui-modal class = "modal width-large box close" data-button-alias = "none" data-open-event = "execution-stdout-{{execution.$id}}" >
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
< h1 > STDOUT< / h1 >
2020-10-31 08:53:27 +13:00
< div class = "margin-bottom ide" data-ls-if = "({{execution.stdout.length}})" >
< pre data-ls-bind = "{{execution.stdout}}" > < / pre >
<!-- <input type="hidden" data - ls - bind="{{execution.stdout}}" data - forms - code="bash" /> -->
2020-07-19 09:15:02 +12:00
< / div >
2020-07-18 18:16:34 +12:00
2020-10-31 08:53:27 +13:00
< div class = "margin-bottom" data-ls-if = "(!{{execution.stdout.length}})" >
< p > No output was logged.< / p >
< / div >
2020-07-19 09:15:02 +12:00
< / div >
2020-07-18 18:16:34 +12:00
2020-07-19 09:15:02 +12:00
< div data-ui-modal class = "modal width-large box close" data-button-alias = "none" data-open-event = "execution-stderr-{{execution.$id}}" >
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
2020-07-18 18:16:34 +12:00
2020-07-19 09:15:02 +12:00
< h1 > STDERR< / h1 >
2020-07-18 18:16:34 +12:00
2020-10-31 08:53:27 +13:00
< div class = "margin-bottom ide" data-ls-if = "({{execution.stderr.length}})" >
< pre data-ls-bind = "{{execution.stderr}}" > < / pre >
<!-- <input type="hidden" data - ls - bind="{{execution.stderr}}" data - forms - code="bash" /> -->
< / div >
< div class = "margin-bottom" data-ls-if = "(!{{execution.stderr.length}})" >
< p > No errors were logged.< / p >
2020-07-19 09:15:02 +12:00
< / div >
2020-07-18 18:16:34 +12:00
< / div >
< / div >
2020-07-19 09:15:02 +12:00
< / td >
< / tr >
< / tbody >
< / table >
< / div >
< div class = "text-align-center paging" >
< form
data-service="functions.listExecutions"
data-event="submit"
data-param-function-id="{{router.params.id}}"
data-param-search="{{router.params.search}}"
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-order-type="DESC"
data-scope="sdk"
data-name="project-function-executions"
data-success="state"
data-success-param-state-keys="search,offset">
< button name = "offset" data-paging-back data-offset = "{{router.params.offset}}" data-sum = "{{project-function-executions.sum}}" class = "margin-end round small" aria-label = "Back" > < i class = "icon-left-open" > < / i > < / button >
< / form >
< span data-ls-bind = "{{router.params.offset|pageCurrent}} / {{project-function-executions.sum|pageTotal}}" > < / span >
< form
data-service="functions.listExecutions"
data-event="submit"
data-param-function-id="{{router.params.id}}"
data-param-search="{{router.params.search}}"
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-order-type="DESC"
data-scope="sdk"
data-name="project-function-executions"
data-success="state"
data-success-param-state-keys="search,offset">
< button name = "offset" data-paging-next data-offset = "{{router.params.offset}}" data-sum = "{{project-function-executions.sum}}" class = "margin-start round small" aria-label = "Next" > < i class = "icon-right-open" > < / i > < / button >
< / form >
< / div >
2020-07-17 20:14:16 +12:00
< / div >
< div data-ls-if = "(!{{project-function-executions.executions.length}})" class = "box dashboard margin-bottom" >
< div class = "margin-bottom-small margin-top-small margin-end margin-start" >
< h3 class = "margin-bottom-small text-bold" > No Logs Founds< / h3 >
< p class = "margin-bottom-no" > Execute your function to view execution logs.< / p >
< / div >
< / div >
2020-06-14 08:26:45 +12:00
< / div >
< / li >
2020-05-11 16:39:00 +12:00
< li data-state = "/console/functions/function/settings?id={{router.params.id}}&project={{router.params.project}}" >
< h2 > Settings< / h2 >
< div class = "row responsive margin-top-negative" >
2020-05-13 10:00:48 +12:00
< div class = "col span-8 margin-bottom" >
< label > < / label >
2020-05-11 16:39:00 +12:00
< form
2021-01-18 19:29:26 +13:00
data-analytics
data-analytics-activity
2020-05-11 16:39:00 +12:00
data-analytics-event="submit"
data-analytics-category="console"
data-analytics-label="Update Function"
data-service="functions.update"
data-scope="sdk"
data-event="submit"
data-param-function-id="{{router.params.id}}"
data-success="alert,trigger"
data-success-param-alert-text="Updated function successfully"
data-success-param-trigger-events="functions.update"
data-failure="alert"
data-failure-param-alert-text="Failed to update function"
data-failure-param-alert-classname="error">
< div class = "box" >
2020-07-17 20:14:16 +12:00
< section class = "margin-bottom-large" >
< label for = "name" > Name< / label >
2020-09-08 09:28:40 +12:00
< input name = "name" id = "function-name" type = "text" autocomplete = "off" data-ls-bind = "{{project-function.name}}" data-forms-text-direction required placeholder = "Function Name" maxlength = "128" / >
2021-02-02 11:34:54 +13:00
< label for = "execute" > Execute Access < span class = "tooltip small" data-tooltip = "Choose who can execute this function using the client API." > < i class = "icon-info-circled" > < / i > < / span > < span class = "text-size-small" > (< a data-ls-attrs = "href={{env.HOME}}/docs/permissions" target = "_blank" rel = "noopener" > Learn more< / a > )< / span > < / label >
2021-08-08 00:49:36 +12:00
< input type = "hidden" id = "execute" name = "execute" data-forms-tags data-cast-to = "json" data-ls-bind = "{{project-function.execute}}" placeholder = "User ID, Team ID or Role" / >
2021-08-09 17:47:05 +12:00
< div class = "text-fade text-size-xs margin-top-negative-small margin-bottom" > Add 'role:all' for wildcard access< / div >
2021-02-02 11:34:54 +13:00
2020-07-17 20:14:16 +12:00
< label for = "timeout" > Timeout (seconds) < span class = "tooltip small" data-tooltip = "Limit the execution time of your function." > < i class = "icon-info-circled" > < / i > < / span > < / label >
2021-02-02 11:34:54 +13:00
< input name = "timeout" id = "function-timeout" type = "number" autocomplete = "off" data-ls-bind = "{{project-function.timeout}}" min = "1" max = " <?php echo $this -> escape ( $timeout ); ?> " data-cast-to = "integer" />
2020-07-20 02:42:46 +12:00
< div class = "text-size-small text-fade margin-bottom margin-top-negative-small" > Max value is <?php echo $this -> escape ( number_format ( $timeout )); ?> seconds (<?php echo $this -> escape (( int ) ( $timeout / 60 )); ?> minutes)</ div >
2020-07-17 20:14:16 +12:00
< / section >
2020-10-31 08:53:27 +13:00
< section class = "margin-bottom" data-forms-select-all >
2020-07-17 20:14:16 +12:00
< label for = "events" class = "margin-bottom" > Events < span class = "tooltip small" data-tooltip = "Choose which events should trigger this function." > < i class = "icon-info-circled" > < / i > < / span > < / label >
< div class = "row responsive thin margin-top-small" >
2021-08-04 18:39:23 +12:00
<?php foreach ( $events as $i => $event ) : ?>
2020-10-31 08:53:27 +13:00
< div class = "col span-6 text-one-liner margin-bottom text-height-large text-size-small" title = " <?php echo $event ; ?> " >
2021-12-07 04:56:55 +13:00
< input type = "checkbox" name = "events" data-ls-bind = "{{project-function.events}}" id = " <?php echo $event ; ?> " value = " <?php echo $event ; ?> " data-by-key = "true" />
2021-02-02 22:50:13 +13:00
< label class = "inline" for = " <?php echo $event ; ?> " > <?php echo $event ; ?> </ label >
2020-07-17 20:14:16 +12:00
< / div >
2021-08-04 18:39:23 +12:00
<?php if (( $i + 1 ) % 2 === 0 ) : ?>
2020-07-17 20:14:16 +12:00
< / div >
< div class = "row responsive thin" >
2021-08-04 18:39:23 +12:00
<?php endif ; ?>
2020-07-17 20:14:16 +12:00
2021-08-04 18:39:23 +12:00
<?php endforeach ; ?>
2020-07-17 20:14:16 +12:00
< / div >
< / section >
2021-02-02 11:34:54 +13:00
< label for = "schedule" > Schedule (CRON Syntax) < span class = "tooltip small" data-tooltip = "Set a CRON schedule to trigger this function." > < i class = "icon-info-circled" > < / i > < / span > < / label >
< input type = "text" id = "function-schedule" class = "full-width" name = "schedule" autocomplete = "off" data-ls-bind = "{{project-function.schedule}}" placeholder = "* * * * *" / >
< div class = "text-size-small text-fade margin-bottom margin-top-negative-small" > Leave blank for no schedule< / div >
2020-07-17 20:14:16 +12:00
< h3 class = "margin-bottom-small" > Variables < span class = "tooltip small" data-tooltip = "Set variables or secret keys that will be passed as env vars to your function at runtime." > < i class = "icon-info-circled" > < / i > < / span > < / h3 >
2020-05-11 16:39:00 +12:00
< div data-ls-if = "(!{{project-function.vars.length}})" >
< hr class = "margin-bottom margin-top-no" / >
< fieldset name = "vars" data-cast-to = "object" >
2021-01-19 06:12:02 +13:00
< div data-ls-loop = "project-function.vars" data-ls-as = "var" id = "project-vars" style = "visibility: visible;" >
2020-05-11 16:39:00 +12:00
< div class = "margin-bottom-small" >
< div data-forms-remove class = "row thin" >
< div class = "col span-10" >
2020-05-13 10:00:48 +12:00
< input type = "hidden" data-forms-key-value data-ls-attrs = "name={{$index}}" data-ls-bind = "{{var}}" / >
2020-05-11 16:39:00 +12:00
< / div >
< div class = "col span-2" >
2022-02-08 22:46:44 +13:00
< button type = "button" data-remove class = "close pull-end is-margin-top-10" > < i class = "icon-cancel" > < / i > < / button >
2020-05-11 16:39:00 +12:00
< / div >
< / div >
< / div >
< / div >
2020-05-14 08:59:02 +12:00
< div data-forms-clone = "" data-target = "project-vars" data-label = "Add Variable" data-first = "0" >
2020-05-11 16:39:00 +12:00
< div class = "margin-bottom-small" >
2022-01-06 03:20:36 +13:00
< div data-forms-remove class = "row thin" >
2020-05-11 16:39:00 +12:00
< div class = "col span-10" >
2022-01-06 03:20:36 +13:00
< input type = "hidden" data-ls-attrs = "data-forms-key-value" / >
2020-05-11 16:39:00 +12:00
< / div >
< div class = "col span-2" >
2022-02-08 22:46:44 +13:00
< button type = "button" data-remove class = "close pull-end is-margin-top-10" > < i class = "icon-cancel" > < / i > < / button >
2020-05-11 16:39:00 +12:00
< / div >
< / div >
< / div >
< / div >
< / fieldset >
< hr class = "margin-bottom margin-top-small" / >
< / div >
< button > Update< / button >
< / div >
< / form >
< / div >
< div class = "col span-4 sticky-top" >
< label > Function ID< / label >
< div class = "input-copy margin-bottom" >
< input id = "uid" type = "text" autocomplete = "off" placeholder = "" data-ls-bind = "{{project-function.$id}}" disabled data-forms-copy >
< / div >
< ul class = "margin-bottom-large text-fade text-size-small" >
< li class = "margin-bottom-small" > < i class = "icon-angle-circled-right margin-start-tiny margin-end-tiny" > < / i > < button data-ls-ui-trigger = "open-json" class = "link text-size-small" > View as JSON< / button > < / li >
2020-07-15 23:22:38 +12:00
< li class = "margin-bottom-small" > < i class = "icon-angle-circled-right margin-start-tiny margin-end-tiny" > < / i > Last Updated: < span data-ls-bind = "{{project-function.dateUpdated|dateText}}" > < / span > < / li >
< li class = "margin-bottom-small" > < i class = "icon-angle-circled-right margin-start-tiny margin-end-tiny" > < / i > Created: < span data-ls-bind = "{{project-function.dateCreated|dateText}}" > < / span > < / li >
2020-05-11 16:39:00 +12:00
< / ul >
< form name = "functions.delete" class = "margin-bottom"
2021-01-18 19:29:26 +13:00
data-analytics
data-analytics-activity
2020-05-11 16:39:00 +12:00
data-analytics-event="submit"
data-analytics-category="console"
data-analytics-label="Delete Function"
data-service="functions.delete"
data-event="submit"
data-param-function-id="{{router.params.id}}"
data-confirm="Are you sure you want to delete this function?"
data-success="alert,trigger,redirect"
data-success-param-alert-text="Function deleted successfully"
data-success-param-trigger-events="functions.delete"
data-success-param-redirect-url="/console/functions?project={{router.params.project}}"
data-failure="alert"
data-failure-param-alert-text="Failed to delete function"
data-failure-param-alert-classname="error">
< button type = "submit" class = "danger fill" > Delete Function< / button >
< / form >
< / div >
< / div >
< / li >
< / ul >
< / div >
2021-02-03 04:53:09 +13:00
< / div >
2021-03-12 01:39:06 +13:00
< div data-ui-modal class = "modal close box sticky-footer" data-button-hide = "on" data-open-event = "execute-now" >
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
< h1 class = "margin-bottom" > Execute Function< / h1 >
2022-01-25 13:36:33 +13:00
< form data-ls-if = "{{project-function.deployment}} !== ''" name = "functions.createExecution" class = "margin-top"
2021-03-12 01:39:06 +13:00
data-analytics
data-analytics-activity
data-analytics-event="submit"
data-analytics-category="console"
data-analytics-label="Create Function Execution"
data-service="functions.createExecution"
data-event="submit"
data-param-function-id="{{router.params.id}}"
data-success="alert,trigger"
data-success-param-alert-text="Function executed successfully"
data-success-param-trigger-events="functions.createExecution"
data-failure="alert"
data-failure-param-alert-text="Failed to execute function"
data-failure-param-alert-classname="error">
2021-03-13 08:40:11 +13:00
< label for = "execution-data" > Custom Data< / label >
< textarea id = "execution-data" name = "data" autocomplete = "off" class = "margin-bottom" placeholder = "Data string (optional)" > < / textarea >
2021-03-12 01:39:06 +13:00
2021-03-12 02:02:18 +13:00
< button type = "submit" style = "vertical-align: top;" > Execute Now< / button >
2021-03-12 01:39:06 +13:00
< / form >
< / div >
2022-01-25 13:36:33 +13:00
< div data-ui-modal class = "modal close box sticky-footer" data-button-hide = "on" data-open-event = "deploy-deployment" >
2021-02-03 04:53:09 +13:00
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
2022-01-25 13:54:44 +13:00
< h1 class = "margin-bottom-xl" > Create a New Deployment< / h1 >
2021-02-03 04:53:09 +13:00
< ul class = "phases padding margin-top-negative-small" data-ui-phases >
< li >
< h2 style = "display: none" > CLI< / h2 >
2021-02-03 20:27:55 +13:00
< p > < b > Unix< / b > < / p >
2021-02-06 01:56:36 +13:00
< div class = "margin-bottom" >
2022-01-25 13:36:33 +13:00
< textarea type = "hidden" data-ls-bind = "appwrite functions createDeployment \
2021-02-06 01:56:36 +13:00
--functionId={{project-function.$id}} \
2021-09-01 21:48:56 +12:00
--entrypoint='scriptFile' \
2021-02-06 01:56:36 +13:00
--code='/myrepo/myfunction'" data-forms-code="bash" data-lang="bash" data-lang-label="Bash">< / textarea >
2021-02-03 20:27:55 +13:00
< / div >
< p > < b > PowerShell< / b > < / p >
2021-02-06 01:56:36 +13:00
< div class = "margin-bottom" >
2022-01-25 13:36:33 +13:00
< textarea type = "hidden" data-ls-bind = "appwrite functions createDeployment `
2021-02-17 23:44:31 +13:00
--functionId={{project-function.$id}} `
2021-09-01 21:48:56 +12:00
--entrypoint='scriptFile' `
2021-02-06 01:56:36 +13:00
--code='/myrepo/myfunction'" data-forms-code="powershell" data-lang="powershell" data-lang-label="PowerShell">< / textarea >
2021-02-03 20:27:55 +13:00
< / div >
2022-01-25 13:36:33 +13:00
< p > Learn more about < a href = "https://appwrite.io/docs/server/functions#functionsCreateDeployment" target = "_blank" > creating deployments< / a > , installing and using the < a href = "https://appwrite.io/docs/command-line" target = "_blank" > Appwrite CLI< / a > .< / p >
2021-02-03 04:53:09 +13:00
< / li >
< li >
< h2 style = "display: none" > Manual< / h2 >
< form class = "margin-top-negative"
data-analytics
data-analytics-activity
data-analytics-event="submit"
data-analytics-category="console"
2022-01-25 13:36:33 +13:00
data-analytics-label="Create Function Deployment"
data-service="functions.createDeployment"
2021-02-03 04:53:09 +13:00
data-scope="sdk"
data-event="submit"
data-success="alert,trigger,reset"
2022-01-25 13:36:33 +13:00
data-success-param-alert-text="Created function deployment successfully"
data-success-param-trigger-events="functions.createDeployment"
2021-02-03 04:53:09 +13:00
data-failure="alert"
2022-01-25 13:36:33 +13:00
data-failure-param-alert-text="Failed to create function deployment"
2021-02-03 04:53:09 +13:00
data-failure-param-alert-classname="error">
2021-08-04 18:39:23 +12:00
2021-02-03 04:53:09 +13:00
< input type = "hidden" name = "functionId" data-ls-bind = "{{router.params.id}}" / >
2022-01-25 13:36:33 +13:00
< label for = "deployment-entrypoint" > Entrypoint< / label >
< input type = "text" id = "deployment-entrypoint" name = "entrypoint" required autocomplete = "off" class = "margin-bottom" placeholder = "main.js" / >
2021-02-03 04:53:09 +13:00
2022-01-25 13:36:33 +13:00
< label for = "deployment-code" > Gzipped Code (tar.gz file)< / label >
< input type = "file" name = "code" id = "deployment-code" size = "1" required accept = "application/x-gzip,.gz" >
2021-12-09 04:08:53 +13:00
< div class = "text-fade text-size-xs margin-top-negative-small margin-bottom" > (Max file size allowed: <?php echo $fileLimitHuman ; ?> )</ div >
2022-02-21 11:21:36 +13:00
< label for = "deployment-activate" class = "margin-bottom-large" > < input type = "checkbox" class = "margin-start-small" id = "deployment-activate" name = "activate" / > Activate Deployment after build< / label >
2021-02-03 04:53:09 +13:00
< footer >
< button type = "submit" > Create< / button > < button data-ui-modal-close = "" type = "button" class = "reverse" > Cancel< / button >
< / footer >
< / form >
< / li >
< / ul >
2021-08-04 18:39:23 +12:00
2021-02-10 05:58:31 +13:00
< / div >