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

pulibrary / tigerdata-app / 93cce249-3dee-4f64-bd68-4e50b5cbf48e

21 Oct 2025 09:49PM UTC coverage: 82.779% (+1.5%) from 81.319%
93cce249-3dee-4f64-bd68-4e50b5cbf48e

push

circleci

web-flow
Stop mediaflux when we stop everything else (#2066)

Ref #2065

2490 of 3008 relevant lines covered (82.78%)

226.2 hits per line

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

89.66
/app/models/mediaflux/project_user_add_request.rb
1
# frozen_string_literal: true
2
module Mediaflux
1✔
3
  class ProjectUserAddRequest < Request
1✔
4
    attr_reader :project, :project_metadata
1✔
5

6
    # Constructor
7
    # @param session_token [String] the API token for the authenticated session
8
    # @param project [Project] project to be created in Mediaflux
9
    def initialize(session_token:, project:)
1✔
10
      super(session_token: session_token)
2✔
11
      @project = project
2✔
12
      @id = @project.mediaflux_id
2✔
13
      @xml_namespace = self.class.default_xml_namespace
2✔
14
      @xml_namespace_uri = self.class.default_xml_namespace_uri
2✔
15

16
      @all_data_users = @project.metadata_model.ro_users + @project.metadata_model.rw_users
2✔
17
      @ro_users = @project.metadata_model.ro_users
2✔
18
      @rw_users = @project.metadata_model.rw_users
2✔
19
    end
20

21
    # Specifies the Mediaflux service to use when updating assets
22
    # @return [String]
23
    def self.service
1✔
24
      "tigerdata.project.user.add"
4✔
25
    end
26

27
    # Returns the entire response returned by the project create service.
28
    # This includes debug information that is useful to troubleshoot issues
29
    # if the request fails.
30
    def debug_output
1✔
31
      response_xml.xpath("response/reply/result/result").to_s
2✔
32
    end
33

34
    private
1✔
35

36
      # rubocop:disable Metrics/MethodLength
37
      # rubocop:disable Metrics/AbcSize
38
      # rubocop:disable Metrics/BlockLength
39
      #
40
      # This is what the call would look like from aterm:
41
      # tigerdata.project.user.add \
42
      #   :id 1234 \
43
      #   :data-user "md1908" \
44
      #
45
      # OR FOR MULTIPLE USERS:
46
      # tigerdata.project.user.add \
47
      #   :id 1234 \
48
      #   :data-user "md1908" \
49
      #   :data-user "md1909" \
50
      #   :data-user "md1910" \
51
      #
52
      def build_http_request_body(name:)
1✔
53
        super do |xml|
4✔
54
          xml.args do
4✔
55
            xml.id @id
4✔
56
            # send each user in the list
57
            @ro_users.each do |user|
4✔
58
              xml.send("data-user") do
4✔
59
                xml.parent.set_attribute("readonly", "true")
4✔
60
                xml.text(user)
4✔
61
              end
62
            end
63
            @rw_users.each do |user|
4✔
64
              xml.send("data-user") do
×
65
                xml.parent.set_attribute("readonly", "false")
×
66
                xml.text(user)
×
67
              end
68
            end
69
          end
70
        end
71
      end
72
    # rubocop:enable Metrics/AbcSize
73
    # rubocop:enable Metrics/MethodLength
74
    # rubocop:enable Metrics/BlockLength
75
  end
76
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