mirror of
https://github.com/status-im/consul.git
synced 2025-01-22 03:29:43 +00:00
6589cbbd0d
* ui: Add the most basic workspace root in /ui * We already have a LICENSE file in the repository root * Change directory path in build scripts ui-v2 -> ui * Make yarn install flags configurable from elsewhere * Minimal workspace root makefile * Call the new docker specific target * Update yarn in the docker build image * Reconfigure the netlify target and move to the higher makefile * Move ui-v2 -> ui/packages/consul-ui * Change repo root to refleect new folder structure * Temporarily don't hoist consul-api-double * Fixup CI configuration * Fixup lint errors * Fixup Netlify target
84 lines
2.2 KiB
JavaScript
84 lines
2.2 KiB
JavaScript
import Adapter from './application';
|
|
import { SLUG_KEY } from 'consul-ui/models/nspace';
|
|
|
|
// namespaces aren't categorized by datacenter, therefore no dc
|
|
export default Adapter.extend({
|
|
requestForQuery: function(request, { index, uri }) {
|
|
return request`
|
|
GET /v1/namespaces
|
|
X-Request-ID: ${uri}
|
|
|
|
${{ index }}
|
|
`;
|
|
},
|
|
requestForQueryRecord: function(request, { index, id }) {
|
|
if (typeof id === 'undefined') {
|
|
throw new Error('You must specify an name');
|
|
}
|
|
return request`
|
|
GET /v1/namespace/${id}
|
|
|
|
${{ index }}
|
|
`;
|
|
},
|
|
requestForCreateRecord: function(request, serialized, data) {
|
|
return request`
|
|
PUT /v1/namespace/${data[SLUG_KEY]}
|
|
|
|
${{
|
|
Name: serialized.Name,
|
|
Description: serialized.Description,
|
|
ACLs: {
|
|
PolicyDefaults: serialized.ACLs.PolicyDefaults.map(item => ({ ID: item.ID })),
|
|
RoleDefaults: serialized.ACLs.RoleDefaults.map(item => ({ ID: item.ID })),
|
|
},
|
|
}}
|
|
`;
|
|
},
|
|
requestForUpdateRecord: function(request, serialized, data) {
|
|
return request`
|
|
PUT /v1/namespace/${data[SLUG_KEY]}
|
|
|
|
${{
|
|
Description: serialized.Description,
|
|
ACLs: {
|
|
PolicyDefaults: serialized.ACLs.PolicyDefaults.map(item => ({ ID: item.ID })),
|
|
RoleDefaults: serialized.ACLs.RoleDefaults.map(item => ({ ID: item.ID })),
|
|
},
|
|
}}
|
|
`;
|
|
},
|
|
requestForDeleteRecord: function(request, serialized, data) {
|
|
return request`
|
|
DELETE /v1/namespace/${data[SLUG_KEY]}
|
|
`;
|
|
},
|
|
requestForAuthorize: function(request, { dc, ns, index }) {
|
|
return request`
|
|
POST /v1/internal/acl/authorize?${{ dc, ns, index }}
|
|
|
|
${[
|
|
{
|
|
Resource: 'operator',
|
|
Access: 'write',
|
|
},
|
|
]}
|
|
`;
|
|
},
|
|
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) {
|
|
// Completely skip the serializer here
|
|
return respond(function(headers, body) {
|
|
return body;
|
|
});
|
|
},
|
|
snapshot,
|
|
type.modelName
|
|
);
|
|
},
|
|
});
|