Unify API keys and web hooks into a single admin nav header.
This commit is contained in:
parent
fa6b10cf3c
commit
547750e9dd
|
@ -0,0 +1,7 @@
|
||||||
|
import RESTAdapter from 'discourse/adapters/rest';
|
||||||
|
|
||||||
|
export default RESTAdapter.extend({
|
||||||
|
basePath() {
|
||||||
|
return '/admin/api/';
|
||||||
|
}
|
||||||
|
});
|
|
@ -0,0 +1,7 @@
|
||||||
|
import RESTAdapter from 'discourse/adapters/rest';
|
||||||
|
|
||||||
|
export default RESTAdapter.extend({
|
||||||
|
basePath() {
|
||||||
|
return '/admin/api/';
|
||||||
|
}
|
||||||
|
});
|
|
@ -33,7 +33,7 @@ export default Ember.Component.extend({
|
||||||
redeliver() {
|
redeliver() {
|
||||||
return bootbox.confirm(I18n.t('admin.web_hooks.events.redeliver_confirm'), I18n.t('no_value'), I18n.t('yes_value'), result => {
|
return bootbox.confirm(I18n.t('admin.web_hooks.events.redeliver_confirm'), I18n.t('no_value'), I18n.t('yes_value'), result => {
|
||||||
if (result) {
|
if (result) {
|
||||||
ajax(`/admin/web_hooks/${this.get('model.web_hook_id')}/events/${this.get('model.id')}/redeliver`, { type: 'POST' }).then(json => {
|
ajax(`/admin/api/web_hooks/${this.get('model.web_hook_id')}/events/${this.get('model.id')}/redeliver`, { type: 'POST' }).then(json => {
|
||||||
this.set('model', json.web_hook_event);
|
this.set('model', json.web_hook_event);
|
||||||
}).catch(popupAjaxError);
|
}).catch(popupAjaxError);
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,7 +41,7 @@ export default Ember.Controller.extend({
|
||||||
ping() {
|
ping() {
|
||||||
this.set('pingDisabled', true);
|
this.set('pingDisabled', true);
|
||||||
|
|
||||||
ajax(`/admin/web_hooks/${this.get('model.extras.web_hook_id')}/ping`, {
|
ajax(`/admin/api/web_hooks/${this.get('model.extras.web_hook_id')}/ping`, {
|
||||||
type: 'POST'
|
type: 'POST'
|
||||||
}).catch(error => {
|
}).catch(error => {
|
||||||
this.set('pingDisabled', false);
|
this.set('pingDisabled', false);
|
||||||
|
@ -52,7 +52,7 @@ export default Ember.Controller.extend({
|
||||||
showInserted() {
|
showInserted() {
|
||||||
const webHookId = this.get('model.extras.web_hook_id');
|
const webHookId = this.get('model.extras.web_hook_id');
|
||||||
|
|
||||||
ajax(`/admin/web_hooks/${webHookId}/events/bulk`, {
|
ajax(`/admin/api/web_hooks/${webHookId}/events/bulk`, {
|
||||||
type: 'GET',
|
type: 'GET',
|
||||||
data: { ids: this.get('incomingEventIds') }
|
data: { ids: this.get('incomingEventIds') }
|
||||||
}).then(data => {
|
}).then(data => {
|
||||||
|
|
|
@ -52,7 +52,7 @@ ApiKey.reopenClass({
|
||||||
@returns {Promise} a promise that resolves to the array of `ApiKey` instances
|
@returns {Promise} a promise that resolves to the array of `ApiKey` instances
|
||||||
**/
|
**/
|
||||||
find: function() {
|
find: function() {
|
||||||
return ajax("/admin/api").then(function(keys) {
|
return ajax("/admin/api/keys").then(function(keys) {
|
||||||
return keys.map(function (key) {
|
return keys.map(function (key) {
|
||||||
return ApiKey.create(key);
|
return ApiKey.create(key);
|
||||||
});
|
});
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
export default Ember.Route.extend({
|
||||||
|
beforeModel() {
|
||||||
|
this.transitionTo('adminApiKeys');
|
||||||
|
}
|
||||||
|
});
|
|
@ -35,11 +35,15 @@ export default {
|
||||||
this.route('edit', { path: '/:id' });
|
this.route('edit', { path: '/:id' });
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
this.route('api');
|
|
||||||
|
this.resource('adminApi', { path: '/api' }, function() {
|
||||||
|
this.resource('adminApiKeys', { path: '/keys' });
|
||||||
|
|
||||||
this.resource('adminWebHooks', { path: '/web_hooks' }, function() {
|
this.resource('adminWebHooks', { path: '/web_hooks' }, function() {
|
||||||
this.route('show', { path: '/:web_hook_id' });
|
this.route('show', { path: '/:web_hook_id' });
|
||||||
this.route('showEvents', { path: '/:web_hook_id/events' });
|
this.route('showEvents', { path: '/:web_hook_id/events' });
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
|
||||||
this.resource('admin.backups', { path: '/backups' }, function() {
|
this.resource('admin.backups', { path: '/backups' }, function() {
|
||||||
this.route('logs');
|
this.route('logs');
|
||||||
|
|
|
@ -13,6 +13,6 @@ export default Discourse.Route.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
renderTemplate() {
|
renderTemplate() {
|
||||||
this.render('admin/templates/web-hooks-show-events', { into: 'admin' });
|
this.render('admin/templates/web-hooks-show-events', { into: 'adminApi' });
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -21,6 +21,6 @@ export default Discourse.Route.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
renderTemplate() {
|
renderTemplate() {
|
||||||
this.render('admin/templates/web-hooks-show', { into: 'admin' });
|
this.render('admin/templates/web-hooks-show', { into: 'adminApi' });
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -19,8 +19,7 @@
|
||||||
{{nav-item route='adminLogs' label='admin.logs.title'}}
|
{{nav-item route='adminLogs' label='admin.logs.title'}}
|
||||||
{{#if currentUser.admin}}
|
{{#if currentUser.admin}}
|
||||||
{{nav-item route='adminCustomize' label='admin.customize.title'}}
|
{{nav-item route='adminCustomize' label='admin.customize.title'}}
|
||||||
{{nav-item route='admin.api' label='admin.api.title'}}
|
{{nav-item route='adminApi' label='admin.api.title'}}
|
||||||
{{nav-item route='adminWebHooks' label='admin.web_hooks.title'}}
|
|
||||||
{{nav-item route='admin.backups' label='admin.backups.title'}}
|
{{nav-item route='admin.backups' label='admin.backups.title'}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{nav-item route='adminPlugins' label='admin.plugins.title'}}
|
{{nav-item route='adminPlugins' label='admin.plugins.title'}}
|
||||||
|
|
|
@ -0,0 +1,34 @@
|
||||||
|
{{#if model}}
|
||||||
|
<table class='api-keys'>
|
||||||
|
<tr>
|
||||||
|
<th>{{i18n 'admin.api.key'}}</th>
|
||||||
|
<th>{{i18n 'admin.api.user'}}</th>
|
||||||
|
<th> </th>
|
||||||
|
</tr>
|
||||||
|
{{#each model as |k|}}
|
||||||
|
<tr>
|
||||||
|
<td class='key'>{{k.key}}</td>
|
||||||
|
<td>
|
||||||
|
{{#if k.user}}
|
||||||
|
{{#link-to 'adminUser' k.user}}
|
||||||
|
{{avatar k.user imageSize="small"}}
|
||||||
|
{{/link-to}}
|
||||||
|
{{else}}
|
||||||
|
{{i18n 'admin.api.all_users'}}
|
||||||
|
{{/if}}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{{d-button action="regenerateKey" actionParam=k icon="undo" label='admin.api.regenerate'}}
|
||||||
|
{{d-button action="revokeKey" actionParam=k icon="times" label='admin.api.revoke'}}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{{/each}}
|
||||||
|
</table>
|
||||||
|
{{else}}
|
||||||
|
<p>{{i18n 'admin.api.none'}}</p>
|
||||||
|
{{/if}}
|
||||||
|
|
||||||
|
{{#unless hasMasterKey}}
|
||||||
|
<button class='btn' {{action "generateMasterKey"}}><i class="fa fa-key"></i>{{i18n 'admin.api.generate_master'}}</button>
|
||||||
|
{{/unless }}
|
||||||
|
|
|
@ -1,33 +1,10 @@
|
||||||
{{#if model}}
|
<div class="api">
|
||||||
<table class='api-keys'>
|
{{#admin-nav}}
|
||||||
<tr>
|
{{nav-item route='adminApiKeys' label='admin.api.title'}}
|
||||||
<th>{{i18n 'admin.api.key'}}</th>
|
{{nav-item route='adminWebHooks' label='admin.web_hooks.title'}}
|
||||||
<th>{{i18n 'admin.api.user'}}</th>
|
{{/admin-nav}}
|
||||||
<th> </th>
|
|
||||||
</tr>
|
|
||||||
{{#each model as |k|}}
|
|
||||||
<tr>
|
|
||||||
<td class='key'>{{k.key}}</td>
|
|
||||||
<td>
|
|
||||||
{{#if k.user}}
|
|
||||||
{{#link-to 'adminUser' k.user}}
|
|
||||||
{{avatar k.user imageSize="small"}}
|
|
||||||
{{/link-to}}
|
|
||||||
{{else}}
|
|
||||||
{{i18n 'admin.api.all_users'}}
|
|
||||||
{{/if}}
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
<button class='btn' {{action "regenerateKey" k}}><i class="fa fa-undo"></i>{{i18n 'admin.api.regenerate'}}</button>
|
|
||||||
<button class='btn' {{action "revokeKey" k}}><i class="fa fa-times"></i>{{i18n 'admin.api.revoke'}}</button>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
{{/each}}
|
|
||||||
</table>
|
|
||||||
{{else}}
|
|
||||||
<p>{{i18n 'admin.api.none'}}</p>
|
|
||||||
{{/if}}
|
|
||||||
|
|
||||||
{{#unless hasMasterKey}}
|
<div class="admin-container">
|
||||||
<button class='btn' {{action "generateMasterKey"}}><i class="fa fa-key"></i>{{i18n 'admin.api.generate_master'}}</button>
|
{{outlet}}
|
||||||
{{/unless }}
|
</div>
|
||||||
|
</div>
|
||||||
|
|
|
@ -63,7 +63,7 @@ class Admin::WebHooksController < Admin::AdminController
|
||||||
json = {
|
json = {
|
||||||
web_hook_events: serialize_data(@web_hook.web_hook_events.limit(limit).offset(offset), AdminWebHookEventSerializer),
|
web_hook_events: serialize_data(@web_hook.web_hook_events.limit(limit).offset(offset), AdminWebHookEventSerializer),
|
||||||
total_rows_web_hook_events: @web_hook.web_hook_events.count,
|
total_rows_web_hook_events: @web_hook.web_hook_events.count,
|
||||||
load_more_web_hook_events: admin_web_hook_events_path(limit: limit, offset: offset + limit, format: :json),
|
load_more_web_hook_events: web_hook_events_admin_api_index_path(limit: limit, offset: offset + limit, format: :json),
|
||||||
extras: {
|
extras: {
|
||||||
web_hook_id: @web_hook.id
|
web_hook_id: @web_hook.id
|
||||||
}
|
}
|
||||||
|
|
|
@ -2413,7 +2413,6 @@ en:
|
||||||
flair_preview: "Preview"
|
flair_preview: "Preview"
|
||||||
flair_note: "Note: Flair will only show for a user's primary group."
|
flair_note: "Note: Flair will only show for a user's primary group."
|
||||||
|
|
||||||
|
|
||||||
api:
|
api:
|
||||||
generate_master: "Generate Master API Key"
|
generate_master: "Generate Master API Key"
|
||||||
none: "There are no active API keys right now."
|
none: "There are no active API keys right now."
|
||||||
|
|
|
@ -200,18 +200,19 @@ Discourse::Application.routes.draw do
|
||||||
|
|
||||||
resources :api, only: [:index], constraints: AdminConstraint.new do
|
resources :api, only: [:index], constraints: AdminConstraint.new do
|
||||||
collection do
|
collection do
|
||||||
|
get "keys" => "api#index"
|
||||||
post "key" => "api#create_master_key"
|
post "key" => "api#create_master_key"
|
||||||
put "key" => "api#regenerate_key"
|
put "key" => "api#regenerate_key"
|
||||||
delete "key" => "api#revoke_key"
|
delete "key" => "api#revoke_key"
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
resources :web_hooks, constraints: AdminConstraint.new
|
resources :web_hooks
|
||||||
get 'web_hook_events/:id' => 'web_hooks#list_events', constraints: AdminConstraint.new, as: :web_hook_events
|
get 'web_hook_events/:id' => 'web_hooks#list_events', as: :web_hook_events
|
||||||
get 'web_hooks/:id/events' => 'web_hooks#list_events', constraints: AdminConstraint.new
|
get 'web_hooks/:id/events' => 'web_hooks#list_events'
|
||||||
get 'web_hooks/:id/events/bulk' => 'web_hooks#bulk_events', constraints: AdminConstraint.new
|
get 'web_hooks/:id/events/bulk' => 'web_hooks#bulk_events'
|
||||||
post 'web_hooks/:web_hook_id/events/:event_id/redeliver' => 'web_hooks#redeliver_event', constraints: AdminConstraint.new
|
post 'web_hooks/:web_hook_id/events/:event_id/redeliver' => 'web_hooks#redeliver_event'
|
||||||
post 'web_hooks/:id/ping' => 'web_hooks#ping', constraints: AdminConstraint.new
|
post 'web_hooks/:id/ping' => 'web_hooks#ping'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
resources :backups, only: [:index, :create], constraints: AdminConstraint.new do
|
resources :backups, only: [:index, :create], constraints: AdminConstraint.new do
|
||||||
member do
|
member do
|
||||||
|
|
Loading…
Reference in New Issue