installer.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416
  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.InstallerController = App.WizardController.extend({
  20. name: 'installerController',
  21. totalSteps: 11,
  22. content: Em.Object.create({
  23. cluster: null,
  24. installOptions: null,
  25. hosts: null,
  26. services: null,
  27. slaveComponentHosts: null,
  28. masterComponentHosts: null,
  29. serviceConfigProperties: null,
  30. advancedServiceConfig: null,
  31. slaveGroupProperties: null,
  32. stacks: null,
  33. controllerName: 'installerController'
  34. }),
  35. init: function () {
  36. this._super();
  37. this.get('isStepDisabled').setEach('value', true);
  38. this.get('isStepDisabled').pushObject(Ember.Object.create({
  39. step: 0,
  40. value: false
  41. }));
  42. },
  43. /**
  44. * redefined connectOutlet method to avoid view loading by unauthorized user
  45. * @param view
  46. * @param content
  47. */
  48. connectOutlet: function(view, content) {
  49. if(App.db.getAuthenticated()) {
  50. this._super(view, content);
  51. }
  52. },
  53. getCluster: function(){
  54. return jQuery.extend({}, this.get('clusterStatusTemplate'));
  55. },
  56. getInstallOptions: function(){
  57. return jQuery.extend({}, this.get('installOptionsTemplate'));
  58. },
  59. getHosts: function(){
  60. return [];
  61. },
  62. /**
  63. * Remove host from model. Used at <code>Confirm hosts(step2)</code> step
  64. * @param hosts Array of hosts, which we want to delete
  65. */
  66. removeHosts: function (hosts) {
  67. //todo Replace this code with real logic
  68. App.db.removeHosts(hosts);
  69. },
  70. /**
  71. * Load confirmed hosts.
  72. * Will be used at <code>Assign Masters(step5)</code> step
  73. */
  74. loadConfirmedHosts: function () {
  75. this.set('content.hosts', App.db.getHosts() || []);
  76. },
  77. /**
  78. * Load services data. Will be used at <code>Select services(step4)</code> step
  79. */
  80. loadServices: function () {
  81. var servicesInfo = App.db.getService();
  82. if(servicesInfo && servicesInfo.length) {
  83. servicesInfo.forEach(function (item, index) {
  84. servicesInfo[index] = Em.Object.create(item);
  85. servicesInfo[index].isInstalled = false;
  86. });
  87. this.set('content.services', servicesInfo);
  88. console.log('installerController.loadServices: loaded data ', JSON.stringify(servicesInfo));
  89. console.log("The type odf serviceInfo: " + typeof servicesInfo);
  90. console.log('selected services ', servicesInfo.filterProperty('isSelected', true).mapProperty('serviceName'));
  91. } else {
  92. console.log("Failed to load Services");
  93. }
  94. App.router.get('clusterController').loadAmbariProperties();
  95. },
  96. stacks: [],
  97. /**
  98. * Load stacks data from server or take exist data from local db
  99. */
  100. loadStacks: function () {
  101. var stacks = App.db.getStacks();
  102. if (stacks && stacks.length) {
  103. var convertedStacks = [];
  104. stacks.forEach(function (stack) {
  105. convertedStacks.pushObject(Ember.Object.create(stack));
  106. });
  107. App.set('currentStackVersion', convertedStacks.findProperty('isSelected').get('name'));
  108. this.set('content.stacks', convertedStacks);
  109. } else {
  110. App.ajax.send({
  111. name: 'wizard.stacks',
  112. sender: this,
  113. success: 'loadStacksSuccessCallback',
  114. error: 'loadStacksErrorCallback'
  115. });
  116. }
  117. },
  118. /**
  119. * Send queries to load versions for each stack
  120. */
  121. loadStacksSuccessCallback: function (data) {
  122. var stacks = data.items;
  123. var result;
  124. this.get('stacks').clear();
  125. stacks.forEach(function (stack) {
  126. App.ajax.send({
  127. name: 'wizard.stacks_versions',
  128. sender: this,
  129. data: {
  130. stackName: stack.Stacks.stack_name
  131. },
  132. success: 'loadStacksVersionsSuccessCallback',
  133. error: 'loadStacksVersionsErrorCallback'
  134. });
  135. }, this);
  136. result = this.get('stacks');
  137. if (!result.length) {
  138. console.log('Error: therea are no active stacks');
  139. } else {
  140. var defaultStackVersion = result.findProperty('name', App.defaultStackVersion);
  141. if (defaultStackVersion) {
  142. defaultStackVersion.set('isSelected', true)
  143. } else {
  144. result.objectAt(0).set('isSelected', true);
  145. }
  146. }
  147. App.db.setStacks(result);
  148. this.set('content.stacks', result);
  149. },
  150. /**
  151. * onError callback for loading stacks data
  152. */
  153. loadStacksErrorCallback: function () {
  154. console.log('Error in loading stacks');
  155. },
  156. /**
  157. * Parse loaded data and create array of stacks objects
  158. */
  159. loadStacksVersionsSuccessCallback: function (data) {
  160. var result = [];
  161. var stackVersions = data.items.filterProperty('Versions.active');
  162. stackVersions.sort(function (a, b) {
  163. if (a.Versions.stack_version > b.Versions.stack_version) {
  164. return -1;
  165. }
  166. if (a.Versions.stack_version < b.Versions.stack_version) {
  167. return 1;
  168. }
  169. return 0;
  170. });
  171. stackVersions.forEach(function (version) {
  172. /*
  173. * operatingSystems:[
  174. * {
  175. * osType: 'centos5',
  176. * baseUrl: 'http://...',
  177. * originalBaseUrl: 'http://...',
  178. * defaultBaseUrl: 'http://...',
  179. * mirrorsList: '';
  180. * },
  181. * {
  182. * osType: 'centos6',
  183. * baseUrl: 'http://...',
  184. * originalBaseUrl: 'http://...',
  185. * defaultBaseUrl: 'http://...',
  186. * mirrorsList: '';
  187. * },
  188. * ]
  189. */
  190. var oses = [];
  191. if (version.operatingSystems) {
  192. version.operatingSystems.forEach(function (os) {
  193. if (os.repositories) {
  194. os.repositories.forEach(function (repo) {
  195. if(repo.Repositories.repo_name == version.Versions.stack_name){
  196. oses.push({
  197. osType: os.OperatingSystems.os_type,
  198. baseUrl: repo.Repositories.base_url,
  199. originalBaseUrl: repo.Repositories.base_url,
  200. defaultBaseUrl: repo.Repositories.default_base_url ?
  201. repo.Repositories.default_base_url : repo.Repositories.base_url,
  202. mirrorsList: repo.Repositories.mirrors_list
  203. });
  204. }
  205. });
  206. }
  207. });
  208. }
  209. result.push(
  210. Ember.Object.create({
  211. name: version.Versions.stack_name + "-" + version.Versions.stack_version,
  212. isSelected: false,
  213. operatingSystems: oses
  214. })
  215. );
  216. }, this);
  217. this.get('stacks').pushObjects(result);
  218. },
  219. /**
  220. * onError callback for loading stacks data
  221. */
  222. loadStacksVersionsErrorCallback: function () {
  223. console.log('Error in loading stacks');
  224. },
  225. /**
  226. * Save data to model
  227. * @param stepController App.WizardStep4Controller
  228. */
  229. saveServices: function (stepController) {
  230. var serviceNames = [];
  231. App.db.setService(stepController.get('content'));
  232. stepController.filterProperty('isSelected', true).forEach(function (item) {
  233. serviceNames.push(item.serviceName);
  234. });
  235. this.set('content.selectedServiceNames', serviceNames);
  236. App.db.setSelectedServiceNames(serviceNames);
  237. console.log('installerController.saveServices: saved data ', serviceNames);
  238. },
  239. /**
  240. * Save Master Component Hosts data to Main Controller
  241. * @param stepController App.WizardStep5Controller
  242. */
  243. saveMasterComponentHosts: function (stepController) {
  244. var obj = stepController.get('selectedServicesMasters');
  245. var masterComponentHosts = [];
  246. obj.forEach(function (_component) {
  247. masterComponentHosts.push({
  248. display_name: _component.get('display_name'),
  249. component: _component.get('component_name'),
  250. hostName: _component.get('selectedHost'),
  251. serviceId: _component.get('serviceId'),
  252. isInstalled: false
  253. });
  254. });
  255. console.log("installerController.saveMasterComponentHosts: saved hosts ", masterComponentHosts);
  256. App.db.setMasterComponentHosts(masterComponentHosts);
  257. this.set('content.masterComponentHosts', masterComponentHosts);
  258. },
  259. /**
  260. * Load master component hosts data for using in required step controllers
  261. */
  262. loadMasterComponentHosts: function () {
  263. var masterComponentHosts = App.db.getMasterComponentHosts() || [];
  264. this.set("content.masterComponentHosts", masterComponentHosts);
  265. console.log("InstallerController.loadMasterComponentHosts: loaded hosts ", masterComponentHosts);
  266. },
  267. /**
  268. * Load master component hosts data for using in required step controllers
  269. */
  270. loadSlaveComponentHosts: function () {
  271. var slaveComponentHosts = App.db.getSlaveComponentHosts() || null;
  272. this.set("content.slaveComponentHosts", slaveComponentHosts);
  273. console.log("InstallerController.loadSlaveComponentHosts: loaded hosts ", slaveComponentHosts);
  274. },
  275. /**
  276. * Load serviceConfigProperties to model
  277. */
  278. loadServiceConfigProperties: function () {
  279. var serviceConfigProperties = App.db.getServiceConfigProperties();
  280. this.set('content.serviceConfigProperties', serviceConfigProperties);
  281. console.log("InstallerController.loadServiceConfigProperties: loaded config ", serviceConfigProperties);
  282. this.set('content.advancedServiceConfig', App.db.getAdvancedServiceConfig());
  283. },
  284. /**
  285. * Load information about hosts with clients components
  286. */
  287. loadClients: function () {
  288. var clients = App.db.getClientsForSelectedServices();
  289. this.set('content.clients', clients);
  290. console.log("InstallerController.loadClients: loaded list ", clients);
  291. },
  292. /**
  293. * Generate clients list for selected services and save it to model
  294. * @param stepController step4WizardController
  295. */
  296. saveClients: function (stepController) {
  297. var clients = [];
  298. var serviceComponents = require('data/service_components');
  299. stepController.get('content').filterProperty('isSelected', true).forEach(function (_service) {
  300. var client = serviceComponents.filterProperty('service_name', _service.serviceName).findProperty('isClient', true);
  301. if (client) {
  302. clients.pushObject({
  303. component_name: client.component_name,
  304. display_name: client.display_name,
  305. isInstalled: false
  306. });
  307. }
  308. }, this);
  309. App.db.setClientsForSelectedServices(clients);
  310. this.set('content.clients', clients);
  311. console.log("InstallerController.saveClients: saved list ", clients);
  312. },
  313. /**
  314. * Save stacks data to local db
  315. * @param stepController step1WizardController
  316. */
  317. saveStacks: function (stepController) {
  318. var stacks = stepController.get('content.stacks');
  319. if (stacks.length) {
  320. App.set('currentStackVersion', stacks.findProperty('isSelected').get('name'));
  321. } else {
  322. App.set('currentStackVersion', App.defaultStackVersion);
  323. }
  324. App.db.setStacks(stacks);
  325. this.set('content.stacks', stacks);
  326. },
  327. /**
  328. * Load data for all steps until <code>current step</code>
  329. */
  330. loadAllPriorSteps: function () {
  331. var step = this.get('currentStep');
  332. switch (step) {
  333. case '10':
  334. case '9':
  335. case '8':
  336. case '7':
  337. this.loadServiceConfigProperties();
  338. case '6':
  339. this.loadSlaveComponentHosts();
  340. this.loadClients();
  341. case '5':
  342. this.loadMasterComponentHosts();
  343. this.loadConfirmedHosts();
  344. case '4':
  345. this.loadServices();
  346. case '3':
  347. this.loadConfirmedHosts();
  348. case '2':
  349. this.load('installOptions');
  350. case '1':
  351. this.loadStacks();
  352. case '0':
  353. this.load('cluster');
  354. }
  355. },
  356. /**
  357. * Clear all temporary data
  358. */
  359. finish: function () {
  360. this.setCurrentStep('0');
  361. this.clearStorageData();
  362. },
  363. setStepsEnable: function () {
  364. for (var i = 0; i <= this.totalSteps; i++) {
  365. var step = this.get('isStepDisabled').findProperty('step', i);
  366. if (i <= this.get('currentStep')) {
  367. step.set('value', false);
  368. } else {
  369. step.set('value', true);
  370. }
  371. }
  372. }.observes('currentStep'),
  373. setLowerStepsDisable: function (stepNo) {
  374. for (var i = 0; i < stepNo; i++) {
  375. var step = this.get('isStepDisabled').findProperty('step', i);
  376. step.set('value', true);
  377. }
  378. }
  379. });