Revision 804:548e23d4cd71

View differences:

app/controllers/application_controller.rb
177 177
  def find_project
178 178
    @project = Project.find(params[:id])
179 179
  rescue ActiveRecord::RecordNotFound
180
    render_404
180
    User.current.logged? ? render_404 : require_login
181 181
  end
182 182

  
183 183
  # Find project of id params[:project_id]
184 184
  def find_project_by_project_id
185 185
    @project = Project.find(params[:project_id])
186 186
  rescue ActiveRecord::RecordNotFound
187
    render_404
187
    User.current.logged? ? render_404 : require_login
188 188
  end
189 189

  
190 190
  # Find a project based on params[:project_id]
app/helpers/projects_helper.rb
150 150

  
151 151
    if s != ''
152 152
      a = ''
153
      a << "<h2>"
154
      a <<  l("label_my_project_plural")
155
      a << "</h2>"
156 153
      a << "<ul class='projects root'>\n"
157 154
      a << s
158 155
      a << "</ul>\n"
app/helpers/repositories_helper.rb
281 281
                        ) +
282 282
                     '<br />' + l(:text_scm_path_encoding_note))
283 283
  end
284

  
285
  # Generates a link to a downloadable archive for a revision
286
  # Options:
287
  # * :text - Link text (default to the formatted revision)
288
  def link_to_revision_archive(repository, revision, project, options={})
289
    method = repository.class.name.demodulize.underscore + "_link_to_revision_archive"
290
    if repository.is_a?(Repository) &&
291
        respond_to?(method) && method != 'link_to_revision_archive'
292
      send(method, repository, revision, project, options)
293
    end
294
  end
295

  
296
  def mercurial_link_to_revision_archive(repository, revision, project, options={})
297
    text = options.delete(:text) || format_revision(revision)
298
    rev = revision.respond_to?(:identifier) ? revision.identifier : revision
299
    if rev.blank? then rev = 'tip' end
300
    content_tag('a', h(text),
301
        { :href => "/hg/#{project.identifier}/archive/#{rev}.zip" }.merge(options));
302
  end
303

  
284 304
end
app/views/account/register.rhtml
29 29
<p><label for="user_mail"><%=l(:field_mail)%> <span class="required">*</span></label>
30 30
<%= text_field 'user', 'mail'  %></p>
31 31

  
32
<!-- We only support English in this site 
32 33
<p><label for="user_language"><%=l(:field_language)%></label>
33 34
<%= select("user", "language", lang_options_for_select) %></p>
34

  
35
-->
35 36

  
36 37
<h3><%=l(:label_ssamr_details)%></h3>
37 38
	
app/views/repositories/_navigation.rhtml
2 2
  <%= javascript_include_tag 'repository_navigation' %>
3 3
<% end %>
4 4

  
5
<%= link_to l(:label_statistics), {:action => 'stats', :id => @project}, :class => 'icon icon-stats' %>
5
<%= link_to_revision_archive(@repository, @changeset, @project, { :text => l(:label_download_revision), :class => 'icon icon-package' }) %>
6 6

  
7 7
<% form_tag({:action => controller.action_name, :id => @project, :path => to_path_param(@path), :rev => ''}, {:method => :get, :id => 'revision_selector'}) do -%>
8 8
  <!-- Branches Dropdown -->
......
19 19
  | <%= l(:label_revision) %>: 
20 20
  <%= text_field_tag 'rev', @rev, :size => 8 %>
21 21
<% end -%>
22

  
23

  
app/views/repositories/revision.rhtml
1 1
<div class="contextual">
2

  
3
  <%= link_to_revision_archive(@repository, @changeset, @project, { :text => l(:label_download_revision), :class => 'icon icon-package' }) %>
4
  &nbsp;&nbsp;
5

  
2 6
  &#171;
3 7
  <% unless @changeset.previous.nil? -%>
4 8
    <%= link_to_revision(@changeset.previous, @project, :text => l(:label_previous)) %>
5 9
  <% else -%>
6 10
    <%= l(:label_previous) %>
7 11
  <% end -%>
8
|
12

  
9 13
  <% unless @changeset.next.nil? -%>
10 14
    <%= link_to_revision(@changeset.next, @project, :text => l(:label_next)) %>
11 15
  <% else -%>
......
21 25
    <%= text_field_tag 'rev', @rev, :size => 8 %>
22 26
    <%= submit_tag 'OK', :name => nil %>
23 27
  <% end %>
28

  
24 29
</div>
25 30

  
26 31
<h2><%= l(:label_revision) %> <%= format_revision(@changeset) %></h2>
app/views/repositories/show.rhtml
51 51
                       :id => @project, :page => nil, :key => User.current.rss_key})) %>
52 52
<%     end %>
53 53

  
54
<p class="statistics">
55
<%= link_to l(:label_statistics), {:action => 'stats', :id => @project}, :class => 'icon icon-stats' %>
56
</p>
57

  
54 58
<%     other_formats_links do |f| %>
55 59
  <%= f.link_to 'Atom', :url => {:action => 'revisions', :id => @project, :key => User.current.rss_key} %>
56 60
<%     end %>
61

  
57 62
<%   end %>
58 63
<% end %>
59 64

  
config/locales/en.yml
169 169
  notice_failed_to_save_issues: "Failed to save %{count} issue(s) on %{total} selected: %{ids}."
170 170
  notice_failed_to_save_members: "Failed to save member(s): %{errors}."
171 171
  notice_no_issue_selected: "No issue is selected! Please, check the issues you want to edit."
172
  notice_account_pending: "Your account was created and is now pending administrator approval."
172
  notice_account_pending: "Your account is now awaiting administrator approval. You will receive a notification email when your account has been activated."
173 173
  notice_default_data_loaded: Default configuration successfully loaded.
174 174
  notice_unable_delete_version: Unable to delete version.
175 175
  notice_unable_delete_time_entry: Unable to delete time log entry.
......
698 698
  label_latest_revision_plural: Latest revisions
699 699
  label_view_revisions: View revisions
700 700
  label_view_all_revisions: View all revisions
701
  label_download_revision: Download as Zip
701 702
  label_max_size: Maximum size
702 703
  label_sort_highest: Move to top
703 704
  label_sort_higher: Move up
extra/soundsoftware/SoundSoftware.pm
110 110
    req_override => OR_AUTHCFG,
111 111
    args_how => TAKE1,
112 112
  },
113
  {
114
    name => 'SoundSoftwareSslRequired',
115
    req_override => OR_AUTHCFG,
116
    args_how => TAKE1,
117
  },
113 118
);
114 119

  
115 120
sub SoundSoftwareDSN { 
......
143 148
    }
