redmine_remotes 0.15.2 → 0.15.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: b73c970478b213277563054f35129ddcc1242da52dfff81eee4d672f9dc04f82
4
- data.tar.gz: '028153033c5e5dbed1dca11f1205a3679f9c1ccafc9ba98c1d9cd456e01db3d6'
3
+ metadata.gz: 67c1e068d64cc326ac7e91e6671c1119e9eba78e7b4f6e94fa24b668087fc8ae
4
+ data.tar.gz: 6fed8dde840f7671c78dd7d407e0246eaf6c87b431dca3d930074597e7ae1842
5
5
  SHA512:
6
- metadata.gz: cca0145c05035eb1ead69f75fefdd33b13fad6e3c5834f260e6165b35b70d0be614401a3b167d31428fcbf6b318e4a9a06d76d23d21fb14f0a6a3ec3740aaac4
7
- data.tar.gz: faf153f23e23b209910f6d852ef1e9ae034833444d89059061c6e3452c3a5370156eb95a66ee49cc5d5c98e1ea94df06721890428653ac101789d2eab4fa6b46
6
+ metadata.gz: e3e6bb227b50856865c4c563c74be4994746d11e8b6248a483e6105e1b34f1957398a744c1309f83b090fef58548bb38fc42956cf76a65e9713f25b99521c23a
7
+ data.tar.gz: d61bd4b29a09a82277a6299999068724fd1b870f1d074e6ddd33f31830ae15e851fe5f94d064e8e74471ce10a1c955f4930b4d9dece81b0f59f300e011a2457e
@@ -19,7 +19,8 @@ class RemoteTracker < ActiveRecord::Base
19
19
  dependent: :destroy
20
20
  has_many :remote_users, class_name: 'RemoteUser', inverse_of: :remote_tracker,
21
21
  dependent: :restrict_with_error
22
- belongs_to :default_local_user, class_name: 'User', inverse_of: :remote_trackers_as_default
22
+ belongs_to :default_local_user, class_name: 'User', inverse_of: :remote_trackers_as_default,
23
+ foreign_key: :default_local_user_id
23
24
 
24
25
  validates :profile, presence: true, inclusion: { in: lists.profile.values }
25
26
  validates :root_url, presence: true, uniqueness: { scope: [:username] }, url: true
@@ -6,7 +6,7 @@ class RemoteUser < ActiveRecord::Base
6
6
  downcase_columns :remote_login
7
7
 
8
8
  belongs_to :remote_tracker, class_name: 'RemoteTracker', inverse_of: :remote_users
9
- belongs_to :local_user, class_name: 'User', inverse_of: :remote_users
9
+ belongs_to :local_user, class_name: 'User', inverse_of: :remote_users, foreign_key: :local_user_id
10
10
 
11
11
  validates :remote_login, presence: true, uniqueness: { scope: [:remote_tracker] }
12
12
  validates :local_user, presence: true
@@ -2,5 +2,5 @@
2
2
 
3
3
  Redmine::Plugin.post_register ::RedmineRemotes::SLUG.to_sym do
4
4
  # Source: https://github.com/esquilo-azul/redmine_nonproject_modules
5
- requires_redmine_plugin(:redmine_nonproject_modules, version_or_higher: '0.3.9')
5
+ requires_redmine_plugin(:redmine_nonproject_modules, version_or_higher: '0.3.11')
6
6
  end
@@ -1,5 +1,9 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ return unless ::RedminePluginsHelper::Available.model?(
4
+ ::RemoteIssue, ::RemoteIssueStatus, ::RemoteUser, ::RemoteTracker, ::RemoteTrackerSetting
5
+ )
6
+
3
7
  ::GroupPermission.add_permission(::RemoteTrackersController::READ_PERMISSION)
