installer.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525
  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. configGroups: [],
  32. slaveGroupProperties: null,
  33. stacks: null,
  34. controllerName: 'installerController'
  35. }),
  36. init: function () {
  37. this._super();
  38. this.get('isStepDisabled').setEach('value', true);
  39. this.get('isStepDisabled').pushObject(Ember.Object.create({
  40. step: 0,
  41. value: false
  42. }));
  43. },
  44. /**
  45. * redefined connectOutlet method to avoid view loading by unauthorized user
  46. * @param view
  47. * @param content
  48. */
  49. connectOutlet: function(view, content) {
  50. if(App.db.getAuthenticated()) {
  51. this._super(view, content);
  52. }
  53. },
  54. getCluster: function(){
  55. return jQuery.extend({}, this.get('clusterStatusTemplate'));
  56. },
  57. getInstallOptions: function(){
  58. return jQuery.extend({}, this.get('installOptionsTemplate'));
  59. },
  60. getHosts: function(){
  61. return [];
  62. },
  63. /**
  64. * Remove host from model. Used at <code>Confirm hosts(step2)</code> step
  65. * @param hosts Array of hosts, which we want to delete
  66. */
  67. removeHosts: function (hosts) {
  68. var dbHosts = this.getDBProperty('hosts');
  69. hosts.forEach(function (_hostInfo) {
  70. var host = _hostInfo.hostName;
  71. delete dbHosts[host];
  72. });
  73. this.setDBProperty('hosts', dbHosts);
  74. },
  75. /**
  76. * Load confirmed hosts.
  77. * Will be used at <code>Assign Masters(step5)</code> step
  78. */
  79. loadConfirmedHosts: function () {
  80. this.set('content.hosts', this.getDBProperty('hosts') || []);
  81. },
  82. /**
  83. * Load services data. Will be used at <code>Select services(step4)</code> step
  84. */
  85. loadServices: function () {
  86. var servicesInfo = this.getDBProperty('service');
  87. if(servicesInfo && servicesInfo.length) {
  88. servicesInfo.forEach(function (item, index) {
  89. servicesInfo[index] = Em.Object.create(item);
  90. servicesInfo[index].isInstalled = false;
  91. });
  92. this.set('content.services', servicesInfo);
  93. console.log('installerController.loadServices: loaded data ', JSON.stringify(servicesInfo));
  94. console.log('selected services ', servicesInfo.filterProperty('isSelected', true).mapProperty('serviceName'));
  95. } else {
  96. console.log("Failed to load Services");
  97. }
  98. },
  99. stacks: [],
  100. /**
  101. * Load stacks data from server or take exist data from local db
  102. */
  103. loadStacks: function () {
  104. var stacks = App.db.getStacks();
  105. if (stacks && stacks.length) {
  106. var convertedStacks = [];
  107. stacks.forEach(function (stack) {
  108. convertedStacks.pushObject(Ember.Object.create(stack));
  109. });
  110. App.set('currentStackVersion', convertedStacks.findProperty('isSelected').get('name'));
  111. this.set('content.stacks', convertedStacks);
  112. } else {
  113. App.ajax.send({
  114. name: 'wizard.stacks',
  115. sender: this,
  116. success: 'loadStacksSuccessCallback',
  117. error: 'loadStacksErrorCallback'
  118. });
  119. }
  120. },
  121. /**
  122. * Send queries to load versions for each stack
  123. */
  124. loadStacksSuccessCallback: function (data) {
  125. var stacks = data.items;
  126. var result;
  127. this.get('stacks').clear();
  128. stacks.forEach(function (stack) {
  129. App.ajax.send({
  130. name: 'wizard.stacks_versions',
  131. sender: this,
  132. data: {
  133. stackName: stack.Stacks.stack_name
  134. },
  135. success: 'loadStacksVersionsSuccessCallback',
  136. error: 'loadStacksVersionsErrorCallback'
  137. });
  138. }, this);
  139. result = this.get('stacks');
  140. if (!result.length) {
  141. console.log('Error: therea are no active stacks');
  142. } else {
  143. var defaultStackVersion = result.findProperty('name', App.defaultStackVersion);
  144. if (defaultStackVersion) {
  145. defaultStackVersion.set('isSelected', true)
  146. } else {
  147. result.objectAt(0).set('isSelected', true);
  148. }
  149. }
  150. App.db.setStacks(result);
  151. this.set('content.stacks', result);
  152. },
  153. /**
  154. * onError callback for loading stacks data
  155. */
  156. loadStacksErrorCallback: function () {
  157. console.log('Error in loading stacks');
  158. },
  159. /**
  160. * Parse loaded data and create array of stacks objects
  161. */
  162. loadStacksVersionsSuccessCallback: function (data) {
  163. var result = [];
  164. var stackVersions = data.items.filterProperty('Versions.active');
  165. stackVersions.sortProperty('Versions.stack_version').reverse().forEach(function (version) {
  166. /*
  167. * operatingSystems:[
  168. * {
  169. * osType: 'centos5',
  170. * baseUrl: 'http://...',
  171. * originalBaseUrl: 'http://...',
  172. * defaultBaseUrl: 'http://...',
  173. * latestBaseUrl: 'http://...',
  174. * mirrorsList: '';
  175. * },
  176. * {
  177. * osType: 'centos6',
  178. * baseUrl: 'http://...',
  179. * originalBaseUrl: 'http://...',
  180. * defaultBaseUrl: 'http://...',
  181. * latestBaseUrl: 'http://...',
  182. * mirrorsList: '';
  183. * },
  184. * ]
  185. */
  186. var oses = [];
  187. if (version.operatingSystems) {
  188. version.operatingSystems.forEach(function (os) {
  189. if (os.repositories) {
  190. os.repositories.forEach(function (repo) {
  191. if(repo.Repositories.repo_name == version.Versions.stack_name) {
  192. var defaultBaseUrl = repo.Repositories.default_base_url || repo.Repositories.base_url;
  193. var latestBaseUrl = repo.Repositories.latest_base_url || defaultBaseUrl;
  194. oses.push({
  195. osType: os.OperatingSystems.os_type,
  196. baseUrl: latestBaseUrl,
  197. latestBaseUrl: latestBaseUrl,
  198. originalLatestBaseUrl: latestBaseUrl,
  199. originalBaseUrl: repo.Repositories.base_url,
  200. defaultBaseUrl: defaultBaseUrl,
  201. mirrorsList: repo.Repositories.mirrors_list
  202. });
  203. }
  204. });
  205. }
  206. });
  207. }
  208. result.push(
  209. Em.Object.create({
  210. name: version.Versions.stack_name + "-" + version.Versions.stack_version,
  211. isSelected: false,
  212. operatingSystems: oses
  213. })
  214. );
  215. }, this);
  216. this.get('stacks').pushObjects(result);
  217. },
  218. /**
  219. * onError callback for loading stacks data
  220. */
  221. loadStacksVersionsErrorCallback: function () {
  222. console.log('Error in loading stacks');
  223. },
  224. /**
  225. * check server version and web client version
  226. */
  227. checkServerClientVersion: function () {
  228. var dfd = $.Deferred();
  229. var self = this;
  230. self.getServerVersion().done(function () {
  231. dfd.resolve();
  232. });
  233. return dfd.promise();
  234. },
  235. getServerVersion: function(){
  236. return App.ajax.send({
  237. name: 'ambari.service.load_server_version',
  238. sender: this,
  239. success: 'getServerVersionSuccessCallback',
  240. error: 'getServerVersionErrorCallback'
  241. });
  242. },
  243. getServerVersionSuccessCallback: function (data) {
  244. var clientVersion = App.get('version');
  245. var serverVersion = (data.RootServiceComponents.component_version).toString();
  246. this.set('versionConflictAlertBody', Em.I18n.t('app.versionMismatchAlert.body').format(serverVersion, clientVersion));
  247. this.set('isServerClientVersionMismatch', clientVersion != serverVersion);
  248. },
  249. getServerVersionErrorCallback: function () {
  250. console.log('ERROR: Cannot load Ambari server version');
  251. },
  252. /**
  253. * Save data to model
  254. * @param stepController App.WizardStep4Controller
  255. */
  256. saveServices: function (stepController) {
  257. var serviceNames = [];
  258. this.setDBProperty('service', stepController.get('content'));
  259. stepController.filterProperty('isSelected', true).forEach(function (item) {
  260. serviceNames.push(item.serviceName);
  261. });
  262. this.set('content.selectedServiceNames', serviceNames);
  263. this.setDBProperty('selectedServiceNames', serviceNames);
  264. console.log('installerController.saveServices: saved data ', serviceNames);
  265. },
  266. /**
  267. * Save Master Component Hosts data to Main Controller
  268. * @param stepController App.WizardStep5Controller
  269. */
  270. saveMasterComponentHosts: function (stepController) {
  271. var obj = stepController.get('selectedServicesMasters');
  272. var masterComponentHosts = [];
  273. obj.forEach(function (_component) {
  274. masterComponentHosts.push({
  275. display_name: _component.get('display_name'),
  276. component: _component.get('component_name'),
  277. hostName: _component.get('selectedHost'),
  278. serviceId: _component.get('serviceId'),
  279. isInstalled: false
  280. });
  281. });
  282. console.log("installerController.saveMasterComponentHosts: saved hosts ", masterComponentHosts);
  283. this.setDBProperty('masterComponentHosts', masterComponentHosts);
  284. this.set('content.masterComponentHosts', masterComponentHosts);
  285. },
  286. /**
  287. * Load master component hosts data for using in required step controllers
  288. */
  289. loadMasterComponentHosts: function () {
  290. var masterComponentHosts = this.getDBProperty('masterComponentHosts') || [];
  291. this.set("content.masterComponentHosts", masterComponentHosts);
  292. console.log("InstallerController.loadMasterComponentHosts: loaded hosts ", masterComponentHosts);
  293. },
  294. /**
  295. * Load master component hosts data for using in required step controllers
  296. */
  297. loadSlaveComponentHosts: function () {
  298. var slaveComponentHosts = this.getDBProperty('slaveComponentHosts') || null;
  299. this.set("content.slaveComponentHosts", slaveComponentHosts);
  300. console.log("InstallerController.loadSlaveComponentHosts: loaded hosts ", slaveComponentHosts);
  301. },
  302. /**
  303. * Load serviceConfigProperties to model
  304. */
  305. loadServiceConfigProperties: function () {
  306. var serviceConfigProperties = this.getDBProperty('serviceConfigProperties');
  307. this.set('content.serviceConfigProperties', serviceConfigProperties);
  308. console.log("InstallerController.loadServiceConfigProperties: loaded config ", serviceConfigProperties);
  309. this.set('content.advancedServiceConfig', this.getDBProperty('advancedServiceConfig'));
  310. },
  311. /**
  312. * Load information about hosts with clients components
  313. */
  314. loadClients: function () {
  315. var clients = this.getDBProperty('clientInfo');
  316. this.set('content.clients', clients);
  317. console.log("InstallerController.loadClients: loaded list ", clients);
  318. },
  319. /**
  320. * Generate clients list for selected services and save it to model
  321. * @param stepController step4WizardController
  322. */
  323. saveClients: function (stepController) {
  324. var clients = [];
  325. var serviceComponents = require('data/service_components');
  326. stepController.get('content').filterProperty('isSelected', true).forEach(function (_service) {
  327. var client = serviceComponents.filterProperty('service_name', _service.serviceName).findProperty('isClient', true);
  328. if (client) {
  329. clients.pushObject({
  330. component_name: client.component_name,
  331. display_name: client.display_name,
  332. isInstalled: false
  333. });
  334. }
  335. }, this);
  336. this.setDBProperty('clientInfo', clients);
  337. this.set('content.clients', clients);
  338. console.log("InstallerController.saveClients: saved list ", clients);
  339. },
  340. /**
  341. * Save stacks data to local db
  342. * @param stepController step1WizardController
  343. */
  344. saveStacks: function (stepController) {
  345. var stacks = stepController.get('content.stacks');
  346. if (stacks.length) {
  347. App.set('currentStackVersion', stacks.findProperty('isSelected').get('name'));
  348. } else {
  349. App.set('currentStackVersion', App.defaultStackVersion);
  350. }
  351. App.db.setStacks(stacks);
  352. this.set('content.stacks', stacks);
  353. },
  354. /**
  355. * Check validation of the customized local urls
  356. * @param stepController step1WizardController
  357. */
  358. checkRepoURL: function (stepController) {
  359. var selectedStack = this.get('content.stacks').findProperty('isSelected', true);
  360. selectedStack.set('reload', true);
  361. var nameVersionCombo = selectedStack.name;
  362. var stackName = nameVersionCombo.split('-')[0];
  363. var stackVersion = nameVersionCombo.split('-')[1];
  364. if (selectedStack && selectedStack.operatingSystems) {
  365. this.set('validationCnt', selectedStack.get('operatingSystems').filterProperty('selected', true).length);
  366. this.set('invalidCnt', 0);
  367. selectedStack.operatingSystems.forEach(function (os) {
  368. os.errorTitle = null;
  369. os.errorContent = null;
  370. if (os.skipValidation) {
  371. this.set('validationCnt', 0);
  372. }
  373. if (os.selected && !os.skipValidation) {
  374. os.validation = 'icon-repeat';
  375. selectedStack.set('reload', !selectedStack.get('reload'));
  376. App.ajax.send({
  377. name: 'wizard.advanced_repositories.valid_url',
  378. sender: this,
  379. data: {
  380. stackName: stackName,
  381. stackVersion: stackVersion,
  382. nameVersionCombo: nameVersionCombo,
  383. osType: os.osType,
  384. data: {
  385. 'Repositories': {
  386. 'base_url': os.baseUrl
  387. }
  388. }
  389. },
  390. success: 'checkRepoURLSuccessCallback',
  391. error: 'checkRepoURLErrorCallback'
  392. });
  393. }
  394. }, this);
  395. }
  396. },
  397. setInvalidUrlCnt: function () {
  398. var selectedStack = this.get('content.stacks').findProperty('isSelected', true);
  399. selectedStack.set('invalidCnt', this.get('invalidCnt'));
  400. }.observes('invalidCnt'),
  401. /**
  402. * onSuccess callback for check Repo URL.
  403. */
  404. checkRepoURLSuccessCallback: function (response, request, data) {
  405. console.log('Success in check Repo URL. data osType: ' + data.osType );
  406. var selectedStack = this.get('content.stacks').findProperty('isSelected', true);
  407. if (selectedStack && selectedStack.operatingSystems) {
  408. var os = selectedStack.operatingSystems.findProperty('osType', data.osType);
  409. os.validation = 'icon-ok';
  410. selectedStack.set('reload', !selectedStack.get('reload'));
  411. this.set('validationCnt', this.get('validationCnt') - 1);
  412. }
  413. },
  414. /**
  415. * onError callback for check Repo URL.
  416. */
  417. checkRepoURLErrorCallback: function (request, ajaxOptions, error, data) {
  418. console.log('Error in check Repo URL. The baseURL sent is: ' + data.data);
  419. var osType = data.url.split('/')[8];
  420. var selectedStack = this.get('content.stacks').findProperty('isSelected', true);
  421. if (selectedStack && selectedStack.operatingSystems) {
  422. var os = selectedStack.operatingSystems.findProperty('osType', osType);
  423. os.validation = 'icon-exclamation-sign';
  424. os.errorTitle = request.status + ":" + request.statusText;
  425. os.errorContent = $.parseJSON(request.responseText) ? $.parseJSON(request.responseText).message : "";
  426. selectedStack.set('reload', !selectedStack.get('reload'));
  427. this.set('validationCnt', this.get('validationCnt') - 1);
  428. this.set('invalidCnt', this.get('invalidCnt') + 1);
  429. }
  430. },
  431. /**
  432. * Load data for all steps until <code>current step</code>
  433. */
  434. loadAllPriorSteps: function () {
  435. var step = this.get('currentStep');
  436. switch (step) {
  437. case '10':
  438. case '9':
  439. case '8':
  440. case '7':
  441. this.loadServiceConfigGroups();
  442. this.loadServiceConfigProperties();
  443. case '6':
  444. this.loadSlaveComponentHosts();
  445. this.loadClients();
  446. case '5':
  447. this.loadMasterComponentHosts();
  448. this.loadConfirmedHosts();
  449. case '4':
  450. this.loadServices();
  451. case '3':
  452. this.loadConfirmedHosts();
  453. case '2':
  454. this.load('installOptions');
  455. case '1':
  456. this.loadStacks();
  457. case '0':
  458. this.load('cluster');
  459. }
  460. },
  461. /**
  462. * Clear all temporary data
  463. */
  464. finish: function () {
  465. this.setCurrentStep('0');
  466. this.clearStorageData();
  467. var persists = App.router.get('applicationController').persistKey();
  468. App.router.get('applicationController').postUserPref(persists,true);
  469. },
  470. setStepsEnable: function () {
  471. for (var i = 0; i <= this.totalSteps; i++) {
  472. var step = this.get('isStepDisabled').findProperty('step', i);
  473. if (i <= this.get('currentStep')) {
  474. step.set('value', false);
  475. } else {
  476. step.set('value', true);
  477. }
  478. }
  479. }.observes('currentStep'),
  480. setLowerStepsDisable: function (stepNo) {
  481. for (var i = 0; i < stepNo; i++) {
  482. var step = this.get('isStepDisabled').findProperty('step', i);
  483. step.set('value', true);
  484. }
  485. }
  486. });