144 149
}
145 150

  
151
sub SoundSoftwareSslRequired { set_val('SoundSoftwareSslRequired', @_); }
152

  
146 153
sub trim {
147 154
    my $string = shift;
148 155
    $string =~ s/\s{2,}/ /g;
......
184 191

  
185 192
    my $project_id = get_project_identifier($dbh, $r);
186 193

  
187
    if (!defined $read_only_methods{$method}) {
188
        print STDERR "SoundSoftware.pm:$$: Method is not read-only\n";
189
        if (project_repo_is_readonly($dbh, $project_id, $r)) {
190
            print STDERR "SoundSoftware.pm:$$: Project repo is read-only, refusing access\n";
191
	    return FORBIDDEN;
192
        } else {
193
	    print STDERR "SoundSoftware.pm:$$: Project repo is read-write, authentication handler required\n";
194
            return OK;
195
        }
196
    }
194
    # We want to delegate most of the work to the authentication
195
    # handler (to ensure that user is asked to login even for 
196
    # nonexistent projects -- so they can't tell whether a private
197
    # project exists or not without authenticating). So 
198
    # 
199
    # * if the project is public
200
    #   - if the method is read-only
201
    #     + set handler to OK, no auth needed
202
    #   - if the method is not read-only
203
    #     + if the repo is read-only, return forbidden
204
    #     + else require auth
205
    # * if the project is not public or does not exist
206
    #     + require auth
207
    #
208
    # If we are requiring auth and are not currently https, and
209
    # https is required, then we must return a redirect to https
210
    # instead of an OK.
197 211

  
198 212
    my $status = get_project_status($dbh, $project_id, $r);
213
    my $readonly = project_repo_is_readonly($dbh, $project_id, $r);
199 214

  
200 215
    $dbh->disconnect();
201 216
    undef $dbh;
202 217

  
203
    if ($status == 0) { # nonexistent
204
	print STDERR "SoundSoftware.pm:$$: Project does not exist, refusing access\n";
205
	return FORBIDDEN;
206
    } elsif ($status == 1) { # public
207
	print STDERR "SoundSoftware.pm:$$: Project is public, no restriction here\n";
208
	$r->set_handlers(PerlAuthenHandler => [\&OK])
209
    } else { # private
210
	print STDERR "SoundSoftware.pm:$$: Project is private, authentication handler required\n";
218
    my $auth_ssl_reqd = will_require_ssl_auth($r);
219

  
220
    if ($status == 1) { # public
221

  
222
	print STDERR "SoundSoftware.pm:$$: Project is public\n";
223

  
224
	if (!defined $read_only_methods{$method}) {
225

  
226
	    print STDERR "SoundSoftware.pm:$$: Method is not read-only\n";
227

  
228
	    if ($readonly) {
229
		print STDERR "SoundSoftware.pm:$$: Project repo is read-only, refusing access\n";
230
		return FORBIDDEN;
231
	    } else {
232
		print STDERR "SoundSoftware.pm:$$: Project repo is read-write, auth required\n";
233
		# fall through, this is the normal case
234
	    }
235

  
236
        } elsif ($auth_ssl_reqd and $r->unparsed_uri =~ m/cmd=branchmap/) {
237

  
238
            # A hac^H^H^Hspecial case. We want to ensure we switch to
239
            # https (if it will be necessarily for authentication) 
240
            # before the first POST request, and this is what I think
241
            # will give us suitable warning for Mercurial.
242

  
243
            print STDERR "SoundSoftware.pm:$$: Switching to HTTPS in preparation\n";
244
            # fall through, this is the normal case
245

  
246
	} else {
247
	    # Public project, read-only method -- this is the only
248
	    # case we can decide for certain to accept in this function
249
	    print STDERR "SoundSoftware.pm:$$: Method is read-only, no restriction here\n";
250
	    $r->set_handlers(PerlAuthenHandler => [\&OK]);
251
	    return OK;
252
	}
253

  
254
    } else { # status != 1, i.e. nonexistent or private -- equivalent here
255

  
256
	print STDERR "SoundSoftware.pm:$$: Project is private or nonexistent, auth required\n";
257
	# fall through
211 258
    }
212 259

  
213
    return OK
260
    if ($auth_ssl_reqd) {
261
        my $redir_to = "https://" . $r->hostname() . $r->unparsed_uri();
262
        print STDERR "SoundSoftware.pm:$$: Need to switch to HTTPS, redirecting to $redir_to\n";
263
        $r->headers_out->add('Location' => $redir_to);
264
        return REDIRECT;
265
    } else {
266
        return OK;
267
    }
214 268
}
215 269

  
216 270
sub authen_handler {
......
237 291
    
238 292
    print STDERR "SoundSoftware.pm:$$: User is " . $r->user . ", got password\n";
239 293

  
294
    my $status = get_project_status($dbh, $project_id, $r);
295
    if ($status == 0) {
296
	# nonexistent, behave like private project you aren't a member of
297
	print STDERR "SoundSoftware.pm:$$: Project doesn't exist, not permitted\n";
298
	$dbh->disconnect();
299
	undef $dbh;
300
	$r->note_auth_failure();
301
	return AUTH_REQUIRED;
302
    }
303

  
240 304
    my $permitted = is_permitted($dbh, $project_id, $r->user, $redmine_pass, $r);
241 305
    
242 306
    $dbh->disconnect();
......
279 343
    $ret;
280 344
}
281 345

  
346
sub will_require_ssl_auth {
347
    my $r = shift;
348

  
349
    my $cfg = Apache2::Module::get_config
350
        (__PACKAGE__, $r->server, $r->per_dir_config);
351

  
352
    if ($cfg->{SoundSoftwareSslRequired} eq "on") {
353
        if ($r->dir_config('HTTPS') eq "on") {
354
            # already have ssl
355
            return 0;
356
        } else {
357
            # require ssl for auth, don't have it yet
358
            return 1;
359
        }
360
    } elsif ($cfg->{SoundSoftwareSslRequired} eq "off") {
361
        # don't require ssl for auth
362
        return 0;
363
    } else {
364
        print STDERR "WARNING: SoundSoftware.pm:$$: SoundSoftwareSslRequired should be either 'on' or 'off'\n";
365
        # this is safer
366
        return 1;
367
    }
368
}
369

  
282 370
sub project_repo_is_readonly {
283 371
    my $dbh = shift;
284 372
    my $project_id = shift;
......
368 456
		}
369 457
		$sthldap->finish();
370 458
		undef $sthldap;
459
                last if ($ret);
371 460
	    }
