fair-queue.js 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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. import DS from 'ember-data';
  19. export default DS.JSONAPISerializer.extend({
  20. normalizeSingleResponse(store, primaryModelClass, payload, id,
  21. requestType) {
  22. var children = [];
  23. if (payload.childQueues) {
  24. payload.childQueues.queue.forEach(function(queue) {
  25. children.push(queue.queueName);
  26. });
  27. }
  28. var fixedPayload = {
  29. id: id,
  30. type: primaryModelClass.modelName,
  31. attributes: {
  32. name: payload.queueName,
  33. parent: payload.myParent,
  34. children: children,
  35. maxApps: payload.maxApps,
  36. minResources: payload.minResources,
  37. maxResources: payload.maxResources,
  38. usedResources: payload.usedResources,
  39. demandResources: payload.demandResources,
  40. steadyFairResources: payload.steadyFairResources,
  41. fairResources: payload.fairResources,
  42. clusterResources: payload.clusterResources,
  43. pendingContainers: payload.pendingContainers,
  44. allocatedContainers: payload.allocatedContainers,
  45. reservedContainers: payload.reservedContainers,
  46. schedulingPolicy: payload.schedulingPolicy,
  47. preemptable: payload.preemptable,
  48. numPendingApplications: payload.numPendingApps,
  49. numActiveApplications: payload.numActiveApps,
  50. type: "fair",
  51. },
  52. };
  53. return this._super(store, primaryModelClass, fixedPayload, id, requestType);
  54. },
  55. handleQueue(store, primaryModelClass, payload, id, requestType) {
  56. var data = [];
  57. var includedData = [];
  58. if(!payload) return data;
  59. var result = this.normalizeSingleResponse(store, primaryModelClass,
  60. payload, id, requestType);
  61. data.push(result);
  62. if (payload.childQueues) {
  63. for (var i = 0; i < payload.childQueues.queue.length; i++) {
  64. var queue = payload.childQueues.queue[i];
  65. queue.myParent = payload.queueName;
  66. var childResult = this.handleQueue(store, primaryModelClass, queue,
  67. queue.queueName,
  68. requestType);
  69. data = data.concat(childResult);
  70. }
  71. }
  72. return data;
  73. },
  74. normalizeArrayResponse(store, primaryModelClass, payload, id, requestType) {
  75. var normalizedArrayResponse = {};
  76. var result = this.handleQueue(store, primaryModelClass,
  77. payload.scheduler.schedulerInfo.rootQueue, "root", requestType);
  78. normalizedArrayResponse.data = result;
  79. return normalizedArrayResponse;
  80. }
  81. });