0
0
Fork 1
Spiegel von https://github.com/paviliondev/discourse-custom-wizard.git synchronisiert 2024-09-19 23:31:11 +02:00

API Admin client-side cleanups

Dieser Commit ist enthalten in:
Angus McLeod 2019-06-03 09:40:54 +10:00
Ursprung cc98a14d15
Commit 22d1c6fd06
3 geänderte Dateien mit 40 neuen und 25 gelöschten Zeilen

Datei anzeigen

@ -10,15 +10,20 @@ export default Ember.Controller.extend({
notAuthorized: Ember.computed.not('api.authorized'),
authorizationTypes: ['oauth', 'basic'],
isOauth: Ember.computed.equal('api.authType', 'oauth'),
isBasicAuth: Ember.computed.equal('api.authType', 'basic'),
endpointMethods: ['GET', 'PUT', 'POST', 'PATCH', 'DELETE'],
saveDisabled: Ember.computed.empty('api.name'),
showRemove: Ember.computed.not('isNew'),
@computed('saveDisabled', 'authType', 'authUrl')
@computed('saveDisabled', 'api.authType', 'api.authUrl')
authDisabled(saveDisabled, authType, authUrl) {
return saveDisabled || !authType || !authUrl;
},
@computed('api.name', 'api.authType')
saveDisabled(name, authType) {
return !name || !authType;
},
@observes('api.title')
titleWatcher() {
const title = this.get('api.title');
@ -48,18 +53,19 @@ export default Ember.Controller.extend({
authorize() {
const api = this.get('api');
const { authType, authUrl, authParams } = api;
if (authType !== 'oauth') return;
let query = '?';
if (authType === 'oauth') {
query += `client_id=${api.clientId}&redirect_uri=${encodeURIComponent(api.redirectUri)}&response_type=code`;
query += `client_id=${api.clientId}`;
query += `&redirect_uri=${encodeURIComponent(api.redirectUri)}`;
query += `&response_type=code`;
if (authParams) {
authParams.forEach(p => {
query += `&${p.key}=${encodeURIComponent(p.value)}`;
});
}
} else {
// basic auth - no need to authorize separately
if (authParams) {
authParams.forEach(p => {
query += `&${p.key}=${encodeURIComponent(p.value)}`;
});
}
window.location.href = authUrl + query;
@ -68,15 +74,18 @@ export default Ember.Controller.extend({
save() {
const api = this.get('api');
const name = api.name;
const authType = api.authType;
let refreshList = false;
if (!name ) return;
if (!name || !authType) return;
let data = {
title: api.title
auth_type: authType
};
if (this.get('isNew') || (api.title !== this.get('originalTitle'))) {
if (api.title) data['title'] = api.title;
if (api.get('isNew') || (api.title !== this.get('originalTitle'))) {
refreshList = true;
}
@ -84,10 +93,8 @@ export default Ember.Controller.extend({
data['new'] = true;
};
if (api.authType) data['auth_type'] = api.authType;
if (api.authUrl) data['auth_url'] = api.authUrl;
if (data.auth_type === 'oauth') {
if (authType === 'oauth') {
data['auth_url'] = api.authUrl;
data['client_id'] = api.clientId;
data['client_secret'] = api.clientSecret;
@ -98,13 +105,13 @@ export default Ember.Controller.extend({
}
data['token_url'] = api.tokenUrl;
} else {
} else if (authType === 'basic') {
data['username'] = api.username;
data['password'] = api.password;
}
const endpoints = api.endpoints;
if (endpoints.length) {
data['endpoints'] = JSON.stringify(endpoints);
}

Datei anzeigen

@ -34,7 +34,12 @@
</div>
<div class="actions">
{{d-button label="admin.wizard.api.auth.btn" action="authorize" disabled=authDisabled class="btn-primary"}}
{{#if isOauth}}
{{d-button label="admin.wizard.api.auth.btn"
action="authorize"
disabled=authDisabled
class="btn-primary"}}
{{/if}}
</div>
</div>
@ -107,7 +112,9 @@
{{d-button label='admin.wizard.api.auth.params.new' icon='plus' action='addParam'}}
</div>
</div>
{{else}}
{{/if}}
{{#if isBasicAuth}}
<div class="control-group">
<label>{{i18n 'admin.wizard.api.auth.username'}}</label>
<div class="controls">

Datei anzeigen

@ -334,9 +334,6 @@
margin-bottom: 20px;
.settings {
border-right: 1px solid #333;
margin-right: 20px;
padding-right: 20px;
width: 50%;
max-width: 50%;
}
@ -352,6 +349,9 @@
}
.status {
border-left: 1px solid $primary;
margin-left: 20px;
padding-left: 20px;
width: 50%;
max-width: 50%;
@ -384,6 +384,7 @@
.endpoint {
display: flex;
margin-top: 20px;
.combo-box {
width: 200px;