372 461
	} else {
373 462
	    print STDERR "SoundSoftware.pm:$$: User $redmine_user lacks required role for this project\n";
......
383 472
sub get_project_identifier {
384 473
    my $dbh = shift;
385 474
    my $r = shift;
386

  
387 475
    my $location = $r->location;
388
    my ($repo) = $r->uri =~ m{$location/*([^/]+)};
476
    my ($repo) = $r->uri =~ m{$location/*([^/]*)};
389 477

  
390 478
    return $repo if (!$repo);
391 479

  
392 480
    $repo =~ s/[^a-zA-Z0-9\._-]//g;
393

  
481
    
394 482
    # The original Redmine.pm returns the string just calculated as
395 483
    # the project identifier.  That won't do for us -- we may have
396 484
    # (and in fact already do have, in our test instance) projects
......
410 498

  
411 499
    my $prefix = $cfg->{SoundSoftwareRepoPrefix};
412 500
    if (!defined $prefix) { $prefix = '%/'; }
413

  
414 501
    my $identifier = '';
415 502

  
416 503
    $sth->execute($prefix . $repo);
......
449 536
    # to project identifier if any are found
450 537
    if ($name =~ m/[^\w\d\s\._-]/) {
451 538
	$name = $project_id;
539
    } elsif ($name =~ m/^\s*$/) {
540
	# empty or whitespace
541
	$name = $project_id;
542
    }
543
    
544
    if ($name =~ m/^\s*$/) {
545
        # nothing even in $project_id -- probably a nonexistent project.
546
        # use repo name instead (don't want to admit to user that project
547
        # doesn't exist)
548
        my $location = $r->location;
549
        my ($repo) = $r->uri =~ m{$location/*([^/]*)};
550
        $name = $repo;
452 551
    }
453 552

  
454 553
    my $realm = '"Mercurial repository for ' . "'$name'" . '"';
public/help/wiki_syntax_detailed.html
68 68

  
69 69
        <p>Wiki links are displayed in red if the page doesn't exist yet, eg: <a href="#" class="wiki-page new">Nonexistent page</a>.</p>
70 70

  
71
        <p>Links to other resources:</p>
71
        <p>Links to other resources:</p>

72 72

  
73 73
        <ul>
74 74
            <li>Documents:
......
76 76
                    <li><strong>document#17</strong> (link to document with id 17)</li>
77 77
                    <li><strong>document:Greetings</strong> (link to the document with title "Greetings")</li>
78 78
                    <li><strong>document:"Some document"</strong> (double quotes can be used when document title contains spaces)</li>
79
                    <li><strong>sandbox:document:"Some document"</strong> (link to a document with title "Some document" in other project "sandbox")</li>
79
                    <li><strong>sandbox:document:"Some document"</strong> (link to a document with title "Some document" in other project "sandbox")</li>

80 80
                </ul></li>
81 81
        </ul>
82 82

  
......
99 99
        </ul>
100 100

  
101 101
        <ul>
102
             <li>Repository files:
102
             <li>Repository files:

103 103
                <ul>
104
                    <li><strong>source:some/file</strong>           (link to the file located at /some/file in the project's repository)</li>
105
                    <li><strong>source:some/file@52</strong>        (link to the file's revision 52)</li>
106
                    <li><strong>source:some/file#L120</strong>      (link to line 120 of the file)</li>
107
                    <li><strong>source:some/file@52#L120</strong>   (link to line 120 of the file's revision 52)</li>
108
                    <li><strong>source:"some file@52#L120"</strong> (use double quotes when the URL contains spaces</li>
104
                    <li><strong>source:some/file</strong>           (link to the file located at /some/file in the project's repository)</li>

105
                    <li><strong>source:some/file@52</strong>        (link to the file's revision 52)</li>

106
                    <li><strong>source:some/file#L120</strong>      (link to line 120 of the file)</li>

107
                    <li><strong>source:some/file@52#L120</strong>   (link to line 120 of the file's revision 52)</li>

108
                    <li><strong>source:"some file@52#L120"</strong> (use double quotes when the URL contains spaces</li>

109 109
                    <li><strong>export:some/file</strong>           (force the download of the file)</li>
110 110
                    <li><strong>sandbox:source:some/file</strong>   (link to the file located at /some/file in the repository of the project "sandbox")</li>
111
                    <li><strong>sandbox:export:some/file</strong>   (force the download of the file)</li>
112
                </ul></li>
111
                    <li><strong>sandbox:export:some/file</strong>   (force the download of the file)</li>

112
                </ul></li>

113 113
        </ul>
114 114

  
115 115
        <ul>
116
            <li>Forum messages:
117
                <ul>
118
                    <li><strong>message#1218</strong> (link to message with id 1218)</li>
119
                </ul></li>
120
        </ul>
121

  
122
        <ul>
123
            <li>Projects:
124
                <ul>
125
                    <li><strong>project#3</strong> (link to project with id 3)</li>
126
                    <li><strong>project:someproject</strong> (link to project named "someproject")</li>
127
                </ul></li>
128
        </ul>
129

  
130

  
131
        <p>Escaping:</p>
132

  
133
        <ul>
116
            <li>Forum messages:

117
                <ul>

118
                    <li><strong>message#1218</strong> (link to message with id 1218)</li>

119
                </ul></li>

120
        </ul>

121

  
122
        <ul>

123
            <li>Projects:

124
                <ul>

125
                    <li><strong>project#3</strong> (link to project with id 3)</li>

126
                    <li><strong>project:someproject</strong> (link to project named "someproject")</li>

127
                </ul></li>

128
        </ul>

129

  
130

  
131
        <p>Escaping:</p>

132

  
133
        <ul>

134 134
            <li>You can prevent Redmine links from being parsed by preceding them with an exclamation mark: !</li>
135 135
        </ul>
136 136

  
......
198 198
        <p>Redmine assigns an anchor to each of those headings thus you can link to them with "#Heading", "#Subheading" and so forth.</p>
199 199

  
200 200

  
201

  
202

  
203
<h3><a name="9" class="wiki-page"></a>Bullets and Numbering</h3>
204

  
205
<pre>
206
* First Level Bullet
207
** Second Level Bullet
208
** Another Second Level Bullet
209
*** Third Level Bullet
210
** Back to 2nd Level Bullet
211
* Back to 1st Level Bullet
212
</pre>
213

  
214
<ul>
215
    <li>First Level Bullet</li>
216
    <ul>
217
      <li>Second Level Bullet</li>
218
      <li>Another Second Level Bullet</li>
219
        <ul>
220
          <li>Third Level Bullet</li>
221
        </ul>
222
        <li>Back to 2nd Level Bullet</li>
223
    </ul>
224
    
225
    <li>Back to 1st Level Bullet</li>
226
</ul>
227

  
228
<pre>
229
# First Level Numbering
230
## Second Level Numbering
231
## Another Second Level Numbering
232
### Third Level Numbering
233
## Back to 2nd Level Numbering
234
# Back to 1st Level Numbering
235
</pre>
236

  
237
<ol>
238
    <li>First Level Numbering</li>
239
    <ol>
240
      <li>Second Level Numbering</li>
241
      <li>Another Second Level Numbering</li>
242
        <ol>
243
          <li>Third Level Numbering</li>
244
        </ol>
245
        <li>Back to 2nd Level Numbering</li>
246
    </ol>
247
    <li>Back to 1st Level Numbering</li>
248
</ol>
249

  
250
<pre>
251
# First Level Numbering
252
#* Bullet inside numbering environment
253
#* Another Bullet inside numbering environment
254
# Back to 1st Level Numbering
255
</pre>
256

  
257
<ol>
258
    <li>First Level Numbering</li>
259
    <ul>
260
      <li>Bullet inside numbering environment</li>
261
      <li>Another Bullet inside numbering environment</li>
262
    </ul>
263
    
264
    <li>Back to 1st Level Numbering</li>
265
</ol>
266

  
267

  
268

  
269

  
270

  
271

  
272

  
201 273
        <h3><a name="9" class="wiki-page"></a>Paragraphs</h3>
202 274

  
203 275
<pre>
......
242 314

  
243 315
    <h2><a name="13" class="wiki-page"></a>Code highlighting</h2>
244 316

  
245
    <p>Code highlightment relies on <a href="http://coderay.rubychan.de/" class="external">CodeRay</a>, a fast syntax highlighting library written completely in Ruby. It currently supports c, cpp, css, delphi, groovy, html, java, javascript, json, php, python, rhtml, ruby, scheme, sql, xml and yaml languages.</p>
317
    <p>Code highlightment relies on <a href="http://coderay.rubychan.de/" class="external">CodeRay</a>, a fast syntax highlighting library written completely in Ruby. It currently supports c, cpp, css, delphi, groovy, html, java, javascript, json, php, python, rhtml, ruby, scheme, sql, xml and yaml languages.</p>

246 318

  
247 319
    <p>You can highlight code in your wiki page using this syntax:</p>
248 320

  
public/themes/soundsoftware/stylesheets/application.css
134 134
#footer { background-color: #fdfbf5; border: 0; border-top: 2px solid #a9b680; color: #3e442c; text-align: right; }
135 135
#footer a { color: #be5700; font-weight: bold; }
136 136

  
137
p.statistics { text-align: right; font-size:0.9em; color: #666; }
138

  
137 139
#main { margin-top: 135px; font:95%; background: #fdfaf0; }
138 140
#main a { font-weight: medium; color: #be5700;}
139 141
#main a:hover { color: #be5700; text-decoration: underline; }
......
224 226

  
225 227
.embedded #matlabdoc th { text-align: left; }
226 228

  
229
/* autocomplete positioning fix */
230
div.autocomplete {
231
	margin-top:136px;
232
}
227 233

  
234
#my_projects_fieldset.collapsible {
235
	font-size: 1.0em;
236
	font-color: green;
237
}
228 238

  
239

  
240

  
241

  
vendor/plugins/redmine_bibliography/app/helpers/publications_helper.rb
12 12
  def projects_check_box_tags(name, projects)
13 13
    s = ''
14 14
    projects.sort.each do |project|
15
      s << "<label>#{ check_box_tag name, project.id, false } #{link_to_project project}</label>\n"
15
      if User.current.allowed_to?(:edit_publication, project) 
16
        s << "<label>#{ check_box_tag name, project.id, false } #{link_to_project project}</label>\n"
17
        s << '<br />'
18
      end
16 19
    end
20

  
17 21
    s 
18 22
  end
19 23
  
......
43 47
    f.hidden_field(:_destroy) + link_to_function(name, "remove_fields(this)", :class => 'icon icon-del')
44 48
  end
45 49
    
46
  def link_to_add_fields(name, f, association)
50
  def link_to_add_author_fields(name, f, association, action)
47 51
    new_object = f.object.class.reflect_on_association(association).klass.new
48 52
    fields = f.fields_for(association, new_object, :child_index => "new_#{association}") do |builder|
49 53
      render(association.to_s.singularize + "_fields", :f => builder)
50 54
    end    
51
    link_to_function(name, h("add_fields(this, '#{association}', '#{escape_javascript(fields)}')"), { :class => 'icon icon-add', :id => "add_another_author" })
55
    link_to_function(name, h("add_author_fields(this, '#{association}', '#{escape_javascript(fields)}', '#{action}')"), { :class => 'icon icon-add', :id => "add_another_author" })
52 56
  end  
53 57

  
54 58
  def sanitized_object_name(object_name)
vendor/plugins/redmine_bibliography/app/views/projects/_bibliography_box.html.erb
7 7
   <dl>
8 8
     <% @project.publications.each do |publication| %>
9 9
     <dt>
10
       <%= link_to publication.title, :controller => 'publications', :action => 'show', :id => publication, :project_id => @project %>
11
     </dt>
12
     <dd>
13 10
     <span class="authors">
14
       <%= publication.authorships.map { |a| h a.name_on_paper }.join(', ') %>
11
       <%= publication.authorships.map { |a| h a.name_on_paper }.join(', ') %><% if !publication.authorships.empty? %>.<% end %>
15 12
     </span>
13
     <span class="title"><%= link_to publication.title, :controller => 'publications', :action => 'show', :id => publication, :project_id => @project %></span>
16 14
     <% if publication.bibtex_entry.year.to_s != "" %>
17 15
     <span class="year">
18
       <%= publication.bibtex_entry.year %>
16
       &nbsp;(<%= publication.bibtex_entry.year %>)
19 17
     </span>
20 18
     <% end %>
21
     </dd>
19
     </dt><dd></dd>
22 20
   <% end -%>
23 21
   </dl>
24 22
  </div>
vendor/plugins/redmine_bibliography/app/views/publications/_authorship_fields.rhtml
19 19

  
20 20
      <p style="margin-bottom: -2.5em; padding-bottom; 0"><label><%= l(:identify_author_question) %></label></p>
21 21
      <p class="author_identify">
22
        <label class='inline'><%= radio_button_tag(:identify_author, "yes", false, :name => form_tag_name(f.object_name,:identify_author ), :id => form_tag_id( f.object_name, :identify_author_yes ), :onclick => "identify_author_status($(this).value, #{form_object_id(f.object_name) });") %> <%= l(:identify_author_yes) %> </label><br />
22
        <label class='inline'><%= radio_button_tag(:identify_author, "yes", false, :name => form_tag_name(f.object_name,:identify_author ), :id => form_tag_id( f.object_name, :identify_author_yes ), :onchange => "identify_author_status($(this).value, #{form_object_id(f.object_name) });") %> <%= l(:identify_author_yes) %> </label><br />
23 23
       
24
        <label class='inline'><%= radio_button_tag(:identify_author, "correct", false, :name => form_tag_name(f.object_name,:identify_author ), :id => form_tag_id( f.object_name, :identify_author_corrections ), :onclick => "identify_author_status($(this).value, #{form_object_id(f.object_name) });") %> <%= l(:identify_author_correct) %> </label><br />
24
        <label class='inline'><%= radio_button_tag(:identify_author, "correct", false, :name => form_tag_name(f.object_name,:identify_author ), :id => form_tag_id( f.object_name, :identify_author_corrections ), :onchange => "identify_author_status($(this).value, #{form_object_id(f.object_name) });") %> <%= l(:identify_author_correct) %> </label><br />
25 25
        
26
        <label class='inline'><%= radio_button_tag(:identify_author, "no", true, :name => form_tag_name(f.object_name,:identify_author ), :id => form_tag_id( f.object_name, :identify_author_no ), :onclick => "identify_author_status($(this).value, #{form_object_id(f.object_name) });") %> <%= l(:identify_author_no) %> </label><br />
26
        <label class='inline'><%= radio_button_tag(:identify_author, "no", true, :name => form_tag_name(f.object_name,:identify_author ), :id => form_tag_id( f.object_name, :identify_author_no ), :onchange => "identify_author_status($(this).value, #{form_object_id(f.object_name) });") %> <%= l(:identify_author_no) %> </label><br />
27 27
      </p>
28 28
    </div>	
29 29
  
......
45 45

  
46 46
  <p>
47 47

  
48
  <% if params[:action] == 'new' %>
49
   <%= button_to_function l(:label_save_author), {}, { :onclick => "toggle_save_author(#{form_object_id(f.object_name)}); return false;", :id => form_tag_id( f.object_name, :edit_save_button )} %>
50
  <% else %>
51
<%= button_to_function l(:label_edit_author), {}, { :onclick => "toggle_save_author(#{form_object_id(f.object_name)}); return false;", :id => form_tag_id( f.object_name, :edit_save_button )} %>
52

  
53
 <% end %>
48
  <%- if params[:action] == 'new' -%>
49
    <%= button_to_function l(:label_save_author), {}, { :onclick => "toggle_save_author(#{form_object_id(f.object_name)}); return false;", :id => form_tag_id( f.object_name, :edit_save_button )} %>
50
  <%- else -%>
51
    <%= button_to_function l(:label_edit_author), {}, { :onclick => "toggle_save_author(#{form_object_id(f.object_name)}); return false;", :id => form_tag_id( f.object_name, :edit_save_button )} %>
52
  <%- end -%>
54 53

  
55 54

  
56 55
  <%= link_to_remove_fields l("remove_author"), f %>
vendor/plugins/redmine_bibliography/app/views/publications/_form.html.erb
24 24
    <% f.fields_for :authorships do |builder| -%>
25 25
      <%= render "authorship_fields", :f => builder %>
26 26
    <%- end -%>
27
    <%= link_to_add_fields l(:label_add_an_author), f, :authorships %>
27
    <%= link_to_add_author_fields l(:label_add_an_author), f, :authorships, params[:action] %>
28 28
  </div>
29 29
</div>
30 30

  
vendor/plugins/redmine_bibliography/app/views/users/show.rhtml
51 51

  
52 52
    <% @publications.each do |publication|%>    
53 53
      <dt>
54
        <%= link_to publication.title, :controller => 'publications', :action => 'show', :id => publication %>
55
      </dt>
56

  
57
      <dd>
58 54
        <span class="authors">
59
          <%= publication.authorships.map { |a| h a.name_on_paper }.join(', ') %>
55
          <%= publication.authorships.map { |a| h a.name_on_paper }.join(', ') %><% if !publication.authorships.empty? %>.<% end %>
60 56
        </span>
57
        <span class="title"><%= link_to publication.title, :controller => 'publications', :action => 'show', :id => publication %></span>
61 58
        <% if publication.bibtex_entry.year.to_s != "" %>
62 59
          <span class="year">
63
            <%= publication.bibtex_entry.year %>
60
            &nbsp;(<%= publication.bibtex_entry.year %>)
64 61
          </span>
65 62
        <% end %>
63
      </dt>
64
      <dd>
66 65
      </dd>
67 66
  	<% end %>
68 67
  </div>
vendor/plugins/redmine_bibliography/assets/javascripts/authors.js
3 3
    $(link).up(".fields").hide();
4 4
}
5 5

  
6
function add_fields(link, association, content) {
7
    var new_id = new Date().getTime();
8
    var regexp = new RegExp("new_" + association, "g")
9
    $(link).insert({
10
	before: content.replace(regexp, new_id)
11
    });
6
function add_author_fields(link, association, content, action) {
7
	var new_id = new Date().getTime();
8
  var regexp = new RegExp("new_" + association, "g");
9
  $(link).insert({
10
		before: content.replace(regexp, new_id)
11
  });
12
	if(action != "new"){
13
		toggle_save_author(new_id, $(link));
14
	};
12 15
}
13 16

  
14 17
function identify_author_status(status, object_id) {
vendor/plugins/redmine_bibliography/assets/stylesheets/bibliography.css
39 39
div#bibliography dd { margin-bottom: 1em; padding-left: 18px; font-size: 0.9em; }
40 40
div#bibliography .box dd { margin-bottom: 0.6em; padding-left: 0; }
41 41
div#bibliography dd .authors { font-style: italic; }
42
div#bibliography dt .title { font-style: italic; }
42 43
div#bibliography dd span.authors { color: #808080; }
43 44
div#bibliography dd span.year { padding-left: 0.6em; }
44 45

  
vendor/plugins/redmine_tags/COPYING
1
redmine_tags is a redMine plugin, that adds tagging support.
2

  
3
Copyright (c) 2010 Eric Davis
4
Copyright (c) 2010 Aleksey V Zapparov AKA ixti
5

  
6
redmine_tags is free software: you can redistribute it and/or modify
7
it under the terms of the GNU General Public License as published by
8
the Free Software Foundation, either version 3 of the License, or
9
(at your option) any later version.
10

  
11
redmine_tags is distributed in the hope that it will be useful,
12
but WITHOUT ANY WARRANTY; without even the implied warranty of
13
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
GNU General Public License for more details.
15

  
16
You should have received a copy of the GNU General Public License
17
along with redmine_tags.  If not, see <http://www.gnu.org/licenses/>.
vendor/plugins/redmine_tags/LICENSE
1
                    GNU GENERAL PUBLIC LICENSE
2
                       Version 3, 29 June 2007
3

  
4
 Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
5
 Everyone is permitted to copy and distribute verbatim copies
6
 of this license document, but changing it is not allowed.
7

  
8
                            Preamble
9

  
10
  The GNU General Public License is a free, copyleft license for
11
software and other kinds of works.
12

  
13
  The licenses for most software and other practical works are designed
14
to take away your freedom to share and change the works.  By contrast,
15
the GNU General Public License is intended to guarantee your freedom to
16
share and change all versions of a program--to make sure it remains free
17
software for all its users.  We, the Free Software Foundation, use the
18
GNU General Public License for most of our software; it applies also to
19
any other work released this way by its authors.  You can apply it to
20
your programs, too.
21

  
22
  When we speak of free software, we are referring to freedom, not
23
price.  Our General Public Licenses are designed to make sure that you
24
have the freedom to distribute copies of free software (and charge for
25
them if you wish), that you receive source code or can get it if you
26
want it, that you can change the software or use pieces of it in new
27
free programs, and that you know you can do these things.
28

  
29
  To protect your rights, we need to prevent others from denying you
30
these rights or asking you to surrender the rights.  Therefore, you have
31
certain responsibilities if you distribute copies of the software, or if
32
you modify it: responsibilities to respect the freedom of others.
33

  
34
  For example, if you distribute copies of such a program, whether
35
gratis or for a fee, you must pass on to the recipients the same
36
freedoms that you received.  You must make sure that they, too, receive
37
or can get the source code.  And you must show them these terms so they
38
know their rights.
39

  
40
  Developers that use the GNU GPL protect your rights with two steps:
41
(1) assert copyright on the software, and (2) offer you this License
42
giving you legal permission to copy, distribute and/or modify it.
43

  
44
  For the developers' and authors' protection, the GPL clearly explains
45
that there is no warranty for this free software.  For both users' and
46
authors' sake, the GPL requires that modified versions be marked as
47
changed, so that their problems will not be attributed erroneously to
48
authors of previous versions.
49

  
50
  Some devices are designed to deny users access to install or run
51
modified versions of the software inside them, although the manufacturer
52
can do so.  This is fundamentally incompatible with the aim of
53
protecting users' freedom to change the software.  The systematic
54
pattern of such abuse occurs in the area of products for individuals to
55
use, which is precisely where it is most unacceptable.  Therefore, we
56
have designed this version of the GPL to prohibit the practice for those
57
products.  If such problems arise substantially in other domains, we
58
stand ready to extend this provision to those domains in future versions
59
of the GPL, as needed to protect the freedom of users.
60

  
61
  Finally, every program is threatened constantly by software patents.
62
States should not allow patents to restrict development and use of
63
software on general-purpose computers, but in those that do, we wish to
64
avoid the special danger that patents applied to a free program could
65
make it effectively proprietary.  To prevent this, the GPL assures that
66
patents cannot be used to render the program non-free.
67

  
68
  The precise terms and conditions for copying, distribution and
69
modification follow.
70

  
71
                       TERMS AND CONDITIONS
72

  
73
  0. Definitions.
74

  
75
  "This License" refers to version 3 of the GNU General Public License.
76

  
77
  "Copyright" also means copyright-like laws that apply to other kinds of
78
works, such as semiconductor masks.
79

  
80
  "The Program" refers to any copyrightable work licensed under this
81
License.  Each licensee is addressed as "you".  "Licensees" and
82
"recipients" may be individuals or organizations.
83

  
84
  To "modify" a work means to copy from or adapt all or part of the work
85
in a fashion requiring copyright permission, other than the making of an
86
exact copy.  The resulting work is called a "modified version" of the
87
earlier work or a work "based on" the earlier work.
88

  
89
  A "covered work" means either the unmodified Program or a work based
90
on the Program.
91

  
92
  To "propagate" a work means to do anything with it that, without
93
permission, would make you directly or secondarily liable for
94
infringement under applicable copyright law, except executing it on a
95
computer or modifying a private copy.  Propagation includes copying,
96
distribution (with or without modification), making available to the
97
public, and in some countries other activities as well.
98

  
99
  To "convey" a work means any kind of propagation that enables other
100
parties to make or receive copies.  Mere interaction with a user through
101
a computer network, with no transfer of a copy, is not conveying.
102

  
103
  An interactive user interface displays "Appropriate Legal Notices"
104
to the extent that it includes a convenient and prominently visible
105
feature that (1) displays an appropriate copyright notice, and (2)
106
tells the user that there is no warranty for the work (except to the
107
extent that warranties are provided), that licensees may convey the
108
work under this License, and how to view a copy of this License.  If
109
the interface presents a list of user commands or options, such as a
110
menu, a prominent item in the list meets this criterion.
111

  
112
  1. Source Code.
113

  
114
  The "source code" for a work means the preferred form of the work
115
for making modifications to it.  "Object code" means any non-source
116
form of a work.
117

  
118
  A "Standard Interface" means an interface that either is an official
119
standard defined by a recognized standards body, or, in the case of
120
interfaces specified for a particular programming language, one that
121
is widely used among developers working in that language.
122

  
123
  The "System Libraries" of an executable work include anything, other
124
than the work as a whole, that (a) is included in the normal form of
125
packaging a Major Component, but which is not part of that Major
126
Component, and (b) serves only to enable use of the work with that
127
Major Component, or to implement a Standard Interface for which an
128
implementation is available to the public in source code form.  A
129
"Major Component", in this context, means a major essential component
130
(kernel, window system, and so on) of the specific operating system
131
(if any) on which the executable work runs, or a compiler used to
132
produce the work, or an object code interpreter used to run it.
133

  
134
  The "Corresponding Source" for a work in object code form means all
135
the source code needed to generate, install, and (for an executable
136
work) run the object code and to modify the work, including scripts to
137
control those activities.  However, it does not include the work's
138
System Libraries, or general-purpose tools or generally available free
139
programs which are used unmodified in performing those activities but
140
which are not part of the work.  For example, Corresponding Source
141
includes interface definition files associated with source files for
142
the work, and the source code for shared libraries and dynamically
143
linked subprograms that the work is specifically designed to require,
144
such as by intimate data communication or control flow between those
145
subprograms and other parts of the work.
146

  
147
  The Corresponding Source need not include anything that users
148
can regenerate automatically from other parts of the Corresponding
149
Source.
150

  
151
  The Corresponding Source for a work in source code form is that
152
same work.
153

  
154
  2. Basic Permissions.
155

  
156
  All rights granted under this License are granted for the term of
157
copyright on the Program, and are irrevocable provided the stated
158
conditions are met.  This License explicitly affirms your unlimited
159
permission to run the unmodified Program.  The output from running a
160
covered work is covered by this License only if the output, given its
161
content, constitutes a covered work.  This License acknowledges your
162
rights of fair use or other equivalent, as provided by copyright law.
163

  
164
  You may make, run and propagate covered works that you do not
165
convey, without conditions so long as your license otherwise remains
166
in force.  You may convey covered works to others for the sole purpose
167
of having them make modifications exclusively for you, or provide you
168
with facilities for running those works, provided that you comply with
169
the terms of this License in conveying all material for which you do
170
not control copyright.  Those thus making or running the covered works
171
for you must do so exclusively on your behalf, under your direction
172
and control, on terms that prohibit them from making any copies of
173
your copyrighted material outside their relationship with you.
174

  
175
  Conveying under any other circumstances is permitted solely under
176
the conditions stated below.  Sublicensing is not allowed; section 10
177
makes it unnecessary.
178

  
179
  3. Protecting Users' Legal Rights From Anti-Circumvention Law.
180

  
181
  No covered work shall be deemed part of an effective technological
182
measure under any applicable law fulfilling obligations under article
183
11 of the WIPO copyright treaty adopted on 20 December 1996, or
184
similar laws prohibiting or restricting circumvention of such
185
measures.
186

  
187
  When you convey a covered work, you waive any legal power to forbid
188
circumvention of technological measures to the extent such circumvention
189
is effected by exercising rights under this License with respect to
190
the covered work, and you disclaim any intention to limit operation or
191
modification of the work as a means of enforcing, against the work's
192
users, your or third parties' legal rights to forbid circumvention of
193
technological measures.
194

  
195
  4. Conveying Verbatim Copies.
196

  
197
  You may convey verbatim copies of the Program's source code as you
198
receive it, in any medium, provided that you conspicuously and
199
appropriately publish on each copy an appropriate copyright notice;
200
keep intact all notices stating that this License and any
201
non-permissive terms added in accord with section 7 apply to the code;
202
keep intact all notices of the absence of any warranty; and give all
203
recipients a copy of this License along with the Program.
204

  
205
  You may charge any price or no price for each copy that you convey,
206
and you may offer support or warranty protection for a fee.
207

  
208
  5. Conveying Modified Source Versions.
209

  
210
  You may convey a work based on the Program, or the modifications to
211
produce it from the Program, in the form of source code under the
212
terms of section 4, provided that you also meet all of these conditions:
213

  
214
    a) The work must carry prominent notices stating that you modified
215
    it, and giving a relevant date.
216

  
217
    b) The work must carry prominent notices stating that it is
218
    released under this License and any conditions added under section
219
    7.  This requirement modifies the requirement in section 4 to
220
    "keep intact all notices".
221

  
222
    c) You must license the entire work, as a whole, under this
