queryservice_helper.go 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. package customcost
  2. import (
  3. "fmt"
  4. "github.com/opencost/opencost/core/pkg/filter"
  5. "github.com/opencost/opencost/core/pkg/opencost"
  6. "github.com/opencost/opencost/core/pkg/util/httputil"
  7. )
  8. func ParseCustomCostTotalRequest(qp httputil.QueryParams) (*CostTotalRequest, error) {
  9. windowStr := qp.Get("window", "")
  10. if windowStr == "" {
  11. return nil, fmt.Errorf("missing require window param")
  12. }
  13. window, err := opencost.ParseWindowUTC(windowStr)
  14. if err != nil {
  15. return nil, fmt.Errorf("invalid window parameter: %w", err)
  16. }
  17. if window.IsOpen() {
  18. return nil, fmt.Errorf("invalid window parameter: %s", window.String())
  19. }
  20. aggregateByRaw := qp.GetList("aggregate", ",")
  21. aggregateBy, err := ParseCustomCostProperties(aggregateByRaw)
  22. if err != nil {
  23. return nil, err
  24. }
  25. var filter filter.Filter
  26. //filterString := qp.Get("filter", "")
  27. //if filterString != "" {
  28. // parser := cloudcost.NewCloudCostFilterParser()
  29. // filter, err = parser.Parse(filterString)
  30. // if err != nil {
  31. // return nil, fmt.Errorf("parsing 'filter' parameter: %s", err)
  32. // }
  33. //}
  34. opts := &CostTotalRequest{
  35. Start: *window.Start(),
  36. End: *window.End(),
  37. AggregateBy: aggregateBy,
  38. Filter: filter,
  39. }
  40. return opts, nil
  41. }
  42. func ParseCustomCostTimeseriesRequest(qp httputil.QueryParams) (*CostTimeseriesRequest, error) {
  43. windowStr := qp.Get("window", "")
  44. if windowStr == "" {
  45. return nil, fmt.Errorf("missing require window param")
  46. }
  47. window, err := opencost.ParseWindowUTC(windowStr)
  48. if err != nil {
  49. return nil, fmt.Errorf("invalid window parameter: %w", err)
  50. }
  51. if window.IsOpen() {
  52. return nil, fmt.Errorf("invalid window parameter: %s", window.String())
  53. }
  54. aggregateByRaw := qp.GetList("aggregate", ",")
  55. aggregateBy, err := ParseCustomCostProperties(aggregateByRaw)
  56. if err != nil {
  57. return nil, err
  58. }
  59. accumulate := opencost.ParseAccumulate(qp.Get("accumulate", ""))
  60. var filter filter.Filter
  61. //filterString := qp.Get("filter", "")
  62. //if filterString != "" {
  63. // parser := cloudcost.NewCloudCostFilterParser()
  64. // filter, err = parser.Parse(filterString)
  65. // if err != nil {
  66. // return nil, fmt.Errorf("parsing 'filter' parameter: %s", err)
  67. // }
  68. //}
  69. opts := &CostTimeseriesRequest{
  70. Start: *window.Start(),
  71. End: *window.End(),
  72. AggregateBy: aggregateBy,
  73. Accumulate: accumulate,
  74. Filter: filter,
  75. }
  76. return opts, nil
  77. }