From cca571847aa66ea69bd3f63b3c844eafe82764b5 Mon Sep 17 00:00:00 2001 From: Simon Johnson <2924684+simon622@users.noreply.github.com> Date: Thu, 12 Oct 2023 13:59:00 +0100 Subject: [PATCH] Merge pull request #151 fix(17040) - Add local and remote subscription varients and add excludes to local * Changes object type hierachy and added specialisation for excludes * regen openapi * refactor(17040): apply changes to openAPI to codegen stubs --- ext/hivemq-edge-openapi-2023.7.yaml | 75 ++++++++++++++----- .../frontend/src/api/__generated__/index.ts | 2 + .../src/api/__generated__/models/Bridge.ts | 3 +- .../models/BridgeSubscription.ts | 6 +- .../models/LocalBridgeSubscription.ts | 51 +++++++++++++ .../src/api/__generated__/schemas/$Bridge.ts | 2 +- .../schemas/$BridgeSubscription.ts | 11 +-- .../schemas/$LocalBridgeSubscription.ts | 45 +++++++++++ .../__generated__/services/BridgesService.ts | 6 +- .../services/ProtocolAdaptersService.ts | 10 +-- .../useConnection/useGetAdaptersStatus.tsx | 2 +- .../useConnection/useGetBridgesStatus.tsx | 2 +- .../useGetBridgeConnectionStatus.tsx | 2 +- .../useGetBridges/useSetConnectionStatus.tsx | 2 +- .../useSetConnectionStatus.tsx | 2 +- .../components/panels/SubscriptionsPanel.tsx | 60 ++++++++------- .../com/hivemq/api/model/bridge/Bridge.java | 69 ++++++++++------- .../resources/impl/BridgeResourceImpl.java | 2 +- 18 files changed, 247 insertions(+), 105 deletions(-) create mode 100644 hivemq-edge/src/frontend/src/api/__generated__/models/LocalBridgeSubscription.ts create mode 100644 hivemq-edge/src/frontend/src/api/__generated__/schemas/$LocalBridgeSubscription.ts diff --git a/ext/hivemq-edge-openapi-2023.7.yaml b/ext/hivemq-edge-openapi-2023.7.yaml index d9338fd9a3..89f9565914 100644 --- a/ext/hivemq-edge-openapi-2023.7.yaml +++ b/ext/hivemq-edge-openapi-2023.7.yaml @@ -443,7 +443,7 @@ paths: /api/v1/management/bridges/status: get: description: Obtain the details. - operationId: status + operationId: get-bridges-status responses: "200": content: @@ -567,7 +567,7 @@ paths: /api/v1/management/bridges/{bridgeId}/connection-status: get: description: Get the up to date status of a bridge. - operationId: getStatus + operationId: get-bridge-status parameters: - description: The name of the bridge to query. in: path @@ -596,7 +596,7 @@ paths: /api/v1/management/bridges/{bridgeId}/status: put: description: Transition the connection status of a bridge. - operationId: changeStatus + operationId: transition-bridge-status parameters: - description: The id of the bridge whose runtime-status will change. in: path @@ -805,8 +805,8 @@ paths: - Protocol Adapters /api/v1/management/protocol-adapters/adapters/{adapterId}/status: get: - description: Get the up to date status of a bridge. - operationId: getStatus_1 + description: Get the up to date status an adapter. + operationId: get-adapter-status parameters: - description: The name of the adapter to query. in: path @@ -829,12 +829,12 @@ paths: schema: $ref: '#/components/schemas/Status' description: Success - summary: Get the up to date status of a bridge + summary: Get the up to date status of an adapter tags: - Protocol Adapters put: description: Transition the runtime status of an adapter. - operationId: changeStatus_1 + operationId: transition-adapter-status parameters: - description: The id of the adapter whose runtime status will change. in: path @@ -893,7 +893,7 @@ paths: /api/v1/management/protocol-adapters/status: get: description: Obtain the details. - operationId: status_1 + operationId: get-adapters-status responses: "200": content: @@ -1186,7 +1186,7 @@ components: type: array description: localSubscriptions associated with the bridge items: - $ref: '#/components/schemas/BridgeSubscription' + $ref: '#/components/schemas/LocalBridgeSubscription' loopPreventionEnabled: type: boolean format: boolean @@ -1265,7 +1265,7 @@ components: $ref: '#/components/schemas/Bridge' BridgeSubscription: type: object - description: localSubscriptions associated with the bridge + description: remoteSubscriptions associated with the bridge properties: customUserProperties: type: array @@ -1276,14 +1276,6 @@ components: type: string description: The destination topic for this filter set. example: some/topic/value - excludes: - type: array - description: The exclusion patterns - items: - type: string - description: The exclusion patterns - nullable: true - nullable: true filters: type: array description: The filters for this subscription. @@ -1548,6 +1540,53 @@ components: description: List of result items that are returned by this endpoint items: $ref: '#/components/schemas/Listener' + LocalBridgeSubscription: + type: object + description: localSubscriptions associated with the bridge + properties: + customUserProperties: + type: array + description: The customUserProperties for this subscription + items: + $ref: '#/components/schemas/BridgeCustomUserProperty' + destination: + type: string + description: The destination topic for this filter set. + example: some/topic/value + excludes: + type: array + description: The exclusion patterns + items: + type: string + description: The exclusion patterns + nullable: true + nullable: true + filters: + type: array + description: The filters for this subscription. + example: some/topic/value + items: + type: string + description: The filters for this subscription. + example: some/topic/value + maxQoS: + type: integer + format: int32 + default: 0 + description: The maxQoS for this subscription. + enum: + - 0 + - 1 + - 2 + maximum: 2 + minimum: 0 + preserveRetain: + type: boolean + description: The preserveRetain for this subscription + required: + - destination + - filters + - maxQoS Metric: type: object description: List of result items that are returned by this endpoint diff --git a/hivemq-edge/src/frontend/src/api/__generated__/index.ts b/hivemq-edge/src/frontend/src/api/__generated__/index.ts index 6ca98666f0..b64992927f 100644 --- a/hivemq-edge/src/frontend/src/api/__generated__/index.ts +++ b/hivemq-edge/src/frontend/src/api/__generated__/index.ts @@ -31,6 +31,7 @@ export type { Link } from './models/Link'; export type { LinkList } from './models/LinkList'; export { Listener } from './models/Listener'; export type { ListenerList } from './models/ListenerList'; +export { LocalBridgeSubscription } from './models/LocalBridgeSubscription'; export type { Metric } from './models/Metric'; export type { MetricList } from './models/MetricList'; export type { Module } from './models/Module'; @@ -70,6 +71,7 @@ export { $Link } from './schemas/$Link'; export { $LinkList } from './schemas/$LinkList'; export { $Listener } from './schemas/$Listener'; export { $ListenerList } from './schemas/$ListenerList'; +export { $LocalBridgeSubscription } from './schemas/$LocalBridgeSubscription'; export { $Metric } from './schemas/$Metric'; export { $MetricList } from './schemas/$MetricList'; export { $Module } from './schemas/$Module'; diff --git a/hivemq-edge/src/frontend/src/api/__generated__/models/Bridge.ts b/hivemq-edge/src/frontend/src/api/__generated__/models/Bridge.ts index 217e7d4f4b..fc43dd59c2 100644 --- a/hivemq-edge/src/frontend/src/api/__generated__/models/Bridge.ts +++ b/hivemq-edge/src/frontend/src/api/__generated__/models/Bridge.ts @@ -4,6 +4,7 @@ /* eslint-disable */ import type { BridgeSubscription } from './BridgeSubscription'; +import type { LocalBridgeSubscription } from './LocalBridgeSubscription'; import type { Status } from './Status'; import type { TlsConfiguration } from './TlsConfiguration'; @@ -31,7 +32,7 @@ export type Bridge = { /** * localSubscriptions associated with the bridge */ - localSubscriptions?: Array; + localSubscriptions?: Array; /** * Is loop prevention enabled on the connection */ diff --git a/hivemq-edge/src/frontend/src/api/__generated__/models/BridgeSubscription.ts b/hivemq-edge/src/frontend/src/api/__generated__/models/BridgeSubscription.ts index a68b44dbf8..6b57f333ad 100644 --- a/hivemq-edge/src/frontend/src/api/__generated__/models/BridgeSubscription.ts +++ b/hivemq-edge/src/frontend/src/api/__generated__/models/BridgeSubscription.ts @@ -6,7 +6,7 @@ import type { BridgeCustomUserProperty } from './BridgeCustomUserProperty'; /** - * localSubscriptions associated with the bridge + * remoteSubscriptions associated with the bridge */ export type BridgeSubscription = { /** @@ -17,10 +17,6 @@ export type BridgeSubscription = { * The destination topic for this filter set. */ destination: string; - /** - * The exclusion patterns - */ - excludes?: Array | null; /** * The filters for this subscription. */ diff --git a/hivemq-edge/src/frontend/src/api/__generated__/models/LocalBridgeSubscription.ts b/hivemq-edge/src/frontend/src/api/__generated__/models/LocalBridgeSubscription.ts new file mode 100644 index 0000000000..7870a2c09c --- /dev/null +++ b/hivemq-edge/src/frontend/src/api/__generated__/models/LocalBridgeSubscription.ts @@ -0,0 +1,51 @@ +/* generated using openapi-typescript-codegen -- do no edit */ +/* istanbul ignore file */ +/* tslint:disable */ +/* eslint-disable */ + +import type { BridgeCustomUserProperty } from './BridgeCustomUserProperty'; + +/** + * localSubscriptions associated with the bridge + */ +export type LocalBridgeSubscription = { + /** + * The customUserProperties for this subscription + */ + customUserProperties?: Array; + /** + * The destination topic for this filter set. + */ + destination: string; + /** + * The exclusion patterns + */ + excludes?: Array | null; + /** + * The filters for this subscription. + */ + filters: Array; + /** + * The maxQoS for this subscription. + */ + maxQoS: LocalBridgeSubscription.maxQoS; + /** + * The preserveRetain for this subscription + */ + preserveRetain?: boolean; +}; + +export namespace LocalBridgeSubscription { + + /** + * The maxQoS for this subscription. + */ + export enum maxQoS { + '_0' = 0, + '_1' = 1, + '_2' = 2, + } + + +} + diff --git a/hivemq-edge/src/frontend/src/api/__generated__/schemas/$Bridge.ts b/hivemq-edge/src/frontend/src/api/__generated__/schemas/$Bridge.ts index 3e38adc3a5..7c38e5a95d 100644 --- a/hivemq-edge/src/frontend/src/api/__generated__/schemas/$Bridge.ts +++ b/hivemq-edge/src/frontend/src/api/__generated__/schemas/$Bridge.ts @@ -42,7 +42,7 @@ export const $Bridge = { localSubscriptions: { type: 'array', contains: { - type: 'BridgeSubscription', + type: 'LocalBridgeSubscription', }, }, loopPreventionEnabled: { diff --git a/hivemq-edge/src/frontend/src/api/__generated__/schemas/$BridgeSubscription.ts b/hivemq-edge/src/frontend/src/api/__generated__/schemas/$BridgeSubscription.ts index b4144d2f72..9bc68fd6cc 100644 --- a/hivemq-edge/src/frontend/src/api/__generated__/schemas/$BridgeSubscription.ts +++ b/hivemq-edge/src/frontend/src/api/__generated__/schemas/$BridgeSubscription.ts @@ -3,7 +3,7 @@ /* tslint:disable */ /* eslint-disable */ export const $BridgeSubscription = { - description: `localSubscriptions associated with the bridge`, + description: `remoteSubscriptions associated with the bridge`, properties: { customUserProperties: { type: 'array', @@ -16,15 +16,6 @@ export const $BridgeSubscription = { description: `The destination topic for this filter set.`, isRequired: true, }, - excludes: { - type: 'array', - contains: { - type: 'string', - description: `The exclusion patterns`, - isNullable: true, - }, - isNullable: true, - }, filters: { type: 'array', contains: { diff --git a/hivemq-edge/src/frontend/src/api/__generated__/schemas/$LocalBridgeSubscription.ts b/hivemq-edge/src/frontend/src/api/__generated__/schemas/$LocalBridgeSubscription.ts new file mode 100644 index 0000000000..3b9adee137 --- /dev/null +++ b/hivemq-edge/src/frontend/src/api/__generated__/schemas/$LocalBridgeSubscription.ts @@ -0,0 +1,45 @@ +/* generated using openapi-typescript-codegen -- do no edit */ +/* istanbul ignore file */ +/* tslint:disable */ +/* eslint-disable */ +export const $LocalBridgeSubscription = { + description: `localSubscriptions associated with the bridge`, + properties: { + customUserProperties: { + type: 'array', + contains: { + type: 'BridgeCustomUserProperty', + }, + }, + destination: { + type: 'string', + description: `The destination topic for this filter set.`, + isRequired: true, + }, + excludes: { + type: 'array', + contains: { + type: 'string', + description: `The exclusion patterns`, + isNullable: true, + }, + isNullable: true, + }, + filters: { + type: 'array', + contains: { + type: 'string', + description: `The filters for this subscription.`, + }, + isRequired: true, + }, + maxQoS: { + type: 'Enum', + isRequired: true, + }, + preserveRetain: { + type: 'boolean', + description: `The preserveRetain for this subscription`, + }, + }, +} as const; diff --git a/hivemq-edge/src/frontend/src/api/__generated__/services/BridgesService.ts b/hivemq-edge/src/frontend/src/api/__generated__/services/BridgesService.ts index c2ffd4d24d..e14ae7b6ad 100644 --- a/hivemq-edge/src/frontend/src/api/__generated__/services/BridgesService.ts +++ b/hivemq-edge/src/frontend/src/api/__generated__/services/BridgesService.ts @@ -53,7 +53,7 @@ export class BridgesService { * @returns StatusList The Connection Details Verification Result. * @throws ApiError */ - public status(): CancelablePromise { + public getBridgesStatus(): CancelablePromise { return this.httpRequest.request({ method: 'GET', url: '/api/v1/management/bridges/status', @@ -128,7 +128,7 @@ export class BridgesService { * @returns Status Success * @throws ApiError */ - public getStatus( + public getBridgeStatus( bridgeId: string, ): CancelablePromise { return this.httpRequest.request({ @@ -148,7 +148,7 @@ export class BridgesService { * @returns StatusTransitionResult Success * @throws ApiError */ - public changeStatus( + public transitionBridgeStatus( bridgeId: string, requestBody: StatusTransitionCommand, ): CancelablePromise { diff --git a/hivemq-edge/src/frontend/src/api/__generated__/services/ProtocolAdaptersService.ts b/hivemq-edge/src/frontend/src/api/__generated__/services/ProtocolAdaptersService.ts index 8a73c36ef3..be05970700 100644 --- a/hivemq-edge/src/frontend/src/api/__generated__/services/ProtocolAdaptersService.ts +++ b/hivemq-edge/src/frontend/src/api/__generated__/services/ProtocolAdaptersService.ts @@ -123,13 +123,13 @@ export class ProtocolAdaptersService { } /** - * Get the up to date status of a bridge - * Get the up to date status of a bridge. + * Get the up to date status of an adapter + * Get the up to date status an adapter. * @param adapterId The name of the adapter to query. * @returns Status Success * @throws ApiError */ - public getStatus1( + public getAdapterStatus( adapterId: string, ): CancelablePromise { return this.httpRequest.request({ @@ -149,7 +149,7 @@ export class ProtocolAdaptersService { * @returns StatusTransitionResult Success * @throws ApiError */ - public changeStatus1( + public transitionAdapterStatus( adapterId: string, requestBody: StatusTransitionCommand, ): CancelablePromise { @@ -193,7 +193,7 @@ export class ProtocolAdaptersService { * @returns StatusList The Connection Details Verification Result. * @throws ApiError */ - public status1(): CancelablePromise { + public getAdaptersStatus(): CancelablePromise { return this.httpRequest.request({ method: 'GET', url: '/api/v1/management/protocol-adapters/status', diff --git a/hivemq-edge/src/frontend/src/api/hooks/useConnection/useGetAdaptersStatus.tsx b/hivemq-edge/src/frontend/src/api/hooks/useConnection/useGetAdaptersStatus.tsx index a6f1376169..a5fcddb1f1 100644 --- a/hivemq-edge/src/frontend/src/api/hooks/useConnection/useGetAdaptersStatus.tsx +++ b/hivemq-edge/src/frontend/src/api/hooks/useConnection/useGetAdaptersStatus.tsx @@ -9,7 +9,7 @@ export const useGetAdaptersStatus = () => { return useQuery( [QUERY_KEYS.ADAPTERS, QUERY_KEYS.CONNECTION_STATUS], async () => { - const item = await appClient.protocolAdapters.status1() + const item = await appClient.protocolAdapters.getAdaptersStatus() return item }, { diff --git a/hivemq-edge/src/frontend/src/api/hooks/useConnection/useGetBridgesStatus.tsx b/hivemq-edge/src/frontend/src/api/hooks/useConnection/useGetBridgesStatus.tsx index ea3219a5b4..83247b0272 100644 --- a/hivemq-edge/src/frontend/src/api/hooks/useConnection/useGetBridgesStatus.tsx +++ b/hivemq-edge/src/frontend/src/api/hooks/useConnection/useGetBridgesStatus.tsx @@ -9,7 +9,7 @@ export const useGetBridgesStatus = () => { return useQuery( [QUERY_KEYS.BRIDGES, QUERY_KEYS.CONNECTION_STATUS], async () => { - const item = await appClient.bridges.status() + const item = await appClient.bridges.getBridgesStatus() return item }, { diff --git a/hivemq-edge/src/frontend/src/api/hooks/useGetBridges/useGetBridgeConnectionStatus.tsx b/hivemq-edge/src/frontend/src/api/hooks/useGetBridges/useGetBridgeConnectionStatus.tsx index a58b313b6f..f060c50878 100644 --- a/hivemq-edge/src/frontend/src/api/hooks/useGetBridges/useGetBridgeConnectionStatus.tsx +++ b/hivemq-edge/src/frontend/src/api/hooks/useGetBridges/useGetBridgeConnectionStatus.tsx @@ -13,7 +13,7 @@ export const useGetBridgeConnectionStatus = (name: string | undefined) => { return useQuery( [QUERY_KEYS.BRIDGES, name, QUERY_KEYS.CONNECTION_STATUS], async () => { - const item = await appClient.bridges.getStatus(name as string) + const item = await appClient.bridges.getBridgeStatus(name as string) return item }, { diff --git a/hivemq-edge/src/frontend/src/api/hooks/useGetBridges/useSetConnectionStatus.tsx b/hivemq-edge/src/frontend/src/api/hooks/useGetBridges/useSetConnectionStatus.tsx index b08971dca9..d44767e531 100644 --- a/hivemq-edge/src/frontend/src/api/hooks/useGetBridges/useSetConnectionStatus.tsx +++ b/hivemq-edge/src/frontend/src/api/hooks/useGetBridges/useSetConnectionStatus.tsx @@ -14,7 +14,7 @@ export const useSetConnectionStatus = () => { const queryClient = useQueryClient() const setConnectionStatus = ({ name, requestBody }: SetConnectionStatusProps) => { - return appClient.bridges.changeStatus(name, requestBody) + return appClient.bridges.transitionBridgeStatus(name, requestBody) } return useMutation(setConnectionStatus, { diff --git a/hivemq-edge/src/frontend/src/api/hooks/useProtocolAdapters/useSetConnectionStatus.tsx b/hivemq-edge/src/frontend/src/api/hooks/useProtocolAdapters/useSetConnectionStatus.tsx index f0ad9baada..9d616c1ac5 100644 --- a/hivemq-edge/src/frontend/src/api/hooks/useProtocolAdapters/useSetConnectionStatus.tsx +++ b/hivemq-edge/src/frontend/src/api/hooks/useProtocolAdapters/useSetConnectionStatus.tsx @@ -14,7 +14,7 @@ export const useSetConnectionStatus = () => { const queryClient = useQueryClient() const changeStatus = ({ adapterId, requestBody }: SetConnectionStatusProps) => { - return appClient.protocolAdapters.changeStatus1(adapterId, requestBody) + return appClient.protocolAdapters.transitionAdapterStatus(adapterId, requestBody) } return useMutation(changeStatus, { diff --git a/hivemq-edge/src/frontend/src/modules/Bridges/components/panels/SubscriptionsPanel.tsx b/hivemq-edge/src/frontend/src/modules/Bridges/components/panels/SubscriptionsPanel.tsx index 79747249a6..6f04a989f7 100644 --- a/hivemq-edge/src/frontend/src/modules/Bridges/components/panels/SubscriptionsPanel.tsx +++ b/hivemq-edge/src/frontend/src/modules/Bridges/components/panels/SubscriptionsPanel.tsx @@ -174,34 +174,38 @@ const SubscriptionsPanel: FC = ({ form, type }) => { /> - - {t('bridge.subscription.excludes')} - { - const { value, onChange, ...rest } = field - const formatValue = value?.map((e) => ({ value: e, label: e })) - return ( - onChange(values.map((item) => item.value))} - inputId={`${type}.${index}.excludes`} - // options={[{ value: 'ddfd', label: 'fgg' }]} - // menuIsOpen={false} - isClearable={true} - placeholder={'add topic'} - isMulti={true} - components={{ - DropdownIndicator: null, - }} - /> - ) - }} - control={form.control} - /> - {errors[type]?.[index]?.filters?.message} - + {type === 'localSubscriptions' && ( + + + {t('bridge.subscription.excludes')} + + { + const { value, onChange, ...rest } = field + const formatValue = value?.map((e) => ({ value: e, label: e })) + return ( + onChange(values.map((item) => item.value))} + inputId={`${type}.${index}.excludes`} + // options={[{ value: 'ddfd', label: 'fgg' }]} + // menuIsOpen={false} + isClearable={true} + placeholder={'add topic'} + isMulti={true} + components={{ + DropdownIndicator: null, + }} + /> + ) + }} + control={form.control} + /> + {errors[type]?.[index]?.filters?.message} + + )} diff --git a/hivemq-edge/src/main/java/com/hivemq/api/model/bridge/Bridge.java b/hivemq-edge/src/main/java/com/hivemq/api/model/bridge/Bridge.java index b43960f52f..78d703d0ce 100644 --- a/hivemq-edge/src/main/java/com/hivemq/api/model/bridge/Bridge.java +++ b/hivemq-edge/src/main/java/com/hivemq/api/model/bridge/Bridge.java @@ -134,7 +134,7 @@ public class Bridge { @JsonProperty("localSubscriptions") @Schema(description = "localSubscriptions associated with the bridge") - private final @NotNull List localSubscriptions; + private final @NotNull List localSubscriptions; @JsonProperty("tlsConfiguration") @Schema(description = "tlsConfiguration associated with the bridge", nullable = true) @@ -159,7 +159,7 @@ public Bridge( @NotNull @JsonProperty("loopPreventionEnabled") final boolean loopPreventionEnabled, @NotNull @JsonProperty("loopPreventionHopCount") final int loopPreventionHopCount, @NotNull @JsonProperty("remoteSubscriptions") final List remoteSubscriptions, - @NotNull @JsonProperty("localSubscriptions") final List localSubscriptions, + @NotNull @JsonProperty("localSubscriptions") final List localSubscriptions, @Nullable @JsonProperty("tlsConfiguration") final TlsConfiguration tlsConfiguration, @Nullable @JsonProperty("status") final Status status) { this.id = id; @@ -231,7 +231,7 @@ public List getRemoteSubscriptions() { return remoteSubscriptions; } - public List getLocalSubscriptions() { + public List getLocalSubscriptions() { return localSubscriptions; } @@ -248,17 +248,6 @@ public static class BridgeSubscription { example = "some/topic/value") private final @NotNull List filters; - @JsonProperty("destination") - @Schema(name = "destination", - description = "The destination topic for this filter set.", - required = true, - example = "some/topic/value") - private final @NotNull String destination; - - @JsonProperty("excludes") - @Schema(description = "The exclusion patterns", nullable = true) - private final @Nullable List excludes; - @JsonProperty("customUserProperties") @Schema(description = "The customUserProperties for this subscription") private final @NotNull List customUserProperties; @@ -278,33 +267,36 @@ public static class BridgeSubscription { maximum = "2") private final int maxQoS; + @JsonProperty("destination") + @Schema(name = "destination", + description = "The destination topic for this filter set.", + required = true, + example = "some/topic/value") + private final @NotNull String destination; + @JsonCreator(mode = JsonCreator.Mode.PROPERTIES) public BridgeSubscription( @NotNull @JsonProperty("filters") final List filters, @NotNull @JsonProperty("destination") final String destination, - @Nullable @JsonProperty("excludes") final List excludes, @NotNull @JsonProperty("customUserProperties") final List customUserProperties, @JsonProperty("preserveRetain") final boolean preserveRetain, @JsonProperty("maxQoS") final int maxQoS) { this.filters = filters; this.destination = destination; - this.excludes = excludes; this.customUserProperties = customUserProperties; this.preserveRetain = preserveRetain; this.maxQoS = maxQoS; } + public String getDestination() { + return destination; + } + public @NotNull List getFilters() { return filters; } - public @NotNull String getDestination() { - return destination; - } - public @Nullable List getExcludes() { - return excludes; - } public @NotNull List getCustomUserProperties() { return customUserProperties; @@ -319,6 +311,28 @@ public int getMaxQoS() { } } + public static class LocalBridgeSubscription extends BridgeSubscription { + + @JsonProperty("excludes") + @Schema(description = "The exclusion patterns", nullable = true) + private final @Nullable List excludes; + + public LocalBridgeSubscription( + @NotNull @JsonProperty("filters") final List filters, + @NotNull @JsonProperty("destination") final String destination, + @Nullable @JsonProperty("excludes") final List excludes, + @NotNull @JsonProperty("customUserProperties") final List customUserProperties, + @JsonProperty("preserveRetain") final boolean preserveRetain, + @JsonProperty("maxQoS") final int maxQoS) { + super(filters, destination, customUserProperties, preserveRetain, maxQoS); + this.excludes = excludes; + } + + public @Nullable List getExcludes() { + return excludes; + } + } + public static class BridgeCustomUserProperty { @JsonProperty("key") @@ -360,21 +374,21 @@ public static Bridge convert(MqttBridge mqttBridge, Status status) { mqttBridge.getLoopPreventionHopCount() < 1 ? 0 : mqttBridge.getLoopPreventionHopCount(), mqttBridge.getRemoteSubscriptions() .stream() - .map(m -> convertSubscription(m)) + .map(m -> convertRemoteSubscription(m)) .collect(Collectors.toList()), mqttBridge.getLocalSubscriptions() .stream() - .map(m -> convertSubscription(m)) + .map(m -> convertLocalSubscription(m)) .collect(Collectors.toList()), convertTls(mqttBridge.getBridgeTls()), status); return bridge; } - public static BridgeSubscription convertSubscription(LocalSubscription localSubscription) { + public static LocalBridgeSubscription convertLocalSubscription(LocalSubscription localSubscription) { if (localSubscription == null) { return null; } - BridgeSubscription subscription = new BridgeSubscription(localSubscription.getFilters(), + LocalBridgeSubscription subscription = new LocalBridgeSubscription(localSubscription.getFilters(), localSubscription.getDestination(), localSubscription.getExcludes(), localSubscription.getCustomUserProperties() @@ -386,13 +400,12 @@ public static BridgeSubscription convertSubscription(LocalSubscription localSubs return subscription; } - public static BridgeSubscription convertSubscription(RemoteSubscription remoteSubscription) { + public static BridgeSubscription convertRemoteSubscription(RemoteSubscription remoteSubscription) { if (remoteSubscription == null) { return null; } BridgeSubscription subscription = new BridgeSubscription(remoteSubscription.getFilters(), remoteSubscription.getDestination(), - null, remoteSubscription.getCustomUserProperties() .stream() .map(f -> convertProperty(f)) diff --git a/hivemq-edge/src/main/java/com/hivemq/api/resources/impl/BridgeResourceImpl.java b/hivemq-edge/src/main/java/com/hivemq/api/resources/impl/BridgeResourceImpl.java index 3c032f094f..25c2f4bc56 100644 --- a/hivemq-edge/src/main/java/com/hivemq/api/resources/impl/BridgeResourceImpl.java +++ b/hivemq-edge/src/main/java/com/hivemq/api/resources/impl/BridgeResourceImpl.java @@ -338,7 +338,7 @@ private static MqttBridge unconvert(final @NotNull Bridge bridge) { return builder.build(); } - private static LocalSubscription unconvertLocal(final @NotNull Bridge.BridgeSubscription subscription) { + private static LocalSubscription unconvertLocal(final @NotNull Bridge.LocalBridgeSubscription subscription) { return new LocalSubscription(subscription.getFilters(), subscription.getDestination(),