223
    License to anyone who comes into possession of a copy.  This
224
    License will therefore apply, along with any applicable section 7
225
    additional terms, to the whole of the work, and all its parts,
226
    regardless of how they are packaged.  This License gives no
227
    permission to license the work in any other way, but it does not
228
    invalidate such permission if you have separately received it.
229

  
230
    d) If the work has interactive user interfaces, each must display
231
    Appropriate Legal Notices; however, if the Program has interactive
232
    interfaces that do not display Appropriate Legal Notices, your
233
    work need not make them do so.
234

  
235
  A compilation of a covered work with other separate and independent
236
works, which are not by their nature extensions of the covered work,
237
and which are not combined with it such as to form a larger program,
238
in or on a volume of a storage or distribution medium, is called an
239
"aggregate" if the compilation and its resulting copyright are not
240
used to limit the access or legal rights of the compilation's users
241
beyond what the individual works permit.  Inclusion of a covered work
242
in an aggregate does not cause this License to apply to the other
243
parts of the aggregate.
244

  
245
  6. Conveying Non-Source Forms.
246

  
247
  You may convey a covered work in object code form under the terms
248
of sections 4 and 5, provided that you also convey the
249
machine-readable Corresponding Source under the terms of this License,
250
in one of these ways:
251

  
252
    a) Convey the object code in, or embodied in, a physical product
