mno-enterprise-core 3.3.1 → 3.3.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (27) hide show
  1. checksums.yaml +4 -4
  2. data/app/helpers/mno_enterprise/image_helper.rb +4 -0
  3. data/app/models/mno_enterprise/impac/dashboard.rb +22 -4
  4. data/app/models/mno_enterprise/impac/widget.rb +1 -1
  5. data/app/pdf/mno_enterprise/invoice_pdf.rb +7 -5
  6. data/app/views/system_notifications/confirmation-instructions.html.erb +1 -1
  7. data/app/views/system_notifications/delete-request-instructions.html.erb +1 -1
  8. data/app/views/system_notifications/email-change.html.erb +1 -1
  9. data/app/views/system_notifications/organization-invite-existing-user.html.erb +1 -1
  10. data/app/views/system_notifications/organization-invite-new-user.html.erb +1 -1
  11. data/app/views/system_notifications/password-change.html.erb +1 -1
  12. data/app/views/system_notifications/reconfirmation-instructions.html.erb +1 -1
  13. data/app/views/system_notifications/registration-instructions.html.erb +1 -1
  14. data/app/views/system_notifications/reset-password-instructions.html.erb +1 -1
  15. data/app/views/system_notifications/unlock-instructions.html.erb +1 -1
  16. data/config/locales/templates/dashboard/marketplace/en.yml +1 -0
  17. data/config/locales/templates/dashboard/organization/en.yml +4 -1
  18. data/lib/generators/mno_enterprise/install/templates/config/settings.yml +4 -0
  19. data/lib/mno_enterprise/concerns/controllers/auth/confirmations_controller.rb +3 -0
  20. data/lib/mno_enterprise/concerns/controllers/auth/registrations_controller.rb +7 -1
  21. data/lib/mno_enterprise/concerns/models/ability.rb +1 -1
  22. data/lib/mno_enterprise/smtp_client.rb +2 -0
  23. data/lib/mno_enterprise/testing_support/factories/users.rb +1 -0
  24. data/lib/mno_enterprise/version.rb +1 -1
  25. data/spec/helpers/image_helper_spec.rb +26 -19
  26. data/spec/models/mno_enterprise/impac/dashboard_spec.rb +17 -5
  27. metadata +2 -2
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: b36015e6f83cd3b2b8568c374127f08851e3fa19
4
- data.tar.gz: 3bc67afb284d6876665d4ee2c8fb9e0f71488a6b
3
+ metadata.gz: f917a6e753baa8624dce8b43b2bcb11fbcf2181e
4
+ data.tar.gz: 65f316eaa0ffdc58c30b77fa277c5ab7a719b736
5
5
  SHA512:
6
- metadata.gz: bad44bd8652ccd321ecf95edd1db48d9dc8c465d213a0ab184f866320a0c12ae295aafbcdcc4de982612a13c3702a1f0e411d399faee0e2ba9d586c87f7c0b09
7
- data.tar.gz: 317554cdc777ab9f5fac31da149caf1f0d8aea70bf0cabaf197f94e06d07faef1a63e996a1246373304582de44855996aad0496c430463504fe782a53ea74c9a
6
+ metadata.gz: 3b7d6482aab8df033971214542cd4812f207c57d428d62501a20c2bffc529bb5b99d6a1ebc566e1ca7737e5bda6ba05b72d1530cb4b09dfdc55addb077613168
7
+ data.tar.gz: 73a4607b1a631b6654fd83193880abce436ed050800d165497059ef5c32a3ef66fc5a9c71c923582be1685e83ab69a2777f99c354bcf831a2ddd48f0ab543c3e
@@ -28,5 +28,9 @@ module MnoEnterprise
28
28
  def engine_image_path(file_name)
29
29
  "#{MnoEnterprise::Engine.root}#{IMAGES_LOCATION}#{file_name}"
30
30
  end
31
+
32
+ def fit_image
33
+ 'max-width: 150px; max-height: 150px;'
34
+ end
31
35
  end
32
36
  end
@@ -1,11 +1,16 @@
1
1
  module MnoEnterprise
2
2
  class Impac::Dashboard < BaseResource
3
3
 
