2020-05-05 17:29:35 +01:00
|
|
|
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 = () => ({});
|
|
|
|
}
|
2020-11-09 17:29:12 +00:00
|
|
|
|
|
|
|
export default class OidcProviderAdapter extends Adapter {
|
|
|
|
@service('env') env;
|
|
|
|
|
|
|
|
requestForQuery(request, { dc, ns, index, uri }) {
|
2020-05-05 17:29:35 +01:00
|
|
|
return request`
|
|
|
|
GET /v1/internal/ui/oidc-auth-methods?${{ dc }}
|
2020-07-17 14:42:45 +01:00
|
|
|
X-Request-ID: ${uri}
|
2020-05-05 17:29:35 +01:00
|
|
|
|
|
|
|
${{
|
|
|
|
index,
|
|
|
|
...this.formatNspace(ns),
|
|
|
|
}}
|
|
|
|
`;
|
2020-11-09 17:29:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
requestForQueryRecord(request, { dc, ns, id }) {
|
2020-05-05 17:29:35 +01:00
|
|
|
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,
|
2020-05-11 16:37:11 +01:00
|
|
|
RedirectURI: `${this.env.var('CONSUL_BASE_UI_URL')}/oidc/callback`,
|
2020-05-05 17:29:35 +01:00
|
|
|
}}
|
|
|
|
`;
|
2020-11-09 17:29:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
requestForAuthorize(request, { dc, ns, id, code, state }) {
|
2020-05-05 17:29:35 +01:00
|
|
|
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,
|
|
|
|
}}
|
|
|
|
`;
|
2020-11-09 17:29:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
requestForLogout(request, { id }) {
|
2020-05-05 17:29:35 +01:00
|
|
|
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}
|
|
|
|
`;
|
2020-11-09 17:29:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
authorize(store, type, id, snapshot) {
|
2020-07-13 14:23:15 +01:00
|
|
|
return this.rpc(
|
2020-05-05 17:29:35 +01:00
|
|
|
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
|
|
|
|
);
|
2020-11-09 17:29:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
logout(store, type, id, snapshot) {
|
2020-07-13 14:23:15 +01:00
|
|
|
return this.rpc(
|
2020-05-05 17:29:35 +01:00
|
|
|
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
|
|
|
|
);
|
2020-11-09 17:29:12 +00:00
|
|
|
}
|
|
|
|
}
|