253
    (including a physical distribution medium), accompanied by the
254
    Corresponding Source fixed on a durable physical medium
255
    customarily used for software interchange.
256

  
257
    b) Convey the object code in, or embodied in, a physical product
258
    (including a physical distribution medium), accompanied by a
259
    written offer, valid for at least three years and valid for as
260
    long as you offer spare parts or customer support for that product
261
    model, to give anyone who possesses the object code either (1) a
262
    copy of the Corresponding Source for all the software in the
263
    product that is covered by this License, on a durable physical
264
    medium customarily used for software interchange, for a price no
265
    more than your reasonable cost of physically performing this
266
    conveying of source, or (2) access to copy the
267
    Corresponding Source from a network server at no charge.
268

  
269
    c) Convey individual copies of the object code with a copy of the
270
    written offer to provide the Corresponding Source.  This
271
    alternative is allowed only occasionally and noncommercially, and
272
    only if you received the object code with such an offer, in accord
273
    with subsection 6b.
274

  
275
    d) Convey the object code by offering access from a designated
276
    place (gratis or for a charge), and offer equivalent access to the
277
    Corresponding Source in the same way through the same place at no
278
    further charge.  You need not require recipients to copy the
279
    Corresponding Source along with the object code.  If the place to
280
    copy the object code is a network server, the Corresponding Source
