import Adapter from './application'; import { SLUG_KEY } from 'consul-ui/models/nspace'; // namespaces aren't categorized by datacenter, therefore no dc export default class NspaceAdapter extends Adapter { requestForQuery(request, { index, uri }) { return request` GET /v1/namespaces X-Request-ID: ${uri} ${{ index }} `; } requestForQueryRecord(request, { index, id }) { if (typeof id === 'undefined') { throw new Error('You must specify an name'); } return request` GET /v1/namespace/${id} ${{ index }} `; } requestForCreateRecord(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(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(request, serialized, data) { return request` DELETE /v1/namespace/${data[SLUG_KEY]} `; } requestForAuthorize(request, { dc, ns, index }) { return request` POST /v1/internal/acl/authorize?${{ dc, ns, index }} ${[ { Resource: 'operator', Access: 'write', }, ]} `; } authorize(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 ); } }