4
- attributes :full_name, :widgets_order, :settings, :organization_ids, :widgets_templates, :currency
4
+ attributes :full_name, :widgets_order, :settings, :organization_ids, :widgets_templates, :currency, :published, :dashboard_type
5
5
 
6
6
  has_many :widgets, class_name: 'MnoEnterprise::Impac::Widget'
7
7
  has_many :kpis, class_name: 'MnoEnterprise::Impac::Kpi'
8
8
  belongs_to :owner, polymorphic: true
9
+ default_scope -> { where(dashboard_type: 'dashboard') }
10
+ scope :templates, -> { where(dashboard_type: 'template') }
11
+ scope :published_templates, -> { where(dashboard_type: 'template', published: true) }
12
+
13
+ custom_post :copy
9
14
 
10
15
  #============================================
11
16
  # Instance methods
@@ -16,10 +21,11 @@ module MnoEnterprise
16
21
  self.name
17
22
  end
18
23
 
19
- # Return all the organizations linked to this dashboard and to which
20
- # the user has access
24
+ # Return all the organizations linked to this dashboard and to which the user has access
25
+ # If the dashboard is a template, return all the current user's organization
21
26
  def organizations(org_list = nil)
22
27
  if org_list
28
+ return org_list if dashboard_type == 'template'
23
29
  org_list.to_a.select { |e| self.organization_ids.include?(e.uid) }
24
30
  else
25
31
  MnoEnterprise::Organization.where('uid.in' => self.organization_ids).to_a
@@ -40,8 +46,20 @@ module MnoEnterprise
40
46
  def to_audit_event
41
47
  {
42
48
  name: name,
43
- organization_id: (owner_type == 'MnoEnterprise::Organization') ? owner_id : nil
49
+ organization_id: (owner_type == 'Organization') ? owner_id : nil
50
+ }
51
+ end
52
+
53
+ def copy(owner, name, organization_ids)
54
+ owner_type = owner.class.name.demodulize
55
+ attrs = {
56
+ id: self.id,
57
+ name: name,
58
+ organization_ids: organization_ids,
59
+ owner_type: owner_type,
60
+ owner_id: owner.id
44
61
  }
62
+ self.class.copy(attrs)
45
63
  end
46
64
  end
47
65
  end
@@ -9,7 +9,7 @@ module MnoEnterprise
9
9
 
10
10
  def to_audit_event
11
11
 
12
- if settings['organization_ids'].any?
12
+ if settings.present? && settings['organization_ids'].present?
13
13
  organization = MnoEnterprise::Organization.find_by(uid: settings['organization_ids'].first)
14
14
  { name: name, organization_id: organization.id }
15
15
  else
@@ -128,7 +128,7 @@ module MnoEnterprise
128
128
  @pdf.repeat :all do
129
129
  @pdf.bounding_box([0, @pdf.bounds.top+@format[:header_size]], width: 540, height: @format[:footer_size]) do
130
130
  @pdf.float do
131
- @pdf.image main_logo_white_bg_path(true), scale: 0.5
131
+ @pdf.image main_logo_white_bg_path(true), fit: [135, (@format[:footer_size])]
132
132
  end
133
133
  @pdf.move_down 52
134
134
  @pdf.font_size(20) { @pdf.text "#{title} #{@data[:period_month]}", style: :bold, align: :right }
@@ -145,9 +145,10 @@ module MnoEnterprise
145
145
  @pdf.stroke_horizontal_rule
146
146
  @pdf.move_down 10
147
147
  @pdf.font_size(8) do
148
- @pdf.text "<color rgb='999999'>Maestrano is a service of Maestrano Pty Ltd (ABN: 80 152 564 424),</color>", inline_format: true
149
- @pdf.text "<color rgb='999999'>Suite 504, 46 Market Street, Sydney, NSW 2000, Australia.</color>", inline_format: true
150
- @pdf.text "<color rgb='999999'>All charges are in #{@data[:invoice_currency_name]} (#{@data[:invoice_currency]}).</color>", inline_format: true
148
+ @pdf.text "<color rgb='999999'>This invoice has been generated by Maestrano Pty Ltd on behalf of the #{MnoEnterprise.app_name} platform (the \"Service\").</color>", inline_format: true
149
+ @pdf.text "<color rgb='999999'>All charges in this invoice are in #{@data[:invoice_currency_name]} (#{@data[:invoice_currency]}). Credit card payments will be processed by Maestrano Pty Ltd.</color>", inline_format: true
150
+ @pdf.text " ", inline_format: true
151
+ @pdf.text "<color rgb='999999'>Maestrano Pty Ltd | Suite 504, 46 Market Street, Sydney, NSW 2000, Australia | ABN: 80 152 564 424</color>", inline_format: true
151
152
  end