281
    may be on a different server (operated by you or a third party)
282
    that supports equivalent copying facilities, provided you maintain
283
    clear directions next to the object code saying where to find the
284
    Corresponding Source.  Regardless of what server hosts the
285
    Corresponding Source, you remain obligated to ensure that it is
286
    available for as long as needed to satisfy these requirements.
287

  
288
    e) Convey the object code using peer-to-peer transmission, provided
289
    you inform other peers where the object code and Corresponding
290
    Source of the work are being offered to the general public at no
291
    charge under subsection 6d.
292

  
293
  A separable portion of the object code, whose source code is excluded
294
from the Corresponding Source as a System Library, need not be
295
included in conveying the object code work.
296

  
297
  A "User Product" is either (1) a "consumer product", which means any
298
tangible personal property which is normally used for personal, family,
299
or household purposes, or (2) anything designed or sold for incorporation
300
into a dwelling.  In determining whether a product is a consumer product,
301
doubtful cases shall be resolved in favor of coverage.  For a particular
302
product received by a particular user, "normally used" refers to a
303
typical or common use of that class of product, regardless of the status
304
of the particular user or of the way in which the particular user
305
actually uses, or expects or is expected to use, the product.  A product
306
is a consumer product regardless of whether the product has substantial
307
commercial, industrial or non-consumer uses, unless such uses represent
308
the only significant mode of use of the product.
309

  
310
  "Installation Information" for a User Product means any methods,
311
procedures, authorization keys, or other information required to install
312
and execute modified versions of a covered work in that User Product from
313
a modified version of its Corresponding Source.  The information must
314
suffice to ensure that the continued functioning of the modified object
315
code is in no case prevented or interfered with solely because
316
modification has been made.
317

  
318
  If you convey an object code work under this section in, or with, or
319
specifically for use in, a User Product, and the conveying occurs as
320
part of a transaction in which the right of possession and use of the
321
User Product is transferred to the recipient in perpetuity or for a
322
fixed term (regardless of how the transaction is characterized), the
323
Corresponding Source conveyed under this section must be accompanied
324
by the Installation Information.  But this requirement does not apply
325
if neither you nor any third party retains the ability to install
326
modified object code on the User Product (for example, the work has
327
been installed in ROM).
328

  
329
  The requirement to provide Installation Information does not include a
