2022-03-25 15:39:39 +01:00
|
|
|
class CCPExecutionForm extends HTMLElement{
|
|
|
|
|
|
|
|
#boot;
|
|
|
|
#rootdoc;
|
|
|
|
#data;
|
|
|
|
#method;
|
2022-07-18 18:08:53 +02:00
|
|
|
#serviceurl;
|
2024-06-07 17:39:35 +02:00
|
|
|
#messages = {
|
|
|
|
"en" : {
|
|
|
|
"confirm_form_overwrite" : "Please confirm the overwrite of the previous execution form.",
|
|
|
|
"Inputs" : "Inputs",
|
|
|
|
"Options" : "Options",
|
|
|
|
"Outputs" : "Outputs",
|
|
|
|
"Execute" : "Execute",
|
|
|
|
"execute_help" : "Submit an execution request",
|
|
|
|
"generate_code" : "Generate code for",
|
|
|
|
"generate_code_help" : "Generate example code for a selectable programming language or runtime",
|
|
|
|
"direct_link" : "Direct link",
|
|
|
|
"direct_link_help" : "Navigate to the link for directly reopening this method in the execution form",
|
|
|
|
"automatic_archive_option" : "Select what you like to archive automatically when the execution is completed",
|
|
|
|
"automatic_archive_provenance" : "Automatically archive whole execution provenance",
|
|
|
|
"automatic_archive_provenance_help" : "Automatically archive the whole execution provenance to the workspace",
|
|
|
|
"automatic_archive_outputs" : "Automatically archive uncompressed outputs only",
|
|
|
|
"automatic_archive_outputs_help" : "Automatically archive only the outputs to the workspace",
|
|
|
|
"automatic_archive_none" : "Do not archive anything automatically",
|
|
|
|
"automatic_archive_none_help" : "Do not archive anything automatically",
|
|
|
|
"execution_accepted" : "Execution request accepted with id: ",
|
|
|
|
"drop_method_invitation" : "Drop a method here to request an execution",
|
|
|
|
"err_execution_not_accepted" : "Error. Execution has not been accepted by server",
|
|
|
|
"err_code_generation" : "Error while generating code",
|
|
|
|
"err_load_method" : "Error while loading method",
|
|
|
|
"err_no_runtimes" : "This method has no compatible runtimes available",
|
|
|
|
"err_execute" : "Error while sending execution request",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-25 15:39:39 +01:00
|
|
|
constructor(){
|
|
|
|
super()
|
|
|
|
this.#boot = document.querySelector("d4s-boot-2")
|
|
|
|
this.#rootdoc = this.attachShadow({ "mode" : "open"})
|
2024-04-11 17:25:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
connectedCallback(){
|
|
|
|
this.#serviceurl = this.getAttribute("serviceurl")
|
2023-03-17 10:49:21 +01:00
|
|
|
this.connectNewExecutionRequest()
|
2024-02-02 17:45:04 +01:00
|
|
|
this.render()
|
|
|
|
|
2024-02-02 17:32:51 +01:00
|
|
|
const params = new URLSearchParams(window.location.search)
|
2024-02-02 17:45:04 +01:00
|
|
|
if(params.get('execution')){
|
|
|
|
const execution = { id : params.get('execution') }
|
|
|
|
this.prepareFromExecution(execution)
|
|
|
|
} else if(params.get('method')){
|
2024-02-02 17:35:59 +01:00
|
|
|
this.#method = params.get('method')
|
|
|
|
this.loadMethod()
|
2024-02-02 17:45:04 +01:00
|
|
|
} else {
|
|
|
|
this.showMethod()
|
2024-02-02 17:35:59 +01:00
|
|
|
}
|
2022-03-25 15:39:39 +01:00
|
|
|
}
|
2024-04-11 17:25:41 +02:00
|
|
|
|
2022-03-25 15:39:39 +01:00
|
|
|
static get observedAttributes() {
|
2022-05-05 12:19:06 +02:00
|
|
|
return ["method"];
|
2022-03-25 15:39:39 +01:00
|
|
|
}
|
|
|
|
|
2024-06-07 17:39:35 +02:00
|
|
|
getLabel(key, localehint){
|
|
|
|
const locale = localehint ? localehint : navigator.language
|
|
|
|
const actlocale = this.#messages[locale] ? locale : "en"
|
|
|
|
const msg = this.#messages[actlocale][key]
|
|
|
|
return msg == null || msg == undefined ? key : this.#messages[actlocale][key]
|
|
|
|
}
|
|
|
|
|
2022-03-25 15:39:39 +01:00
|
|
|
attributeChangedCallback(name, oldValue, newValue) {
|
2023-06-15 10:36:25 +02:00
|
|
|
//if((oldValue != newValue) && (name === "method")){
|
|
|
|
if(name === "method"){
|
2022-03-25 15:39:39 +01:00
|
|
|
this.#method = newValue
|
|
|
|
this.loadMethod()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-03-17 10:49:21 +01:00
|
|
|
connectNewExecutionRequest(){
|
|
|
|
document.addEventListener("newexecutionrequest", ev=>{
|
2024-06-07 17:39:35 +02:00
|
|
|
if(this.#data){
|
|
|
|
if(window.confirm(this.getLabel("confirm_form_overwrite"))){
|
|
|
|
this.setAttribute("method", ev.detail)
|
|
|
|
this.parentElement.scrollIntoViewIfNeeded()
|
|
|
|
}
|
|
|
|
}else{
|
2023-03-17 11:02:25 +01:00
|
|
|
this.setAttribute("method", ev.detail)
|
2024-06-07 17:39:35 +02:00
|
|
|
this.parentElement.scrollIntoViewIfNeeded()
|
2023-03-17 10:49:21 +01:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-07-18 18:08:53 +02:00
|
|
|
render(){
|
|
|
|
this.#rootdoc.innerHTML = `
|
|
|
|
<div>
|
2024-04-16 13:07:23 +02:00
|
|
|
<link rel="canonical" href="https://getbootstrap.com/docs/5.0/components/modal/">
|
2022-07-18 18:08:53 +02:00
|
|
|
<link rel="stylesheet" href="https://cdn.dev.d4science.org/ccp/css/common.css"></link>
|
2024-04-17 17:47:28 +02:00
|
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" crossorigin="anonymous">
|
2024-04-24 13:02:54 +02:00
|
|
|
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons"/>
|
2022-07-18 18:08:53 +02:00
|
|
|
<style>
|
2023-03-20 11:07:42 +01:00
|
|
|
.ccp-execution-form{
|
|
|
|
position: relative;
|
|
|
|
}
|
2022-07-18 18:08:53 +02:00
|
|
|
</style>
|
|
|
|
<template id="EXECUTION_FORM_TEMPLATE">
|
|
|
|
<div class="ccp-execution-form" name="execution_form">
|
|
|
|
<h5 class="ccp-method-title"></h5>
|
|
|
|
<p class="description font-italic font-weight-lighter"></p>
|
2023-03-20 11:07:42 +01:00
|
|
|
<div class="plexiglass d-none"></div>
|
2022-07-18 18:08:53 +02:00
|
|
|
<form name="execution_form" class="d-flex flex-column gap-3" style="gap:5px">
|
|
|
|
<div class="card">
|
|
|
|
<div class="card-header">
|
2024-06-07 17:39:35 +02:00
|
|
|
<h5>${this.getLabel("Inputs")}</h5>
|
2022-07-18 18:08:53 +02:00
|
|
|
</div>
|
|
|
|
<div class="card-body ccp-inputs">
|
2023-09-26 17:14:47 +02:00
|
|
|
<div>
|
2022-07-18 18:08:53 +02:00
|
|
|
<div class="form-group"></div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2024-02-09 11:42:49 +01:00
|
|
|
<div class="card">
|
|
|
|
<div class="card-header">
|
2024-06-07 17:39:35 +02:00
|
|
|
<h5>${this.getLabel("Options")}</h5>
|
2024-02-09 11:42:49 +01:00
|
|
|
</div>
|
|
|
|
<div class="card-body">
|
2024-06-05 18:57:15 +02:00
|
|
|
<div class="p-1">
|
2024-06-07 17:39:35 +02:00
|
|
|
<label class="small text-muted p-0">${this.getLabel("automatic_archive_option")}.</label>
|
2024-06-05 18:57:15 +02:00
|
|
|
<select name="archive-selector" class="form-select p-2" style="padding:2px">
|
2024-06-07 17:39:35 +02:00
|
|
|
<option value="execution" title="${this.getLabel("automatic_archive_provenance_help")}">${this.getLabel("automatic_archive_provenance")}</option>
|
|
|
|
<option value="outputs" title="${this.getLabel("automatic_archive_outputs_help")}">${this.getLabel("automatic_archive_outputs")}</option>
|
|
|
|
<option value="none" title="${this.getLabel("automatic_archive_none_help")}">${this.getLabel("automatic_archive_none")}</option>
|
2024-06-05 18:57:15 +02:00
|
|
|
</select>
|
|
|
|
</div>
|
2024-02-09 11:42:49 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2022-07-18 18:08:53 +02:00
|
|
|
<div class="card">
|
|
|
|
<div class="card-header">
|
2024-06-07 17:39:35 +02:00
|
|
|
<h5>${this.getLabel("Outputs")}</h5>
|
2022-07-18 18:08:53 +02:00
|
|
|
</div>
|
|
|
|
<div class="card-body">
|
2024-04-17 17:47:28 +02:00
|
|
|
<div class="row ccp-outputs">
|
2022-07-18 18:08:53 +02:00
|
|
|
<div class="col form-group"></div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2024-04-17 17:47:28 +02:00
|
|
|
<div class="row">
|
2023-04-14 11:51:08 +02:00
|
|
|
<div class="col-6">
|
2024-06-07 17:39:35 +02:00
|
|
|
<button title="${this.getLabel("execute_help")}" id="execute_method_button" class="btn btn-info">${this.getLabel("Execute")}</button>
|
2023-03-20 11:07:42 +01:00
|
|
|
</div>
|
2023-04-14 11:51:08 +02:00
|
|
|
<div class="col-6">
|
2024-06-07 17:41:41 +02:00
|
|
|
<div class="mb-3" title="${this.getLabel("generate_code_help")}">
|
2024-06-07 17:39:35 +02:00
|
|
|
<label>${this.getLabel("generate_code")}</label>
|
2023-06-07 17:24:07 +02:00
|
|
|
<div class="d-flex">
|
2024-02-02 18:12:35 +01:00
|
|
|
<select name="language-selector" class="form-control" style="padding:2px">
|
|
|
|
<option value="text/python" data-ext="py" title="Generate plain Python3">Python 3</option>
|
|
|
|
<option value="text/plain+r" data-ext="r" title="Generate plain R">R</option>
|
|
|
|
<option value="application/vnd.jupyter+python" data-ext="ipynb" title="Generate Jupyter notebook with Python 3 cells">Jupyter Python3</option>
|
|
|
|
<option value="text/julia" data-ext="jl" title="Generate Julia 1.9.0 code (HTTP 1.10.0, JSON3 1.13.2)">Julia 1.9.0</option>
|
2024-04-10 12:28:47 +02:00
|
|
|
<option value="application/x-sh+curl" data-ext="sh" title="Generate Bash script (curl)">Bash (curl)</option>
|
|
|
|
<option value="application/x-sh+wget" data-ext="sh" title="Generate Bash script (wget)">Bash (wget)</option>
|
2024-06-04 16:07:11 +02:00
|
|
|
<option value="application/json+galaxy" data-ext="json" title="Generate JSON request for Galaxy">Galaxy CCP request (preview)</option>
|
|
|
|
<option value="application/xml+galaxy" data-ext="xml" title="Generate installable Galaxy tool">Galaxy tool (preview)</option>
|
2024-04-10 12:28:47 +02:00
|
|
|
</select>
|
2024-06-07 17:41:41 +02:00
|
|
|
<button name="codegen" class="btn btn-primary ccp-toolbar-button ccp-toolbar-button-small">
|
2024-02-02 18:12:35 +01:00
|
|
|
<svg viewBox="0 96 960 960">
|
|
|
|
<path d="M320 814 80 574l242-242 43 43-199 199 197 197-43 43Zm318 2-43-43 199-199-197-197 43-43 240 240-242 242Z"></path>
|
|
|
|
</svg>
|
|
|
|
</button>
|
|
|
|
</div>
|
2024-02-02 18:33:42 +01:00
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<div class="d-flex">
|
2024-06-07 17:39:35 +02:00
|
|
|
<a title="${this.getLabel("direct_link_help")}" name="direct_link_method" class="text-truncate" href="${window.location.href}">${this.getLabel("direct_link")}</a>
|
2023-06-07 17:24:07 +02:00
|
|
|
</div>
|
2023-03-20 11:07:42 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2023-04-14 11:51:08 +02:00
|
|
|
</div>
|
2022-07-18 18:08:53 +02:00
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<template id="EXECUTION_FORM_EMPTY_TEMPLATE">
|
|
|
|
<div name="execution_form">
|
2024-06-07 17:39:35 +02:00
|
|
|
<i style="padding:3rem">${this.getLabel("drop_method_invitation")}!</i>
|
2022-07-18 18:08:53 +02:00
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<div name="execution_form"></div>
|
|
|
|
</div>
|
|
|
|
`
|
2022-03-25 15:39:39 +01:00
|
|
|
}
|
|
|
|
|
2023-03-20 11:07:42 +01:00
|
|
|
lockRender(){
|
2023-05-08 11:10:33 +02:00
|
|
|
const plexi = this.#rootdoc.querySelector(".plexiglass")
|
|
|
|
plexi.innerHTML = ``
|
|
|
|
plexi.classList.toggle("d-none")
|
2023-03-20 11:07:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
unlockRender(){
|
|
|
|
this.#rootdoc.querySelector(".plexiglass").classList.toggle("d-none")
|
|
|
|
}
|
|
|
|
|
2023-05-08 11:10:33 +02:00
|
|
|
writeToPlexi(message){
|
|
|
|
const plexi = this.#rootdoc.querySelector(".plexiglass")
|
|
|
|
plexi.innerHTML = `
|
|
|
|
<div class="d-flex" style="flex-direction: column;justify-content:center;position:relative;height:100%;align-items: center;">
|
|
|
|
<div class="mx-2 p-4 bg-success text-white border" style="border-radius: 5px;box-shadow: 2px 2px 2px darkgray;">
|
|
|
|
<div>${message}</h5></div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
`
|
|
|
|
}
|
|
|
|
|
2022-03-25 15:39:39 +01:00
|
|
|
loadMethod(){
|
2023-02-02 12:30:38 +01:00
|
|
|
return this.#boot.secureFetch(this.#serviceurl + "/processes/" + this.#method).then(
|
2022-03-25 15:39:39 +01:00
|
|
|
(resp)=>{
|
2022-04-12 19:51:38 +02:00
|
|
|
if(resp.status === 200){
|
|
|
|
return resp.json()
|
2024-06-07 17:39:35 +02:00
|
|
|
}else throw this.getLabel("err_load_method")
|
2022-04-12 19:51:38 +02:00
|
|
|
}
|
|
|
|
).then(data=>{
|
|
|
|
this.#data = data
|
2023-03-07 18:51:56 +01:00
|
|
|
const infra =
|
|
|
|
this.#data.links.filter(l => l.rel === "compatibleWith")[0]
|
|
|
|
return this.#boot.secureFetch(this.#serviceurl + "/" + infra.href)
|
2022-05-05 12:19:06 +02:00
|
|
|
|
|
|
|
}).then(resp=>{
|
|
|
|
this.#data.executable = resp.status === 200
|
|
|
|
}).then(()=>{
|
2022-04-12 19:51:38 +02:00
|
|
|
this.showMethod()
|
2023-03-20 11:10:23 +01:00
|
|
|
}).catch(err=>alert(err))
|
2022-03-25 15:39:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
showEmpty(resp){
|
|
|
|
BSS.apply(this.#empty_executionform_bss, this.#rootdoc)
|
|
|
|
}
|
|
|
|
|
|
|
|
showMethod(){
|
|
|
|
if(this.#method == null) this.showEmpty();
|
|
|
|
else{
|
|
|
|
BSS.apply(this.#executionform_bss, this.#rootdoc)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-12 19:51:38 +02:00
|
|
|
sendExecutionRequest(){
|
2023-03-20 11:07:42 +01:00
|
|
|
this.lockRender()
|
2022-04-12 19:51:38 +02:00
|
|
|
const url = this.#serviceurl + "/processes/" + this.#method + "/execution"
|
2022-05-05 12:19:06 +02:00
|
|
|
const req = this.buildRequest()
|
2022-04-12 19:51:38 +02:00
|
|
|
this.#boot.secureFetch(
|
2022-05-05 12:19:06 +02:00
|
|
|
url, { method : "POST", body : JSON.stringify(req), headers : { "Content-Type" : "application/json"}}
|
2022-04-12 19:51:38 +02:00
|
|
|
).then(reply=>{
|
|
|
|
if(reply.status !== 200 && reply.status !== 201){
|
2024-06-07 17:39:35 +02:00
|
|
|
throw this.getLabel("err_execute")
|
2022-04-12 19:51:38 +02:00
|
|
|
}
|
2022-05-05 12:19:06 +02:00
|
|
|
return reply.json()
|
|
|
|
}).then(data=>{
|
|
|
|
if(data.status !== "accepted"){
|
2024-06-07 17:39:35 +02:00
|
|
|
throw this.getLabel("err_execution_not_accepted")
|
2022-05-05 12:19:06 +02:00
|
|
|
}
|
2023-05-05 18:39:15 +02:00
|
|
|
const event = new CustomEvent('newexecution', { detail: data.jobID });
|
2023-01-26 11:31:08 +01:00
|
|
|
document.dispatchEvent(event)
|
2024-06-07 17:39:35 +02:00
|
|
|
this.writeToPlexi(this.getLabel("execution_accepted") + " " + data.jobID)
|
2023-05-08 11:10:33 +02:00
|
|
|
window.setTimeout(()=>this.unlockRender(), 3000)
|
2024-06-07 17:39:35 +02:00
|
|
|
}).catch(err => {alert(this.getLabel("err_execute") + ": " + err); this.unlockRender()})
|
2022-05-05 12:19:06 +02:00
|
|
|
}
|
|
|
|
|
2023-04-14 11:51:08 +02:00
|
|
|
generateCode(mime, filename){
|
|
|
|
const url = this.#serviceurl + "/methods/" + this.#method + "/code"
|
|
|
|
const req = this.buildRequest()
|
|
|
|
this.#boot.secureFetch(
|
|
|
|
url, { method : "POST", body : JSON.stringify(req), headers : { "Content-Type" : "application/json", "Accept" : mime}}
|
|
|
|
).then(reply=>{
|
2024-06-07 17:39:35 +02:00
|
|
|
if(reply.status !== 200) throw this.getLabel("err_code_generation");
|
2023-04-14 11:51:08 +02:00
|
|
|
return reply.blob()
|
|
|
|
}).then(blob => {
|
|
|
|
const objectURL = URL.createObjectURL(blob)
|
|
|
|
var tmplnk = document.createElement("a")
|
|
|
|
tmplnk.download = filename
|
|
|
|
tmplnk.href = objectURL
|
|
|
|
document.body.appendChild(tmplnk)
|
|
|
|
tmplnk.click()
|
|
|
|
document.body.removeChild(tmplnk)
|
|
|
|
}).catch(err=>{ alert(err)})
|
|
|
|
}
|
|
|
|
|
2022-05-05 12:19:06 +02:00
|
|
|
buildRequest(){
|
|
|
|
let request = { inputs : {}, outputs : {}, response : "raw"}
|
|
|
|
|
|
|
|
//fill inputs
|
|
|
|
const inputs = this.getInputs()
|
|
|
|
inputs.forEach(i=>{
|
|
|
|
request.inputs[i.name] = i.value
|
|
|
|
})
|
|
|
|
|
|
|
|
//fill outputs
|
|
|
|
const outputs = this.getOutputs()
|
|
|
|
outputs.forEach(o=>{
|
|
|
|
if(o.enabled) request.outputs[o.name] = { transmissionMode : "value" };
|
|
|
|
})
|
2024-02-09 11:42:49 +01:00
|
|
|
|
2024-06-05 18:57:15 +02:00
|
|
|
const archiveoption = this.#rootdoc.querySelector("select[name='archive-selector']").value
|
|
|
|
switch(archiveoption){
|
|
|
|
case 'execution':
|
|
|
|
request.subscribers = [{ successUri : "http://registry:8080/executions/archive-to-folder" }]
|
|
|
|
break;
|
|
|
|
case 'outputs':
|
|
|
|
request.subscribers = [{ successUri : "http://registry:8080/executions/outputs/archive-to-folder" }]
|
|
|
|
break
|
|
|
|
default:
|
|
|
|
break
|
2024-02-09 11:42:49 +01:00
|
|
|
}
|
2022-05-05 12:19:06 +02:00
|
|
|
return request
|
|
|
|
}
|
|
|
|
|
|
|
|
getInputs(){
|
|
|
|
return Array.prototype.slice.call(this.#rootdoc.querySelectorAll("d4s-ccp-input"))
|
|
|
|
}
|
|
|
|
|
|
|
|
getOutputs(){
|
|
|
|
return Array.prototype.slice.call(this.#rootdoc.querySelectorAll("d4s-ccp-output"))
|
2022-04-12 19:51:38 +02:00
|
|
|
}
|
|
|
|
|
2024-02-09 11:57:23 +01:00
|
|
|
initInputValues(inputs){
|
2023-02-02 12:30:38 +01:00
|
|
|
Object.keys(inputs).forEach(k=>{
|
|
|
|
const w = this.#rootdoc.querySelector(`d4s-ccp-input[name=${k}]`)
|
|
|
|
if(w){
|
|
|
|
w.value = (inputs[k])
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2024-02-09 11:57:23 +01:00
|
|
|
|
|
|
|
initOptionValues(request){
|
2024-06-05 19:05:13 +02:00
|
|
|
const archiveselector = this.#rootdoc.querySelector("select[name='archive-selector']")
|
|
|
|
if(request.subscribers){
|
|
|
|
if(request.subscribers.filter(s=>s.successUri === "http://registry:8080/executions/archive-to-folder").length === 1){
|
|
|
|
archiveselector.value = "execution"
|
|
|
|
}else if(request.subscribers.filter(s=>s.successUri === "http://registry:8080/executions/outputs/archive-to-folder").length === 1){
|
|
|
|
archiveselector.value = "outputs"
|
2024-06-05 19:07:54 +02:00
|
|
|
}else{
|
|
|
|
archiveselector.value = "none"
|
2024-06-05 19:05:13 +02:00
|
|
|
}
|
|
|
|
}else{
|
|
|
|
archiveselector.value = "none"
|
|
|
|
}
|
2024-02-09 11:57:23 +01:00
|
|
|
}
|
2023-02-02 12:30:38 +01:00
|
|
|
|
|
|
|
prepareFromExecution(exec){
|
2024-06-12 12:46:59 +02:00
|
|
|
//if exec carries already full information then it comes from archive. Use this info instead of fetching.
|
|
|
|
if(exec.fullrequest && exec.fullmethod && exec.fullinfrastructure){
|
|
|
|
this.#data = exec.fullmethod
|
|
|
|
this.#method = this.#data.id
|
|
|
|
this.#boot.secureFetch(this.#serviceurl + "/infrastructures/" + exec.fullinfrastructure.id)
|
|
|
|
.then(resp=>{
|
|
|
|
if(resp.ok){
|
2024-06-12 12:51:06 +02:00
|
|
|
this.#data.executable = true
|
2024-06-12 12:46:59 +02:00
|
|
|
this.showMethod()
|
|
|
|
this.initInputValues(exec.fullrequest.inputs)
|
|
|
|
this.initOptionValues(exec.fullrequest)
|
|
|
|
}else throw("Unable to find infrastructure")
|
|
|
|
}).catch(err=>alert(err))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
//fetch method and request and validate infra
|
2023-02-02 12:30:38 +01:00
|
|
|
let f1 =
|
|
|
|
this.#boot.secureFetch(this.#serviceurl + `/executions/${exec.id}/metadata/method.json`)
|
|
|
|
.then(resp=>{
|
|
|
|
if(resp.status === 200){
|
|
|
|
return resp.json()
|
2024-06-07 17:39:35 +02:00
|
|
|
}else throw this.getLabel("err_load_method")
|
2023-02-02 12:30:38 +01:00
|
|
|
}
|
|
|
|
).then(data=>data)
|
|
|
|
|
|
|
|
let f2 =
|
|
|
|
this.#boot.secureFetch(this.#serviceurl + `/executions/${exec.id}/metadata/request.json`)
|
|
|
|
.then(resp=>{
|
|
|
|
if(resp.status === 200){
|
|
|
|
return resp.json()
|
2024-06-07 17:39:35 +02:00
|
|
|
}else throw this.getLabel("err_load_method")
|
2023-02-02 12:30:38 +01:00
|
|
|
}
|
|
|
|
).then(data=>data)
|
|
|
|
|
|
|
|
var requestdata = null
|
|
|
|
Promise.all([f1, f2]).then(m_and_r => {
|
|
|
|
this.#data = m_and_r[0]
|
|
|
|
requestdata = m_and_r[1]
|
|
|
|
this.#method = this.#data.id
|
2023-03-07 18:51:56 +01:00
|
|
|
const infra =
|
|
|
|
this.#data.links.filter(l => l.rel === "compatibleWith")[0]
|
|
|
|
return this.#boot.secureFetch(this.#serviceurl + "/" + infra.href)
|
2023-02-02 12:30:38 +01:00
|
|
|
}).then(resp=>{
|
|
|
|
this.#data.executable = resp.status === 200
|
|
|
|
}).then(()=>{
|
|
|
|
this.showMethod()
|
2024-02-09 11:57:23 +01:00
|
|
|
this.initInputValues(requestdata.inputs)
|
|
|
|
this.initOptionValues(requestdata)
|
2023-02-02 12:30:38 +01:00
|
|
|
}).catch(err=>alert(err))
|
|
|
|
}
|
|
|
|
|
2022-03-25 15:39:39 +01:00
|
|
|
#empty_executionform_bss = {
|
|
|
|
template : "#EXECUTION_FORM_EMPTY_TEMPLATE",
|
2022-03-28 16:42:02 +02:00
|
|
|
target : "div[name=execution_form]",
|
2022-03-25 15:39:39 +01:00
|
|
|
on_drop : ev=>{
|
2023-02-02 12:30:38 +01:00
|
|
|
if(ev.dataTransfer){
|
|
|
|
if(ev.dataTransfer.getData('text/plain+ccpmethod')){
|
|
|
|
const id = ev.dataTransfer.getData('text/plain+ccpmethod')
|
|
|
|
this.setAttribute("method", id);
|
|
|
|
ev.preventDefault()
|
|
|
|
ev.stopPropagation()
|
|
|
|
ev.currentTarget.style.backgroundColor = "white"
|
|
|
|
}else if(ev.dataTransfer.getData('text/plain+ccpexecution')){
|
|
|
|
this.prepareFromExecution(JSON.parse(ev.dataTransfer.getData('application/json+ccpexecution')))
|
|
|
|
ev.preventDefault()
|
|
|
|
ev.stopPropagation()
|
|
|
|
ev.currentTarget.style.backgroundColor = "white"
|
|
|
|
}
|
2022-03-25 15:39:39 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
on_dragover : ev=>{
|
|
|
|
ev.preventDefault()
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
#executionform_bss = {
|
|
|
|
template : "#EXECUTION_FORM_TEMPLATE",
|
2022-03-28 16:52:09 +02:00
|
|
|
target : "div[name=execution_form]",
|
2022-03-25 15:39:39 +01:00
|
|
|
in : ()=>this.#data,
|
|
|
|
on_drop : ev=>{
|
2023-02-02 12:30:38 +01:00
|
|
|
if(ev.dataTransfer){
|
|
|
|
if(ev.dataTransfer.getData('text/plain+ccpmethod')){
|
|
|
|
const id = ev.dataTransfer.getData('text/plain+ccpmethod');
|
|
|
|
this.setAttribute("method", id);
|
|
|
|
ev.preventDefault()
|
|
|
|
ev.stopPropagation()
|
|
|
|
}else if(ev.dataTransfer.getData('text/plain+ccpexecution')){
|
|
|
|
this.prepareFromExecution(JSON.parse(ev.dataTransfer.getData('application/json+ccpexecution')))
|
|
|
|
ev.preventDefault()
|
|
|
|
ev.stopPropagation()
|
|
|
|
ev.currentTarget.style.backgroundColor = "white"
|
|
|
|
}
|
2022-03-25 15:39:39 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
on_dragover : ev=>{
|
|
|
|
ev.preventDefault()
|
|
|
|
},
|
|
|
|
recurse : [
|
|
|
|
{
|
2022-05-05 16:51:47 +02:00
|
|
|
target: ".ccp-method-title",
|
2023-04-03 12:51:08 +02:00
|
|
|
apply : (e,d)=>e.innerHTML = `
|
|
|
|
${d.title} <span class="badge badge-primary ml-1">${d.version}</span>
|
2023-04-03 13:08:56 +02:00
|
|
|
${ d.metadata.filter(md=>md.role === 'author').map(a=>`<span class="badge badge-warning ml-1">${a.title}</span>`)}
|
2023-04-03 12:51:08 +02:00
|
|
|
`
|
2022-03-25 15:39:39 +01:00
|
|
|
},
|
|
|
|
{
|
|
|
|
target: "p.description",
|
|
|
|
apply : (e,d)=>e.textContent = d.description
|
|
|
|
},
|
|
|
|
{
|
|
|
|
target: "div.ccp-inputs",
|
|
|
|
in : (e,d)=>d,
|
|
|
|
recurse : [
|
|
|
|
{
|
|
|
|
"in" : (e,d)=>{ return Object.values(d.inputs) },
|
|
|
|
target : "div",
|
|
|
|
apply : (e,d)=>{
|
2023-12-13 18:29:44 +01:00
|
|
|
e.innerHTML = `<d4s-ccp-input name="${d.id}" input='${btoa(JSON.stringify(d))}'></d4s-ccp-input>`
|
2022-03-25 15:39:39 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
2022-04-12 19:51:38 +02:00
|
|
|
},
|
|
|
|
{
|
|
|
|
target: "div.ccp-outputs",
|
|
|
|
in : (e,d)=>d,
|
|
|
|
recurse : [
|
|
|
|
{
|
|
|
|
"in" : (e,d)=>{ return Object.values(d.outputs) },
|
|
|
|
target : "div",
|
|
|
|
apply : (e,d)=>{
|
2023-12-13 18:29:44 +01:00
|
|
|
e.innerHTML = `<d4s-ccp-output name="${d.id}" output='${btoa(JSON.stringify(d))}'></d4s-ccp-output>`
|
2022-04-12 19:51:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
target: "div.ccp-runtimes *[name=refresh-runtimes]",
|
|
|
|
on_click : ev=>{
|
|
|
|
BSS.apply(this.#executionform_bss)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
target: "#execute_method_button",
|
|
|
|
on_click : ev=>{
|
|
|
|
ev.preventDefault()
|
|
|
|
ev.stopPropagation()
|
2022-05-05 12:19:06 +02:00
|
|
|
if(this.#data.executable) this.sendExecutionRequest();
|
2024-06-07 17:39:35 +02:00
|
|
|
else alert(this.getLabel("err_no_runtimes"))
|
2022-04-12 19:51:38 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
},
|
2023-04-14 11:51:08 +02:00
|
|
|
{
|
|
|
|
target: "button[name=codegen]",
|
|
|
|
on_click : ev=>{
|
|
|
|
ev.preventDefault()
|
|
|
|
ev.stopPropagation()
|
|
|
|
const langsel = ev.target.parentElement.querySelector("select[name=language-selector]")
|
|
|
|
const lang = langsel.value
|
|
|
|
const ext = langsel.selectedOptions[0].getAttribute("data-ext")
|
|
|
|
this.generateCode(lang, `ccprequest.${ext}`)
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
},
|
2024-02-02 18:07:28 +01:00
|
|
|
{
|
|
|
|
target: "a[name=direct_link_method]",
|
2024-04-09 13:22:14 +02:00
|
|
|
apply : (e,d)=>e.href = window.location.origin + window.location.pathname + "?method=" + d.id
|
2024-02-02 18:07:28 +01:00
|
|
|
}
|
2022-03-25 15:39:39 +01:00
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
window.customElements.define('d4s-ccp-executionform', CCPExecutionForm);
|