redmine_remotes 0.15.2 → 0.15.5

Sign up to get free protection for your applications and to get access to all the features.
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