330
requirement to continue to provide support service, warranty, or updates
331
for a work that has been modified or installed by the recipient, or for
332
the User Product in which it has been modified or installed.  Access to a
333
network may be denied when the modification itself materially and
334
adversely affects the operation of the network or violates the rules and
335
protocols for communication across the network.
336

  
337
  Corresponding Source conveyed, and Installation Information provided,
338
in accord with this section must be in a format that is publicly
339
documented (and with an implementation available to the public in
340
source code form), and must require no special password or key for
341
unpacking, reading or copying.
342

  
343
  7. Additional Terms.
344

  
345
  "Additional permissions" are terms that supplement the terms of this
346
License by making exceptions from one or more of its conditions.
347
Additional permissions that are applicable to the entire Program shall
348
be treated as though they were included in this License, to the extent
349
that they are valid under applicable law.  If additional permissions
350
apply only to part of the Program, that part may be used separately
351
under those permissions, but the entire Program remains governed by
352
this License without regard to the additional permissions.
353

  
354
  When you convey a copy of a covered work, you may at your option
355
remove any additional permissions from that copy, or from any part of
356
it.  (Additional permissions may be written to require their own
357
removal in certain cases when you modify the work.)  You may place
358
additional permissions on material, added by you to a covered work,
359
for which you have or can give appropriate copyright permission.
360

  
361
  Notwithstanding any other provision of this License, for material you
362
add to a covered work, you may (if authorized by the copyright holders of
363
that material) supplement the terms of this License with terms:
364

  
365
    a) Disclaiming warranty or limiting liability differently from the
366
    terms of sections 15 and 16 of this License; or
367

  
368
    b) Requiring preservation of specified reasonable legal notices or
369
    author attributions in that material or in the Appropriate Legal
370
    Notices displayed by works containing it; or
371

  
372
    c) Prohibiting misrepresentation of the origin of that material, or
373
    requiring that modified versions of such material be marked in
374
    reasonable ways as different from the original version; or
375

  
376
    d) Limiting the use for publicity purposes of names of licensors or
377
    authors of the material; or
378

  
379
    e) Declining to grant rights under trademark law for use of some
380
    trade names, trademarks, or service marks; or
381

  
382
    f) Requiring indemnification of licensors and authors of that
383
    material by anyone who conveys the material (or modified versions of
384
    it) with contractual assumptions of liability to the recipient, for
385
    any liability that these contractual assumptions directly impose on
386
    those licensors and authors.
387

  
388
  All other non-permissive additional terms are considered "further
389
restrictions" within the meaning of section 10.  If the Program as you
390
received it, or any part of it, contains a notice stating that it is
391
governed by this License along with a term that is a further
392
restriction, you may remove that term.  If a license document contains
393
a further restriction but permits relicensing or conveying under this
394
License, you may add to a covered work material governed by the terms
395
of that license document, provided that the further restriction does
396
not survive such relicensing or conveying.
397

  
398
  If you add terms to a covered work in accord with this section, you
399
must place, in the relevant source files, a statement of the
400
additional terms that apply to those files, or a notice indicating
401
where to find the applicable terms.
402

  
403
  Additional terms, permissive or non-permissive, may be stated in the
404
form of a separately written license, or stated as exceptions;
405
the above requirements apply either way.
406

  
407
  8. Termination.
408

  
409
  You may not propagate or modify a covered work except as expressly
410
provided under this License.  Any attempt otherwise to propagate or
411
modify it is void, and will automatically terminate your rights under
412
this License (including any patent licenses granted under the third
413
paragraph of section 11).
414

  
415
  However, if you cease all violation of this License, then your
416
license from a particular copyright holder is reinstated (a)
417
provisionally, unless and until the copyright holder explicitly and
418
finally terminates your license, and (b) permanently, if the copyright
419
holder fails to notify you of the violation by some reasonable means
420
prior to 60 days after the cessation.
421

  
422
  Moreover, your license from a particular copyright holder is
423
reinstated permanently if the copyright holder notifies you of the
424
violation by some reasonable means, this is the first time you have
425
received notice of violation of this License (for any work) from that
426
copyright holder, and you cure the violation prior to 30 days after
427
your receipt of the notice.
428

  
429
  Termination of your rights under this section does not terminate the
430
licenses of parties who have received copies or rights from you under
431
this License.  If your rights have been terminated and not permanently
432
reinstated, you do not qualify to receive new licenses for the same
433
material under section 10.
434

  
435
  9. Acceptance Not Required for Having Copies.
436

  
437
  You are not required to accept this License in order to receive or
438
run a copy of the Program.  Ancillary propagation of a covered work
439
occurring solely as a consequence of using peer-to-peer transmission
440
to receive a copy likewise does not require acceptance.  However,
441
nothing other than this License grants you permission to propagate or
442
modify any covered work.  These actions infringe copyright if you do
443
not accept this License.  Therefore, by modifying or propagating a
444
covered work, you indicate your acceptance of this License to do so.
445

  
446
  10. Automatic Licensing of Downstream Recipients.
447

  
448
  Each time you convey a covered work, the recipient automatically
449
receives a license from the original licensors, to run, modify and
450
propagate that work, subject to this License.  You are not responsible
451
for enforcing compliance by third parties with this License.
452

  
453
  An "entity transaction" is a transaction transferring control of an
454
organization, or substantially all assets of one, or subdividing an
455
organization, or merging organizations.  If propagation of a covered
456
work results from an entity transaction, each party to that
457
transaction who receives a copy of the work also receives whatever
458
licenses to the work the party's predecessor in interest had or could
459
give under the previous paragraph, plus a right to possession of the
460
Corresponding Source of the work from the predecessor in interest, if
461
the predecessor has it or can get it with reasonable efforts.
462

  
463
  You may not impose any further restrictions on the exercise of the
464
rights granted or affirmed under this License.  For example, you may
465
not impose a license fee, royalty, or other charge for exercise of
466
rights granted under this License, and you may not initiate litigation
467
(including a cross-claim or counterclaim in a lawsuit) alleging that
468
any patent claim is infringed by making, using, selling, offering for
469
sale, or importing the Program or any portion of it.
470

  
471
  11. Patents.
472

  
473
  A "contributor" is a copyright holder who authorizes use under this
474
License of the Program or a work on which the Program is based.  The
475
work thus licensed is called the contributor's "contributor version".
476

  
477
  A contributor's "essential patent claims" are all patent claims
478
owned or controlled by the contributor, whether already acquired or
479
hereafter acquired, that would be infringed by some manner, permitted
480
by this License, of making, using, or selling its contributor version,
481
but do not include claims that would be infringed only as a
482
consequence of further modification of the contributor version.  For
483
purposes of this definition, "control" includes the right to grant
484
patent sublicenses in a manner consistent with the requirements of
485
this License.
486

  
487
  Each contributor grants you a non-exclusive, worldwide, royalty-free
488
patent license under the contributor's essential patent claims, to
489
make, use, sell, offer for sale, import and otherwise run, modify and
490
propagate the contents of its contributor version.
491

  
492
  In the following three paragraphs, a "patent license" is any express
493
agreement or commitment, however denominated, not to enforce a patent
494
(such as an express permission to practice a patent or covenant not to
495
sue for patent infringement).  To "grant" such a patent license to a
496
party means to make such an agreement or commitment not to enforce a
497
patent against the party.
498

  
499
  If you convey a covered work, knowingly relying on a patent license,
500
and the Corresponding Source of the work is not available for anyone
501
to copy, free of charge and under the terms of this License, through a
502
publicly available network server or other readily accessible means,
503
then you must either (1) cause the Corresponding Source to be so
504
available, or (2) arrange to deprive yourself of the benefit of the
505
patent license for this particular work, or (3) arrange, in a manner
506
consistent with the requirements of this License, to extend the patent
507
license to downstream recipients.  "Knowingly relying" means you have
508
actual knowledge that, but for the patent license, your conveying the
509
covered work in a country, or your recipient's use of the covered work
510
in a country, would infringe one or more identifiable patents in that
511
country that you have reason to believe are valid.
512

  
513
  If, pursuant to or in connection with a single transaction or
