GlideFlow : client
Utilisez l’API GlideFlow pour les interactions côté client avec des actions, des flux et des flux secondaires.
Vous pouvez utiliser cette API n’importe où dans la plateforme qui accepte les scripts clients. L’action, le flux ou le flux secondaire doit être défini comme appelable par le client et disposer d’une ACL valide à l’aide de la fonctionnalité Gérer la sécurité dans Concepteur de flux.
Certaines des méthodes de GlideFlow renvoient des objets de promesse . Une promesse représente le résultat final d’une opération asynchrone. Pour plus d’informations sur les promesses, consultez la documentation Promise - Javascript MDN ou AngularJS.
- Démarrez des actions, des flux ou des flux secondaires via un script.
- Obtenir une exécution existante.
- Obtenez l’état et toutes les sorties disponibles.
- Attendez l’achèvement d’une action, d’un flux ou d’un flux secondaire.
Il n’existe aucun constructeur pour la classe GlideFlow . Accédez aux méthodes GlideFlow à l’aide de l’objet global GlideFlow.
GlideFlow : execution.awaitCompletion()
Renvoie un objet de complétion pour l’exécution.
| Nom | Type | Description |
|---|---|---|
| Aucun |
| Type | Description |
|---|---|
| Objet | Objet contenant les détails de complétion d’un flux ou d’une exécution d’action. |
Dans cet exemple, une action est exécutée à l’aide de startAction(), qui renvoie un objet d’exécution. Le code utilise ensuite awaitCompletion() sur cet objet d’exécution, qui renvoie un objet de complétion. Le code utilise cet objet de complétion pour consigner l’état et les sorties de l’exécution.
(function() {
var inputs = {};
inputs['input1'] = 'string input'; // String
GlideFlow.startAction('global.action_name', inputs)
.then(function(execution) {
return execution.awaitCompletion();
}, errorResolver)
.then(function(completion) {
var status = completion.status;
console.log(status);
// Available Outputs:
var outputs = completion.outputs;
console.log(outputs);
}, errorResolver());
function errorResolver(error) {
// Handle errors in error resolver
console.error(error);
}
})();
GlideFlow : execution.getExecutionStatus()
Renvoie une chaîne contenant l’état d’exécution de l’exécution en cours.
| Nom | Type | Description |
|---|---|---|
| Aucun |
| Type | Description |
|---|---|
| Chaîne | Chaîne contenant l’état d’exécution. |
Dans cet exemple, le code obtient un objet d’exécution à l’aide de la méthode getExecution. La méthode getExecution nécessite un ID, qui est renvoyé par la méthode utilisée pour démarrer l’exécution. Le code utilise ensuite getExecutionStatus() pour déterminer si l’exécution a été terminée avant de continuer.
// Get an existing action, getStatus, and getOutputs if complete
(function() {
GlideFlow.getExecution('mamIN4Q35vmEFe744EwJV5GHrSz8fmJG')
.then(function(execution) {
execution.getExecutionStatus().then(
function(status) {
if (status === 'COMPLETE')
execution.getOutputs().then(
function(outputs) {
console.log(outputs);
},
errorResolver
);
},
errorResolver
);
}, errorResolver);
function errorResolver(error) {
// Handle errors in error resolver
console.error(error);
}
})();
GlideFlow : execution.getOutputs()
Renvoie un objet de sortie pour l’exécution.
Utilisez cette méthode pour accéder à la sortie générée par l’exécution d’une action, d’un flux ou d’un flux secondaire.
| Nom | Type | Description |
|---|---|---|
| Aucun |
| Type | Description |
|---|---|
| Objet | Objet contenant les sorties d’une action, d’un flux ou d’un flux secondaire. |
Dans cet exemple, le code obtient un objet d’exécution à l’aide de la méthode getExecution. Une fois l’exécution terminée, le code utilise getOutputs() pour renvoyer un objet outputs, qu’il enregistre ensuite à l’aide de la méthode console.log.
// Get an existing action, getStatus, and getOutputs if complete
(function() {
GlideFlow.getExecution('mamIN4Q35vmEFe744EwJV5GHrSz8fmJG')
.then(function(execution) {
execution.getExecutionStatus().then(
function(status) {
if (status === 'COMPLETE')
execution.getOutputs().then(
function(outputs) {
console.log(outputs);
},
errorResolver
);
},
errorResolver
);
}, errorResolver);
function errorResolver(error) {
// Handle errors in error resolver
console.error(error);
}
})();
GlideFlow : getExecution(String executionId)
Obtenir une instance d’exécution existante par ID.
| Nom | Type | Description |
|---|---|---|
| executionId | Chaîne | ID de l’exécution à récupérer. |
| Type | Description |
|---|---|
| Objet | Promesse d’un objet d’exécution. |
Dans cet exemple, le code obtient une exécution, puis attend qu’elle soit terminée avant de consigner l’état d’achèvement et les sorties des exécutions à l’aide de console.log.
// Get an existing action and await completion
(function() {
GlideFlow.getExecution('79cd437e0b202300a150a95e93673ae3')
.then(function(execution) {
return execution.awaitCompletion();
}, errorResolver)
.then(function(completion) {
var status = completion.status;
console.log(status);
// Available Outputs:
var outputs = completion.outputs;
console.log(outputs);
}, errorResolver());
function errorResolver(error) {
// Handle errors in error resolver
console.error(error);
}
})();
GlideFlow - startAction(String scopedName.actionName, Entrées de carte)
Démarrez une action.
| Nom | Type | Description |
|---|---|---|
| scopedName (en anglais seulement) | Chaîne | Nom délimité du flux à exécuter. |
| entrées | Objet | Objet contenant des entrées définies pour l’action. |
| Type | Description |
|---|---|
| Objet | Objet contenant des détails sur l’exécution de l’action. |
Dans cet exemple, le code démarre l’action de action_name globale à l’aide d’arguments dans la variable d’objet d’entrée inputs. Une fois l’opération terminée, l’exemple utilise console.log ou console.error pour signaler la réussite ou l’échec du flux.
// Start an action and await completion.
(function() {
var inputs = {};
inputs['input1'] = 'string input'; // String
GlideFlow.startAction('global.action_name', inputs)
.then(function(execution) {
return execution.awaitCompletion();
}, errorResolver)
.then(function(completion) {
var status = completion.status;
console.log(status);
// Available Outputs:
var outputs = completion.outputs;
console.log(outputs);
}, errorResolver());
function errorResolver(error) {
// Handle errors in error resolver
console.error(error);
}
})();
GlideFlow - startFlow(String scopedName.flowName, Entrées de carte)
Démarrez un flux.
| Nom | Type | Description |
|---|---|---|
| scopedName (en anglais seulement) | Chaîne | Nom délimité du flux à exécuter. |
| entrées | Objet | Un objet contenant des entrées définies pour le flux. |
| Type | Description |
|---|---|
| Objet | Objet contenant des détails sur l’exécution du flux. |
Cet exemple de flux est normalement déclenché lorsqu’un enregistrement de la table d’incidents est mis à jour. Étant donné que vous activez le flux à partir du script client, vous devez fournir ces informations. Le code crée une variable d’entrée qui contient l’enregistrement actuel et la table de l’enregistrement
// Start a Flow
(function() {
var inputs = {};
inputs['current'] = { // GlideRecord
table : 'incident',
sys_id : '79cd437e0b202300a150a95e93673ae3'
};
inputs['table_name'] = 'incident';
GlideFlow.startFlow('global.flow_name', inputs)
.then(
function(execution) {
console.log('Started flow_name with execution id :' + execution.getExecutionId());
},
function(error) {
console.log('Unable to start flow: ' + error);
}
);
})();
GlideFlow - startSubflow(String scopedName.subflowName, Entrées de carte)
Démarrez un flux secondaire.
| Nom | Type | Description |
|---|---|---|
| scopedName (en anglais seulement) | Chaîne | Nom délimité du flux à exécuter. |
| entrées | Objet | Un objet contenant les entrées utilisées pour le flux secondaire. |
| Type | Description |
|---|---|
| Objet | Objet contenant des détails sur l’exécution du flux secondaire. |
Dans cet exemple, le code démarre le flux secondaire de subflow_name globale à l’aide d’arguments dans la variable de tableau d’entrées. Une fois l’opération terminée, l’exemple utilise console.log ou console.error pour signaler la réussite ou l’échec du flux.
// Start an action and await completion.
(function() {
var inputs = {};
inputs['input1'] = 'string input'; // String
GlideFlow.startSubflow('global.subflow_name', inputs)
.then(function(execution) {
return execution.awaitCompletion();
}, errorResolver)
.then(function(completion) {
var status = completion.status;
console.log(status);
// Available Outputs:
var outputs = completion.outputs;
console.log(outputs);
}, errorResolver());
function errorResolver(error) {
// Handle errors in error resolver
console.error(error);
}
})();