2022-07-04 10:31:58 +00:00
|
|
|
import RepositoryService from 'consul-ui/services/repository';
|
|
|
|
import dataSource from 'consul-ui/decorators/data-source';
|
|
|
|
|
|
|
|
export default class PeerService extends RepositoryService {
|
|
|
|
|
|
|
|
getModelName() {
|
|
|
|
return 'peer';
|
|
|
|
}
|
|
|
|
|
2022-07-14 10:23:16 +00:00
|
|
|
@dataSource('/:partition/:ns/:dc/peering/token-for/:name')
|
|
|
|
async fetchToken({dc, ns, partition, name}, configuration, request) {
|
|
|
|
return (await request`
|
|
|
|
POST /v1/peering/token
|
|
|
|
|
|
|
|
${{
|
|
|
|
PeerName: name,
|
|
|
|
Datacenter: dc,
|
|
|
|
Partition: partition || undefined,
|
|
|
|
}}
|
|
|
|
`)((headers, body, cache) => body)
|
|
|
|
}
|
|
|
|
|
2022-07-04 10:31:58 +00:00
|
|
|
@dataSource('/:partition/:ns/:dc/peers')
|
|
|
|
async fetchAll({ dc, ns, partition }, { uri }, request) {
|
|
|
|
return (await request`
|
|
|
|
GET /v1/peerings
|
|
|
|
|
|
|
|
${{
|
|
|
|
partition,
|
|
|
|
}}
|
|
|
|
`)(
|
|
|
|
(headers, body, cache) => {
|
|
|
|
return {
|
|
|
|
meta: {
|
|
|
|
version: 2,
|
|
|
|
interval: 10000,
|
|
|
|
uri: uri,
|
|
|
|
},
|
|
|
|
body: body.map(item => {
|
|
|
|
return cache(
|
|
|
|
{
|
|
|
|
...item,
|
|
|
|
Datacenter: dc,
|
|
|
|
Partition: partition,
|
|
|
|
},
|
|
|
|
uri => uri`peer:///${partition}/${ns}/${dc}/peer/${item.Name}`
|
|
|
|
);
|
|
|
|
})
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@dataSource('/:partition/:ns/:dc/peer/:name')
|
|
|
|
async fetchOne({partition, ns, dc, name}, { uri }, request) {
|
|
|
|
if (name === '') {
|
|
|
|
return this.create({
|
|
|
|
Datacenter: dc,
|
|
|
|
Namespace: '',
|
|
|
|
Partition: partition,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return (await request`
|
|
|
|
GET /v1/peering/${name}
|
|
|
|
|
|
|
|
${{
|
|
|
|
partition,
|
|
|
|
}}
|
|
|
|
`)((headers, body, cache) => {
|
|
|
|
return {
|
|
|
|
meta: {
|
|
|
|
version: 2,
|
|
|
|
interval: 10000,
|
|
|
|
uri: uri,
|
|
|
|
},
|
|
|
|
body: cache(
|
|
|
|
{
|
|
|
|
...body,
|
|
|
|
Datacenter: dc,
|
|
|
|
Partition: partition,
|
|
|
|
},
|
|
|
|
uri => uri`peer:///${partition}/${ns}/${dc}/peer/${body.Name}`
|
|
|
|
)
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
2022-07-07 17:23:26 +00:00
|
|
|
|
2022-07-14 10:23:16 +00:00
|
|
|
async persist(item, request) {
|
|
|
|
// mark it as ESTABLISHING ourselves as the request is successful
|
|
|
|
// and we don't have blocking queries here to get immediate updates
|
|
|
|
return (await request`
|
|
|
|
POST /v1/peering/establish
|
|
|
|
|
|
|
|
${{
|
|
|
|
PeerName: item.Name,
|
|
|
|
PeeringToken: item.PeeringToken,
|
|
|
|
Datacenter: item.Datacenter,
|
|
|
|
Partition: item.Partition || undefined,
|
|
|
|
}}
|
|
|
|
`)((headers, body, cache) => {
|
|
|
|
const partition = item.Partition;
|
|
|
|
const ns = item.Namespace;
|
|
|
|
const dc = item.Datacenter;
|
|
|
|
return {
|
|
|
|
meta: {
|
|
|
|
version: 2,
|
|
|
|
},
|
|
|
|
body: cache(
|
|
|
|
{
|
|
|
|
...item,
|
|
|
|
State: 'ESTABLISHING'
|
|
|
|
},
|
|
|
|
uri => uri`peer:///${partition}/${ns}/${dc}/peer/${item.Name}`
|
|
|
|
)
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-07-07 17:23:26 +00:00
|
|
|
async remove(item, request) {
|
|
|
|
// soft delete
|
|
|
|
// we just return the item we want to delete
|
2022-07-14 10:23:16 +00:00
|
|
|
// but mark it as DELETING ourselves as the request is successful
|
2022-07-07 17:23:26 +00:00
|
|
|
// and we don't have blocking queries here to get immediate updates
|
|
|
|
return (await request`
|
|
|
|
DELETE /v1/peering/${item.Name}
|
|
|
|
`)((headers, body, cache) => {
|
|
|
|
const partition = item.Partition;
|
|
|
|
const ns = item.Namespace;
|
|
|
|
const dc = item.Datacenter;
|
|
|
|
return {
|
|
|
|
meta: {
|
|
|
|
version: 2,
|
|
|
|
},
|
|
|
|
body: cache(
|
|
|
|
{
|
|
|
|
...item,
|
|
|
|
State: 'DELETING'
|
|
|
|
},
|
|
|
|
uri => uri`peer:///${partition}/${ns}/${dc}/peer/${item.Name}`
|
|
|
|
)
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
2022-07-04 10:31:58 +00:00
|
|
|
}
|