cluster.js 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  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.MainAdminClusterController = Em.Controller.extend({
  21. name: 'mainAdminClusterController',
  22. services: [],
  23. allRepos: [],
  24. upgradeVersion: '',
  25. /**
  26. * get the newest version of HDP from server
  27. */
  28. updateUpgradeVersion: function () {
  29. if (App.router.get('clusterController.isLoaded')) {
  30. App.ajax.send({
  31. name: 'cluster.update_upgrade_version',
  32. sender: this,
  33. success: 'updateUpgradeVersionSuccessCallback',
  34. error: 'updateUpgradeVersionErrorCallback'
  35. });
  36. }
  37. }.observes('App.router.clusterController.isLoaded', 'App.currentStackVersion', 'App.router.mainServiceController.content.length'),
  38. updateUpgradeVersionSuccessCallback: function (data) {
  39. var upgradeVersion = this.get('upgradeVersion') || App.defaultStackVersion;
  40. var currentVersion = App.get('currentStackVersionNumber');
  41. upgradeVersion = upgradeVersion.replace(/HDP-/, '');
  42. data.items.mapProperty('Versions.stack_version').forEach(function (version) {
  43. upgradeVersion = (stringUtils.compareVersions(upgradeVersion, version) === -1) ? version : upgradeVersion;
  44. });
  45. var currentStack = data.items.findProperty('Versions.stack_version', currentVersion);
  46. var upgradeStack = data.items.findProperty('Versions.stack_version', upgradeVersion);
  47. var minUpgradeVersion = upgradeStack.Versions.min_upgrade_version;
  48. if (minUpgradeVersion && (stringUtils.compareVersions(minUpgradeVersion, currentVersion) === 1)) {
  49. upgradeVersion = currentVersion;
  50. upgradeStack = currentStack;
  51. }
  52. upgradeVersion = 'HDP-' + upgradeVersion;
  53. this.set('upgradeVersion', upgradeVersion);
  54. if (currentStack && upgradeStack) {
  55. this.parseServicesInfo(currentStack, upgradeStack);
  56. }
  57. else {
  58. console.log('HDP stack doesn\'t have services with defaultStackVersion');
  59. }
  60. },
  61. updateUpgradeVersionErrorCallback: function (request, ajaxOptions, error) {
  62. console.log('Error message is: ' + request.responseText);
  63. console.log('HDP stack doesn\'t have services with defaultStackVersion');
  64. },
  65. /**
  66. * get the installed repositories of HDP from server
  67. */
  68. loadRepositories: function () {
  69. if (App.router.get('clusterController.isLoaded')) {
  70. var nameVersionCombo = App.get('currentStackVersion');
  71. var stackName = nameVersionCombo.split('-')[0];
  72. var stackVersion = nameVersionCombo.split('-')[1];
  73. App.ajax.send({
  74. name: 'cluster.load_repositories',
  75. sender: this,
  76. data: {
  77. stackName: stackName,
  78. stackVersion: stackVersion
  79. },
  80. success: 'loadRepositoriesSuccessCallback',
  81. error: 'loadRepositoriesErrorCallback'
  82. });
  83. }
  84. }.observes('App.router.clusterController.isLoaded'),
  85. loadRepositoriesSuccessCallback: function (data) {
  86. var allRepos = [];
  87. data.items.forEach(function (os) {
  88. if (!App.supports.ubuntu && os.OperatingSystems.os_type == 'debian12') return; // @todo: remove after Ubuntu support confirmation
  89. os.repositories.forEach(function (repository) {
  90. var osType = repository.Repositories.os_type;
  91. var repo = Em.Object.create({
  92. baseUrl: repository.Repositories.base_url,
  93. osType: osType,
  94. repoId: repository.Repositories.repo_id,
  95. repoName : repository.Repositories.repo_name,
  96. stackName : repository.Repositories.stack_name,
  97. stackVersion : repository.Repositories.stack_version,
  98. isFirst: false
  99. });
  100. var group = allRepos.findProperty('name', osType);
  101. if (!group) {
  102. group = {
  103. name: osType,
  104. repositories: []
  105. };
  106. repo.set('isFirst', true);
  107. allRepos.push(group);
  108. }
  109. group.repositories.push(repo);
  110. });
  111. }, this);
  112. allRepos.stackVersion = App.get('currentStackVersionNumber');
  113. this.set('allRepos', allRepos);
  114. },
  115. loadRepositoriesErrorCallback: function (request, ajaxOptions, error) {
  116. console.log('Error message is: ' + request.responseText);
  117. },
  118. /**
  119. * parse services info(versions, description) by version
  120. */
  121. parseServicesInfo: function (currentStack, upgradeStack) {
  122. var result = [];
  123. var installedServices = App.Service.find().mapProperty('serviceName');
  124. var displayOrder = App.StackService.displayOrder;
  125. if (currentStack.stackServices.length && upgradeStack.stackServices.length) {
  126. // loop through all the service components
  127. displayOrder.forEach(function (_stackServiceName) {
  128. var entry = currentStack.stackServices.
  129. findProperty("StackServices.service_name", _stackServiceName);
  130. var stackService = App.StackService.find().findProperty('serviceName', _stackServiceName);
  131. if (!!stackService) {
  132. var myService = Em.Object.create({
  133. serviceName: stackService.get('serviceName'),
  134. displayName: stackService.get('displayNameOnSelectServicePage'),
  135. isSelected: true,
  136. isInstalled: false,
  137. isHidden: stackService.get('isHiddenOnSelectServicePage'),
  138. description: stackService.get('comments'),
  139. version: stackService.get('serviceVersion'),
  140. newVersion: ''
  141. });
  142. // it's possible that there is no corresponding service in the new stack
  143. var matchedService = upgradeStack.stackServices.findProperty("StackServices.service_name", stackService.get('serviceName'));
  144. if (matchedService) {
  145. myService.newVersion = matchedService.StackServices.service_version;
  146. }
  147. result.push(myService);
  148. }
  149. }, this);
  150. }
  151. this.set('services', result);
  152. }
  153. });