152
153
  end
153
154
  end
@@ -246,11 +247,12 @@ module MnoEnterprise
246
247
  @pdf.move_down 10
247
248
  @pdf.indent(5) do
248
249
  @pdf.font_size(8) do
250
+ @pdf.text "<color rgb='999999'> This charge will appear as INV #{@data[:invoice_reference]} on your bank statement.</color>", inline_format: true
249
251
  @pdf.text "<color rgb='999999'> Charges are all displayed in #{@data[:invoice_currency_name]} (#{@data[:invoice_currency]})</color>", inline_format: true
250
252
  if @data[:invoice_fully_paid]
251
253
  @pdf.text "<color rgb='999999'> No credit card payments required for this invoice</color>", inline_format: true
252
254
  else
253
- @pdf.text "<color rgb='999999'> Your designated credit card will be charged on #{@data[:period_charge_date].strftime("%B,%e %Y")} at midnight UTC</color>", inline_format: true
255
+ @pdf.text "<color rgb='999999'> Your designated credit card will be charged on #{@data[:period_charge_date].strftime("%B,%e %Y")} at midnight UTC by Maestrano Pty Ltd as service provider to the #{MnoEnterprise.app_name} platform.</color>", inline_format: true
254
256
  end
255
257
  end
256
258
  end
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi <%= @info[:first_name] %></p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi <%= @info[:first_name] %></p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi <%= @info[:first_name] %></p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi there,</p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi there,</p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi <%= @info[:first_name] %></p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi <%= @info[:first_name] %></p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi there,</p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi <%= @info[:first_name] %></p>
@@ -6,7 +6,7 @@
6
6
  </head>
7
7
  <body>
8
8
  <p class="header">
9
- <%= image_tag('mno_enterprise/main-logo.png') %>
9
+ <%= image_tag(main_logo_white_bg_path, style: fit_image) %>
10
10
  </p>
11
11
 
12
12
  <p>Hi <%= @info[:first_name] %></p>
@@ -122,3 +122,4 @@ en:
122
122
  companies_number: "Number of companies using the application"
123
123
  pricing: "Pricing"
124
124
  pricing_not_available: "pricing information not available"
125
+ no_review: "Rating not yet available"
@@ -94,12 +94,15 @@ en:
94
94
  cancel: Cancel
95
95
  next: Next
96
96
  invite: Invite
97
+ roles_info:
98
+ member: "A <b>Member</b> can see other members and access the company apps"
99
+ admin: "An <b>Admin</b> can manage other members (except Super Admin users) and manage the company apps"
100
+ super_admin: "A <b>Super Admin</b> has all power within the company including access to billing management"
97
101
  edition_modal:
98
102
  cancel: Cancel
99
103
  change: Change
100
104
  roles:
101
105
  member: A member can see other members and access the company apps
102
- power_user: A Power User can see other members and start idle company apps (on per hour plan)
103
106
  admin: An Admin can manage other members (except Super Admin users) and manage the company apps
104
107
  super_admin: A Super Admin has all power within the company including access to billing management
105
108
  removal_modal:
@@ -71,6 +71,10 @@ admin_panel:
71
71
  enabled: true
72
72
  finance:
73
73
  enabled: true
74
+ # Ability to enable Intercom on the admin panel
75
+ # Intercom needs to be properly setup for the dashboard
76
+ intercom:
77
+ enabled: false
74
78
  impersonation:
75
79
  disabled: false
76
80
  staff:
@@ -92,6 +92,9 @@ module MnoEnterprise::Concerns::Controllers::Auth::ConfirmationsController
92
92
  end
93
93
 
94
94
  if resource.errors.empty?
95
+ if params[:tos] == "accept"
96
+ params[:user][:meta_data] = resource.meta_data.merge(tos_accepted_at: Time.current)
97
+ end
95
98
  resource.assign_attributes(params[:user]) unless resource.confirmed?
