From 2385f41e6498c518d75d9e4fd34a391905f5715b Mon Sep 17 00:00:00 2001 From: gkc Date: Wed, 11 Dec 2024 13:38:12 +0000 Subject: [PATCH] fix: removed `requestTransformer` and `responseTransformer` from PolicyService and PolicyServiceImpl which were introduced in order to support legacy NoPorts authorization checks - this legacy support is now being handled within the NoPorts policy service --- packages/at_policy/lib/src/policy/impl.dart | 42 +++++-------------- .../at_policy/lib/src/policy/interfaces.dart | 14 ------- 2 files changed, 11 insertions(+), 45 deletions(-) diff --git a/packages/at_policy/lib/src/policy/impl.dart b/packages/at_policy/lib/src/policy/impl.dart index 2dfc79c7..fa5fb3a3 100644 --- a/packages/at_policy/lib/src/policy/impl.dart +++ b/packages/at_policy/lib/src/policy/impl.dart @@ -35,12 +35,6 @@ class PolicyServiceImpl with AtClientBindings implements PolicyService { @override final bool allowAll; - @override - RpcTransformer? requestTransformer; - - @override - RpcTransformer? responseTransformer; - late final AtRpc rpc; static const JsonEncoder jsonPrettyPrinter = JsonEncoder.withIndent(' '); @@ -53,8 +47,6 @@ class PolicyServiceImpl with AtClientBindings implements PolicyService { required this.loggingAtsign, required this.allowList, required this.allowAll, - this.requestTransformer, - this.responseTransformer, }) { rpc = AtRpc( atClient: atClient, @@ -80,14 +72,9 @@ class PolicyServiceImpl with AtClientBindings implements PolicyService { logger.info('Received request from $fromAtSign: ' '${jsonPrettyPrinter.convert(rpcRequest.toJson())}'); - Map requestPayload = rpcRequest.payload; - if (requestTransformer != null) { - requestPayload = await requestTransformer!(requestPayload); - } PolicyRequest policyRequest; - try { - policyRequest = PolicyRequest.fromJson(requestPayload); + policyRequest = PolicyRequest.fromJson(rpcRequest.payload); } catch (e) { final msg = 'Failed PolicyRequest.fromJson: ${e.toString()}'; logger.severe(msg); @@ -130,32 +117,25 @@ class PolicyServiceImpl with AtClientBindings implements PolicyService { '\n$st'); } - PolicyResponse policyResponse; AtRpcResp rpcResponse; try { - policyResponse = await handler.getPolicyDetails(policyRequest); - Map responsePayload = policyResponse.toJson(); - if (responseTransformer != null) { - responsePayload = await responseTransformer!(responsePayload); - } + PolicyResponse policyResponse = + await handler.getPolicyDetails(policyRequest); rpcResponse = AtRpcResp( reqId: rpcRequest.reqId, respType: AtRpcRespType.success, - payload: responsePayload); + payload: policyResponse.toJson()); } catch (e) { logger.severe('Exception: $e'); - policyResponse = PolicyResponse( + rpcResponse = AtRpcResp( + reqId: rpcRequest.reqId, + respType: AtRpcRespType.error, + payload: PolicyResponse( + message: 'Exception: $e', + policyDetails: [], + ).toJson(), message: 'Exception: $e', - policyDetails: [], ); - Map responsePayload = policyResponse.toJson(); - if (responseTransformer != null) { - responsePayload = await responseTransformer!(responsePayload); - } - rpcResponse = AtRpcResp( - reqId: rpcRequest.reqId, - respType: AtRpcRespType.error, - payload: responsePayload); } return rpcResponse; diff --git a/packages/at_policy/lib/src/policy/interfaces.dart b/packages/at_policy/lib/src/policy/interfaces.dart index 644966f9..b4521810 100644 --- a/packages/at_policy/lib/src/policy/interfaces.dart +++ b/packages/at_policy/lib/src/policy/interfaces.dart @@ -9,9 +9,6 @@ abstract class PolicyRequestHandler { Future getPolicyDetails(PolicyRequest req); } -typedef RpcTransformer = Future> Function( - Map); - /// - Listens for requests for policy info from services /// - Returns info for each of the policy intents in the request. abstract class PolicyService implements AtRpcCallbacks { @@ -37,13 +34,6 @@ abstract class PolicyService implements AtRpcCallbacks { bool get allowAll; - /// For handling requests where the request payload json is not a - /// [PolicyRequest], but it can be transformed into one. e.g. legacy requests - RpcTransformer? requestTransformer; - - /// Transform PolicyResponses into some other (e.g. legacy) format - RpcTransformer? responseTransformer; - factory PolicyService({ required AtClient atClient, required String baseNamespace, @@ -52,8 +42,6 @@ abstract class PolicyService implements AtRpcCallbacks { String? loggingAtsign, Set? allowList, bool allowAll = true, - RpcTransformer? requestTransformer, - RpcTransformer? responseTransformer, }) { return PolicyServiceImpl( atClient: atClient, @@ -63,8 +51,6 @@ abstract class PolicyService implements AtRpcCallbacks { loggingAtsign: loggingAtsign ?? atClient.getCurrentAtSign()!, allowList: allowList ?? {}, allowAll: allowAll, - requestTransformer: requestTransformer, - responseTransformer: responseTransformer, ); } }