/********************************************* * Copyright (c) 2014 AnsibleWorks, Inc. * * LogViewer.js * */ 'use strict'; angular.module('LogViewerHelper', ['ModalDialog', 'Utilities', 'FormGenerator', 'VariablesHelper']) .factory('LogViewer', ['$compile', 'CreateDialog', 'GetJob', 'Wait', 'GenerateForm', 'LogViewerStatusForm', 'AddTable', 'AddTextarea', 'LogViewerOptionsForm', 'EnvTable', 'GetBasePath', 'LookUpName', 'Empty', 'AddPreFormattedText', 'ParseVariableString', function($compile, CreateDialog, GetJob, Wait, GenerateForm, LogViewerStatusForm, AddTable, AddTextarea, LogViewerOptionsForm, EnvTable, GetBasePath, LookUpName, Empty, AddPreFormattedText, ParseVariableString) { return function(params) { var parent_scope = params.scope, url = params.url, getIcon = params.getIcon, scope = parent_scope.$new(); if (scope.removeModalReady) { scope.removeModalReady(); } scope.removeModalReady = scope.$on('ModalReady', function() { Wait('stop'); $('#logviewer-modal-dialog').dialog('open'); }); if (scope.removeJobReady) { scope.removeJobReady(); } scope.removeJobReady = scope.$on('JobReady', function(e, data) { var key, resizeText, elem; for (key in data) { scope[key] = data[key]; } AddTable({ scope: scope, form: LogViewerStatusForm, id: 'status-form-container', getIcon: getIcon }); AddTable({ scope: scope, form: LogViewerOptionsForm, id: 'options-form-container', getIcon: getIcon }); if (data.result_stdout) { AddPreFormattedText({ id: 'stdout-form-container', val: data.result_stdout }); } else { $('#logview-tabs li:eq(1)').hide(); } if (data.result_traceback) { AddPreFormattedText({ id: 'traceback-form-container', val: data.result_traceback }); } else { $('#logview-tabs li:eq(2)').hide(); } /*if (data.job_env) { EnvTable({ id: 'env-form-container', vars: data.job_env }); }*/ if (data.extra_vars) { AddTextarea({ container_id: 'variables-container', fld_id: 'variables', val: ParseVariableString(data.extra_vars) }); } else { $('#logview-tabs li:eq(4)').hide(); } if (data.source_vars) { AddTextarea({ container_id: 'source-container', fld_id: 'source-variables', val: ParseVariableString(data.source_vars) }); } else { $('#logview-tabs li:eq(5)').hide(); } if (!Empty(scope.credential)) { LookUpName({ scope: scope, scope_var: 'credential', url: GetBasePath('credentials') + scope.credential + '/' }); } if (!Empty(scope.inventory)) { LookUpName({ scope: scope, scope_var: 'inventory', url: GetBasePath('inventory') + scope.inventory + '/' }); } if (!Empty(scope.project)) { LookUpName({ scope: scope, scope_var: 'project', url: GetBasePath('projects') + scope.project + '/' }); } if (!Empty(scope.cloud_credential)) { LookUpName({ scope: scope, scope_var: 'cloud_credential', url: GetBasePath('credentials') + scope.cloud_credential + '/' }); } if (!Empty(scope.inventory_source)) { LookUpName({ scope: scope, scope_var: 'inventory_source', url: GetBasePath('inventory_sources') + scope.inventory_source + '/' }); } resizeText = function() { var u = $('#logview-tabs').outerHeight() + 25, h = $('#logviewer-modal-dialog').innerHeight(), rows = Math.floor((h - u) / 20); rows -= 3; rows = (rows < 6) ? 6 : rows; $('#logviewer-modal-dialog #variables').attr({ rows: rows }); $('#logviewer-modal-dialog #source-variables').attr({ rows: rows }); }; elem = angular.element(document.getElementById('logviewer-modal-dialog')); $compile(elem)(scope); CreateDialog({ scope: scope, width: 600, height: 550, minWidth: 450, callback: 'ModalReady', id: 'logviewer-modal-dialog', onResizeStop: resizeText, onOpen: function() { $('#logview-tabs a:first').tab('show'); resizeText(); } }); }); GetJob({ url: url, scope: scope }); scope.modalOK = function() { $('#logviewer-modal-dialog').dialog('close'); }; }; }]) .factory('GetJob', ['Rest', 'ProcessErrors', function(Rest, ProcessErrors) { return function(params) { var url = params.url, scope = params.scope; Rest.setUrl(url); Rest.get() .success(function(data){ scope.$emit('JobReady', data); }) .error(function(data, status) { ProcessErrors(scope, data, status, null, { hdr: 'Error!', msg: 'Failed to retrieve ' + url + '. GET returned: ' + status }); }); }; }]) .factory('LookUpName', ['Rest', 'ProcessErrors', 'Empty', function(Rest, ProcessErrors, Empty) { return function(params) { var url = params.url, scope_var = params.scope_var, scope = params.scope; Rest.setUrl(url); Rest.get() .success(function(data) { if (!Empty(data.name)) { scope[scope_var + '_name'] = data.name; } if (!Empty(data.group)) { // Used for inventory_source scope.group = data.group; } }) .error(function(data, status) { ProcessErrors(scope, data, status, null, { hdr: 'Error!', msg: 'Failed to retrieve ' + url + '. GET returned: ' + status }); }); }; }]) .factory('AddTable', ['Empty', 'Find', function(Empty, Find) { return function(params) { var form = params.form, id = params.id, scope = params.scope, getIcon = params.getIcon, fld, html, url, urls = [ { "variable": "credential", "url": "/#/credentials/" }, { "variable": "project", "url": "/#/projects/" }, { "variable": "inventory", "url": "/#/inventories/" }, { "variable": "cloud_credential", "url": "/#/credentials/" }, { "variable": "inventory_source", "url": "/#/home/groups/?id=" } ]; html = "\n"; for (fld in form.fields) { if (!Empty(scope[fld])) { html += "" + "\n"; } } html += "
" + form.fields[fld].label + ""; url = Find({ list: urls, key: "variable", val: fld }); if (url) { html += "{{ " + fld + '_name' + " }}"; } else if (fld === 'elapsed') { html += scope[fld] + " seconds"; } else if (getIcon && fld === 'status') { html += " " + scope[fld]; //html += " " + scope[fld]; } else if (fld === 'status') { html += " " + scope[fld]; } else { html += scope[fld]; } html += "
\n"; $('#' + id).empty().html(html); }; }]) .factory('AddTextarea', [ function() { return function(params) { var container_id = params.container_id, val = params.val, fld_id = params.fld_id, html; html = "
\n" + "" + "
\n"; $('#' + container_id).empty().html(html); }; }]) .factory('AddPreFormattedText', [function() { return function(params) { var id = params.id, val = params.val, html; html = "
" + val + "
\n"; $('#' + id).empty().html(html); }; }]) .factory('EnvTable', [ function() { return function(params) { var id = params.id, vars = params.vars, key, html; html = "\n"; for (key in vars) { html += "" + "\n"; } html += "
" + key + "" + vars[key] + "
\n"; $('#' + id).empty().html(html); }; }]);