manage_clusters_controller.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. var App = require('app');
  19. App.MainMirroringManageClustersController = Em.ArrayController.extend({
  20. name: 'mainMirroringManageClustersController',
  21. // link to popup object
  22. popup: null,
  23. clusters: [],
  24. // array of original clusters to compare with changed ones
  25. originalClusters: [],
  26. queriesCount: 0,
  27. // array of error messages
  28. queryErrors: [],
  29. isLoaded: function () {
  30. return App.router.get('mainMirroringController.isLoaded');
  31. }.property('App.router.mainMirroringController.isLoaded'),
  32. onLoad: function () {
  33. if (this.get('isLoaded')) {
  34. var clusters = [];
  35. var originalClusters = [];
  36. App.TargetCluster.find().forEach(function (cluster) {
  37. var newCluster = {
  38. name: cluster.get('name'),
  39. execute: cluster.get('execute'),
  40. workflow: cluster.get('workflow'),
  41. readonly: cluster.get('readonly'),
  42. staging: cluster.get('staging'),
  43. working: cluster.get('working'),
  44. temp: cluster.get('temp')
  45. };
  46. clusters.push(Ember.Object.create(newCluster));
  47. originalClusters.push(Ember.Object.create(newCluster));
  48. }, this);
  49. this.set('clusters', clusters);
  50. this.set('originalClusters', originalClusters);
  51. }
  52. }.observes('isLoaded'),
  53. selectedCluster: null,
  54. addCluster: function () {
  55. var self = this;
  56. App.showPromptPopup(Em.I18n.t('mirroring.manageClusters.specifyName'),
  57. function (clusterName) {
  58. self.get('clusters').pushObject(Ember.Object.create({
  59. name: clusterName,
  60. execute: '',
  61. workflow: '',
  62. readonly: '',
  63. staging: '',
  64. working: '',
  65. temp: ''
  66. }));
  67. }
  68. );
  69. },
  70. removeCluster: function () {
  71. var self = this;
  72. App.showConfirmationPopup(function () {
  73. self.set('clusters', self.get('clusters').without(self.get('selectedCluster')));
  74. });
  75. },
  76. save: function () {
  77. // define clusters need to be deleted, modified or created
  78. var clusters = this.get('clusters');
  79. var originalClusters = this.get('originalClusters');
  80. var originalClustersNames = originalClusters.mapProperty('name');
  81. var clustersToModify = [];
  82. var clustersToCreate = [];
  83. clusters.forEach(function (cluster) {
  84. var clusterName = cluster.get('name');
  85. if (originalClustersNames.contains(clusterName)) {
  86. if (JSON.stringify(cluster) !== JSON.stringify(originalClusters.findProperty('name', clusterName))) {
  87. clustersToModify.push(clusterName);
  88. }
  89. originalClustersNames = originalClustersNames.without(clusterName);
  90. } else {
  91. clustersToCreate.push(clusterName);
  92. }
  93. }, this);
  94. var clustersToDelete = originalClustersNames;
  95. var queriesCount = clustersToCreate.length + clustersToDelete.length + clustersToModify.length;
  96. this.set('queriesCount', queriesCount);
  97. // send request to delete, modify or create cluster
  98. if (queriesCount) {
  99. this.get('queryErrors').clear();
  100. clustersToDelete.forEach(function (cluster) {
  101. App.ajax.send({
  102. name: 'mirroring.delete_entity',
  103. sender: this,
  104. data: {
  105. name: cluster,
  106. type: 'cluster',
  107. falconServer: App.get('falconServerURL')
  108. },
  109. success: 'onQueryResponse',
  110. error: 'onQueryResponse'
  111. });
  112. }, this);
  113. clustersToCreate.forEach(function (cluster) {
  114. App.ajax.send({
  115. name: 'mirroring.submit_entity',
  116. sender: this,
  117. data: {
  118. type: 'cluster',
  119. entity: this.formatClusterXML(clusters.findProperty('name', cluster)),
  120. falconServer: App.get('falconServerURL')
  121. },
  122. success: 'onQueryResponse',
  123. error: 'onQueryResponse'
  124. });
  125. }, this);
  126. clustersToModify.forEach(function (cluster) {
  127. App.ajax.send({
  128. name: 'mirroring.update_entity',
  129. sender: this,
  130. data: {
  131. name: cluster,
  132. type: 'cluster',
  133. entity: this.formatClusterXML(clusters.findProperty('name', cluster)),
  134. falconServer: App.get('falconServerURL')
  135. },
  136. success: 'onQueryResponse',
  137. error: 'onQueryResponse'
  138. });
  139. }, this);
  140. } else {
  141. this.get('popup').hide();
  142. }
  143. },
  144. // close popup after getting response from all queries or show popup with errors
  145. onQueryResponse: function () {
  146. var queryErrors = this.get('queryErrors');
  147. if (arguments.length === 4) {
  148. queryErrors.push(arguments[2]);
  149. }
  150. var queriesCount = this.get('queriesCount');
  151. this.set('queriesCount', --queriesCount);
  152. if (queriesCount < 1) {
  153. if (queryErrors.length) {
  154. App.showAlertPopup(Em.I18n.t('common.error'), Em.I18n.t('mirroring.manageClusters.error') + ': ' + queryErrors.join(', '));
  155. } else {
  156. this.get('popup').hide();
  157. }
  158. }
  159. },
  160. /**
  161. * Return XML-formatted string made from cluster object
  162. * @param {Object} cluster - object with cluster data
  163. * @return {String}
  164. */
  165. formatClusterXML: function (cluster) {
  166. return '<?xml version="1.0"?><cluster colo="local" description="" name="' + cluster.get('name') +
  167. '" xmlns="uri:falcon:cluster:0.1"><interfaces><interface type="readonly" endpoint="' + cluster.get('readonly') +
  168. '" version="2.2.0" /><interface type="execute" endpoint="' + cluster.get('execute') +
  169. '" version="2.2.0" /><interface type="workflow" endpoint="' + cluster.get('workflow') +
  170. '" version="4.0.0" />' + '<interface type="messaging" endpoint="tcp://' + App.get('falconServerURL') +':61616?daemon=true" version="5.1.6" />' +
  171. '<interface type="write" endpoint="hdfs://c6401.ambari.apache.org:8020" version="2.2.0" />' +
  172. '</interfaces><locations><location name="staging" path="' + cluster.get('staging') +
  173. '" /><location name="temp" path="' + cluster.get('temp') +
  174. '" /><location name="working" path="' + cluster.get('working') +
  175. '" /></locations></cluster>';
  176. }
  177. });