4
8
  ::GroupPermission.add_permission(
5
9
  ::RemoteTrackersController::WRITE_PERMISSION,
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class CreateRemoteTrackers < ActiveRecord::Migration
3
+ class CreateRemoteTrackers < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  create_table :remote_trackers do |t| # rubocop:disable Rails/CreateTableWithTimestamps
6
8
  t.string :profile
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class CreateRemoteUsers < ActiveRecord::Migration
3
+ class CreateRemoteUsers < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  create_table :remote_users do |t| # rubocop:disable Rails/CreateTableWithTimestamps
6
8
  t.references :remote_tracker, index: true
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class CreateRemoteIssueStatuses < ActiveRecord::Migration
3
+ class CreateRemoteIssueStatuses < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  create_table :remote_issue_statuses do |t| # rubocop:disable Rails/CreateTableWithTimestamps
6
8
  t.references :remote_tracker, index: true
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class RenameIssueStatusIdToLocalIssueStatusIdInRemoteIssueStatuses < ActiveRecord::Migration
3
+ class RenameIssueStatusIdToLocalIssueStatusIdInRemoteIssueStatuses < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  rename_column :remote_issue_statuses, :issue_status_id, :local_issue_status_id
6
8
  end
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class CreateRemoteIssues < ActiveRecord::Migration
3
+ class CreateRemoteIssues < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  create_table :remote_issues do |t| # rubocop:disable Rails/CreateTableWithTimestamps
6
8
  t.references :remote_tracker, index: true
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddDefaultLocalUserIdToRemoteTrackers < ActiveRecord::Migration
3
+ class AddDefaultLocalUserIdToRemoteTrackers < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  add_reference :remote_trackers, :default_local_user, index: true
6
8
 
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class CreateRemoteTrackerSettings < ActiveRecord::Migration
3
+ class CreateRemoteTrackerSettings < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  create_table :remote_tracker_settings do |t|
6
8
  t.references :remote_tracker, index: true
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddTimestampsToRedmineTrackers < ActiveRecord::Migration
3
+ class AddTimestampsToRedmineTrackers < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  class RemoteTracker < ::ActiveRecord::Base; end
5
7
 
6
8
  def change
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddTimestampsToRemoteIssues < ActiveRecord::Migration
3
+ class AddTimestampsToRemoteIssues < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  class RemoteIssue < ::ActiveRecord::Base; end
5
7
 
6
8
  def change
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddTimestampsToRemoteUsers < ActiveRecord::Migration
3
+ class AddTimestampsToRemoteUsers < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  class RemoteUser < ::ActiveRecord::Base; end
5
7
 
6
8
  def change
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddOutdatedAtToRemoteIssues < ActiveRecord::Migration
3
+ class AddOutdatedAtToRemoteIssues < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  add_column :remote_issues, :outdated_at, :datetime
6
8
  end
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddFetchedAtToRemoteIssues < ActiveRecord::Migration
3
+ class AddFetchedAtToRemoteIssues < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  add_column :remote_issues, :fetched_at, :timestamp
6
8
  end
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddFetchedAtToRemoteTrackers < ActiveRecord::Migration
3
+ class AddFetchedAtToRemoteTrackers < (
4
+ ::Rails.version < '5.1' ? ::ActiveRecord::Migration : ::ActiveRecord::Migration[4.2]
5
+ )
4
6
  def change
5
7
  add_column :remote_trackers, :fetched_at, :datetime
6
8
  end
@@ -6,11 +6,16 @@ module RedmineRemotes
6
6
  module Esosti
7
7
  module Entities
8
8
  class Issue < ::Avmtrf1::Esosti::Entities::Issue
9
+ DEFAULT_TYPE_FOR_URL_PREFIX = '_unmapped_'
9
10
  EXTRA_DESCRIPTION_BEFORE = { reported_by: 'Relatado por', affected_person: 'Pessoa afetada',
10
11
  type_description: 'Tipo de solicitação' }.freeze
12
+ TYPES_FOR_URL = {
13
+ 'INCIDENTE' => 'ms_incident',
14
+ 'SS' => 'ms_sr'
15
+ }.freeze
11
16
 
12
17
  def human_view_url
13
- instance.issue_human_view_url(uid)
18
+ instance.issue_human_view_url(type_for_url, uid)
14
19
  end
15
20
 
16
21
  def author_login
@@ -63,6 +68,14 @@ module RedmineRemotes
63
68
  description.gsub(/\s+/, ' ')
64
69
  end
65
70
 
71
+ def type_for_url
72
+ TYPES_FOR_URL[type_class] || "#{DEFAULT_TYPE_FOR_URL_PREFIX}#{type_class}"
73
+ end
74
+
75
+ def type_class
76
+ attributes.fetch('CLASS')
77
+ end
78
+
66
79
  def type_description
67
80
  attributes.fetch('DESCRIPTION')
68
81
  end
@@ -17,8 +17,8 @@ module RedmineRemotes
17
17
  end
18
18
  end
19
19
 
20
- def issue_human_view_url(ticket_uid)
21
- "#{root_url}/itsm/ui/?event=loadapp&value=ms_sr&uniqueid=#{ticket_uid}"
20
+ def issue_human_view_url(ticket_type, ticket_uid)
21
+ "#{root_url}/itsm/ui/?event=loadapp&value=#{ticket_type}&uniqueid=#{ticket_uid}"
22
22
  end
23
23
 
24
24
  def fetch_issues_changed(start_time, _end_time)
@@ -7,10 +7,10 @@ module EacRedmineUsability
7
7
 
8
8
  included do
9
9
  has_many :remote_users, class_name: 'RemoteUser', inverse_of: :local_user,
10
- dependent: :destroy
10
+ dependent: :destroy, foreign_key: :local_user_id
11
11
  has_many :remote_trackers_as_default,
12
12
  class_name: 'RemoteTracker', inverse_of: :default_local_user,
13
- dependent: :restrict_with_error
13
+ dependent: :restrict_with_error, foreign_key: :default_local_user_id
14
14
  end
15
15
  end
16
16
  end
@@ -3,7 +3,7 @@
3
3
  module RedmineRemotes
4
4
  SLUG = 'redmine_remotes'
5
5
  NAME = 'Redmine Remotes'
6
- VERSION = '0.15.2'
6
+ VERSION = '0.15.5'
7
7
  AUTHOR = 'Eduardo Henrique Bogoni'
8
8
  SUMMARY = 'Integração do Redmine com trackers diversos.'
9
9
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: redmine_remotes
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.15.2
4
+ version: 0.15.5
5
5
  platform: ruby
6
6
  authors:
7
7
  - Eduardo Henrique Bogoni
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-06-29 00:00:00.000000000 Z
11
+ date: 2022-07-12 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: aranha-parsers