• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

pulibrary / tigerdata-app / 8ae424c0-a413-4a0e-be61-cbcf50354201

04 Nov 2025 08:59PM UTC coverage: 91.37% (-0.03%) from 91.403%
8ae424c0-a413-4a0e-be61-cbcf50354201

Pull #2144

circleci

leefaisonr
revert coverage reporter version for circleci
Pull Request #2144: upgrade mflux_dev to v0.18.0

2827 of 3094 relevant lines covered (91.37%)

485.7 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

100.0
/app/models/mediaflux/project_list_request.rb
1
# frozen_string_literal: true
2
module Mediaflux
4✔
3
  class ProjectListRequest < Request
4✔
4
    attr_reader :aql_query, :collection, :action, :deep_search, :iterator, :size
4✔
5

6
    # Constructor
7
    # @param session_token [String] the API token for the authenticated session
8
    # @param aql_query [String] Optional AQL query string
9
    # @param collection [Integer] Optional collection id
10
    # @param action [String] Optional, by default it uses get-name but it could also be get-meta to get all
11
    #                        the fields for the assets or `get-values` to get a limited list of fields.
12
    # @param deep_search [Bool] Optional, false by default. When true queries the collection and it subcollections.
13
    # @param iterator [Bool] Optional, true by default. When true returns an iterator.  When false returns a list of results
14
    def initialize(session_token:, aql_query: nil, action: "get-meta", deep_search: true)
4✔
15
      super(session_token: session_token)
72✔
16
      @aql_query = aql_query
72✔
17
      @collection = collection
72✔
18
      @action = action
72✔
19
      @deep_search = deep_search
72✔
20
      # For now we hard-code the size to infinity since only Administrators will fetch a large
21
      # number of projects and they should get them all. At some point in the future we might
22
      # want to implement pagination for this list but not now..
23
      @size = "infinity"
72✔
24
    end
25

26
    # Specifies the Mediaflux service to use when running a query
27
    # @return [String]
28
    def self.service
4✔
29
      "asset.query"
144✔
30
    end
31

32
    # Returns the iterator that could be used to fetch the data
33
    def results
4✔
34
      xml = response_xml
72✔
35
      assets = xml.xpath("/response/reply/result/asset")
72✔
36
      assets.map do |asset|
72✔
37
        metadata = asset.xpath("./meta//tigerdata:project", "tigerdata" => "tigerdata")
2,470✔
38
        {
39
          mediaflux_id: asset.xpath("@id").first.value,
2,470✔
40
          title: metadata.xpath("./Title").text,
41
          description: metadata.xpath("./Description").text,
42
          project_purpose: metadata.xpath("./ProjectPurpose").text,
43
          data_sponsor: metadata.xpath("./DataSponsor").text,
44
          data_manager: metadata.xpath("./DataManager").text,
45
          data_users: data_users_from_string(metadata.xpath("./DataUser").text),
46
          directory: metadata.xpath("./ProjectDirectory").text
47
        }
48
      end
49
    end
50

51
    private
4✔
52

53
      def build_http_request_body(name:)
4✔
54
        super do |xml|
144✔
55
          xml.args do
144✔
56
            xml.where aql_query if aql_query.present?
144✔
57
            xml.action action if action.present?
144✔
58
            xml.size size if size.present?
144✔
59
          end
60
        end
61
      end
62

63
      def data_users_from_string(users)
4✔
64
        return [] if users.blank?
2,470✔
65
        users.split(",")
645✔
66
      end
67
  end
68
end
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc