stack_and_upgrade_controller.js 43 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319
  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. var stringUtils = require('utils/string_utils');
  20. App.MainAdminStackAndUpgradeController = Em.Controller.extend(App.LocalStorage, {
  21. name: 'mainAdminStackAndUpgradeController',
  22. /**
  23. * @type {boolean}
  24. */
  25. isLoaded: false,
  26. /**
  27. * @type {object}
  28. * @default null
  29. */
  30. upgradeData: null,
  31. /**
  32. * @type {number}
  33. * @default null
  34. */
  35. upgradeId: null,
  36. /**
  37. * @type {string}
  38. * @default null
  39. */
  40. upgradeVersion: null,
  41. /**
  42. * @type {string}
  43. * @default null
  44. */
  45. upgradeTypeDisplayName: null,
  46. /**
  47. * @type {object}
  48. * @default null
  49. */
  50. failuresTolerance: null,
  51. /**
  52. * @type {boolean}
  53. * @default false
  54. */
  55. isDowngrade: false,
  56. /**
  57. * version that currently applied to server
  58. * should be plain object, because stored to localStorage
  59. * @type {object|null}
  60. */
  61. currentVersion: null,
  62. /**
  63. * versions to which cluster could be upgraded
  64. * @type {Array}
  65. */
  66. targetVersions: [],
  67. /**
  68. * methods through which cluster could be upgraded, "allowed" indicated if the method is allowed
  69. * by stack upgrade path
  70. * @type {Array}
  71. */
  72. upgradeMethods: [
  73. Em.Object.create({
  74. displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.title'),
  75. type: 'ROLLING',
  76. icon: "icon-dashboard",
  77. description: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.RU.description'),
  78. selected: false,
  79. allowed: true
  80. }),
  81. Em.Object.create({
  82. displayName: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.EU.title'),
  83. type: 'NON_ROLLING',
  84. icon: "icon-bolt",
  85. description: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.EU.description'),
  86. selected: false,
  87. allowed: true
  88. })
  89. ],
  90. /**
  91. * @type {boolean} true if some request that should disable actions is in progress
  92. */
  93. requestInProgress: false,
  94. /**
  95. * @type {boolean} true while no updated upgrade info is loaded after retry
  96. */
  97. isRetryPending: false,
  98. /**
  99. * properties that stored to localStorage to resume wizard progress
  100. */
  101. wizardStorageProperties: ['upgradeId', 'upgradeVersion', 'currentVersion', 'upgradeTypeDisplayName', 'failuresTolerance', 'isDowngrade', 'isSuspended'],
  102. /**
  103. * mutable properties of Upgrade Task
  104. * @type {Array}
  105. */
  106. taskDetailsProperties: ['status', 'stdout', 'stderr', 'error_log', 'host_name', 'output_log'],
  107. /**
  108. * Context for Finalize item
  109. * @type {string}
  110. */
  111. finalizeContext: 'Confirm Finalize',
  112. /**
  113. * Check if current item is Finalize
  114. * @type {boolean}
  115. */
  116. isFinalizeItem: false,
  117. isLoadUpgradeDataPending: false,
  118. /**
  119. * path to the mock json
  120. * @type {String}
  121. */
  122. mockRepoUrl: '/data/stack_versions/repo_versions_all.json',
  123. /**
  124. * api to get RepoVersions
  125. * @type {String}
  126. */
  127. realRepoUrl: function () {
  128. return App.get('apiPrefix') + App.get('stackVersionURL') +
  129. '/compatible_repository_versions?fields=*,operating_systems/*,operating_systems/repositories/*';
  130. }.property('App.stackVersionURL'),
  131. /**
  132. * path to the mock json
  133. * @type {String}
  134. */
  135. mockStackUrl: '/data/stack_versions/stack_version_all.json',
  136. /**
  137. * api to get ClusterStackVersions with repository_versions (use to init data load)
  138. * @type {String}
  139. */
  140. realStackUrl: function () {
  141. return App.get('apiPrefix') + '/clusters/' + App.get('clusterName') +
  142. '/stack_versions?fields=*,repository_versions/*,repository_versions/operating_systems/repositories/*';
  143. }.property('App.clusterName'),
  144. /**
  145. * api to get ClusterStackVersions without repository_versions (use to update data)
  146. * @type {String}
  147. */
  148. realUpdateUrl: function () {
  149. return App.get('apiPrefix') + '/clusters/' + App.get('clusterName') + '/stack_versions?fields=ClusterStackVersions/*';
  150. }.property('App.clusterName'),
  151. /**
  152. * Determines if list of services with checks that failed and were skipped by user during the upgrade is loaded
  153. * @type {boolean}
  154. */
  155. areSkippedServiceChecksLoaded: false,
  156. /**
  157. * List of services with checks that failed and were skipped by user during the upgrade
  158. * @type {array}
  159. */
  160. skippedServiceChecks: [],
  161. /**
  162. * status of tasks/items/groups which should be grayed out and disabled
  163. * @type {Array}
  164. */
  165. nonActiveStates: ['PENDING', 'ABORTED'],
  166. /**
  167. * status of Upgrade request
  168. * @type {string}
  169. */
  170. requestStatus: function () {
  171. if (this.get('isSuspended')) {
  172. return 'SUSPENDED';
  173. } else if (this.get('upgradeData.Upgrade')){
  174. return this.get('upgradeData.Upgrade.request_status');
  175. } else {
  176. return '';
  177. }
  178. }.property('isSuspended', 'upgradeData.Upgrade.request_status'),
  179. init: function () {
  180. this.initDBProperties();
  181. },
  182. /**
  183. * restore data from localStorage
  184. */
  185. initDBProperties: function () {
  186. var props = this.getDBProperties(this.get('wizardStorageProperties'));
  187. Em.keys(props).forEach(function (k) {
  188. if (props[k]) {
  189. this.set(k, props[k]);
  190. }
  191. }, this);
  192. },
  193. /**
  194. * load all data:
  195. * - upgrade data
  196. * - stack versions
  197. * - repo versions
  198. */
  199. load: function () {
  200. var dfd = $.Deferred();
  201. var self = this;
  202. this.loadUpgradeData(true).done(function() {
  203. self.loadStackVersionsToModel(true).done(function () {
  204. self.loadRepoVersionsToModel().done(function() {
  205. var currentVersion = App.StackVersion.find().findProperty('state', 'CURRENT');
  206. if (currentVersion) {
  207. self.set('currentVersion', {
  208. repository_version: currentVersion.get('repositoryVersion.repositoryVersion'),
  209. repository_name: currentVersion.get('repositoryVersion.displayName')
  210. });
  211. }
  212. dfd.resolve();
  213. });
  214. });
  215. });
  216. return dfd.promise();
  217. },
  218. /**
  219. * load upgrade tasks by upgrade id
  220. * @return {$.Deferred}
  221. * @param {boolean} onlyState
  222. */
  223. loadUpgradeData: function (onlyState) {
  224. var upgradeId = this.get('upgradeId'),
  225. deferred = $.Deferred(),
  226. self = this;
  227. if (Em.isNone(upgradeId)) {
  228. deferred.resolve();
  229. console.log('Upgrade in INIT state');
  230. } else {
  231. this.set('isLoadUpgradeDataPending', true);
  232. App.ajax.send({
  233. name: (onlyState) ? 'admin.upgrade.state' : 'admin.upgrade.data',
  234. sender: this,
  235. data: {
  236. id: upgradeId
  237. },
  238. success: 'loadUpgradeDataSuccessCallback'
  239. }).then(deferred.resolve).complete(function () {
  240. self.set('isLoadUpgradeDataPending', false);
  241. });
  242. }
  243. return deferred.promise();
  244. },
  245. /**
  246. * parse and push upgrade tasks to controller
  247. * @param data
  248. */
  249. loadUpgradeDataSuccessCallback: function (data) {
  250. if (Em.isNone(data)) return;
  251. App.set('upgradeState', data.Upgrade.request_status);
  252. this.setDBProperty('upgradeState', data.Upgrade.request_status);
  253. if (data.upgrade_groups) {
  254. this.updateUpgradeData(data);
  255. }
  256. if (this.get('isRetryPending') && data.Upgrade.request_status != 'ABORTED') {
  257. this.setProperties({
  258. requestInProgress: false,
  259. isRetryPending: false
  260. });
  261. }
  262. },
  263. /**
  264. * update data of Upgrade
  265. * @param {object} newData
  266. */
  267. updateUpgradeData: function (newData) {
  268. var oldData = this.get('upgradeData'),
  269. nonActiveStates = this.get('nonActiveStates'),
  270. groupsMap = {},
  271. itemsMap = {};
  272. if (Em.isNone(oldData) || (newData.upgrade_groups.length !== oldData.upgradeGroups.length)) {
  273. this.initUpgradeData(newData);
  274. } else {
  275. //create entities maps
  276. newData.upgrade_groups.forEach(function (newGroup) {
  277. groupsMap[newGroup.UpgradeGroup.group_id] = newGroup.UpgradeGroup;
  278. newGroup.upgrade_items.forEach(function (item) {
  279. itemsMap[item.UpgradeItem.stage_id] = item.UpgradeItem;
  280. })
  281. });
  282. //update existed entities with new data
  283. oldData.upgradeGroups.forEach(function (oldGroup) {
  284. oldGroup.set('status', groupsMap[oldGroup.get('group_id')].status);
  285. oldGroup.set('progress_percent', groupsMap[oldGroup.get('group_id')].progress_percent);
  286. oldGroup.set('completed_task_count', groupsMap[oldGroup.get('group_id')].completed_task_count);
  287. oldGroup.upgradeItems.forEach(function (item) {
  288. item.set('status', itemsMap[item.get('stage_id')].status);
  289. item.set('progress_percent', itemsMap[item.get('stage_id')].progress_percent);
  290. });
  291. var hasExpandableItems = oldGroup.upgradeItems.some(function (item) {
  292. return !nonActiveStates.contains(item.get('status'));
  293. });
  294. oldGroup.set('hasExpandableItems', hasExpandableItems);
  295. });
  296. oldData.set('Upgrade', newData.Upgrade);
  297. }
  298. },
  299. /**
  300. * change structure of Upgrade
  301. * In order to maintain nested views in template object should have direct link to its properties, for example
  302. * item.UpgradeItem.<properties> -> item.<properties>
  303. * @param {object} newData
  304. */
  305. initUpgradeData: function (newData) {
  306. var upgradeGroups = [],
  307. nonActiveStates = this.get('nonActiveStates');
  308. //wrap all entities into App.upgradeEntity
  309. newData.upgrade_groups.forEach(function (newGroup) {
  310. var hasExpandableItems = newGroup.upgrade_items.some(function (item) {
  311. return !nonActiveStates.contains(item.UpgradeItem.status);
  312. }),
  313. oldGroup = App.upgradeEntity.create({type: 'GROUP', hasExpandableItems: hasExpandableItems}, newGroup.UpgradeGroup),
  314. upgradeItems = [];
  315. newGroup.upgrade_items.forEach(function (item) {
  316. var oldItem = App.upgradeEntity.create({type: 'ITEM'}, item.UpgradeItem);
  317. oldItem.set('tasks', []);
  318. upgradeItems.pushObject(oldItem);
  319. });
  320. upgradeItems.reverse();
  321. oldGroup.set('upgradeItems', upgradeItems);
  322. upgradeGroups.pushObject(oldGroup);
  323. });
  324. upgradeGroups.reverse();
  325. this.set('upgradeData', Em.Object.create({
  326. upgradeGroups: upgradeGroups,
  327. Upgrade: newData.Upgrade
  328. }));
  329. },
  330. /**
  331. * request Upgrade Item and its tasks from server
  332. * @return {$.ajax}
  333. */
  334. getUpgradeItem: function (item) {
  335. return App.ajax.send({
  336. name: 'admin.upgrade.upgrade_item',
  337. sender: this,
  338. data: {
  339. upgradeId: item.get('request_id'),
  340. groupId: item.get('group_id'),
  341. stageId: item.get('stage_id')
  342. },
  343. success: 'getUpgradeItemSuccessCallback'
  344. });
  345. },
  346. /**
  347. * success callback of <code>getTasks</code>
  348. * @param {object} data
  349. */
  350. getUpgradeItemSuccessCallback: function (data) {
  351. this.get('upgradeData.upgradeGroups').forEach(function (group) {
  352. if (group.get('group_id') === data.UpgradeItem.group_id) {
  353. group.get('upgradeItems').forEach(function (item) {
  354. if (item.get('stage_id') === data.UpgradeItem.stage_id) {
  355. if (item.get('tasks.length')) {
  356. item.set('isTasksLoaded', true);
  357. data.tasks.forEach(function (task) {
  358. var currentTask = item.get('tasks').findProperty('id', task.Tasks.id);
  359. this.get('taskDetailsProperties').forEach(function (property) {
  360. currentTask.set(property, task.Tasks[property]);
  361. }, this);
  362. }, this);
  363. } else {
  364. var tasks = [];
  365. data.tasks.forEach(function (task) {
  366. tasks.pushObject(App.upgradeEntity.create({type: 'TASK'}, task.Tasks));
  367. });
  368. item.set('tasks', tasks);
  369. }
  370. item.set('isTasksLoaded', true);
  371. }
  372. }, this);
  373. }
  374. }, this);
  375. },
  376. /**
  377. * downgrade confirmation popup
  378. * @param {object} event
  379. */
  380. confirmDowngrade: function (event) {
  381. var self = this;
  382. var currentVersion = this.get('currentVersion');
  383. return App.showConfirmationPopup(
  384. function() {
  385. self.downgrade.call(self, currentVersion, event);
  386. },
  387. Em.I18n.t('admin.stackUpgrade.downgrade.body').format(currentVersion.repository_name),
  388. null,
  389. Em.I18n.t('admin.stackUpgrade.dialog.downgrade.header').format(currentVersion.repository_name),
  390. Em.I18n.t('admin.stackUpgrade.downgrade.proceed')
  391. );
  392. },
  393. /**
  394. * make call to start downgrade process
  395. * @param {object} currentVersion
  396. * @param {object} event
  397. */
  398. downgrade: function (currentVersion, event) {
  399. this.set('requestInProgress', true);
  400. this.abortUpgrade();
  401. App.ajax.send({
  402. name: 'admin.downgrade.start',
  403. sender: this,
  404. data: {
  405. from: App.RepositoryVersion.find().findProperty('displayName', this.get('upgradeVersion')).get('repositoryVersion'),
  406. value: currentVersion.repository_version,
  407. label: currentVersion.repository_name,
  408. isDowngrade: true
  409. },
  410. success: 'upgradeSuccessCallback',
  411. callback: function() {
  412. this.sender.set('requestInProgress', false);
  413. }
  414. });
  415. },
  416. /**
  417. * abort upgrade (in order to start Downgrade)
  418. */
  419. abortUpgrade: function () {
  420. return App.ajax.send({
  421. name: 'admin.upgrade.abort',
  422. sender: this,
  423. data: {
  424. upgradeId: this.get('upgradeId')
  425. }
  426. });
  427. },
  428. retryUpgrade: function () {
  429. this.setProperties({
  430. requestInProgress: true,
  431. isRetryPending: true
  432. });
  433. return App.ajax.send({
  434. name: 'admin.upgrade.retry',
  435. sender: this,
  436. data: {
  437. upgradeId: this.get('upgradeId')
  438. }
  439. });
  440. },
  441. /**
  442. * make call to start upgrade process and show popup with current progress
  443. * @param {object} version
  444. */
  445. upgrade: function (version) {
  446. this.set('requestInProgress', true);
  447. App.ajax.send({
  448. name: 'admin.upgrade.start',
  449. sender: this,
  450. data: version,
  451. success: 'upgradeSuccessCallback',
  452. callback: function() {
  453. this.sender.set('requestInProgress', false);
  454. }
  455. });
  456. this.setDBProperty('currentVersion', this.get('currentVersion'));
  457. },
  458. /**
  459. * success callback of <code>upgrade()</code>
  460. * @param {object} data
  461. */
  462. upgradeSuccessCallback: function (data, opt, params) {
  463. this.set('upgradeData', null);
  464. this.set('upgradeId', data.resources[0].Upgrade.request_id);
  465. this.set('upgradeVersion', params.label);
  466. this.set('isDowngrade', !!params.isDowngrade);
  467. var upgradeMethod = this.get('upgradeMethods').findProperty('type', params.type);
  468. var upgradeTypeDisplayName = upgradeMethod ? upgradeMethod.get('displayName') : null;
  469. this.set('upgradeTypeDisplayName', upgradeTypeDisplayName);
  470. this.set('failuresTolerance', Em.Object.create({
  471. skipComponentFailures: params.skipComponentFailures == 'true',
  472. skipSCFailures: params.skipSCFailures == 'true'
  473. }));
  474. this.setDBProperties({
  475. upgradeVersion: params.label,
  476. upgradeId: data.resources[0].Upgrade.request_id,
  477. upgradeState: 'PENDING',
  478. isDowngrade: !!params.isDowngrade,
  479. upgradeTypeDisplayName: upgradeTypeDisplayName,
  480. failuresTolerance: Em.Object.create({
  481. skipComponentFailures: params.skipComponentFailures == 'true',
  482. skipSCFailures: params.skipSCFailures == 'true'
  483. })
  484. });
  485. App.set('upgradeState', 'PENDING');
  486. App.clusterStatus.setClusterStatus({
  487. wizardControllerName: this.get('name'),
  488. localdb: App.db.data
  489. });
  490. this.load();
  491. this.openUpgradeDialog();
  492. },
  493. /**
  494. * success callback of updating upgrade options including failures tolerance. etc
  495. * @param {object} data
  496. */
  497. updateOptionsSuccessCallback: function (data, opt, params) {
  498. this.set('failuresTolerance', Em.Object.create({
  499. skipComponentFailures: params.skipComponentFailures == 'true',
  500. skipSCFailures: params.skipSCFailures == 'true'
  501. }));
  502. },
  503. /**
  504. * Open upgrade options window: upgrade type and failures tolerance
  505. * @param {boolean} isInUpgradeWizard
  506. * @param {object} version
  507. * @return App.ModalPopup
  508. */
  509. upgradeOptions: function(isInUpgradeWizard, version) {
  510. var self = this;
  511. return App.ModalPopup.show({
  512. encodeBody: false,
  513. primary: isInUpgradeWizard? Em.I18n.t('ok') : Em.I18n.t('common.proceed'),
  514. primaryClass: 'btn-success',
  515. classNames: ['upgrade-options-popup'],
  516. header: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.header'),
  517. bodyClass: Em.View.extend({
  518. templateName: require('templates/main/admin/stack_upgrade/upgrade_options'),
  519. didInsertElement: function() {
  520. //add pre-upgrade check results to each method object and set selected method
  521. var view = this;
  522. self.get('upgradeMethods').forEach(function(method){
  523. if (!isInUpgradeWizard && method.get('allowed')) {
  524. self.runPreUpgradeCheckOnly.call(self, {
  525. value: version.get('repositoryVersion'),
  526. label: version.get('displayName'),
  527. type: method.get('type')
  528. });
  529. }
  530. });
  531. App.tooltip($(".failure-tolerance-tooltip"), {
  532. placement: "top",
  533. title: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.tolerance.tooltip')
  534. });
  535. App.tooltip($(".not-allowed-by-version"), {
  536. placement: "bottom",
  537. title: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.notAllowed')
  538. });
  539. Em.run.later(this, function () {
  540. App.tooltip($(".thumbnail.check-failed"), {
  541. placement: "bottom",
  542. title: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.preCheck.failed.tooltip')
  543. });
  544. }, 1000);
  545. },
  546. parentView: this.get('parentView'),
  547. isInUpgradeWizard: isInUpgradeWizard,
  548. versionText: isInUpgradeWizard? '' : Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.bodyMsg.version').format(version.get('displayName')),
  549. upgradeMethods: function () {
  550. self.updateSelectedMethod(isInUpgradeWizard);
  551. return self.get('upgradeMethods');
  552. }.property('self.upgradeMethods'),
  553. selectMethod: function(event) {
  554. if (isInUpgradeWizard || !event.context.get('allowed') || event.context.get('isPrecheckFailed')) return;
  555. var selectedMethod = event.context;
  556. this.get('upgradeMethods').forEach(function(method){
  557. method.set('selected', false);
  558. });
  559. selectedMethod.set('selected', true);
  560. this.set('parentView.selectedMethod', selectedMethod);
  561. },
  562. openMessage: function(event) {
  563. if (isInUpgradeWizard || !event.context.get('allowed')) return;
  564. var data = event.context.get('precheckResultsData');
  565. var header = Em.I18n.t('popup.clusterCheck.Upgrade.header').format(version.get('displayName')),
  566. failTitle = Em.I18n.t('popup.clusterCheck.Upgrade.fail.title'),
  567. failAlert = new Em.Handlebars.SafeString(Em.I18n.t('popup.clusterCheck.Upgrade.fail.alert')),
  568. warningTitle = Em.I18n.t('popup.clusterCheck.Upgrade.warning.title'),
  569. warningAlert = new Em.Handlebars.SafeString(Em.I18n.t('popup.clusterCheck.Upgrade.warning.alert')),
  570. configsMergeWarning = data.items.findProperty('UpgradeChecks.id', "CONFIG_MERGE"),
  571. configs = [];
  572. if (configsMergeWarning && Em.get(configsMergeWarning, 'UpgradeChecks.status') === 'WARNING') {
  573. data.items = data.items.rejectProperty('UpgradeChecks.id', 'CONFIG_MERGE');
  574. var configsMergeCheckData = Em.get(configsMergeWarning, 'UpgradeChecks.failed_detail');
  575. if (configsMergeCheckData) {
  576. configs = configsMergeCheckData.map(function (item) {
  577. var isDeprecated = Em.isNone(item.new_stack_value),
  578. willBeRemoved = Em.isNone(item.result_value);
  579. return {
  580. type: item.type,
  581. name: item.property,
  582. currentValue: item.current,
  583. recommendedValue: isDeprecated ? Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.deprecated') : item.new_stack_value,
  584. isDeprecated: isDeprecated,
  585. resultingValue: willBeRemoved ? Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.willBeRemoved') : item.result_value,
  586. willBeRemoved: willBeRemoved
  587. };
  588. });
  589. }
  590. }
  591. App.showPreUpgradeCheckPopup(data, header, failTitle, failAlert, warningTitle, warningAlert, function () {
  592. self.runPreUpgradeCheckOnly.call(self, {
  593. value: version.get('repositoryVersion'),
  594. label: version.get('displayName'),
  595. type: event.context.get('type')
  596. });
  597. }, configs, version.get('displayName'));
  598. }
  599. }),
  600. selectedMethod: '',
  601. skipComponentFailures: self.get('failuresTolerance.skipComponentFailures'),
  602. skipSCFailures: self.get('failuresTolerance.skipSCFailures'),
  603. disablePrimary: function() {
  604. if (isInUpgradeWizard) return false;
  605. var selectedMethod = self.get('upgradeMethods').findProperty('selected', true);
  606. return selectedMethod ? selectedMethod.get('isPrecheckFailed') : true;
  607. }.property('selectedMethod', 'selectedMethod.isPrecheckFailed'),
  608. onPrimary: function () {
  609. this.hide();
  610. if (isInUpgradeWizard) {
  611. return App.ajax.send({
  612. name: 'admin.upgrade.update.options',
  613. sender: self,
  614. data: {
  615. upgradeId: self.get('upgradeId'),
  616. skipComponentFailures: this.get('skipComponentFailures')? 'true': 'false',
  617. skipSCFailures: this.get('skipSCFailures')? 'true': 'false'
  618. },
  619. success: 'updateOptionsSuccessCallback'
  620. });
  621. } else {
  622. version.upgradeType = self.get('upgradeMethods').findProperty('selected', true).get('type');
  623. version.upgradeTypeDisplayName = self.get('upgradeMethods').findProperty('selected', true).get('displayName');
  624. version.skipComponentFailures = this.get('skipComponentFailures');
  625. version.skipSCFailures = this.get('skipSCFailures');
  626. self.runPreUpgradeCheck.call(self, version);
  627. }
  628. },
  629. onSecondary: function () {
  630. this.hide();
  631. },
  632. onClose: function () {
  633. this.hide();
  634. }
  635. });
  636. },
  637. /**
  638. * open upgrade options from upgrade wizard
  639. * @return App.ModalPopup
  640. */
  641. openUpgradeOptions: function () {
  642. this.upgradeOptions(true, null);
  643. },
  644. /**
  645. * upgrade confirmation popup including upgrade options: upgrade type and failures tolerance
  646. * @param {object} version
  647. * @return App.ModalPopup
  648. */
  649. confirmUpgrade: function (version) {
  650. this.upgradeOptions(false, version);
  651. },
  652. /**
  653. * send request for pre upgrade check only
  654. */
  655. runPreUpgradeCheckOnly: function(data) {
  656. if (App.get('supports.preUpgradeCheck')) {
  657. App.ajax.send({
  658. name: "admin.upgrade.pre_upgrade_check",
  659. sender: this,
  660. data: data,
  661. success: "runPreUpgradeCheckOnlySuccess",
  662. error: "runPreUpgradeCheckError"
  663. });
  664. }
  665. },
  666. /**
  667. * success callback of <code>runPreUpgradeCheckOnly()</code>
  668. * Show a message how many fails/warnings/passed
  669. * on clicking that message a popup window show up
  670. * @param data {object}
  671. * @param opt {object}
  672. * @param params {object}
  673. */
  674. runPreUpgradeCheckOnlySuccess: function (data, opt, params) {
  675. var self = this;
  676. var message = '';
  677. var messageClass = 'GREEN';
  678. var messageIconClass = 'icon-ok';
  679. if (data.items.someProperty('UpgradeChecks.status', 'WARNING')) {
  680. message = message + data.items.filterProperty('UpgradeChecks.status', 'WARNING').length + ' Warning ';
  681. messageClass = 'ORANGE';
  682. messageIconClass = 'icon-warning-sign';
  683. }
  684. if (data.items.someProperty('UpgradeChecks.status', 'FAIL')) {
  685. message = data.items.filterProperty('UpgradeChecks.status', 'FAIL').length + ' Required ' + message;
  686. messageClass = 'RED';
  687. messageIconClass = 'icon-remove';
  688. }
  689. if (!message) {
  690. message = Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.preCheck.allPassed');
  691. }
  692. var method = self.get('upgradeMethods').findProperty('type', params.type);
  693. method.set('precheckResultsMessage', message);
  694. method.set('precheckResultsMessageClass', messageClass);
  695. method.set('isPrecheckFailed', messageClass == 'RED');
  696. method.set('precheckResultsMessageIconClass', messageIconClass);
  697. method.set('precheckResultsData', data);
  698. this.updateSelectedMethod(false);
  699. Em.run.later(this, function () {
  700. App.tooltip($(".thumbnail.check-failed"), {
  701. placement: "bottom",
  702. title: Em.I18n.t('admin.stackVersions.version.upgrade.upgradeOptions.preCheck.failed.tooltip')
  703. });
  704. $(".thumbnail").not(".check-failed").not(".not-allowed-by-version").tooltip("destroy");
  705. }, 1000);
  706. },
  707. /**
  708. * In Upgrade Wizard: update which method already been selected on open
  709. * Not in upgrade wizard: de-select the method with pre-check errors
  710. * @param isInUpgradeWizard {boolean}
  711. */
  712. updateSelectedMethod: function(isInUpgradeWizard) {
  713. var self = this;
  714. if (isInUpgradeWizard) {
  715. this.get('upgradeMethods').forEach(function(method){
  716. if (method.get('displayName') == self.get('upgradeTypeDisplayName')) {
  717. method.set('selected', true);
  718. } else {
  719. method.set('selected', false);
  720. }
  721. });
  722. } else {
  723. var ruMethod = this.get('upgradeMethods').findProperty('type', 'ROLLING');
  724. var euMethod = this.get('upgradeMethods').findProperty('type', 'NON_ROLLING');
  725. if (ruMethod.get('isPrecheckFailed')) ruMethod.set('selected', false);
  726. if (euMethod.get('isPrecheckFailed')) euMethod.set('selected', false);
  727. }
  728. },
  729. /**
  730. * send request for pre upgrade check
  731. * @param version
  732. */
  733. runPreUpgradeCheck: function(version) {
  734. var params = {
  735. value: version.get('repositoryVersion'),
  736. label: version.get('displayName'),
  737. type: version.get('upgradeType'),
  738. skipComponentFailures: version.get('skipComponentFailures') ? 'true' : 'false',
  739. skipSCFailures: version.get('skipSCFailures') ? 'true' : 'false'
  740. };
  741. if (App.get('supports.preUpgradeCheck')) {
  742. this.set('requestInProgress', true);
  743. App.ajax.send({
  744. name: "admin.upgrade.pre_upgrade_check",
  745. sender: this,
  746. data: params,
  747. success: "runPreUpgradeCheckSuccess",
  748. error: "runPreUpgradeCheckError"
  749. });
  750. } else {
  751. this.upgrade(params);
  752. }
  753. },
  754. /**
  755. * success callback of <code>runPreUpgradeCheckSuccess()</code>
  756. * if there are some fails - it shows popup else run upgrade
  757. * @param data {object}
  758. * @param opt {object}
  759. * @param params {object}
  760. * @returns {App.ModalPopup|undefined}
  761. */
  762. runPreUpgradeCheckSuccess: function (data, opt, params) {
  763. var self = this;
  764. if (data.items.someProperty('UpgradeChecks.status', 'FAIL') || data.items.someProperty('UpgradeChecks.status', 'WARNING')) {
  765. this.set('requestInProgress', false);
  766. var header = Em.I18n.t('popup.clusterCheck.Upgrade.header').format(params.label),
  767. failTitle = Em.I18n.t('popup.clusterCheck.Upgrade.fail.title'),
  768. failAlert = new Em.Handlebars.SafeString(Em.I18n.t('popup.clusterCheck.Upgrade.fail.alert')),
  769. warningTitle = Em.I18n.t('popup.clusterCheck.Upgrade.warning.title'),
  770. warningAlert = new Em.Handlebars.SafeString(Em.I18n.t('popup.clusterCheck.Upgrade.warning.alert')),
  771. configsMergeWarning = data.items.findProperty('UpgradeChecks.id', "CONFIG_MERGE"),
  772. configs = [];
  773. if (configsMergeWarning && Em.get(configsMergeWarning, 'UpgradeChecks.status') === 'WARNING') {
  774. data.items = data.items.rejectProperty('UpgradeChecks.id', 'CONFIG_MERGE');
  775. var configsMergeCheckData = Em.get(configsMergeWarning, 'UpgradeChecks.failed_detail');
  776. if (configsMergeCheckData) {
  777. configs = configsMergeCheckData.map(function (item) {
  778. var isDeprecated = Em.isNone(item.new_stack_value),
  779. willBeRemoved = Em.isNone(item.result_value);
  780. return {
  781. type: item.type,
  782. name: item.property,
  783. currentValue: item.current,
  784. recommendedValue: isDeprecated ? Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.deprecated') : item.new_stack_value,
  785. isDeprecated: isDeprecated,
  786. resultingValue: willBeRemoved ? Em.I18n.t('popup.clusterCheck.Upgrade.configsMerge.willBeRemoved') : item.result_value,
  787. willBeRemoved: willBeRemoved
  788. };
  789. });
  790. }
  791. }
  792. App.showClusterCheckPopup(data, header, failTitle, failAlert, warningTitle, warningAlert, function () {
  793. self.upgrade(params);
  794. }, configs, params.label);
  795. } else {
  796. this.upgrade(params);
  797. }
  798. },
  799. runPreUpgradeCheckError: function() {
  800. this.set('requestInProgress', false);
  801. },
  802. confirmRetryUpgrade: function (version) {
  803. var self = this;
  804. return App.showConfirmationPopup(
  805. function () {
  806. self.retryUpgrade();
  807. },
  808. Em.I18n.t('admin.stackUpgrade.upgrade.retry.confirm.body').format(version.get('displayName')),
  809. null,
  810. Em.I18n.t('admin.stackUpgrade.dialog.header').format(version.get('upgradeTypeDislayName'), version.get('displayName'))
  811. );
  812. },
  813. confirmRetryDowngrade: function () {
  814. var self = this,
  815. currentVersion = this.get('currentVersion');
  816. return App.showConfirmationPopup(
  817. function() {
  818. self.retryUpgrade();
  819. },
  820. Em.I18n.t('admin.stackUpgrade.downgrade.retry.body').format(currentVersion.repository_name),
  821. null,
  822. Em.I18n.t('admin.stackUpgrade.dialog.downgrade.header').format(currentVersion.repository_name),
  823. Em.I18n.t('admin.stackUpgrade.downgrade.proceed')
  824. );
  825. },
  826. /**
  827. * confirmation popup before install repository version
  828. */
  829. installRepoVersionConfirmation: function (repo) {
  830. var self = this;
  831. return App.showConfirmationPopup(function () {
  832. self.installRepoVersion(repo);
  833. },
  834. Em.I18n.t('admin.stackVersions.version.install.confirm').format(repo.get('displayName'))
  835. );
  836. },
  837. /**
  838. * sends request to install repoVersion to the cluster
  839. * and create clusterStackVersion resourse
  840. * @param {Em.Object} repo
  841. * @return {$.ajax}
  842. * @method installRepoVersion
  843. */
  844. installRepoVersion: function (repo) {
  845. this.set('requestInProgress', true);
  846. var data = {
  847. ClusterStackVersions: {
  848. stack: repo.get('stackVersionType'),
  849. version: repo.get('stackVersionNumber'),
  850. repository_version: repo.get('repositoryVersion')
  851. },
  852. id: repo.get('id')
  853. };
  854. return App.ajax.send({
  855. name: 'admin.stack_version.install.repo_version',
  856. sender: this,
  857. data: data,
  858. success: 'installRepoVersionSuccess',
  859. callback: function() {
  860. this.sender.set('requestInProgress', false);
  861. }
  862. });
  863. },
  864. /**
  865. * transform repo data into json for
  866. * saving changes to repository version
  867. * @param {Em.Object} repo
  868. * @returns {{operating_systems: Array}}
  869. */
  870. prepareRepoForSaving: function(repo) {
  871. var repoVersion = { "operating_systems": [] };
  872. repo.get('operatingSystems').forEach(function (os, k) {
  873. repoVersion.operating_systems.push({
  874. "OperatingSystems": {
  875. "os_type": os.get("osType")
  876. },
  877. "repositories": []
  878. });
  879. os.get('repositories').forEach(function (repository) {
  880. repoVersion.operating_systems[k].repositories.push({
  881. "Repositories": {
  882. "base_url": repository.get('baseUrl'),
  883. "repo_id": repository.get('repoId'),
  884. "repo_name": repository.get('repoName')
  885. }
  886. });
  887. });
  888. });
  889. return repoVersion;
  890. },
  891. /**
  892. * Return stack version for the repo object
  893. * @param {Em.Object} repo
  894. * */
  895. getStackVersionNumber: function(repo){
  896. var stackVersionNumber = repo.get('stackVersion');
  897. if(null == stackVersionNumber)
  898. stackVersionNumber = App.get('currentStackVersion');
  899. return stackVersionNumber;
  900. },
  901. /**
  902. * perform validation if <code>skip<code> is false and run save if
  903. * validation successfull or run save without validation is <code>skip<code> is true
  904. * @param {Em.Object} repo
  905. * @param {boolean} skip
  906. * @returns {$.Deferred}
  907. */
  908. saveRepoOS: function (repo, skip) {
  909. var self = this;
  910. var deferred = $.Deferred();
  911. this.validateRepoVersions(repo, skip).done(function(data) {
  912. if (data.length > 0) {
  913. deferred.resolve(data);
  914. } else {
  915. var repoVersion = self.prepareRepoForSaving(repo);
  916. var stackVersionNumber = self.getStackVersionNumber(repo);
  917. console.log("Repository stack version:"+stackVersionNumber);
  918. App.ajax.send({
  919. name: 'admin.stack_versions.edit.repo',
  920. sender: this,
  921. data: {
  922. stackName: App.get('currentStackName'),
  923. stackVersion: stackVersionNumber,
  924. repoVersionId: repo.get('repoVersionId'),
  925. repoVersion: repoVersion
  926. }
  927. }).success(function() {
  928. deferred.resolve([]);
  929. });
  930. }
  931. });
  932. return deferred.promise();
  933. },
  934. /**
  935. * send request for validation for each repository
  936. * @param {Em.Object} repo
  937. * @param {boolean} skip
  938. * @returns {*}
  939. */
  940. validateRepoVersions: function(repo, skip) {
  941. var deferred = $.Deferred(),
  942. totalCalls = 0,
  943. invalidUrls = [];
  944. if (skip) {
  945. deferred.resolve(invalidUrls);
  946. } else {
  947. var stackVersionNumber = this.getStackVersionNumber(repo);
  948. repo.get('operatingSystems').forEach(function (os) {
  949. if (os.get('isSelected')) {
  950. os.get('repositories').forEach(function (repo) {
  951. totalCalls++;
  952. App.ajax.send({
  953. name: 'admin.stack_versions.validate.repo',
  954. sender: this,
  955. data: {
  956. repo: repo,
  957. repoId: repo.get('repoId'),
  958. baseUrl: repo.get('baseUrl'),
  959. osType: os.get('osType'),
  960. stackName: App.get('currentStackName'),
  961. stackVersion: stackVersionNumber
  962. }
  963. })
  964. .success(function () {
  965. totalCalls--;
  966. if (totalCalls === 0) deferred.resolve(invalidUrls);
  967. })
  968. .error(function () {
  969. repo.set('hasError', true);
  970. invalidUrls.push(repo);
  971. totalCalls--;
  972. if (totalCalls === 0) deferred.resolve(invalidUrls);
  973. });
  974. });
  975. } else {
  976. return deferred.resolve(invalidUrls);
  977. }
  978. });
  979. }
  980. return deferred.promise();
  981. },
  982. /**
  983. * success callback for <code>installRepoVersion()<code>
  984. * saves request id to the db
  985. * @param data
  986. * @param opt
  987. * @param params
  988. * @method installStackVersionSuccess
  989. */
  990. installRepoVersionSuccess: function (data, opt, params) {
  991. var version = App.RepositoryVersion.find(params.id);
  992. App.db.set('repoVersionInstall', 'id', [data.Requests.id]);
  993. App.clusterStatus.setClusterStatus({
  994. wizardControllerName: this.get('name'),
  995. localdb: App.db.data
  996. });
  997. version.set('defaultStatus', 'INSTALLING');
  998. if (version.get('stackVersion')) {
  999. version.set('stackVersion.state', 'INSTALLING');
  1000. }
  1001. },
  1002. /**
  1003. * opens a popup with installations state per host
  1004. * @param {Em.Object} version
  1005. * @method showProgressPopup
  1006. */
  1007. showProgressPopup: function(version) {
  1008. var popupTitle = Em.I18n.t('admin.stackVersions.details.install.hosts.popup.title').format(version.get('displayName'));
  1009. var requestIds = App.get('testMode') ? [1] : App.db.get('repoVersionInstall', 'id');
  1010. var hostProgressPopupController = App.router.get('highAvailabilityProgressPopupController');
  1011. hostProgressPopupController.initPopup(popupTitle, requestIds, this);
  1012. },
  1013. /**
  1014. * reset upgradeState to INIT when upgrade is COMPLETED
  1015. * and clean auxiliary data
  1016. */
  1017. finish: function () {
  1018. if (App.get('upgradeState') === 'COMPLETED') {
  1019. this.setDBProperties({
  1020. upgradeId: undefined,
  1021. upgradeState: 'INIT',
  1022. upgradeVersion: undefined,
  1023. currentVersion: undefined,
  1024. upgradeTypeDisplayName: undefined,
  1025. failuresTolerance: undefined,
  1026. isDowngrade: undefined
  1027. });
  1028. App.clusterStatus.setClusterStatus({
  1029. localdb: App.db.data
  1030. });
  1031. App.set('upgradeState', 'INIT');
  1032. }
  1033. }.observes('App.upgradeState'),
  1034. /**
  1035. * Check <code>App.upgradeState</code> for HOLDING
  1036. * If it is, send request to check if current item is Finalize
  1037. * @method updateFinalize
  1038. */
  1039. updateFinalize: function () {
  1040. var upgradeState = App.get('upgradeState');
  1041. if (upgradeState === 'HOLDING') {
  1042. return App.ajax.send({
  1043. name: 'admin.upgrade.finalizeContext',
  1044. sender: this,
  1045. success: 'updateFinalizeSuccessCallback',
  1046. error: 'updateFinalizeErrorCallback'
  1047. })
  1048. }
  1049. else {
  1050. this.set('isFinalizeItem', false);
  1051. }
  1052. }.observes('App.upgradeState'),
  1053. /**
  1054. *
  1055. * @param {object|null} data
  1056. * @method updateFinalizeSuccessCallback
  1057. */
  1058. updateFinalizeSuccessCallback: function (data) {
  1059. var context = data ? Em.get(data, 'items.firstObject.upgrade_groups.firstObject.upgrade_items.firstObject.UpgradeItem.context') : '';
  1060. this.set('isFinalizeItem', context === this.get('finalizeContext'));
  1061. },
  1062. updateFinalizeErrorCallback: function() {
  1063. this.set('isFinalizeItem', false);
  1064. },
  1065. /**
  1066. * show dialog with tasks of upgrade
  1067. * @return {App.ModalPopup}
  1068. */
  1069. openUpgradeDialog: function () {
  1070. App.router.transitionTo('admin.stackUpgrade');
  1071. },
  1072. /**
  1073. * returns url to get data for repoVersion or clusterStackVersion
  1074. * @param {Boolean} stack true if load clusterStackVersion
  1075. * @param {Boolean} fullLoad true if load all data
  1076. * @returns {String}
  1077. * @method getUrl
  1078. */
  1079. getUrl: function(stack, fullLoad) {
  1080. if (App.get('testMode')) {
  1081. return stack ? this.get('mockStackUrl') : this.get('mockRepoUrl')
  1082. } else {
  1083. if (fullLoad) {
  1084. return stack ? this.get('realStackUrl') : this.get('realRepoUrl');
  1085. } else {
  1086. return this.get('realUpdateUrl');
  1087. }
  1088. }
  1089. },
  1090. /**
  1091. * get stack versions from server and push it to model
  1092. * @return {*}
  1093. * @method loadStackVersionsToModel
  1094. */
  1095. loadStackVersionsToModel: function (fullLoad) {
  1096. var dfd = $.Deferred();
  1097. App.HttpClient.get(this.getUrl(true, fullLoad), App.stackVersionMapper, {
  1098. complete: function () {
  1099. dfd.resolve();
  1100. }
  1101. });
  1102. return dfd.promise();
  1103. },
  1104. /**
  1105. * get repo versions from server and push it to model
  1106. * @return {*}
  1107. * @params {Boolean} isUpdate - if true loads part of data that need to be updated
  1108. * @method loadRepoVersionsToModel()
  1109. */
  1110. loadRepoVersionsToModel: function () {
  1111. var dfd = $.Deferred();
  1112. App.HttpClient.get(this.getUrl(false, true), App.repoVersionMapper, {
  1113. complete: function () {
  1114. dfd.resolve();
  1115. }
  1116. });
  1117. return dfd.promise();
  1118. },
  1119. /**
  1120. * set status to Upgrade item
  1121. * @param item
  1122. * @param status
  1123. */
  1124. setUpgradeItemStatus: function(item, status) {
  1125. this.set('requestInProgress', true);
  1126. return App.ajax.send({
  1127. name: 'admin.upgrade.upgradeItem.setState',
  1128. sender: this,
  1129. data: {
  1130. upgradeId: item.get('request_id'),
  1131. itemId: item.get('stage_id'),
  1132. groupId: item.get('group_id'),
  1133. status: status
  1134. },
  1135. callback: function() {
  1136. this.sender.set('requestInProgress', false);
  1137. }
  1138. }).done(function () {
  1139. item.set('status', status);
  1140. });
  1141. },
  1142. currentVersionObserver: function () {
  1143. var versionNumber = this.get('currentVersion.repository_version');
  1144. var currentVersionObject = App.RepositoryVersion.find().findProperty('status', 'CURRENT');
  1145. var versionName = currentVersionObject && currentVersionObject.get('stackVersionType');
  1146. App.set('isStormMetricsSupported', versionName != 'HDP' || stringUtils.compareVersions(versionNumber, '2.2.2') > -1 || !versionNumber);
  1147. }.observes('currentVersion.repository_version'),
  1148. /**
  1149. * get the installed repositories of HDP from server
  1150. */
  1151. loadRepositories: function () {
  1152. if (App.router.get('clusterController.isLoaded')) {
  1153. var nameVersionCombo = App.get('currentStackVersion');
  1154. var stackName = nameVersionCombo.split('-')[0];
  1155. var stackVersion = nameVersionCombo.split('-')[1];
  1156. App.ajax.send({
  1157. name: 'cluster.load_repositories',
  1158. sender: this,
  1159. data: {
  1160. stackName: stackName,
  1161. stackVersion: stackVersion
  1162. },
  1163. success: 'loadRepositoriesSuccessCallback',
  1164. error: 'loadRepositoriesErrorCallback'
  1165. });
  1166. }
  1167. }.observes('App.router.clusterController.isLoaded'),
  1168. loadRepositoriesSuccessCallback: function (data) {
  1169. var allRepos = [];
  1170. data.items.forEach(function (os) {
  1171. os.repositories.forEach(function (repository) {
  1172. var osType = repository.Repositories.os_type;
  1173. var repo = Em.Object.create({
  1174. baseUrl: repository.Repositories.base_url,
  1175. osType: osType,
  1176. repoId: repository.Repositories.repo_id,
  1177. repoName : repository.Repositories.repo_name,
  1178. stackName : repository.Repositories.stack_name,
  1179. stackVersion : repository.Repositories.stack_version,
  1180. isFirst: false
  1181. });
  1182. var group = allRepos.findProperty('name', osType);
  1183. if (!group) {
  1184. group = {
  1185. name: osType,
  1186. repositories: []
  1187. };
  1188. repo.set('isFirst', true);
  1189. allRepos.push(group);
  1190. }
  1191. group.repositories.push(repo);
  1192. });
  1193. }, this);
  1194. allRepos.stackVersion = App.get('currentStackVersionNumber');
  1195. this.set('allRepos', allRepos);
  1196. },
  1197. loadRepositoriesErrorCallback: function (request, ajaxOptions, error) {
  1198. console.log('Error message is: ' + request.responseText);
  1199. },
  1200. /**
  1201. * @returns {$.ajax}
  1202. */
  1203. suspendUpgrade: function () {
  1204. var self = this;
  1205. return this.abortUpgrade().done(function () {
  1206. App.set('upgradeState', 'ABORTED');
  1207. self.set('isSuspended', true);
  1208. self.setDBProperty('upgradeState', 'ABORTED');
  1209. self.setDBProperty('isSuspended', true);
  1210. App.clusterStatus.setClusterStatus({
  1211. wizardControllerName: self.get('name'),
  1212. localdb: App.db.data
  1213. });
  1214. });
  1215. },
  1216. /**
  1217. * @returns {$.ajax}
  1218. */
  1219. resumeUpgrade: function() {
  1220. var self = this;
  1221. this.retryUpgrade().done(function () {
  1222. App.set('upgradeState', 'PENDING');
  1223. App.propertyDidChange('upgradeAborted');
  1224. self.set('isSuspended', false);
  1225. self.setDBProperty('upgradeState', 'PENDING');
  1226. self.setDBProperty('isSuspended', false);
  1227. App.clusterStatus.setClusterStatus({
  1228. wizardControllerName: self.get('name'),
  1229. localdb: App.db.data
  1230. });
  1231. });
  1232. }
  1233. });