Revision 1297:0a574315af3e .svn/pristine/80

View differences:

.svn/pristine/80/802de8028b84ebe07ae260e0526782b40e01a36e.svn-base
1
<h2><%= l(:label_board) %></h2>
2

  
3
<%= labelled_form_for @board, :url => project_board_path(@project, @board) do |f| %>
4
  <%= render :partial => 'form', :locals => {:f => f} %>
5
  <%= submit_tag l(:button_save) %>
6
<% end %>
.svn/pristine/80/804fabd59700e32f703fdceb063185c9ec0bc16d.svn-base
1
# Redmine - project management software
2
# Copyright (C) 2006-2012  Jean-Philippe Lang
3
#
4
# This program is free software; you can redistribute it and/or
5
# modify it under the terms of the GNU General Public License
6
# as published by the Free Software Foundation; either version 2
7
# of the License, or (at your option) any later version.
8
#
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
#
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17

  
18
namespace :redmine do
19
  namespace :email do
20

  
21
    desc <<-END_DESC
22
Read an email from standard input.
23

  
24
General options:
25
  unknown_user=ACTION      how to handle emails from an unknown user
26
                           ACTION can be one of the following values:
27
                           ignore: email is ignored (default)
28
                           accept: accept as anonymous user
29
                           create: create a user account
30
  no_permission_check=1    disable permission checking when receiving
31
                           the email
32

  
33
Issue attributes control options:
34
  project=PROJECT          identifier of the target project
35
  status=STATUS            name of the target status
36
  tracker=TRACKER          name of the target tracker
37
  category=CATEGORY        name of the target category
38
  priority=PRIORITY        name of the target priority
39
  allow_override=ATTRS     allow email content to override attributes
40
                           specified by previous options
41
                           ATTRS is a comma separated list of attributes
42

  
43
Examples:
44
  # No project specified. Emails MUST contain the 'Project' keyword:
45
  rake redmine:email:read RAILS_ENV="production" < raw_email
46

  
47
  # Fixed project and default tracker specified, but emails can override
48
  # both tracker and priority attributes:
49
  rake redmine:email:read RAILS_ENV="production" \\
50
                  project=foo \\
51
                  tracker=bug \\
52
                  allow_override=tracker,priority < raw_email
53
END_DESC
54

  
55
    task :read => :environment do
56
      options = { :issue => {} }
57
      %w(project status tracker category priority).each { |a| options[:issue][a.to_sym] = ENV[a] if ENV[a] }
58
      options[:allow_override] = ENV['allow_override'] if ENV['allow_override']
59
      options[:unknown_user] = ENV['unknown_user'] if ENV['unknown_user']
60
      options[:no_permission_check] = ENV['no_permission_check'] if ENV['no_permission_check']
61

  
62
      MailHandler.receive(STDIN.read, options)
63
    end
64

  
65
    desc <<-END_DESC
66
Read emails from an IMAP server.
67

  
68
General options:
69
  unknown_user=ACTION      how to handle emails from an unknown user
70
                           ACTION can be one of the following values:
71
                           ignore: email is ignored (default)
72
                           accept: accept as anonymous user
73
                           create: create a user account
74
  no_permission_check=1    disable permission checking when receiving
75
                           the email
76

  
77
Available IMAP options:
78
  host=HOST                IMAP server host (default: 127.0.0.1)
79
  port=PORT                IMAP server port (default: 143)
80
  ssl=SSL                  Use SSL? (default: false)
81
  username=USERNAME        IMAP account
82
  password=PASSWORD        IMAP password
83
  folder=FOLDER            IMAP folder to read (default: INBOX)
84

  
85
Issue attributes control options:
86
  project=PROJECT          identifier of the target project
87
  status=STATUS            name of the target status
88
  tracker=TRACKER          name of the target tracker
89
  category=CATEGORY        name of the target category
90
  priority=PRIORITY        name of the target priority
91
  allow_override=ATTRS     allow email content to override attributes
92
                           specified by previous options
93
                           ATTRS is a comma separated list of attributes
94

  
95
Processed emails control options:
96
  move_on_success=MAILBOX  move emails that were successfully received
97
                           to MAILBOX instead of deleting them
98
  move_on_failure=MAILBOX  move emails that were ignored to MAILBOX
99

  
100
Examples:
101
  # No project specified. Emails MUST contain the 'Project' keyword:
102

  
103
  rake redmine:email:receive_imap RAILS_ENV="production" \\
104
    host=imap.foo.bar username=redmine@example.net password=xxx
105

  
106

  
107
  # Fixed project and default tracker specified, but emails can override
108
  # both tracker and priority attributes:
109

  
110
  rake redmine:email:receive_imap RAILS_ENV="production" \\
