repository_version_mapper.js 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  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. App.repoVersionMapper = App.QuickDataMapper.create({
  20. modelRepoVersions: App.RepositoryVersion,
  21. modelOperatingSystems: App.OS,
  22. modelRepositories: App.Repository,
  23. modelServices: App.ServiceSimple,
  24. modelRepoVersion: function (isCurrentStackOnly) {
  25. var repoVersionsKey = isCurrentStackOnly ? 'RepositoryVersions' : 'CompatibleRepositoryVersions';
  26. return {
  27. id: repoVersionsKey + '.id',
  28. stack_version_id: repoVersionsKey + '.stackVersionId',
  29. display_name: repoVersionsKey + '.display_name',
  30. type: repoVersionsKey + '.type',
  31. repository_version: repoVersionsKey + '.repository_version',
  32. upgrade_pack: repoVersionsKey + '.upgrade_pack',
  33. stack_version_type: repoVersionsKey + '.stack_name',
  34. stack_version_number: repoVersionsKey + '.stack_version',
  35. services_key: 'services',
  36. services_type: 'array',
  37. services: {
  38. item: 'id'
  39. },
  40. operating_systems_key: 'operating_systems',
  41. operating_systems_type: 'array',
  42. operating_systems: {
  43. item: 'id'
  44. }
  45. };
  46. },
  47. modelOS: {
  48. id: 'id',
  49. repository_version_id: 'repository_version_id',
  50. os_type: 'OperatingSystems.os_type',
  51. stack_name: 'OperatingSystems.stack_name',
  52. stack_version: 'OperatingSystems.stack_version',
  53. repositories_key: 'repositories',
  54. repositories_type: 'array',
  55. repositories: {
  56. item: 'id'
  57. }
  58. },
  59. modelService: {
  60. id: 'id',
  61. name: 'name',
  62. display_name: 'display_name',
  63. latest_version: 'latest_version'
  64. },
  65. modelRepository: {
  66. id: 'id',
  67. operating_system_id: 'Repositories.operating_system_id',
  68. base_url : 'Repositories.base_url',
  69. default_base_url : 'Repositories.default_base_url',
  70. latest_base_url : 'Repositories.latest_base_url',
  71. mirrors_list : 'Repositories.mirrors_list',
  72. os_type : 'Repositories.os_type',
  73. repo_id : 'Repositories.repo_id',
  74. repo_name : 'Repositories.repo_name',
  75. stack_name : 'Repositories.stack_name',
  76. stack_version : 'Repositories.stack_version'
  77. },
  78. map: function (json, loadAll, isCurrentStackOnly) {
  79. var modelRepoVersions = this.get('modelRepoVersions');
  80. var modelOperatingSystems = this.get('modelOperatingSystems');
  81. var modelRepositories = this.get('modelRepositories');
  82. var modelServices = this.get('modelServices');
  83. var resultRepoVersion = [];
  84. var resultOS = [];
  85. var resultRepo = [];
  86. var resultService = [];
  87. var repoVersionsKey = isCurrentStackOnly ? 'RepositoryVersions' : 'CompatibleRepositoryVersions';
  88. if (json && json.items) {
  89. json.items.forEach(function (item) {
  90. ////////////// to test//////////////
  91. item[repoVersionsKey].type = "PATCH";
  92. item[repoVersionsKey].release = {
  93. "stack_id": "HDP-2.2",
  94. "version": "2.2.4.1",
  95. "build": "885",
  96. "compatible_with": "", /* regex */
  97. "release_notes": "http://someurl"
  98. };
  99. item[repoVersionsKey].services = [
  100. {
  101. "name": "HDFS",
  102. "display_name": "HDFS",
  103. "versions": [
  104. {
  105. "version": "2.1.1",
  106. "version_id": "10",
  107. "components": [ "NAMENODE"]
  108. }
  109. ]
  110. },
  111. {
  112. "name": "YARN",
  113. "display_name": "YARN",
  114. "versions": [
  115. {
  116. "version": "2.7.1.2.3"
  117. }
  118. ]
  119. },
  120. {
  121. "name": "ZOOKEEPER",
  122. "display_name": "ZooKeeper",
  123. "versions": [
  124. {
  125. "version": "3.4.6.2.3"
  126. }
  127. ]
  128. },
  129. {
  130. "name": "wrong",
  131. "display_name": "MapReduce2",
  132. "versions": [
  133. {
  134. "version": "2.7.1.2.3"
  135. }
  136. ]
  137. },
  138. {
  139. "name": "AMBARI_METRICS",
  140. "display_name": "Ambari Metrics",
  141. "versions": [
  142. {
  143. "version": "0.1.0"
  144. }
  145. ]
  146. }
  147. ];
  148. //////////////////////////////
  149. if (loadAll || (item[repoVersionsKey] && !App.StackVersion.find().someProperty('repositoryVersion.id', item[repoVersionsKey].id))) {
  150. var repo = item;
  151. var osArray = [];
  152. var serviceArray = [];
  153. if (item.operating_systems) {
  154. item.operating_systems.forEach(function (os) {
  155. os.id = item[repoVersionsKey].repository_version + os.OperatingSystems.os_type;
  156. os.repository_version_id = repo.id;
  157. var repoArray = [];
  158. if (Em.get(os, 'repositories')) {
  159. os.repositories.forEach(function (repo) {
  160. repo.id = repo.Repositories.repo_id + os.id;
  161. repo.operating_system_id = os.id;
  162. repoArray.pushObject(repo);
  163. resultRepo.push(this.parseIt(repo, this.get('modelRepository')));
  164. }, this);
  165. }
  166. os.repositories = repoArray;
  167. osArray.pushObject(os);
  168. resultOS.push(this.parseIt(os, this.get('modelOS')));
  169. }, this);
  170. }
  171. if (item[repoVersionsKey].services) {
  172. item[repoVersionsKey].services.forEach(function (service) {
  173. var serviceObj = {
  174. id: service.name,
  175. name: service.name,
  176. display_name: service.display_name,
  177. latest_version: service.versions[0] ? service.versions[0].version : ''
  178. };
  179. serviceArray.pushObject(serviceObj);
  180. resultService.push(this.parseIt(serviceObj, this.get('modelService')));
  181. }, this);
  182. }
  183. repo.operating_systems = osArray;
  184. repo.services = serviceArray;
  185. resultRepoVersion.push(this.parseIt(repo, this.modelRepoVersion(isCurrentStackOnly)));
  186. }
  187. }, this);
  188. }
  189. App.store.commit();
  190. App.store.loadMany(modelRepositories, resultRepo);
  191. App.store.loadMany(modelOperatingSystems, resultOS);
  192. App.store.loadMany(modelServices, resultService);
  193. App.store.loadMany(modelRepoVersions, resultRepoVersion);
  194. }
  195. });