514
arrangement, you convey, or propagate by procuring conveyance of, a
515
covered work, and grant a patent license to some of the parties
516
receiving the covered work authorizing them to use, propagate, modify
517
or convey a specific copy of the covered work, then the patent license
518
you grant is automatically extended to all recipients of the covered
519
work and works based on it.
520

  
521
  A patent license is "discriminatory" if it does not include within
522
the scope of its coverage, prohibits the exercise of, or is
523
conditioned on the non-exercise of one or more of the rights that are
524
specifically granted under this License.  You may not convey a covered
525
work if you are a party to an arrangement with a third party that is
526
in the business of distributing software, under which you make payment
527
to the third party based on the extent of your activity of conveying
528
the work, and under which the third party grants, to any of the
529
parties who would receive the covered work from you, a discriminatory
530
patent license (a) in connection with copies of the covered work
531
conveyed by you (or copies made from those copies), or (b) primarily
532
for and in connection with specific products or compilations that
533
contain the covered work, unless you entered into that arrangement,
534
or that patent license was granted, prior to 28 March 2007.
535

  
536
  Nothing in this License shall be construed as excluding or limiting
537
any implied license or other defenses to infringement that may
538
otherwise be available to you under applicable patent law.
539

  
540
  12. No Surrender of Others' Freedom.
541

  
542
  If conditions are imposed on you (whether by court order, agreement or
543
otherwise) that contradict the conditions of this License, they do not
544
excuse you from the conditions of this License.  If you cannot convey a
545
covered work so as to satisfy simultaneously your obligations under this
546
License and any other pertinent obligations, then as a consequence you may
547
not convey it at all.  For example, if you agree to terms that obligate you
548
to collect a royalty for further conveying from those to whom you convey
549
the Program, the only way you could satisfy both those terms and this
550
License would be to refrain entirely from conveying the Program.
551

  
552
  13. Use with the GNU Affero General Public License.
553

  
554
  Notwithstanding any other provision of this License, you have
555
permission to link or combine any covered work with a work licensed
556
under version 3 of the GNU Affero General Public License into a single
557
combined work, and to convey the resulting work.  The terms of this
558
License will continue to apply to the part which is the covered work,
559
but the special requirements of the GNU Affero General Public License,
560
section 13, concerning interaction through a network will apply to the
561
combination as such.
562

  
563
  14. Revised Versions of this License.
564

  
565
  The Free Software Foundation may publish revised and/or new versions of
566
the GNU General Public License from time to time.  Such new versions will
567
be similar in spirit to the present version, but may differ in detail to
568
address new problems or concerns.
569

  
570
  Each version is given a distinguishing version number.  If the
571
Program specifies that a certain numbered version of the GNU General
572
Public License "or any later version" applies to it, you have the
573
option of following the terms and conditions either of that numbered
574
version or of any later version published by the Free Software
575
Foundation.  If the Program does not specify a version number of the
576
GNU General Public License, you may choose any version ever published
577
by the Free Software Foundation.
578

  
579
  If the Program specifies that a proxy can decide which future
580
versions of the GNU General Public License can be used, that proxy's
581
public statement of acceptance of a version permanently authorizes you
582
to choose that version for the Program.
583

  
584
  Later license versions may give you additional or different
585
permissions.  However, no additional obligations are imposed on any
586
author or copyright holder as a result of your choosing to follow a
587
later version.
588

  
589
  15. Disclaimer of Warranty.
590

  
591
  THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
592
APPLICABLE LAW.  EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
593
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
594
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
595
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
596
PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
597
IS WITH YOU.  SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
598
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
599

  
600
  16. Limitation of Liability.
601

  
602
  IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
603
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
604
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
605
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
606
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
607
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
608
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
609
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
610
SUCH DAMAGES.
611

  
612
  17. Interpretation of Sections 15 and 16.
613

  
614
  If the disclaimer of warranty and limitation of liability provided
615
above cannot be given local legal effect according to their terms,
616
reviewing courts shall apply local law that most closely approximates
617
an absolute waiver of all civil liability in connection with the
618
Program, unless a warranty or assumption of liability accompanies a
619
copy of the Program in return for a fee.
vendor/plugins/redmine_tags/README.rdoc
1
= Redmine Tags
2

  
3
Allows marking up different models in Redmine with tags.
4
Inspired by original redmine_tags of Eric Davis. But in
5
comparison extended with some code that was already wrote
6
as part of my own redmine taggable_issues branch.
7

  
8
== Supported models
9

  
10
* Issues
11

  
12
== License
13

  
14
This plugin is licensed under the GNU/GPL v3.
15
See COPYING and LICENSE for details.
vendor/plugins/redmine_tags/app/helpers/filters_helper.rb
1
# This file is a part of redmine_tags
2
# redMine plugin, that adds tagging support.
3
#
4
# Copyright (c) 2010 Aleksey V Zapparov AKA ixti
5
#
6
# redmine_tags is free software: you can redistribute it and/or modify
7
# it under the terms of the GNU General Public License as published by
8
# the Free Software Foundation, either version 3 of the License, or
9
# (at your option) any later version.
10
#
11
# redmine_tags is distributed in the hope that it will be useful,
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
# GNU General Public License for more details.
15
#
16
# You should have received a copy of the GNU General Public License
17
# along with redmine_tags.  If not, see <http://www.gnu.org/licenses/>.
18

  
19
module FiltersHelper
20
  # returns link to the page with issues filtered by specified filters
21
  # === parameters
22
  # * <i>title</i> = link title text
23
  # * <i>filters</i> = filters to be applied (see <tt>link_to_filter_options</tt> for details)
24
  # * <i>options</i> = (optional) base options of the link
25
  # === example
26
  # link_to_filter 'foobar', [[ :tags, '~', 'foobar' ]]
27
  # link_to_filter 'foobar', [[ :tags, '~', 'foobar' ]], :project_id => project
28
  def link_to_filter(title, filters, options = {})
29
    options.merge! link_to_filter_options(filters)
30
    link_to title, options
31
  end
32

  
33

  
34
  # returns hash suitable for passing it to the <tt>to_link</tt>
35
  # === parameters
36
  # * <i>filters</i> = array of arrays. each child array is an array of strings:
37
  #                    name, operator and value
38
  # === example
39
  # link_to 'foobar', link_to_filter_options [[ :tags, '~', 'foobar' ]]
40
  #
41
  # filters = [[ :tags, '~', 'bazbaz' ], [:status_id, 'o']]
42
  # link_to 'bazbaz', link_to_filter_options filters
43
  def link_to_filter_options(filters)
44
    options = {
45
      :controller => 'issues',
46
      :action => 'index',
47
      :set_filter => 1,
48
      :fields => [],
49
      :values => {},
50
      :operators => {}
51
    }
52

  
53
    filters.each do |f|
54
      name, operator, value = f
55
      options[:fields].push(name)
56
      options[:operators][name] = operator
57
      options[:values][name] = [value]
58
    end
59

  
60
    options
61
  end
62
end
vendor/plugins/redmine_tags/app/helpers/tags_helper.rb
1
# This file is a part of redmine_tags
2
# redMine plugin, that adds tagging support.
3
#
4
# Copyright (c) 2010 Aleksey V Zapparov AKA ixti
5
#
6
# redmine_tags is free software: you can redistribute it and/or modify
7
# it under the terms of the GNU General Public License as published by
8
# the Free Software Foundation, either version 3 of the License, or
9
# (at your option) any later version.
10
#
11
# redmine_tags is distributed in the hope that it will be useful,
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
... This diff was truncated because it exceeds the maximum size that can be displayed.

Also available in: Unified diff