mirror of
https://github.com/status-im/consul.git
synced 2025-01-24 20:51:10 +00:00
5fb9df1640
* Adding explicit MPL license for sub-package This directory and its subdirectories (packages) contain files licensed with the MPLv2 `LICENSE` file in this directory and are intentionally licensed separately from the BSL `LICENSE` file at the root of this repository. * Adding explicit MPL license for sub-package This directory and its subdirectories (packages) contain files licensed with the MPLv2 `LICENSE` file in this directory and are intentionally licensed separately from the BSL `LICENSE` file at the root of this repository. * Updating the license from MPL to Business Source License Going forward, this project will be licensed under the Business Source License v1.1. Please see our blog post for more details at <Blog URL>, FAQ at www.hashicorp.com/licensing-faq, and details of the license at www.hashicorp.com/bsl. * add missing license headers * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 --------- Co-authored-by: hashicorp-copywrite[bot] <110428419+hashicorp-copywrite[bot]@users.noreply.github.com>
141 lines
4.1 KiB
JavaScript
141 lines
4.1 KiB
JavaScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import Adapter from './application';
|
|
import { get } from '@ember/object';
|
|
|
|
// Intentions have different namespacing to the rest of the UI in that the don't
|
|
// have a Namespace property, the DestinationNS is essentially its namespace.
|
|
// Listing of intentions still requires the `ns` query string parameter which
|
|
// will give us all the intentions that have the `ns` as either the SourceNS or
|
|
// the DestinationNS.
|
|
|
|
// TODO: Investigate the above to see if we should only list intentions with
|
|
// Source/Destination in the currently selected nspace or leave as is.
|
|
export default class IntentionAdapter extends Adapter {
|
|
requestForQuery(request, { dc, ns, partition, filter, index, uri }) {
|
|
return request`
|
|
GET /v1/connect/intentions?${{ dc }}
|
|
X-Request-ID: ${uri}${
|
|
typeof filter !== 'undefined'
|
|
? `
|
|
X-Range: ${filter}`
|
|
: ``
|
|
}
|
|
|
|
${{
|
|
partition,
|
|
ns: '*',
|
|
index,
|
|
filter,
|
|
}}
|
|
`;
|
|
}
|
|
|
|
requestForQueryRecord(request, { dc, index, id }) {
|
|
if (typeof id === 'undefined') {
|
|
throw new Error('You must specify an id');
|
|
}
|
|
|
|
// get the information we need from the id, which has been previously
|
|
// encoded
|
|
if (id.match(/^peer:/)) {
|
|
// id indicates we are dealing with a peered intention - handle this with
|
|
// different query-param for source - we need to prepend the peer
|
|
const [
|
|
peerIdentifier,
|
|
SourcePeer,
|
|
SourceNS,
|
|
SourceName,
|
|
DestinationPartition,
|
|
DestinationNS,
|
|
DestinationName,
|
|
] = id.split(':').map(decodeURIComponent);
|
|
|
|
return request`
|
|
GET /v1/connect/intentions/exact?${{
|
|
source: `${peerIdentifier}:${SourcePeer}/${SourceNS}/${SourceName}`,
|
|
destination: `${DestinationPartition}/${DestinationNS}/${DestinationName}`,
|
|
dc: dc,
|
|
}}
|
|
Cache-Control: no-store
|
|
|
|
${{ index }}
|
|
`;
|
|
} else {
|
|
const [
|
|
SourcePartition,
|
|
SourceNS,
|
|
SourceName,
|
|
DestinationPartition,
|
|
DestinationNS,
|
|
DestinationName,
|
|
] = id.split(':').map(decodeURIComponent);
|
|
|
|
return request`
|
|
GET /v1/connect/intentions/exact?${{
|
|
source: `${SourcePartition}/${SourceNS}/${SourceName}`,
|
|
destination: `${DestinationPartition}/${DestinationNS}/${DestinationName}`,
|
|
dc: dc,
|
|
}}
|
|
Cache-Control: no-store
|
|
|
|
${{ index }}
|
|
`;
|
|
}
|
|
}
|
|
|
|
requestForCreateRecord(request, serialized, data) {
|
|
const body = {
|
|
SourceName: serialized.SourceName,
|
|
DestinationName: serialized.DestinationName,
|
|
SourceNS: serialized.SourceNS,
|
|
DestinationNS: serialized.DestinationNS,
|
|
SourcePartition: serialized.SourcePartition,
|
|
DestinationPartition: serialized.DestinationPartition,
|
|
SourceType: serialized.SourceType,
|
|
Meta: serialized.Meta,
|
|
Description: serialized.Description,
|
|
};
|
|
|
|
// only send the Action if we have one
|
|
if (get(serialized, 'Action.length')) {
|
|
body.Action = serialized.Action;
|
|
} else {
|
|
// otherwise only send Permissions if we have them
|
|
if (serialized.Permissions) {
|
|
body.Permissions = serialized.Permissions;
|
|
}
|
|
}
|
|
return request`
|
|
PUT /v1/connect/intentions/exact?${{
|
|
source: `${data.SourcePartition}/${data.SourceNS}/${data.SourceName}`,
|
|
destination: `${data.DestinationPartition}/${data.DestinationNS}/${data.DestinationName}`,
|
|
dc: data.Datacenter,
|
|
}}
|
|
|
|
${body}
|
|
`;
|
|
}
|
|
|
|
requestForUpdateRecord(request, serialized, data) {
|
|
// you can no longer save Destinations
|
|
delete serialized.DestinationName;
|
|
delete serialized.DestinationNS;
|
|
delete serialized.DestinationPartition;
|
|
return this.requestForCreateRecord(...arguments);
|
|
}
|
|
|
|
requestForDeleteRecord(request, serialized, data) {
|
|
return request`
|
|
DELETE /v1/connect/intentions/exact?${{
|
|
source: `${data.SourcePartition}/${data.SourceNS}/${data.SourceName}`,
|
|
destination: `${data.DestinationPartition}/${data.DestinationNS}/${data.DestinationName}`,
|
|
dc: data.Datacenter,
|
|
}}
|
|
`;
|
|
}
|
|
}
|