96
99
  resource.perform_confirmation(@confirmation_token)
97
100
  resource.save
@@ -20,7 +20,8 @@ module MnoEnterprise::Concerns::Controllers::Auth::RegistrationsController
20
20
  :surname,
21
21
  :company,
22
22
  :phone,
23
- :phone_country_code
23
+ :phone_country_code,
24
+ {meta_data: [:tos_accepted_at]}
24
25
  )}
25
26
  end
26
27
  end
@@ -44,6 +45,11 @@ module MnoEnterprise::Concerns::Controllers::Auth::RegistrationsController
44
45
 
45
46
  # POST /resource
46
47
  def create
48
+ # Filling the time at which TOS were accepted
49
+ if params[:tos]
50
+ params[:user][:meta_data] = {tos_accepted_at: Time.current}
51
+ end
52
+
47
53
  build_resource(sign_up_params)
48
54
  resource.password ||= Devise.friendly_token
49
55
 
@@ -144,7 +144,7 @@ module MnoEnterprise::Concerns::Models::Ability
144
144
 
145
145
  # Abilities for admin user
146
146
  def admin_abilities(user)
147
- if user.admin_role.to_s.casecmp('admin').zero?
147
+ if user.admin_role.to_s.casecmp('admin').zero? || user.admin_role.to_s.casecmp('staff').zero?
148
148
  can :manage_app_instances, MnoEnterprise::Organization
149
149
  end
150
150
  end
@@ -3,6 +3,8 @@ require 'action_mailer/railtie'
3
3
  module MnoEnterprise
4
4
  # Base class (instantiable) for SMTP adapter
5
5
  class SmtpClient < ActionMailer::Base
6
+ helper MnoEnterprise::ImageHelper
7
+
6
8
  # Send SMTP template - terminal mailing part
7
9
  def deliver(template, from, to, vars={}, opts={})
8
10
  @info = vars
@@ -21,6 +21,7 @@ FactoryGirl.define do
21
21
  updated_at 2.days.ago
22
22
  sso_session "1fdd5sf5a73D7sd1as2a4sd541"
23
23
  admin_role nil
24
+ meta_data Hash[]
24
25
 
25
26
  confirmation_sent_at 2.days.ago
26
27
  confirmation_token "wky763pGjtzWR7dP44PD"
@@ -1,3 +1,3 @@
1
1
  module MnoEnterprise
2
- VERSION = '3.3.1'
2
+ VERSION = '3.3.2'
3
3
  end
@@ -3,67 +3,74 @@ require 'rails_helper'
3
3
  module MnoEnterprise
4
4
  describe ImageHelper do
5
5
 
6
- let(:folder) { "/app/assets/images/mno_enterprise" }
6
+ let(:folder) { '/app/assets/images/mno_enterprise' }
7
7
  let(:root) {"#{Rails.root}#{folder}"}
8
8
  let(:path_engine_main_logo) { "#{MnoEnterprise::Engine.root}#{folder}/main-logo.png" }
9
9
  let(:path_main_logo) { "#{root}/main-logo.png" }
10
10
  let(:path_main_logo_white) { "#{root}/main-logo-whitebg.png" }
11
11
 
12
- describe "#main_logo_white_bg_path" do
12
+ describe '#main_logo_white_bg_path' do
13
13
 
14
- context "when no logos exist" do
14
+ context 'when no logos exist' do
15
15
 
16
- it "returns the engine main-logo filename" do
17
- expect(helper.main_logo_white_bg_path).to match("mno_enterprise/main-logo.png")
16
+ it 'returns the engine main-logo filename' do
17
+ expect(helper.main_logo_white_bg_path).to match('mno_enterprise/main-logo.png')
18
18
  end
19
19
 
20
- it "returns the engine main-logo full path" do
20
+ it 'returns the engine main-logo full path' do
21
21
  expect(helper.main_logo_white_bg_path(true)).to match(path_engine_main_logo)
22
22
  end
23
23
  end
24
24
 
25
- context "when main-logo.png exists and main-logo-whitebg.png do not exist" do
25
+ context 'when main-logo.png exists and main-logo-whitebg.png do not exist' do
26
26
  before { allow(File).to receive(:exists?).with(path_main_logo_white).and_return(false) }
