installer.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526
  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. module.exports = Em.Route.extend(App.RouterRedirections, {
  20. route: '/installer',
  21. App: require('app'),
  22. enter: function (router) {
  23. var self = this;
  24. App.clusterStatus.set('wizardControllerName', App.router.get('installerController.name'));
  25. router.getAuthenticated().done(function (loggedIn) {
  26. if (loggedIn) {
  27. var applicationController = router.get('applicationController');
  28. App.router.get('experimentalController').loadSupports().complete(function () {
  29. applicationController.startKeepAlivePoller();
  30. // check server/web client versions match
  31. App.router.get('installerController').checkServerClientVersion().done(function () {
  32. var name = 'Cluster Install Wizard';
  33. $('title').text('Ambari - ' + name);
  34. $('#main').addClass('install-wizard-content');
  35. App.router.get('mainViewsController').loadAmbariViews();
  36. if (App.isAccessible('ADMIN')) {
  37. router.get('mainController').stopPolling();
  38. Em.run.next(function () {
  39. App.clusterStatus.updateFromServer().complete(function () {
  40. var currentClusterStatus = App.clusterStatus.get('value');
  41. //@TODO: Clean up following states. Navigation should be done solely via currentStep stored in the localDb and API persist endpoint.
  42. // Actual currentStep value for the installer controller should always remain in sync with localdb and at persist store in the server.
  43. if (currentClusterStatus) {
  44. if (self.get('installerStatuses').contains(currentClusterStatus.clusterState)) {
  45. self.redirectToInstaller(router, currentClusterStatus, true);
  46. }
  47. else {
  48. router.transitionTo('main.dashboard.index');
  49. }
  50. }
  51. });
  52. });
  53. } else {
  54. Em.run.next(function () {
  55. App.router.transitionTo('main.views.index');
  56. });
  57. }
  58. });
  59. });
  60. } else {
  61. Ember.run.next(function () {
  62. router.transitionTo('login');
  63. });
  64. }
  65. });
  66. },
  67. routePath: function (router, event) {
  68. router.setNavigationFlow(event);
  69. if (!router.isFwdNavigation) {
  70. this._super(router, event);
  71. } else {
  72. router.set('backBtnForHigherStep', true);
  73. var installerController = router.get('installerController');
  74. router.transitionTo('step' + installerController.get('currentStep'));
  75. }
  76. },
  77. connectOutlets: function (router, context) {
  78. console.log('in /installer:connectOutlets');
  79. router.get('applicationController').connectOutlet('installer');
  80. },
  81. step0: Em.Route.extend({
  82. route: '/step0',
  83. connectOutlets: function (router) {
  84. console.time('step0 connectOutlets');
  85. var controller = router.get('installerController');
  86. controller.setCurrentStep('0');
  87. controller.loadAllPriorSteps().done(function () {
  88. controller.connectOutlet('wizardStep0', controller.get('content'));
  89. console.timeEnd('step0 connectOutlets');
  90. });
  91. },
  92. next: function (router) {
  93. console.time('step0 next');
  94. var installerController = router.get('installerController');
  95. installerController.save('cluster');
  96. App.db.setStacks(undefined);
  97. installerController.set('content.stacks',undefined);
  98. router.transitionTo('step1');
  99. console.timeEnd('step0 next');
  100. }
  101. }),
  102. step1: Em.Route.extend({
  103. route: '/step1',
  104. connectOutlets: function (router) {
  105. console.time('step1 connectOutlets');
  106. var controller = router.get('installerController');
  107. controller.setCurrentStep('1');
  108. controller.loadAllPriorSteps().done(function () {
  109. controller.connectOutlet('wizardStep1', controller.get('content'));
  110. console.timeEnd('step1 connectOutlets');
  111. });
  112. },
  113. back: Em.Router.transitionTo('step0'),
  114. next: function (router) {
  115. console.time('step1 next');
  116. var wizardStep1Controller = router.get('wizardStep1Controller');
  117. var installerController = router.get('installerController');
  118. installerController.validateJDKVersion(function() {
  119. installerController.checkRepoURL(wizardStep1Controller).done(function () {
  120. installerController.setDBProperty('service', undefined);
  121. installerController.setStacks();
  122. installerController.clearInstallOptions();
  123. router.transitionTo('step2');
  124. console.timeEnd('step1 next');
  125. });
  126. }, function() {});
  127. }
  128. }),
  129. step2: Em.Route.extend({
  130. route: '/step2',
  131. connectOutlets: function (router, context) {
  132. console.time('step2 connectOutlets');
  133. router.setNavigationFlow('step2');
  134. var controller = router.get('installerController');
  135. controller.setCurrentStep('2');
  136. controller.loadAllPriorSteps().done(function () {
  137. controller.connectOutlet('wizardStep2', controller.get('content'));
  138. console.timeEnd('step2 connectOutlets');
  139. });
  140. },
  141. back: Em.Router.transitionTo('step1'),
  142. next: function (router) {
  143. console.time('step2 next');
  144. var controller = router.get('installerController');
  145. controller.save('installOptions');
  146. //hosts was saved to content.hosts inside wizardStep2Controller
  147. controller.save('hosts');
  148. router.transitionTo('step3');
  149. console.timeEnd('step2 next');
  150. }
  151. }),
  152. step3: Em.Route.extend({
  153. route: '/step3',
  154. connectOutlets: function (router) {
  155. console.time('step3 connectOutlets');
  156. var controller = router.get('installerController');
  157. controller.setCurrentStep('3');
  158. controller.loadAllPriorSteps().done(function () {
  159. var wizardStep3Controller = router.get('wizardStep3Controller');
  160. wizardStep3Controller.set('wizardController', controller);
  161. controller.connectOutlet('wizardStep3', controller.get('content'));
  162. console.timeEnd('step3 connectOutlets');
  163. });
  164. },
  165. back: function (router) {
  166. router.transitionTo('step2');
  167. },
  168. next: function (router, context) {
  169. console.time('step3 next');
  170. if (!router.transitionInProgress) {
  171. router.set('transitionInProgress', true);
  172. var installerController = router.get('installerController');
  173. var wizardStep3Controller = router.get('wizardStep3Controller');
  174. installerController.saveConfirmedHosts(wizardStep3Controller);
  175. installerController.setDBProperties({
  176. bootStatus: true,
  177. selectedServiceNames: undefined,
  178. installedServiceNames: undefined
  179. });
  180. router.transitionTo('step4');
  181. console.timeEnd('step3 next');
  182. }
  183. },
  184. exit: function (router) {
  185. router.get('wizardStep3Controller').set('stopBootstrap', true);
  186. },
  187. /**
  188. * Wrapper for remove host action.
  189. * Since saving data stored in installerController, we should call this from router
  190. * @param router
  191. * @param context Array of hosts to delete
  192. */
  193. removeHosts: function (router, context) {
  194. var controller = router.get('installerController');
  195. controller.removeHosts(context);
  196. }
  197. }),
  198. step4: Em.Route.extend({
  199. route: '/step4',
  200. connectOutlets: function (router, context) {
  201. console.time('step4 connectOutlets');
  202. router.setNavigationFlow('step4');
  203. var controller = router.get('installerController');
  204. controller.setCurrentStep('4');
  205. controller.loadAllPriorSteps().done(function () {
  206. var wizardStep4Controller = router.get('wizardStep4Controller');
  207. wizardStep4Controller.set('wizardController', controller);
  208. controller.connectOutlet('wizardStep4', App.StackService.find().filterProperty('isInstallable', true));
  209. console.timeEnd('step4 connectOutlets');
  210. });
  211. },
  212. back: Em.Router.transitionTo('step3'),
  213. next: function (router) {
  214. console.time('step4 next');
  215. var controller = router.get('installerController');
  216. var wizardStep4Controller = router.get('wizardStep4Controller');
  217. controller.saveServices(wizardStep4Controller);
  218. controller.saveClients(wizardStep4Controller);
  219. router.get('wizardStep5Controller').clearRecommendations(); // Force reload recommendation between steps 4 and 5
  220. controller.setDBProperties({
  221. recommendations: undefined,
  222. masterComponentHosts: undefined
  223. });
  224. controller.set('stackConfigsLoaded', false);
  225. App.configsCollection.clearAll();
  226. router.transitionTo('step5');
  227. console.timeEnd('step4 next');
  228. }
  229. }),
  230. step5: Em.Route.extend({
  231. route: '/step5',
  232. connectOutlets: function (router, context) {
  233. console.time('step5 connectOutlets');
  234. router.setNavigationFlow('step5');
  235. var controller = router.get('installerController');
  236. var wizardStep5Controller = router.get('wizardStep5Controller');
  237. wizardStep5Controller.setProperties({
  238. servicesMasters: [],
  239. isInitialLayout: true
  240. });
  241. controller.set('stackConfigsLoaded', false);
  242. controller.setCurrentStep('5');
  243. controller.loadAllPriorSteps().done(function () {
  244. controller.connectOutlet('wizardStep5', controller.get('content'));
  245. console.timeEnd('step5 connectOutlets');
  246. });
  247. },
  248. back: Em.Router.transitionTo('step4'),
  249. next: function (router) {
  250. console.time('step5 next');
  251. var controller = router.get('installerController');
  252. var wizardStep5Controller = router.get('wizardStep5Controller');
  253. var wizardStep6Controller = router.get('wizardStep6Controller');
  254. controller.saveMasterComponentHosts(wizardStep5Controller);
  255. controller.setDBProperties({
  256. slaveComponentHosts: undefined,
  257. recommendations: wizardStep5Controller.get('content.recommendations')
  258. });
  259. wizardStep6Controller.set('isClientsSet', false);
  260. router.transitionTo('step6');
  261. console.timeEnd('step5 next');
  262. }
  263. }),
  264. step6: Em.Route.extend({
  265. route: '/step6',
  266. connectOutlets: function (router, context) {
  267. console.time('step6 connectOutlets');
  268. router.setNavigationFlow('step6');
  269. var controller = router.get('installerController');
  270. router.get('wizardStep6Controller').set('hosts', []);
  271. controller.setCurrentStep('6');
  272. controller.loadAllPriorSteps().done(function () {
  273. controller.connectOutlet('wizardStep6', controller.get('content'));
  274. console.timeEnd('step6 connectOutlets');
  275. });
  276. },
  277. back: Em.Router.transitionTo('step5'),
  278. next: function (router) {
  279. console.time('step6 next');
  280. var controller = router.get('installerController');
  281. var wizardStep6Controller = router.get('wizardStep6Controller');
  282. var wizardStep7Controller = router.get('wizardStep7Controller');
  283. if (!wizardStep6Controller.get('submitDisabled')) {
  284. wizardStep6Controller.showValidationIssuesAcceptBox(function () {
  285. if (!router.transitionInProgress) {
  286. router.set('transitionInProgress', true);
  287. controller.saveSlaveComponentHosts(wizardStep6Controller);
  288. controller.get('content').set('serviceConfigProperties', null);
  289. controller.setDBProperties({
  290. serviceConfigProperties: null,
  291. serviceConfigGroups: null,
  292. recommendationsHostGroups: wizardStep6Controller.get('content.recommendationsHostGroups'),
  293. recommendationsConfigs: null
  294. });
  295. router.transitionTo('step7');
  296. console.timeEnd('step6 next');
  297. }
  298. });
  299. }
  300. }
  301. }),
  302. step7: Em.Route.extend({
  303. route: '/step7',
  304. enter: function (router) {
  305. console.time('step7 enter');
  306. var controller = router.get('installerController');
  307. controller.setCurrentStep('7');
  308. console.timeEnd('step7 enter');
  309. },
  310. connectOutlets: function (router, context) {
  311. console.time('step7 connectOutlets');
  312. var controller = router.get('installerController');
  313. router.get('preInstallChecksController').loadStep();
  314. var wizardStep7Controller = router.get('wizardStep7Controller');
  315. controller.loadAllPriorSteps().done(function () {
  316. wizardStep7Controller.set('wizardController', controller);
  317. controller.connectOutlet('wizardStep7', controller.get('content'));
  318. console.timeEnd('step7 connectOutlets');
  319. });
  320. },
  321. back: function (router) {
  322. console.time('step7 back');
  323. var step = router.get('installerController.content.skipSlavesStep') ? 'step5' : 'step6';
  324. var wizardStep7Controller = router.get('wizardStep7Controller');
  325. var goToNextStep = function() {
  326. router.transitionTo(step);
  327. };
  328. if (wizardStep7Controller.hasChanges()) {
  329. wizardStep7Controller.showChangesWarningPopup(goToNextStep);
  330. } else {
  331. goToNextStep();
  332. }
  333. console.timeEnd('step7 back');
  334. },
  335. next: function (router) {
  336. console.time('step7 next');
  337. if(!router.transitionInProgress) {
  338. router.set('transitionInProgress', true);
  339. var controller = router.get('installerController');
  340. var wizardStep7Controller = router.get('wizardStep7Controller');
  341. controller.saveServiceConfigProperties(wizardStep7Controller);
  342. controller.saveServiceConfigGroups(wizardStep7Controller);
  343. controller.setDBProperty('recommendationsConfigs', wizardStep7Controller.get('recommendationsConfigs'));
  344. App.clusterStatus.setClusterStatus({
  345. localdb: App.db.data
  346. }, {
  347. alwaysCallback: function() {
  348. router.transitionTo('step8');
  349. console.timeEnd('step7 next');
  350. }
  351. });
  352. }
  353. }
  354. }),
  355. step8: Em.Route.extend({
  356. route: '/step8',
  357. connectOutlets: function (router, context) {
  358. console.time('step8 connectOutlets');
  359. console.log('in installer.step8:connectOutlets');
  360. var controller = router.get('installerController');
  361. controller.setCurrentStep('8');
  362. controller.loadAllPriorSteps().done(function () {
  363. var wizardStep8Controller = router.get('wizardStep8Controller');
  364. wizardStep8Controller.set('wizardController', controller);
  365. controller.connectOutlet('wizardStep8', controller.get('content'));
  366. console.timeEnd('step8 connectOutlets');
  367. });
  368. },
  369. back: Em.Router.transitionTo('step7'),
  370. next: function (router) {
  371. console.time('step8 next');
  372. if (!router.transitionInProgress) {
  373. router.set('transitionInProgress', true);
  374. var installerController = router.get('installerController');
  375. var wizardStep8Controller = router.get('wizardStep8Controller');
  376. // invoke API call to install selected services
  377. installerController.installServices(false, function () {
  378. installerController.setInfoForStep9();
  379. // We need to do recovery based on whether we are in Add Host or Installer wizard
  380. installerController.saveClusterState('CLUSTER_INSTALLING_3');
  381. wizardStep8Controller.set('servicesInstalled', true);
  382. router.transitionTo('step9');
  383. console.timeEnd('step8 next');
  384. });
  385. }
  386. }
  387. }),
  388. step9: Em.Route.extend({
  389. route: '/step9',
  390. connectOutlets: function (router, context) {
  391. console.time('step9 connectOutlets');
  392. var controller = router.get('installerController'),
  393. wizardStep9Controller = router.get('wizardStep9Controller');
  394. controller.loadAllPriorSteps().done(function () {
  395. wizardStep9Controller.loadDoServiceChecksFlag().done(function () {
  396. controller.setCurrentStep('9');
  397. if (!App.get('testMode')) {
  398. controller.setLowerStepsDisable(9);
  399. }
  400. wizardStep9Controller.set('wizardController', controller);
  401. controller.connectOutlet('wizardStep9', controller.get('content'));
  402. console.timeEnd('step9 connectOutlets');
  403. });
  404. });
  405. },
  406. back: Em.Router.transitionTo('step8'),
  407. retry: function (router) {
  408. console.time('step9 retry');
  409. var installerController = router.get('installerController');
  410. var wizardStep9Controller = router.get('wizardStep9Controller');
  411. if (wizardStep9Controller.get('showRetry')) {
  412. if (wizardStep9Controller.get('content.cluster.status') === 'INSTALL FAILED') {
  413. var isRetry = true;
  414. installerController.installServices(isRetry, function () {
  415. installerController.setInfoForStep9();
  416. wizardStep9Controller.resetHostsForRetry();
  417. // We need to do recovery based on whether we are in Add Host or Installer wizard
  418. installerController.saveClusterState('CLUSTER_INSTALLING_3');
  419. wizardStep9Controller.navigateStep();
  420. });
  421. } else {
  422. wizardStep9Controller.navigateStep();
  423. }
  424. console.timeEnd('step9 retry');
  425. }
  426. },
  427. unroutePath: function (router, context) {
  428. // exclusion for transition to Admin view or Views view
  429. if (context === '/adminView' ||
  430. context === '/main/views.index') {
  431. this._super(router, context);
  432. } else {
  433. return false;
  434. }
  435. },
  436. next: function (router) {
  437. console.time('step9 next');
  438. if(!router.transitionInProgress) {
  439. router.set('transitionInProgress', true);
  440. var installerController = router.get('installerController');
  441. var wizardStep9Controller = router.get('wizardStep9Controller');
  442. installerController.saveInstalledHosts(wizardStep9Controller);
  443. installerController.saveClusterState('CLUSTER_INSTALLED_4');
  444. router.transitionTo('step10');
  445. console.timeEnd('step9 next');
  446. }
  447. }
  448. }),
  449. step10: Em.Route.extend({
  450. route: '/step10',
  451. connectOutlets: function (router, context) {
  452. var controller = router.get('installerController');
  453. controller.loadAllPriorSteps().done(function () {
  454. if (!App.get('testMode')) {
  455. controller.setCurrentStep('10');
  456. controller.setLowerStepsDisable(10);
  457. }
  458. controller.connectOutlet('wizardStep10', controller.get('content'));
  459. });
  460. },
  461. back: Em.Router.transitionTo('step9'),
  462. complete: function (router, context) {
  463. var controller = router.get('installerController');
  464. controller.finish();
  465. controller.setClusterProvisioningState('INSTALLED').complete(function () {
  466. // We need to do recovery based on whether we are in Add Host or Installer wizard
  467. controller.saveClusterState('DEFAULT');
  468. App.router.set('clusterController.isLoaded', false);
  469. router.set('clusterInstallCompleted', true);
  470. router.transitionTo('main.dashboard.index');
  471. });
  472. }
  473. }),
  474. gotoStep0: Em.Router.transitionTo('step0'),
  475. gotoStep1: Em.Router.transitionTo('step1'),
  476. gotoStep2: Em.Router.transitionTo('step2'),
  477. gotoStep3: Em.Router.transitionTo('step3'),
  478. gotoStep4: Em.Router.transitionTo('step4'),
  479. gotoStep5: Em.Router.transitionTo('step5'),
  480. gotoStep6: Em.Router.transitionTo('step6'),
  481. gotoStep7: Em.Router.transitionTo('step7'),
  482. gotoStep8: Em.Router.transitionTo('step8'),
  483. gotoStep9: Em.Router.transitionTo('step9'),
  484. gotoStep10: Em.Router.transitionTo('step10')
  485. });