111
    host=imap.foo.bar username=redmine@example.net password=xxx ssl=1 \\
112
    project=foo \\
113
    tracker=bug \\
114
    allow_override=tracker,priority
115
END_DESC
116

  
117
    task :receive_imap => :environment do
118
      imap_options = {:host => ENV['host'],
119
                      :port => ENV['port'],
120
                      :ssl => ENV['ssl'],
121
                      :username => ENV['username'],
122
                      :password => ENV['password'],
123
                      :folder => ENV['folder'],
124
                      :move_on_success => ENV['move_on_success'],
125
                      :move_on_failure => ENV['move_on_failure']}
126

  
127
      options = { :issue => {} }
128
      %w(project status tracker category priority).each { |a| options[:issue][a.to_sym] = ENV[a] if ENV[a] }
129
      options[:allow_override] = ENV['allow_override'] if ENV['allow_override']
130
      options[:unknown_user] = ENV['unknown_user'] if ENV['unknown_user']
131
      options[:no_permission_check] = ENV['no_permission_check'] if ENV['no_permission_check']
132

  
133
      Redmine::IMAP.check(imap_options, options)
134
    end
135

  
136
    desc <<-END_DESC
137
Read emails from an POP3 server.
138

  
139
Available POP3 options:
140
  host=HOST                POP3 server host (default: 127.0.0.1)
141
  port=PORT                POP3 server port (default: 110)
142
  username=USERNAME        POP3 account
143
  password=PASSWORD        POP3 password
144
  apop=1                   use APOP authentication (default: false)
145
  delete_unprocessed=1     delete messages that could not be processed
146
                           successfully from the server (default
147
                           behaviour is to leave them on the server)
148

  
149
See redmine:email:receive_imap for more options and examples.
150
END_DESC
151

  
152
    task :receive_pop3 => :environment do
153
      pop_options  = {:host => ENV['host'],
154
                      :port => ENV['port'],
155
                      :apop => ENV['apop'],
156
                      :username => ENV['username'],
157
                      :password => ENV['password'],
158
                      :delete_unprocessed => ENV['delete_unprocessed']}
159

  
160
      options = { :issue => {} }
161
      %w(project status tracker category priority).each { |a| options[:issue][a.to_sym] = ENV[a] if ENV[a] }
162
      options[:allow_override] = ENV['allow_override'] if ENV['allow_override']
163
      options[:unknown_user] = ENV['unknown_user'] if ENV['unknown_user']
164
      options[:no_permission_check] = ENV['no_permission_check'] if ENV['no_permission_check']
165

  
166
      Redmine::POP3.check(pop_options, options)
167
    end
168

  
169
    desc "Send a test email to the user with the provided login name"
170
    task :test, [:login] => :environment do |task, args|
171
      include Redmine::I18n
172
      abort l(:notice_email_error, "Please include the user login to test with. Example: rake redmine:email:test[login]") if args[:login].blank?
173

  
174
      user = User.find_by_login(args[:login])
175
      abort l(:notice_email_error, "User #{args[:login]} not found") unless user && user.logged?
176

  
177
      ActionMailer::Base.raise_delivery_errors = true
178
      begin
179
        Mailer.with_synched_deliveries do
180
          Mailer.test_email(user).deliver
181
        end
182
        puts l(:notice_email_sent, user.mail)
183
      rescue Exception => e
184
        abort l(:notice_email_error, e.message)
185
      end
186
    end
187
  end
188
end
.svn/pristine/80/806fc15a74f68aa08e1189f7dd28e0b1f084bd22.svn-base
1
Rails.logger.info 'Starting Example plugin for RedMine'
2

  
3
Redmine::Plugin.register :sample_plugin do
4
  name 'Example plugin'
5
  author 'Author name'
6
  description 'This is a sample plugin for Redmine'
7
  version '0.0.1'
8
  settings :default => {'sample_setting' => 'value', 'foo'=>'bar'}, :partial => 'settings/sample_plugin_settings'
9

  
10
  # This plugin adds a project module
11
  # It can be enabled/disabled at project level (Project settings -> Modules)
12
  project_module :example_module do
13
    # A public action
14
    permission :example_say_hello, {:example => [:say_hello]}, :public => true
15
    # This permission has to be explicitly given
16
    # It will be listed on the permissions screen
17
    permission :example_say_goodbye, {:example => [:say_goodbye]}
18
    # This permission can be given to project members only
19
    permission :view_meetings, {:meetings => [:index, :show]}, :require => :member
20
  end
21

  
22
  # A new item is added to the project menu
23
  menu :project_menu, :sample_plugin, { :controller => 'example', :action => 'say_hello' }, :caption => 'Sample'
24

  
25
  # Meetings are added to the activity view
26
  activity_provider :meetings
27
end

Also available in: Unified diff