cluster.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  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 displayOrderConfig = require('data/services');
  125. if(currentStack.stackServices.length && upgradeStack.stackServices.length){
  126. // loop through all the service components
  127. for (var i = 0; i < displayOrderConfig.length; i++) {
  128. var entry = currentStack.stackServices.
  129. findProperty("StackServices.service_name", displayOrderConfig[i].serviceName);
  130. if (entry) {
  131. entry = entry.StackServices;
  132. if (installedServices.contains(entry.service_name)) {
  133. var myService = Em.Object.create({
  134. serviceName: entry.service_name,
  135. displayName: displayOrderConfig[i].displayName,
  136. isDisabled: displayOrderConfig[i].isDisabled,
  137. isSelected: true,
  138. isInstalled: false,
  139. isHidden: displayOrderConfig[i].isHidden,
  140. description: entry.comments,
  141. version: entry.service_version,
  142. newVersion: ''
  143. });
  144. // it's possible that there is no corresponding service in the new stack
  145. var matchedService = upgradeStack.stackServices.findProperty("StackServices.service_name", displayOrderConfig[i].serviceName);
  146. if (matchedService) {
  147. myService.newVersion = matchedService.StackServices.service_version;
  148. }
  149. //From 1.3.0 for Hive we display only "Hive" (but it install HCat and WebHCat as well)
  150. if (this.get('upgradeVersion').replace(/HDP-/, '') >= '1.3.0' && displayOrderConfig[i].serviceName == 'HIVE') {
  151. myService.set('displayName', 'Hive');
  152. }
  153. result.push(myService);
  154. }
  155. }
  156. else {
  157. console.warn('Service not found - ', displayOrderConfig[i].serviceName);
  158. }
  159. }
  160. }
  161. this.set('services', result);
  162. }
  163. });