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

pulibrary / tigerdata-app / bcfa9906-4aea-4a17-82a6-28399bcb4fc4

25 Nov 2025 09:00PM UTC coverage: 91.366% (+11.7%) from 79.623%
bcfa9906-4aea-4a17-82a6-28399bcb4fc4

Pull #2248

circleci

kelynch
Updated rake task description
Pull Request #2248: Fixed rake task description

2910 of 3185 relevant lines covered (91.37%)

568.34 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)
75✔
16
      @aql_query = aql_query
75✔
17
      @collection = collection
75✔
18
      @action = action
75✔
19
      @deep_search = deep_search
75✔
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"
75✔
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"
150✔
30
    end
31

32
    # Returns the iterator that could be used to fetch the data
33
    def results
4✔
34
      xml = response_xml
74✔
35
      assets = xml.xpath("/response/reply/result/asset")
74✔
36
      assets.map do |asset|
74✔
37
        metadata = asset.xpath("./meta//tigerdata:project", "tigerdata" => "tigerdata")
4,092✔
38
        {
39
          mediaflux_id: asset.xpath("@id").first.value,
4,092✔
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
          project_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|
150✔
55
          xml.args do
150✔
56
            xml.where aql_query if aql_query.present?
150✔
57
            xml.action action if action.present?
150✔
58
            xml.size size if size.present?
150✔
59
          end
60
        end
61
      end
62

63
      def data_users_from_string(users)
4✔
64
        return [] if users.blank?
4,092✔
65
        users.split(",").compact_blank
1,066✔
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