OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/app/views/my/access_token.html.erb

176 lines
6.8 KiB

<%#-- copyright
OpenProject is a project management system.
Copyright (C) 2012-2018 the OpenProject Foundation (OPF)
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License version 3.
OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
Copyright (C) 2006-2017 Jean-Philippe Lang
Copyright (C) 2010-2013 the ChiliProject Team
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
See docs/COPYRIGHT.rdoc for more details.
++#%>
<% html_title(l(:label_my_account), I18n.t('my_account.access_tokens.access_token')) -%>
<% breadcrumb_paths(l(:label_my_account), I18n.t('my_account.access_tokens.access_token')) %>
<%= toolbar title: I18n.t('my_account.access_tokens.access_token') %>
<p><%= l(:text_access_token_hint) %></p>
<% if has_tokens? %>
<div class="generic-table--container">
<div class="generic-table--results-container" style="max-height: 340px;">
<table id="access-token-table" class="generic-table">
<colgroup>
<col highlight-col>
<col highlight-col>
<col highlight-col>
<col highlight-col>
</colgroup>
<thead>
<tr>
<th>
<div class="generic-table--sort-header-outer">
<div class="generic-table--sort-header">
<%= l('attributes.name') %>
</div>
</div>
</th>
<th>
<div class="generic-table--sort-header-outer">
<div class="generic-table--sort-header">
<%= User.human_attribute_name(:created_on) %>
</div>
</div>
</th>
<th>
<div class="generic-table--sort-header-outer">
<div class="generic-table--sort-header">
<%= I18n.t('my_account.access_tokens.headers.expiration') %>
</div>
</div>
</th>
<th>
<div class="generic-table--sort-header-outer">
<div class="generic-table--sort-header">
<%= I18n.t('my_account.access_tokens.headers.action') %>
</div>
</div>
</th>
</tr>
</thead>
<tbody>
<% if Setting.feeds_enabled? %>
<% if @user.rss_token %>
<tr>
<td><%= l(:label_feeds_access_key_type) %></td>
<td>
<span title="<%= format_time(@user.rss_token.created_on) %>">
<%= format_time(@user.rss_token.created_on.to_s) %>
</span>
</td>
<td><%= I18n.t('my_account.access_tokens.indefinite_expiration') %></td>
<td>
<%= link_to l(:button_reset),
{ action: 'generate_rss_key' },
method: :post,
class: 'icon icon-delete' %>
</td>
</tr>
<% else %>
<tr>
<td><%= l(:label_feeds_access_key_type) %></td>
<td><%= l(:label_missing_feeds_access_key) %></td>
<td></td>
<td>
<%= link_to l(:button_generate),
{ action: 'generate_rss_key' },
method: :post,
class: 'icon icon-key' %>
</a>
</td>
</tr>
<% end %>
<% end %>
<% if Setting.rest_api_enabled? %>
<% if @user.api_token %>
<tr>
<td><%= l(:label_api_access_key_type) %></td>
<td>
<span title="<%= format_time(@user.api_token.created_on) %>">
<%= format_time(@user.api_token.created_on.to_s) %>
</span>
</td>
<td><%= I18n.t('my_account.access_tokens.indefinite_expiration') %></td>
<td>
<%= link_to l(:button_reset),
{ action: 'generate_api_key' },
method: :post,
class: 'icon icon-delete' %>
</td>
</tr>
<% else %>
<tr>
<td><%= l(:label_api_access_key_type) %></td>
<td><%= l(:label_missing_api_access_key) %></td>
<td></td>
<td>
<%= link_to l(:button_generate),
{ action: 'generate_api_key' },
method: :post,
class: 'icon icon-key' %>
</a>
</td>
</tr>
<% end %>
<% end %>
<% granted_applications.each do |application, tokens| %>
<% latest = tokens.sort_by(&:created_at).last %>
<tr id="oauth-application-grant-<%= application.id %>">
<td>
<%= t('oauth.application.named', name: application.name) %>
&nbsp;
(<%= t('oauth.x_active_tokens', count: tokens.count) %>)
</td>
<td>
<span><%= format_time(latest.created_at) %></span>
</td>
<td>
<span><%= format_time(latest.created_at + latest.expires_in.seconds) %></span>
</td>
<td>
<%= link_to t(:button_revoke),
revoke_my_oauth_application_path(application_id: application.id),
data: { confirm: I18n.t('oauth.revoke_my_application_confirmation',
token_count: t('oauth.x_active_tokens', count: tokens.count)) },
method: :post,
class: 'icon icon-delete' %>
</td>
</tr>
<% end %>
<%= call_hook(:view_access_tokens_table, user: @user) %>
</tbody>
</table>
</div>
</div>
<% else %>
<%= no_results_box %>
<% end %>