cluster.js 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  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. repositories: [],
  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'),
  38. updateUpgradeVersionSuccessCallback: function(data) {
  39. var upgradeVersion = this.get('upgradeVersion') || App.defaultStackVersion;
  40. var currentStack = {};
  41. var upgradeStack = {};
  42. var currentVersion = App.get('currentStackVersionNumber');
  43. var minUpgradeVersion = currentVersion;
  44. upgradeVersion = upgradeVersion.replace(/HDP-/, '');
  45. data.items.mapProperty('Versions.stack_version').forEach(function(version){
  46. upgradeVersion = (stringUtils.compareVersions(upgradeVersion, version) === -1) ? version : upgradeVersion;
  47. });
  48. currentStack = data.items.findProperty('Versions.stack_version', currentVersion);
  49. upgradeStack = data.items.findProperty('Versions.stack_version', upgradeVersion);
  50. minUpgradeVersion = upgradeStack.Versions.min_upgrade_version;
  51. if(minUpgradeVersion && (stringUtils.compareVersions(minUpgradeVersion, currentVersion) === 1)){
  52. upgradeVersion = currentVersion;
  53. upgradeStack = currentStack;
  54. }
  55. upgradeVersion = 'HDP-' + upgradeVersion;
  56. this.set('upgradeVersion', upgradeVersion);
  57. if(currentStack && upgradeStack) {
  58. this.parseServicesInfo(currentStack, upgradeStack);
  59. }
  60. else {
  61. console.log('HDP stack doesn\'t have services with defaultStackVersion');
  62. }
  63. },
  64. updateUpgradeVersionErrorCallback: function(request, ajaxOptions, error) {
  65. console.log('Error message is: ' + request.responseText);
  66. console.log('HDP stack doesn\'t have services with defaultStackVersion');
  67. },
  68. /**
  69. * get the installed repositories of HDP from server
  70. */
  71. loadRepositories: function(){
  72. if(App.router.get('clusterController.isLoaded')){
  73. var nameVersionCombo = App.get('currentStackVersion');
  74. var stackName = nameVersionCombo.split('-')[0];
  75. var stackVersion = nameVersionCombo.split('-')[1];
  76. App.ajax.send({
  77. name: 'cluster.load_repositories',
  78. sender: this,
  79. data: {
  80. stackName: stackName,
  81. stackVersion: stackVersion
  82. },
  83. success: 'loadRepositoriesSuccessCallback',
  84. error: 'loadRepositoriesErrorCallback'
  85. });
  86. }
  87. }.observes('App.router.clusterController.isLoaded'),
  88. loadRepositoriesSuccessCallback: function (data) {
  89. var allRepos = [];
  90. data.items.forEach(function(os) {
  91. var repo = Em.Object.create({
  92. baseUrl: os.repositories[0].Repositories.base_url,
  93. osType: os.repositories[0].Repositories.os_type
  94. });
  95. allRepos.push(repo);
  96. }, this);
  97. allRepos.stackVersion = App.get('currentStackVersionNumber');
  98. this.set('repositories', allRepos);
  99. },
  100. loadRepositoriesErrorCallback: function(request, ajaxOptions, error) {
  101. console.log('Error message is: ' + request.responseText);
  102. },
  103. /**
  104. * parse services info(versions, description) by version
  105. */
  106. parseServicesInfo: function (currentStack, upgradeStack) {
  107. var result = [];
  108. var installedServices = App.Service.find().mapProperty('serviceName');
  109. var displayOrderConfig = require('data/services');
  110. if(currentStack.stackServices.length && upgradeStack.stackServices.length){
  111. // loop through all the service components
  112. for (var i = 0; i < displayOrderConfig.length; i++) {
  113. var entry = currentStack.stackServices.
  114. findProperty("StackServices.service_name", displayOrderConfig[i].serviceName);
  115. if (entry) {
  116. entry = entry.StackServices;
  117. if (installedServices.contains(entry.service_name)) {
  118. var myService = Em.Object.create({
  119. serviceName: entry.service_name,
  120. displayName: displayOrderConfig[i].displayName,
  121. isDisabled: displayOrderConfig[i].isDisabled,
  122. isSelected: true,
  123. isInstalled: false,
  124. isHidden: displayOrderConfig[i].isHidden,
  125. description: entry.comments,
  126. version: entry.service_version,
  127. newVersion: ''
  128. });
  129. // it's possible that there is no corresponding service in the new stack
  130. var matchedService = upgradeStack.stackServices.findProperty("StackServices.service_name", displayOrderConfig[i].serviceName);
  131. if (matchedService) {
  132. myService.newVersion = matchedService.StackServices.service_version;
  133. }
  134. //From 1.3.0 for Hive we display only "Hive" (but it install HCat and WebHCat as well)
  135. if (this.get('upgradeVersion').replace(/HDP-/, '') >= '1.3.0' && displayOrderConfig[i].serviceName == 'HIVE') {
  136. myService.set('displayName', 'Hive');
  137. }
  138. result.push(myService);
  139. }
  140. }
  141. else {
  142. console.warn('Service not found - ', displayOrderConfig[i].serviceName);
  143. }
  144. }
  145. }
  146. this.set('services', result);
  147. }
  148. });