stack_and_upgrade_controller.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816
  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 {boolean}
  43. * @default false
  44. */
  45. isDowngrade: false,
  46. /**
  47. * version that currently applied to server
  48. * should be plain object, because stored to localStorage
  49. * @type {object|null}
  50. */
  51. currentVersion: null,
  52. /**
  53. * versions to which cluster could be upgraded
  54. * @type {Array}
  55. */
  56. targetVersions: [],
  57. /**
  58. * @type {boolean} true if some request that should disable actions is in progress
  59. */
  60. requestInProgress: false,
  61. /**
  62. * properties that stored to localStorage to resume wizard progress
  63. */
  64. wizardStorageProperties: ['upgradeId', 'upgradeVersion', 'currentVersion', 'isDowngrade'],
  65. /**
  66. * mutable properties of Upgrade Task
  67. * @type {Array}
  68. */
  69. taskDetailsProperties: ['status', 'stdout', 'stderr', 'error_log', 'host_name', 'output_log'],
  70. /**
  71. * path to the mock json
  72. * @type {String}
  73. */
  74. mockRepoUrl: '/data/stack_versions/repo_versions_all.json',
  75. /**
  76. * api to get RepoVersions
  77. * @type {String}
  78. */
  79. realRepoUrl: function () {
  80. return App.get('apiPrefix') + App.get('stackVersionURL') +
  81. '/compatible_repository_versions?fields=*,operating_systems/*,operating_systems/repositories/*';
  82. }.property('App.stackVersionURL'),
  83. /**
  84. * path to the mock json
  85. * @type {String}
  86. */
  87. mockStackUrl: '/data/stack_versions/stack_version_all.json',
  88. /**
  89. * api to get ClusterStackVersions with repository_versions (use to init data load)
  90. * @type {String}
  91. */
  92. realStackUrl: function () {
  93. return App.get('apiPrefix') + '/clusters/' + App.get('clusterName') +
  94. '/stack_versions?fields=*,repository_versions/*,repository_versions/operating_systems/repositories/*';
  95. }.property('App.clusterName'),
  96. /**
  97. * api to get ClusterStackVersions without repository_versions (use to update data)
  98. * @type {String}
  99. */
  100. realUpdateUrl: function () {
  101. return App.get('apiPrefix') + '/clusters/' + App.get('clusterName') + '/stack_versions?fields=ClusterStackVersions/*';
  102. }.property('App.clusterName'),
  103. init: function () {
  104. this.initDBProperties();
  105. },
  106. /**
  107. * restore data from localStorage
  108. */
  109. initDBProperties: function () {
  110. this.get('wizardStorageProperties').forEach(function (property) {
  111. if (this.getDBProperty(property)) {
  112. this.set(property, this.getDBProperty(property));
  113. }
  114. }, this);
  115. },
  116. /**
  117. * load all data:
  118. * - upgrade data
  119. * - stack versions
  120. * - repo versions
  121. */
  122. load: function () {
  123. var dfd = $.Deferred();
  124. var self = this;
  125. this.loadUpgradeData(true).done(function() {
  126. self.loadStackVersionsToModel(true).done(function () {
  127. self.loadRepoVersionsToModel().done(function() {
  128. var currentVersion = App.StackVersion.find().findProperty('state', 'CURRENT');
  129. if (currentVersion) {
  130. self.set('currentVersion', {
  131. repository_version: currentVersion.get('repositoryVersion.repositoryVersion'),
  132. repository_name: currentVersion.get('repositoryVersion.displayName')
  133. });
  134. }
  135. dfd.resolve();
  136. });
  137. });
  138. });
  139. return dfd.promise();
  140. },
  141. /**
  142. * load upgrade tasks by upgrade id
  143. * @return {$.Deferred}
  144. * @param {boolean} onlyState
  145. */
  146. loadUpgradeData: function (onlyState) {
  147. var upgradeId = this.get('upgradeId');
  148. var deferred = $.Deferred();
  149. if (Em.isNone(upgradeId)) {
  150. deferred.resolve();
  151. console.log('Upgrade in INIT state');
  152. } else {
  153. App.ajax.send({
  154. name: (onlyState) ? 'admin.upgrade.state' : 'admin.upgrade.data',
  155. sender: this,
  156. data: {
  157. id: upgradeId
  158. },
  159. success: 'loadUpgradeDataSuccessCallback'
  160. }).then(deferred.resolve);
  161. }
  162. return deferred.promise();
  163. },
  164. /**
  165. * parse and push upgrade tasks to controller
  166. * @param data
  167. */
  168. loadUpgradeDataSuccessCallback: function (data) {
  169. if (Em.isNone(data)) return;
  170. App.set('upgradeState', data.Upgrade.request_status);
  171. this.setDBProperty('upgradeState', data.Upgrade.request_status);
  172. if (data.upgrade_groups) {
  173. this.updateUpgradeData(data);
  174. }
  175. },
  176. /**
  177. * update data of Upgrade
  178. * @param {object} newData
  179. */
  180. updateUpgradeData: function (newData) {
  181. var oldData = this.get('upgradeData'),
  182. groupsMap = {},
  183. itemsMap = {};
  184. if (Em.isNone(oldData) || (newData.upgrade_groups.length !== oldData.upgradeGroups.length)) {
  185. this.initUpgradeData(newData);
  186. } else {
  187. //create entities maps
  188. newData.upgrade_groups.forEach(function (newGroup) {
  189. groupsMap[newGroup.UpgradeGroup.group_id] = newGroup.UpgradeGroup;
  190. newGroup.upgrade_items.forEach(function (item) {
  191. itemsMap[item.UpgradeItem.stage_id] = item.UpgradeItem;
  192. })
  193. });
  194. //update existed entities with new data
  195. oldData.upgradeGroups.forEach(function (oldGroup) {
  196. oldGroup.set('status', groupsMap[oldGroup.get('group_id')].status);
  197. oldGroup.set('progress_percent', groupsMap[oldGroup.get('group_id')].progress_percent);
  198. oldGroup.set('completed_task_count', groupsMap[oldGroup.get('group_id')].completed_task_count);
  199. oldGroup.upgradeItems.forEach(function (item) {
  200. item.set('status', itemsMap[item.get('stage_id')].status);
  201. item.set('progress_percent', itemsMap[item.get('stage_id')].progress_percent);
  202. })
  203. });
  204. oldData.set('Upgrade', newData.Upgrade);
  205. }
  206. },
  207. /**
  208. * change structure of Upgrade
  209. * In order to maintain nested views in template object should have direct link to its properties, for example
  210. * item.UpgradeItem.<properties> -> item.<properties>
  211. * @param {object} newData
  212. */
  213. initUpgradeData: function (newData) {
  214. var upgradeGroups = [];
  215. //wrap all entities into App.upgradeEntity
  216. newData.upgrade_groups.forEach(function (newGroup) {
  217. var oldGroup = App.upgradeEntity.create({type: 'GROUP'}, newGroup.UpgradeGroup);
  218. var upgradeItems = [];
  219. newGroup.upgrade_items.forEach(function (item) {
  220. var oldItem = App.upgradeEntity.create({type: 'ITEM'}, item.UpgradeItem);
  221. oldItem.set('tasks', []);
  222. upgradeItems.pushObject(oldItem);
  223. });
  224. upgradeItems.reverse();
  225. oldGroup.set('upgradeItems', upgradeItems);
  226. upgradeGroups.pushObject(oldGroup);
  227. });
  228. upgradeGroups.reverse();
  229. this.set('upgradeData', Em.Object.create({
  230. upgradeGroups: upgradeGroups,
  231. Upgrade: newData.Upgrade
  232. }));
  233. },
  234. /**
  235. * request Upgrade Item and its tasks from server
  236. * @return {$.ajax}
  237. */
  238. getUpgradeItem: function (item) {
  239. return App.ajax.send({
  240. name: 'admin.upgrade.upgrade_item',
  241. sender: this,
  242. data: {
  243. upgradeId: item.get('request_id'),
  244. groupId: item.get('group_id'),
  245. stageId: item.get('stage_id')
  246. },
  247. success: 'getUpgradeItemSuccessCallback'
  248. });
  249. },
  250. /**
  251. * success callback of <code>getTasks</code>
  252. * @param {object} data
  253. */
  254. getUpgradeItemSuccessCallback: function (data) {
  255. this.get('upgradeData.upgradeGroups').forEach(function (group) {
  256. if (group.get('group_id') === data.UpgradeItem.group_id) {
  257. group.get('upgradeItems').forEach(function (item) {
  258. if (item.get('stage_id') === data.UpgradeItem.stage_id) {
  259. if (item.get('tasks.length')) {
  260. item.set('isTasksLoaded', true);
  261. data.tasks.forEach(function (task) {
  262. var currentTask = item.get('tasks').findProperty('id', task.Tasks.id);
  263. this.get('taskDetailsProperties').forEach(function (property) {
  264. currentTask.set(property, task.Tasks[property]);
  265. }, this);
  266. }, this);
  267. } else {
  268. var tasks = [];
  269. data.tasks.forEach(function (task) {
  270. tasks.pushObject(App.upgradeEntity.create({type: 'TASK'}, task.Tasks));
  271. });
  272. item.set('tasks', tasks);
  273. }
  274. item.set('isTasksLoaded', true);
  275. }
  276. }, this);
  277. }
  278. }, this);
  279. },
  280. /**
  281. * downgrade confirmation popup
  282. * @param {object} event
  283. */
  284. confirmDowngrade: function (event) {
  285. var self = this;
  286. var currentVersion = this.get('currentVersion');
  287. return App.showConfirmationPopup(
  288. function() {
  289. self.downgrade.call(self, currentVersion, event);
  290. },
  291. Em.I18n.t('admin.stackUpgrade.downgrade.body').format(currentVersion.repository_name),
  292. null,
  293. Em.I18n.t('admin.stackUpgrade.dialog.downgrade.header').format(currentVersion.repository_name),
  294. Em.I18n.t('admin.stackUpgrade.downgrade.proceed')
  295. );
  296. },
  297. /**
  298. * make call to start downgrade process
  299. * @param {object} currentVersion
  300. * @param {object} event
  301. */
  302. downgrade: function (currentVersion, event) {
  303. this.set('requestInProgress', true);
  304. this.abortUpgrade();
  305. App.ajax.send({
  306. name: 'admin.downgrade.start',
  307. sender: this,
  308. data: {
  309. value: currentVersion.repository_version,
  310. label: currentVersion.repository_name,
  311. isDowngrade: true
  312. },
  313. success: 'upgradeSuccessCallback',
  314. callback: function() {
  315. this.sender.set('requestInProgress', false);
  316. }
  317. });
  318. },
  319. /**
  320. * abort upgrade (in order to start Downgrade)
  321. */
  322. abortUpgrade: function () {
  323. return App.ajax.send({
  324. name: 'admin.upgrade.abort',
  325. sender: this,
  326. data: {
  327. upgradeId: this.get('upgradeId')
  328. }
  329. });
  330. },
  331. /**
  332. * make call to start upgrade process and show popup with current progress
  333. * @param {object} version
  334. */
  335. upgrade: function (version) {
  336. this.set('requestInProgress', true);
  337. App.ajax.send({
  338. name: 'admin.upgrade.start',
  339. sender: this,
  340. data: version,
  341. success: 'upgradeSuccessCallback',
  342. callback: function() {
  343. this.sender.set('requestInProgress', false);
  344. }
  345. });
  346. this.setDBProperty('currentVersion', this.get('currentVersion'));
  347. },
  348. /**
  349. * success callback of <code>upgrade()</code>
  350. * @param {object} data
  351. */
  352. upgradeSuccessCallback: function (data, opt, params) {
  353. this.set('upgradeData', null);
  354. this.set('upgradeId', data.resources[0].Upgrade.request_id);
  355. this.set('upgradeVersion', params.label);
  356. this.set('isDowngrade', !!params.isDowngrade);
  357. this.setDBProperty('upgradeVersion', params.label);
  358. this.setDBProperty('upgradeId', data.resources[0].Upgrade.request_id);
  359. this.setDBProperty('upgradeState', 'PENDING');
  360. this.setDBProperty('isDowngrade', !!params.isDowngrade);
  361. App.set('upgradeState', 'PENDING');
  362. App.clusterStatus.setClusterStatus({
  363. wizardControllerName: this.get('name'),
  364. localdb: App.db.data
  365. });
  366. this.load();
  367. this.openUpgradeDialog();
  368. },
  369. /**
  370. * upgrade confirmation popup
  371. * @param {object} version
  372. * @return App.ModalPopup
  373. */
  374. confirmUpgrade: function (version) {
  375. var self = this;
  376. return App.showConfirmationPopup(
  377. function () {
  378. self.runPreUpgradeCheck.call(self, version);
  379. },
  380. Em.I18n.t('admin.stackUpgrade.upgrade.confirm.body').format(version.get('displayName')),
  381. null,
  382. Em.I18n.t('admin.stackUpgrade.dialog.header').format(version.get('displayName'))
  383. );
  384. },
  385. /**
  386. * send request for pre upgrade check
  387. * @param version
  388. */
  389. runPreUpgradeCheck: function(version) {
  390. var params = {
  391. value: version.get('repositoryVersion'),
  392. label: version.get('displayName')
  393. };
  394. if (App.get('supports.preUpgradeCheck')) {
  395. this.set('requestInProgress', true);
  396. App.ajax.send({
  397. name: "admin.rolling_upgrade.pre_upgrade_check",
  398. sender: this,
  399. data: params,
  400. success: "runPreUpgradeCheckSuccess",
  401. error: "runPreUpgradeCheckError"
  402. });
  403. } else {
  404. this.upgrade(params);
  405. }
  406. },
  407. /**
  408. * success callback of <code>runPreUpgradeCheckSuccess()</code>
  409. * if there are some fails - it shows popup else run upgrade
  410. * @param data {object}
  411. * @param opt {object}
  412. * @param params {object}
  413. * @returns {App.ModalPopup|undefined}
  414. */
  415. runPreUpgradeCheckSuccess: function (data, opt, params) {
  416. if (data.items.someProperty('UpgradeChecks.status', "FAIL")) {
  417. this.set('requestInProgress', false);
  418. var header = Em.I18n.t('popup.clusterCheck.Upgrade.header').format(params.label);
  419. var title = Em.I18n.t('popup.clusterCheck.Upgrade.title');
  420. var alert = Em.I18n.t('popup.clusterCheck.Upgrade.alert');
  421. App.showClusterCheckPopup(data, header, title, alert);
  422. } else {
  423. this.upgrade(params);
  424. }
  425. },
  426. runPreUpgradeCheckError: function() {
  427. this.set('requestInProgress', false);
  428. },
  429. /**
  430. * confirmation popup before install repository version
  431. */
  432. installRepoVersionConfirmation: function (repo) {
  433. var self = this;
  434. return App.showConfirmationPopup(function () {
  435. self.installRepoVersion(repo);
  436. },
  437. Em.I18n.t('admin.stackVersions.version.install.confirm').format(repo.get('displayName'))
  438. );
  439. },
  440. /**
  441. * sends request to install repoVersion to the cluster
  442. * and create clusterStackVersion resourse
  443. * @param {Em.Object} repo
  444. * @return {$.ajax}
  445. * @method installRepoVersion
  446. */
  447. installRepoVersion: function (repo) {
  448. this.set('requestInProgress', true);
  449. var data = {
  450. ClusterStackVersions: {
  451. stack: repo.get('stackVersionType'),
  452. version: repo.get('stackVersionNumber'),
  453. repository_version: repo.get('repositoryVersion')
  454. },
  455. id: repo.get('id')
  456. };
  457. return App.ajax.send({
  458. name: 'admin.stack_version.install.repo_version',
  459. sender: this,
  460. data: data,
  461. success: 'installRepoVersionSuccess',
  462. callback: function() {
  463. this.sender.set('requestInProgress', false);
  464. }
  465. });
  466. },
  467. /**
  468. * transform repo data into json for
  469. * saving changes to repository version
  470. * @param {Em.Object} repo
  471. * @returns {{operating_systems: Array}}
  472. */
  473. prepareRepoForSaving: function(repo) {
  474. var repoVersion = { "operating_systems": [] };
  475. repo.get('operatingSystems').forEach(function (os, k) {
  476. repoVersion.operating_systems.push({
  477. "OperatingSystems": {
  478. "os_type": os.get("osType")
  479. },
  480. "repositories": []
  481. });
  482. os.get('repositories').forEach(function (repository) {
  483. repoVersion.operating_systems[k].repositories.push({
  484. "Repositories": {
  485. "base_url": repository.get('baseUrl'),
  486. "repo_id": repository.get('repoId'),
  487. "repo_name": repository.get('repoName')
  488. }
  489. });
  490. });
  491. });
  492. return repoVersion;
  493. },
  494. /**
  495. * perform validation if <code>skip<code> is false and run save if
  496. * validation successfull or run save without validation is <code>skip<code> is true
  497. * @param {Em.Object} repo
  498. * @param {boolean} skip
  499. * @returns {$.Deferred}
  500. */
  501. saveRepoOS: function (repo, skip) {
  502. var self = this;
  503. var deferred = $.Deferred();
  504. this.validateRepoVersions(repo, skip).done(function(data) {
  505. if (data.length > 0) {
  506. deferred.resolve(data);
  507. } else {
  508. var repoVersion = self.prepareRepoForSaving(repo);
  509. App.ajax.send({
  510. name: 'admin.stack_versions.edit.repo',
  511. sender: this,
  512. data: {
  513. stackName: App.get('currentStackName'),
  514. stackVersion: App.get('currentStackVersionNumber'),
  515. repoVersionId: repo.get('repoVersionId'),
  516. repoVersion: repoVersion
  517. }
  518. }).success(function() {
  519. deferred.resolve([]);
  520. });
  521. }
  522. });
  523. return deferred.promise();
  524. },
  525. /**
  526. * send request for validation for each repository
  527. * @param {Em.Object} repo
  528. * @param {boolean} skip
  529. * @returns {*}
  530. */
  531. validateRepoVersions: function(repo, skip) {
  532. var deferred = $.Deferred(),
  533. totalCalls = 0,
  534. invalidUrls = [];
  535. if (skip) {
  536. deferred.resolve(invalidUrls);
  537. } else {
  538. repo.get('operatingSystems').forEach(function (os) {
  539. if (os.get('isSelected')) {
  540. os.get('repositories').forEach(function (repo) {
  541. totalCalls++;
  542. App.ajax.send({
  543. name: 'admin.stack_versions.validate.repo',
  544. sender: this,
  545. data: {
  546. repo: repo,
  547. repoId: repo.get('repoId'),
  548. baseUrl: repo.get('baseUrl'),
  549. osType: os.get('osType'),
  550. stackName: App.get('currentStackName'),
  551. stackVersion: App.get('currentStackVersionNumber')
  552. }
  553. })
  554. .success(function () {
  555. totalCalls--;
  556. if (totalCalls === 0) deferred.resolve(invalidUrls);
  557. })
  558. .error(function () {
  559. repo.set('hasError', true);
  560. invalidUrls.push(repo);
  561. totalCalls--;
  562. if (totalCalls === 0) deferred.resolve(invalidUrls);
  563. });
  564. });
  565. } else {
  566. return deferred.resolve(invalidUrls);
  567. }
  568. });
  569. }
  570. return deferred.promise();
  571. },
  572. /**
  573. * success callback for <code>installRepoVersion()<code>
  574. * saves request id to the db
  575. * @param data
  576. * @param opt
  577. * @param params
  578. * @method installStackVersionSuccess
  579. */
  580. installRepoVersionSuccess: function (data, opt, params) {
  581. var version = App.RepositoryVersion.find(params.id);
  582. App.db.set('repoVersionInstall', 'id', [data.Requests.id]);
  583. App.clusterStatus.setClusterStatus({
  584. wizardControllerName: this.get('name'),
  585. localdb: App.db.data
  586. });
  587. version.set('defaultStatus', 'INSTALLING');
  588. if (version.get('stackVersion')) {
  589. version.set('stackVersion.state', 'INSTALLING');
  590. }
  591. },
  592. /**
  593. * opens a popup with installations state per host
  594. * @param {Em.Object} version
  595. * @method showProgressPopup
  596. */
  597. showProgressPopup: function(version) {
  598. var popupTitle = Em.I18n.t('admin.stackVersions.details.install.hosts.popup.title').format(version.get('displayName'));
  599. var requestIds = App.get('testMode') ? [1] : App.db.get('repoVersionInstall', 'id');
  600. var hostProgressPopupController = App.router.get('highAvailabilityProgressPopupController');
  601. hostProgressPopupController.initPopup(popupTitle, requestIds, this);
  602. },
  603. /**
  604. * reset upgradeState to INIT when upgrade is COMPLETED
  605. * and clean auxiliary data
  606. */
  607. finish: function () {
  608. if (App.get('upgradeState') === 'COMPLETED') {
  609. this.setDBProperty('upgradeId', undefined);
  610. this.setDBProperty('upgradeState', 'INIT');
  611. this.setDBProperty('upgradeVersion', undefined);
  612. this.setDBProperty('currentVersion', undefined);
  613. this.setDBProperty('isDowngrade', undefined);
  614. App.clusterStatus.setClusterStatus({
  615. localdb: App.db.data
  616. });
  617. App.set('upgradeState', 'INIT');
  618. }
  619. }.observes('App.upgradeState'),
  620. /**
  621. * show dialog with tasks of upgrade
  622. * @return {App.ModalPopup}
  623. */
  624. openUpgradeDialog: function () {
  625. App.router.transitionTo('admin.stackUpgrade');
  626. },
  627. /**
  628. * returns url to get data for repoVersion or clusterStackVersion
  629. * @param {Boolean} stack true if load clusterStackVersion
  630. * @param {Boolean} fullLoad true if load all data
  631. * @returns {String}
  632. * @method getUrl
  633. */
  634. getUrl: function(stack, fullLoad) {
  635. if (App.get('testMode')) {
  636. return stack ? this.get('mockStackUrl') : this.get('mockRepoUrl')
  637. } else {
  638. if (fullLoad) {
  639. return stack ? this.get('realStackUrl') : this.get('realRepoUrl');
  640. } else {
  641. return this.get('realUpdateUrl');
  642. }
  643. }
  644. },
  645. /**
  646. * get stack versions from server and push it to model
  647. * @return {*}
  648. * @method loadStackVersionsToModel
  649. */
  650. loadStackVersionsToModel: function (fullLoad) {
  651. var dfd = $.Deferred();
  652. App.HttpClient.get(this.getUrl(true, fullLoad), App.stackVersionMapper, {
  653. complete: function () {
  654. dfd.resolve();
  655. }
  656. });
  657. return dfd.promise();
  658. },
  659. /**
  660. * get repo versions from server and push it to model
  661. * @return {*}
  662. * @params {Boolean} isUpdate - if true loads part of data that need to be updated
  663. * @method loadRepoVersionsToModel()
  664. */
  665. loadRepoVersionsToModel: function () {
  666. var dfd = $.Deferred();
  667. App.HttpClient.get(this.getUrl(false, true), App.repoVersionMapper, {
  668. complete: function () {
  669. dfd.resolve();
  670. }
  671. });
  672. return dfd.promise();
  673. },
  674. /**
  675. * set status to Upgrade item
  676. * @param item
  677. * @param status
  678. */
  679. setUpgradeItemStatus: function(item, status) {
  680. this.set('requestInProgress', true);
  681. return App.ajax.send({
  682. name: 'admin.upgrade.upgradeItem.setState',
  683. sender: this,
  684. data: {
  685. upgradeId: item.get('request_id'),
  686. itemId: item.get('stage_id'),
  687. groupId: item.get('group_id'),
  688. status: status
  689. },
  690. callback: function() {
  691. this.sender.set('requestInProgress', false);
  692. }
  693. }).done(function () {
  694. item.set('status', status);
  695. });
  696. },
  697. currentVersionObserver: function () {
  698. var versionNumber = this.get('currentVersion.repository_version');
  699. var currentVersionObject = App.RepositoryVersion.find().findProperty('status', 'CURRENT');
  700. var versionName = currentVersionObject && currentVersionObject.get('stackVersionType');
  701. App.set('isStormMetricsSupported', versionName != 'HDP' || stringUtils.compareVersions(versionNumber, '2.2.2') > -1 || !versionNumber);
  702. }.observes('currentVersion.repository_version'),
  703. /**
  704. * get the installed repositories of HDP from server
  705. */
  706. loadRepositories: function () {
  707. if (App.router.get('clusterController.isLoaded')) {
  708. var nameVersionCombo = App.get('currentStackVersion');
  709. var stackName = nameVersionCombo.split('-')[0];
  710. var stackVersion = nameVersionCombo.split('-')[1];
  711. App.ajax.send({
  712. name: 'cluster.load_repositories',
  713. sender: this,
  714. data: {
  715. stackName: stackName,
  716. stackVersion: stackVersion
  717. },
  718. success: 'loadRepositoriesSuccessCallback',
  719. error: 'loadRepositoriesErrorCallback'
  720. });
  721. }
  722. }.observes('App.router.clusterController.isLoaded'),
  723. loadRepositoriesSuccessCallback: function (data) {
  724. var allRepos = [];
  725. data.items.forEach(function (os) {
  726. os.repositories.forEach(function (repository) {
  727. var osType = repository.Repositories.os_type;
  728. var repo = Em.Object.create({
  729. baseUrl: repository.Repositories.base_url,
  730. osType: osType,
  731. repoId: repository.Repositories.repo_id,
  732. repoName : repository.Repositories.repo_name,
  733. stackName : repository.Repositories.stack_name,
  734. stackVersion : repository.Repositories.stack_version,
  735. isFirst: false
  736. });
  737. var group = allRepos.findProperty('name', osType);
  738. if (!group) {
  739. group = {
  740. name: osType,
  741. repositories: []
  742. };
  743. repo.set('isFirst', true);
  744. allRepos.push(group);
  745. }
  746. group.repositories.push(repo);
  747. });
  748. }, this);
  749. allRepos.stackVersion = App.get('currentStackVersionNumber');
  750. this.set('allRepos', allRepos);
  751. },
  752. loadRepositoriesErrorCallback: function (request, ajaxOptions, error) {
  753. console.log('Error message is: ' + request.responseText);
  754. }
  755. });