8cb402eae7
* Add uri identifiers to all data source things and make them the same 1. Add uri identitifer to data-source service 2. Make <EventSource /> and <DataSource /> as close as possible 3. Add extra `.closed` method to get a list of inactive/closed/closing data-sources from elsewhere * Make the connections cleanup the least worst connection when required * Pass the uri/request id through all the things * Better user erroring * Make event sources close on error * Allow <DataLoader /> data slot to be configurable * Allow the <DataWriter /> removed state to be configurable * Don't error if meta is undefined * Stitch together all the repositories into the data-source/sink * Use data.source over repositories * Add missing <EventSource /> components * Fix up the views/templates * Disable all the old route based blocking query things * We still need the repo for the mixin for the moment * Don't default to default, default != ''
99 lines
2.6 KiB
JavaScript
99 lines
2.6 KiB
JavaScript
import Adapter from './application';
|
|
import { inject as service } from '@ember/service';
|
|
|
|
import { env } from 'consul-ui/env';
|
|
import nonEmptySet from 'consul-ui/utils/non-empty-set';
|
|
|
|
let Namespace;
|
|
if (env('CONSUL_NSPACES_ENABLED')) {
|
|
Namespace = nonEmptySet('Namespace');
|
|
} else {
|
|
Namespace = () => ({});
|
|
}
|
|
export default Adapter.extend({
|
|
env: service('env'),
|
|
requestForQuery: function(request, { dc, ns, index, uri }) {
|
|
return request`
|
|
GET /v1/internal/ui/oidc-auth-methods?${{ dc }}
|
|
X-Request-ID: ${uri}
|
|
|
|
${{
|
|
index,
|
|
...this.formatNspace(ns),
|
|
}}
|
|
`;
|
|
},
|
|
requestForQueryRecord: function(request, { dc, ns, id }) {
|
|
if (typeof id === 'undefined') {
|
|
throw new Error('You must specify an id');
|
|
}
|
|
return request`
|
|
POST /v1/acl/oidc/auth-url?${{ dc }}
|
|
Cache-Control: no-store
|
|
|
|
${{
|
|
...Namespace(ns),
|
|
AuthMethod: id,
|
|
RedirectURI: `${this.env.var('CONSUL_BASE_UI_URL')}/oidc/callback`,
|
|
}}
|
|
`;
|
|
},
|
|
requestForAuthorize: function(request, { dc, ns, id, code, state }) {
|
|
if (typeof id === 'undefined') {
|
|
throw new Error('You must specify an id');
|
|
}
|
|
if (typeof code === 'undefined') {
|
|
throw new Error('You must specify an code');
|
|
}
|
|
if (typeof state === 'undefined') {
|
|
throw new Error('You must specify an state');
|
|
}
|
|
return request`
|
|
POST /v1/acl/oidc/callback?${{ dc }}
|
|
Cache-Control: no-store
|
|
|
|
${{
|
|
...Namespace(ns),
|
|
AuthMethod: id,
|
|
Code: code,
|
|
State: state,
|
|
}}
|
|
`;
|
|
},
|
|
requestForLogout: function(request, { id }) {
|
|
if (typeof id === 'undefined') {
|
|
throw new Error('You must specify an id');
|
|
}
|
|
return request`
|
|
POST /v1/acl/logout
|
|
Cache-Control: no-store
|
|
X-Consul-Token: ${id}
|
|
`;
|
|
},
|
|
authorize: function(store, type, id, snapshot) {
|
|
return this.rpc(
|
|
function(adapter, request, serialized, unserialized) {
|
|
return adapter.requestForAuthorize(request, serialized, unserialized);
|
|
},
|
|
function(serializer, respond, serialized, unserialized) {
|
|
return serializer.respondForAuthorize(respond, serialized, unserialized);
|
|
},
|
|
snapshot,
|
|
type.modelName
|
|
);
|
|
},
|
|
logout: function(store, type, id, snapshot) {
|
|
return this.rpc(
|
|
function(adapter, request, serialized, unserialized) {
|
|
return adapter.requestForLogout(request, serialized, unserialized);
|
|
},
|
|
function(serializer, respond, serialized, unserialized) {
|
|
// its ok to return nothing here for the moment at least
|
|
return {};
|
|
},
|
|
snapshot,
|
|
type.modelName
|
|
);
|
|
},
|
|
});
|