27
27
  before { allow(File).to receive(:exists?).with(path_main_logo).and_return(true) }
28
28
 
29
- it "returns the main-logo filename" do
30
- expect(helper.main_logo_white_bg_path).to match("mno_enterprise/main-logo.png")
29
+ it 'returns the main-logo filename' do
30
+ expect(helper.main_logo_white_bg_path).to match('mno_enterprise/main-logo.png')
31
31
  end
32
32
 
33
- it "returns the main-logo full path" do
33
+ it 'returns the main-logo full path' do
34
34
  expect(helper.main_logo_white_bg_path(true)).to match(path_main_logo)
35
35
  end
36
36
  end
37
37
 
38
- context "when main-logo-whitebg.png exists" do
38
+ context 'when main-logo-whitebg.png exists' do
39
39
  before { allow(File).to receive(:exists?).with(path_main_logo_white).and_return(true) }
40
40
 
41
- it "returns the filename" do
42
- expect(helper.main_logo_white_bg_path).to match("mno_enterprise/main-logo-whitebg.png")
41
+ it 'returns the filename' do
42
+ expect(helper.main_logo_white_bg_path).to match('mno_enterprise/main-logo-whitebg.png')
43
43
  end
44
44
 
45
- it "returns the full path" do
45
+ it 'returns the full path' do
46
46
  expect(helper.main_logo_white_bg_path(true)).to match(path_main_logo_white)
47
47
  end
48
48
  end
49
49
  end
50
50
 
51
- describe "#main_logo_path" do
51
+ describe '#main_logo_path' do
52
52
 
53
- context "when there are no logos" do
53
+ context 'when there are no logos' do
54
54
 
55
- it "returns the engines main-logo " do
55
+ it 'returns the engines main-logo' do
56
56
  expect(helper.main_logo_path).to match(path_engine_main_logo)
57
57
  end
58
58
  end
59
59
 
60
- context "when main-logo.png exists" do
60
+ context 'when main-logo.png exists' do
61
61
  before { allow(File).to receive(:exists?).with(path_main_logo).and_return(true) }
62
62
 
63
- it "returns the full path" do
63
+ it 'returns the full path' do
64
64
  expect(helper.main_logo_path).to match(path_main_logo)
65
65
  end
66
66
  end
67
67
  end
68
+
69
+ describe '#fit_image' do
70
+
71
+ it 'returns the style' do
72
+ expect(helper.fit_image).to match('max-width: 150px; max-height: 150px;')
73
+ end
74
+ end
68
75
  end
69
76
  end
@@ -2,17 +2,14 @@ require 'rails_helper'
2
2
 
3
3
  module MnoEnterprise
4
4
  RSpec.describe Impac::Dashboard, type: :model do
5
- subject(:dashboard) { build(:impac_dashboard) }
5
+ let(:org1) { build(:organization) }
6
+ subject(:dashboard) { build(:impac_dashboard, organization_ids: [org1.uid]) }
6
7
 
7
8
  describe '#full_name' do
8
9
  subject { dashboard.full_name }
9
10
  it { is_expected.to eq(dashboard.name) }
10
11
  end
11
12
 
12
- describe '#sorted_widgets' do
13
- it 'is pending'
14
- end
15
-
16
13
  describe '#filtered_widgets_templates' do
17
14
  let(:templates) {
18
15
  [
@@ -42,5 +39,20 @@ module MnoEnterprise
42
39
  end
43
40
  end
44
41
  end
42
+
43
+ describe '#organizations(orgs_list)' do
44
+ subject { dashboard.organizations(orgs_list) }
45
+
46
+ let(:org2) { build(:organization) }
47
+ let(:orgs_list) { [org1, org2] }
48
+
49
+ it { is_expected.to eq([org1]) }
50
+
51
+ context 'when the dashboard is a template' do
52
+ let(:dashboard) { build(:impac_dashboard, organization_ids: [org1.uid], dashboard_type: 'template') }
53
+
54
+ it { is_expected.to eq([org1, org2]) }
55
+ end
56
+ end
45
57
  end
46
58
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: mno-enterprise-core
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.3.1
4
+ version: 3.3.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Arnaud Lachaume
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2017-07-24 00:00:00.000000000 Z
12
+ date: 2017-11-09 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: rails