repository_version_mapper.js 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  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].release = {
  92. "stack_id": "HDP-2.2",
  93. "version": "2.2.4.1",
  94. "build": "885",
  95. "compatible_with": "", /* regex */
  96. "release_notes": "http://someurl"
  97. };
  98. if (item[repoVersionsKey].id % 2 ) {
  99. item[repoVersionsKey].type = "PATCH";
  100. item[repoVersionsKey].services = [
  101. {
  102. "name": "HDFS",
  103. "display_name": "HDFS",
  104. "versions": [
  105. {
  106. "version": "2.1.1",
  107. "version_id": "10",
  108. "components": [ "NAMENODE"]
  109. }
  110. ]
  111. },
  112. {
  113. "name": "YARN",
  114. "display_name": "YARN",
  115. "versions": [
  116. {
  117. "version": "2.7.1.2.3"
  118. }
  119. ]
  120. },
  121. {
  122. "name": "ZOOKEEPER",
  123. "display_name": "ZooKeeper",
  124. "versions": [
  125. {
  126. "version": "3.4.6.2.3"
  127. }
  128. ]
  129. },
  130. {
  131. "name": "wrong",
  132. "display_name": "MapReduce2",
  133. "versions": [
  134. {
  135. "version": "2.7.1.2.3"
  136. }
  137. ]
  138. },
  139. {
  140. "name": "AMBARI_METRICS",
  141. "display_name": "Ambari Metrics",
  142. "versions": [
  143. {
  144. "version": "0.1.0"
  145. }
  146. ]
  147. }
  148. ];
  149. } else {
  150. item[repoVersionsKey].services = [
  151. {
  152. "name": "HDFS",
  153. "display_name": "HDFS",
  154. "versions": [
  155. {
  156. "version": "2.1.1",
  157. "version_id": "10",
  158. "components": [ "NAMENODE"]
  159. }
  160. ]
  161. },
  162. {
  163. "name": "wrong",
  164. "display_name": "YARN",
  165. "versions": [
  166. {
  167. "version": "2.7.1.2.3"
  168. }
  169. ]
  170. },
  171. {
  172. "name": "wrong",
  173. "display_name": "ZooKeeper",
  174. "versions": [
  175. {
  176. "version": "3.4.6.2.3"
  177. }
  178. ]
  179. },
  180. {
  181. "name": "MAPREDUCE2",
  182. "display_name": "MapReduce2",
  183. "versions": [
  184. {
  185. "version": "2.7.1.2.3"
  186. }
  187. ]
  188. },
  189. {
  190. "name": "AMBARI_METRICS",
  191. "display_name": "Ambari Metrics",
  192. "versions": [
  193. {
  194. "version": "0.1.0"
  195. }
  196. ]
  197. }
  198. ];
  199. }
  200. //////////////////////////////
  201. if (loadAll || (item[repoVersionsKey] && !App.StackVersion.find().someProperty('repositoryVersion.id', item[repoVersionsKey].id))) {
  202. var repo = item;
  203. var osArray = [];
  204. var serviceArray = [];
  205. if (item.operating_systems) {
  206. item.operating_systems.forEach(function (os) {
  207. os.id = item[repoVersionsKey].repository_version + os.OperatingSystems.os_type;
  208. os.repository_version_id = repo.id;
  209. var repoArray = [];
  210. if (Em.get(os, 'repositories')) {
  211. os.repositories.forEach(function (repo) {
  212. repo.id = repo.Repositories.repo_id + os.id;
  213. repo.operating_system_id = os.id;
  214. repoArray.pushObject(repo);
  215. resultRepo.push(this.parseIt(repo, this.get('modelRepository')));
  216. }, this);
  217. }
  218. os.repositories = repoArray;
  219. osArray.pushObject(os);
  220. resultOS.push(this.parseIt(os, this.get('modelOS')));
  221. }, this);
  222. }
  223. if (item[repoVersionsKey].services) {
  224. item[repoVersionsKey].services.forEach(function (service) {
  225. var serviceObj = {
  226. id: service.name,
  227. name: service.name,
  228. display_name: service.display_name,
  229. latest_version: service.versions[0] ? service.versions[0].version : ''
  230. };
  231. serviceArray.pushObject(serviceObj);
  232. resultService.push(this.parseIt(serviceObj, this.get('modelService')));
  233. }, this);
  234. }
  235. repo.operating_systems = osArray;
  236. repo.services = serviceArray;
  237. resultRepoVersion.push(this.parseIt(repo, this.modelRepoVersion(isCurrentStackOnly)));
  238. }
  239. }, this);
  240. }
  241. App.store.commit();
  242. App.store.loadMany(modelRepositories, resultRepo);
  243. App.store.loadMany(modelOperatingSystems, resultOS);
  244. App.store.loadMany(modelServices, resultService);
  245. App.store.loadMany(modelRepoVersions, resultRepoVersion);
  246. }
  247. });