From 97ec42c94db9d05ba9b92329a14d76449b90898d Mon Sep 17 00:00:00 2001 From: Alexey Uzhegov Date: Fri, 16 Feb 2024 19:03:27 +0300 Subject: [PATCH] [YQ-2728] spurious empty TMaybe fix (#1984) (#2033) --- ydb/core/fq/libs/common/util.h | 2 +- .../control_plane_proxy/actors/base_actor.h | 22 +- .../actors/request_actor.h | 15 +- .../actors/ydb_schema_query_actor.cpp | 370 ++++++++++-------- 4 files changed, 223 insertions(+), 186 deletions(-) diff --git a/ydb/core/fq/libs/common/util.h b/ydb/core/fq/libs/common/util.h index 86664504d5d6..658d8e5693c0 100644 --- a/ydb/core/fq/libs/common/util.h +++ b/ydb/core/fq/libs/common/util.h @@ -76,6 +76,6 @@ FederatedQuery::IamAuth GetAuth(const FederatedQuery::Connection& connection); TString RemoveDatabaseFromStr(TString str, const TString& substr); -NYql::TIssues RemoveDatabaseFromIssues(const NYql::TIssues& issues, const TString& str); +NYql::TIssues RemoveDatabaseFromIssues(const NYql::TIssues& issues, const TString& databasePath); } // namespace NFq diff --git a/ydb/core/fq/libs/control_plane_proxy/actors/base_actor.h b/ydb/core/fq/libs/control_plane_proxy/actors/base_actor.h index 871f54ed7d8b..e7d68a5e51a8 100644 --- a/ydb/core/fq/libs/control_plane_proxy/actors/base_actor.h +++ b/ydb/core/fq/libs/control_plane_proxy/actors/base_actor.h @@ -12,30 +12,29 @@ #include #include -namespace NFq { -namespace NPrivate { +namespace NFq::NPrivate { using namespace NActors; using namespace NThreading; using namespace NYdb; template -class TPlainBaseActor : public NActors::TActorBootstrapped { +class TPlainBaseActor : public TActorBootstrapped { public: - using TBase = NActors::TActorBootstrapped; + using TBase = TActorBootstrapped; using TBase::Become; using TBase::SelfId; using TBase::Send; public: TPlainBaseActor(const TActorId& successActorId, - const TActorId& errorActorId, - TDuration requestTimeout, - const NPrivate::TRequestCommonCountersPtr& counters) + const TActorId& errorActorId, + TDuration requestTimeout, + const TRequestCommonCountersPtr& counters) : Counters(counters) , SuccessActorId(successActorId) , ErrorActorId(errorActorId) - , RequestTimeout(requestTimeout) { } + , RequestTimeout(std::move(requestTimeout)) { } void Bootstrap() { CPP_LOG_T("TBaseActor Bootstrap started. Actor id: " << SelfId()); @@ -84,7 +83,7 @@ class TPlainBaseActor : public NActors::TActorBootstrapped { virtual IEventBase* MakeTimeoutEventImpl(NYql::TIssue issue) = 0; protected: - const NPrivate::TRequestCommonCountersPtr Counters; + const TRequestCommonCountersPtr Counters; const TActorId SuccessActorId; const TActorId ErrorActorId; const TDuration RequestTimeout; @@ -112,7 +111,7 @@ class TBaseActor : public TPlainBaseActor { TBaseActor(const TActorId& proxyActorId, const TEventRequestPtr request, TDuration requestTimeout, - const NPrivate::TRequestCommonCountersPtr& counters) + const TRequestCommonCountersPtr& counters) : TPlainBaseActor(proxyActorId, request->Sender, std::move(requestTimeout), @@ -152,5 +151,4 @@ class TBaseActor : public TPlainBaseActor { const TEventRequestPtr Request; }; -} // namespace NPrivate -} // namespace NFq +} // namespace NFq::NPrivate diff --git a/ydb/core/fq/libs/control_plane_proxy/actors/request_actor.h b/ydb/core/fq/libs/control_plane_proxy/actors/request_actor.h index 7be05ece0d06..05db07fc50b4 100644 --- a/ydb/core/fq/libs/control_plane_proxy/actors/request_actor.h +++ b/ydb/core/fq/libs/control_plane_proxy/actors/request_actor.h @@ -12,16 +12,14 @@ #include #include -namespace NFq { -namespace NPrivate { +namespace NFq::NPrivate { template class TRequestActor : - public NActors::TActorBootstrapped< + public TActorBootstrapped< TRequestActor> { protected: - using TBase = NActors::TActorBootstrapped< - TRequestActor>; + using TBase = TActorBootstrapped; using TBase::SelfId; using TBase::Send; using TBase::PassAway; @@ -29,7 +27,7 @@ class TRequestActor : using TBase::Schedule; typename TRequestProxy::TPtr RequestProxy; - ::NFq::TControlPlaneProxyConfig Config; + TControlPlaneProxyConfig Config; TActorId ServiceId; TRequestCounters Counters; TInstant StartTime; @@ -42,7 +40,7 @@ class TRequestActor : static constexpr char ActorName[] = "YQ_CONTROL_PLANE_PROXY_REQUEST_ACTOR"; explicit TRequestActor(typename TRequestProxy::TPtr requestProxy, - const ::NFq::TControlPlaneProxyConfig& config, + const TControlPlaneProxyConfig& config, const TActorId& serviceId, const TRequestCounters& counters, const std::function& probe, @@ -255,5 +253,4 @@ class TCreateQueryRequestActor : } }; -} -} +} // namespace NFq::NPrivate diff --git a/ydb/core/fq/libs/control_plane_proxy/actors/ydb_schema_query_actor.cpp b/ydb/core/fq/libs/control_plane_proxy/actors/ydb_schema_query_actor.cpp index eaf5d9bf0e17..db3e427d115b 100644 --- a/ydb/core/fq/libs/control_plane_proxy/actors/ydb_schema_query_actor.cpp +++ b/ydb/core/fq/libs/control_plane_proxy/actors/ydb_schema_query_actor.cpp @@ -11,8 +11,7 @@ #include #include -namespace NFq { -namespace NPrivate { +namespace NFq::NPrivate { using namespace NActors; using namespace ::NFq::NConfig; @@ -37,16 +36,16 @@ struct TBaseActorTypeTag> { namespace { using TScheduleErrorRecoverySQLGeneration = - std::function; + std::function; using TShouldSkipStepOnError = std::function; -inline TScheduleErrorRecoverySQLGeneration NoRecoverySQLGeneration() { +TScheduleErrorRecoverySQLGeneration NoRecoverySQLGeneration() { return TScheduleErrorRecoverySQLGeneration{}; } -inline TShouldSkipStepOnError NoSkipOnError() { +TShouldSkipStepOnError NoSkipOnError() { return TShouldSkipStepOnError{}; } @@ -69,20 +68,19 @@ struct TEvPrivate { "expect EvEnd < EventSpaceEnd(TEvents::ES_PRIVATE)"); struct TEvProcessNextTaskRequest : - NActors::TEventLocal { }; + TEventLocal { }; struct TEvQueryExecutionResponse : - NActors::TEventLocal { - TEvQueryExecutionResponse(TStatus result) + TEventLocal { + explicit TEvQueryExecutionResponse(TStatus result) : Result(std::move(result)) { } TStatus Result; }; - struct TEvRecoveryResponse : - NActors::TEventLocal { + struct TEvRecoveryResponse : TEventLocal { TEvRecoveryResponse(TMaybe recoverySQL, TStatus result) - : RecoverySQL(recoverySQL) + : RecoverySQL(std::move(recoverySQL)) , Result(std::move(result)) { } TMaybe RecoverySQL; @@ -93,8 +91,8 @@ struct TEvPrivate { template class TSchemaQueryYDBActor : public TBaseActor> { -private: - using TBase = TBaseActor>; + + using TBase = TBaseActor; using TBase::Become; using TBase::Request; using TBase::SelfId; @@ -106,30 +104,33 @@ class TSchemaQueryYDBActor : using TTasksFactoryMethod = std::function; using TQueryFactoryMethod = std::function; using TErrorMessageFactoryMethod = - std::function; + std::function; TSchemaQueryYDBActor(const TActorId& proxyActorId, const TEventRequestPtr request, TDuration requestTimeout, - const NPrivate::TRequestCommonCountersPtr& counters, + const TRequestCommonCountersPtr& counters, TQueryFactoryMethod queryFactoryMethod, TErrorMessageFactoryMethod errorMessageFactoryMethod) - : TBaseActor>( + : TBaseActor( proxyActorId, std::move(request), requestTimeout, counters) , Tasks{TSchemaQueryTask{.SQL = queryFactoryMethod(Request)}} - , ErrorMessageFactoryMethod(errorMessageFactoryMethod) { } + , CompletionStatuses(Tasks.size(), ETaskCompletionStatus::NONE) + , ErrorMessageFactoryMethod(std::move(errorMessageFactoryMethod)) + , DBPath(Request->Get()->ComputeDatabase->connection().database()) { } TSchemaQueryYDBActor(const TActorId& proxyActorId, const TEventRequestPtr request, TDuration requestTimeout, - const NPrivate::TRequestCommonCountersPtr& counters, + const TRequestCommonCountersPtr& counters, TTasksFactoryMethod tasksFactoryMethod, TErrorMessageFactoryMethod errorMessageFactoryMethod) - : TBaseActor>( + : TBaseActor( proxyActorId, std::move(request), requestTimeout, counters) - , Tasks(tasksFactoryMethod(Request)) + , Tasks{tasksFactoryMethod(Request)} , CompletionStatuses(Tasks.size(), ETaskCompletionStatus::NONE) - , ErrorMessageFactoryMethod(errorMessageFactoryMethod) { } + , ErrorMessageFactoryMethod(std::move(errorMessageFactoryMethod)) + , DBPath(Request->Get()->ComputeDatabase->connection().database()) { } static constexpr char ActorName[] = "YQ_CONTROL_PLANE_PROXY_YDB_SCHEMA_QUERY_ACTOR"; @@ -271,7 +272,7 @@ class TSchemaQueryYDBActor : RecoveryHandleExecutionResponse);) void ScheduleNextTask() { - TBase::Send(SelfId(), new typename TEvPrivate::TEvProcessNextTaskRequest{}); + TBase::Send(SelfId(), new TEvPrivate::TEvProcessNextTaskRequest{}); } void TransitionToRollbackState() { @@ -311,8 +312,7 @@ class TSchemaQueryYDBActor : void SaveIssues(const TString& message, const TStatus& status) { auto issue = MakeErrorIssue(TIssuesIds::INTERNAL_ERROR, message); - auto path = Request->Get()->ComputeDatabase->connection().database(); - for (const auto& subIssue : RemoveDatabaseFromIssues(status.GetIssues(), path)) { + for (const auto& subIssue : RemoveDatabaseFromIssues(status.GetIssues(), DBPath)) { issue.AddSubIssue(MakeIntrusive(subIssue)); } @@ -327,11 +327,11 @@ class TSchemaQueryYDBActor : FirstStatus.Clear(); } - static NYdb::TStatus ExtractStatus(const TAsyncStatus& future) { + static TStatus ExtractStatus(const TAsyncStatus& future) { try { return std::move(future.GetValueSync()); // can throw an exception } catch (...) { - return NYdb::TStatus{EStatus::BAD_REQUEST, NYql::TIssues{NYql::TIssue{CurrentExceptionMessage()}}}; + return TStatus{EStatus::BAD_REQUEST, NYql::TIssues{NYql::TIssue{CurrentExceptionMessage()}}}; } } @@ -343,10 +343,10 @@ class TSchemaQueryYDBActor : ->RetryOperation([query = schemeQuery](TSession session) { return session.ExecuteSchemeQuery(query); }) - .Subscribe([actorSystem = NActors::TActivationContext::ActorSystem(), + .Subscribe([actorSystem = TActivationContext::ActorSystem(), self = SelfId()](const TAsyncStatus& future) { actorSystem->Send(self, - new typename TEvPrivate::TEvQueryExecutionResponse{ + new TEvPrivate::TEvQueryExecutionResponse{ ExtractStatus(future), }); }); @@ -371,47 +371,50 @@ class TSchemaQueryYDBActor : i32 CurrentTaskIndex = 0; TMaybe FirstStatus; NYql::TIssues Issues; + TString DBPath; }; class TGenerateRecoverySQLIfExternalDataSourceAlreadyExistsActor : public TPlainBaseActor { public: - using TBase = TPlainBaseActor; + using TBase = TPlainBaseActor; TGenerateRecoverySQLIfExternalDataSourceAlreadyExistsActor( - NActors::TActorId sender, - const TEvControlPlaneProxy::TEvCreateConnectionRequest::TPtr& request, - TPermissions permissions, - TDuration requestTimeout, - const NPrivate::TRequestCommonCountersPtr& counters) - : TPlainBaseActor( - sender, sender, requestTimeout, counters) - , Request(request) - , Permissions(std::move(permissions)) { } - - void BootstrapImpl() { CheckConnectionExistenceInCPS(); } - - IEventBase* MakeTimeoutEventImpl(NYql::TIssue issue) { + const TActorId sender, + const TString& scope, + const TString& user, + const TString& token, + const TString& cloudId, + const TMaybe& quotas, + const TTenantInfo::TPtr& tenantInfo, + const TString& connectionName, + const TPermissions& permissions, + const TDuration& requestTimeout, + const TRequestCommonCountersPtr& counters) + : TPlainBaseActor(sender, sender, requestTimeout, counters) + , Scope(scope) + , User(user) + , Token(token) + , CloudId(cloudId) + , Quotas(quotas) + , TenantInfo(tenantInfo) + , ConnectionName(connectionName) + , Permissions(permissions) { } + + void BootstrapImpl() override { CheckConnectionExistenceInCPS(); } + + IEventBase* MakeTimeoutEventImpl(NYql::TIssue issue) override { return new TEvPrivate::TEvRecoveryResponse( Nothing(), TStatus{EStatus::TIMEOUT, NYql::TIssues{std::move(issue)}}); }; void CheckConnectionExistenceInCPS() { FederatedQuery::ListConnectionsRequest result; - auto connectionName = Request->Get()->Request.content().name(); - result.mutable_filter()->set_name(connectionName); + result.mutable_filter()->set_name(ConnectionName); result.set_limit(2); - auto event = - new TEvControlPlaneStorage::TEvListConnectionsRequest(Request->Get()->Scope, - result, - Request->Get()->User, - Request->Get()->Token, - Request->Get()->CloudId, - Permissions, - Request->Get()->Quotas, - Request->Get()->TenantInfo, - {}); + auto event = new TEvControlPlaneStorage::TEvListConnectionsRequest( + Scope, result, User, Token, CloudId, Permissions, Quotas, TenantInfo, {}); event->IsExactNameMatch = true; @@ -431,55 +434,62 @@ class TGenerateRecoverySQLIfExternalDataSourceAlreadyExistsActor : return; } TBase::SendRequestToSender(new TEvPrivate::TEvRecoveryResponse( - MakeDeleteExternalDataSourceQuery(Request->Get()->Request.content().name()), + MakeDeleteExternalDataSourceQuery(ConnectionName), TStatus{EStatus::SUCCESS, {}})); } private: - NActors::TActorId Sender; - const TEvControlPlaneProxy::TEvCreateConnectionRequest::TPtr& Request; - TPermissions Permissions; + const TString Scope; + const TString User; + const TString Token; + const TString CloudId; + const TMaybe Quotas; + const TTenantInfo::TPtr TenantInfo; + const TString ConnectionName; + const TPermissions Permissions; }; class TGenerateRecoverySQLIfExternalDataTableAlreadyExistsActor : public TPlainBaseActor { public: - using TBase = TPlainBaseActor; + using TBase = TPlainBaseActor; TGenerateRecoverySQLIfExternalDataTableAlreadyExistsActor( - NActors::TActorId sender, - const TEvControlPlaneProxy::TEvCreateBindingRequest::TPtr& request, - TPermissions permissions, - TDuration requestTimeout, - const NPrivate::TRequestCommonCountersPtr& counters) - : TPlainBaseActor( - sender, sender, requestTimeout, counters) - , Request(request) - , Permissions(std::move(permissions)) { } - - void BootstrapImpl() { CheckBindingExistenceInCPS(); } - - IEventBase* MakeTimeoutEventImpl(NYql::TIssue issue) { + const TActorId& sender, + const TString& scope, + const TString& user, + const TString& token, + const TString& cloudId, + const TMaybe& quotas, + const TTenantInfo::TPtr& tenantInfo, + const TString& bindingName, + const TPermissions& permissions, + const TDuration& requestTimeout, + const TRequestCommonCountersPtr& counters) + : TPlainBaseActor(sender, sender, requestTimeout, counters) + , Scope(scope) + , User(user) + , Token(token) + , CloudId(cloudId) + , Quotas(quotas) + , TenantInfo(tenantInfo) + , BindingName(bindingName) + , Permissions(permissions) { } + + void BootstrapImpl() override { CheckBindingExistenceInCPS(); } + + IEventBase* MakeTimeoutEventImpl(NYql::TIssue issue) override { return new TEvPrivate::TEvRecoveryResponse( Nothing(), TStatus{EStatus::TIMEOUT, NYql::TIssues{std::move(issue)}}); - }; + } void CheckBindingExistenceInCPS() { FederatedQuery::ListBindingsRequest result; - auto bindingName = Request->Get()->Request.content().name(); - result.mutable_filter()->set_name(bindingName); + result.mutable_filter()->set_name(BindingName); result.set_limit(2); - auto event = - new TEvControlPlaneStorage::TEvListBindingsRequest(Request->Get()->Scope, - result, - Request->Get()->User, - Request->Get()->Token, - Request->Get()->CloudId, - Permissions, - Request->Get()->Quotas, - Request->Get()->TenantInfo, - {}); + auto event = new TEvControlPlaneStorage::TEvListBindingsRequest( + Scope, result, User, Token, CloudId, Permissions, Quotas, TenantInfo, {}); event->IsExactNameMatch = true; @@ -499,14 +509,19 @@ class TGenerateRecoverySQLIfExternalDataTableAlreadyExistsActor : return; } TBase::SendRequestToSender(new TEvPrivate::TEvRecoveryResponse( - MakeDeleteExternalDataTableQuery(Request->Get()->Request.content().name()), + MakeDeleteExternalDataTableQuery(BindingName), TStatus{EStatus::SUCCESS, {}})); } private: - NActors::TActorId Sender; - const TEvControlPlaneProxy::TEvCreateBindingRequest::TPtr& Request; - TPermissions Permissions; + const TString Scope; + const TString User; + const TString Token; + const TString CloudId; + const TMaybe Quotas; + const TTenantInfo::TPtr TenantInfo; + const TString BindingName; + const TPermissions Permissions; }; bool IsPathDoesNotExistIssue(const TStatus& status) { @@ -518,7 +533,7 @@ bool IsPathExistsIssue(const TStatus& status) { return status.GetIssues().ToOneLineString().Contains("error: path exist"); } -} +} // namespace /// Connection actors IActor* MakeCreateConnectionActor( @@ -539,35 +554,48 @@ IActor* MakeCreateConnectionActor( permissions, withoutRollback, commonConfig, - computeConfig](const TEvControlPlaneProxy::TEvCreateConnectionRequest::TPtr& request) + computeConfig](const TEvControlPlaneProxy::TEvCreateConnectionRequest::TPtr& req) -> std::vector { - auto& connectionContent = request->Get()->Request.content(); + auto& connectionContent = req->Get()->Request.content(); - auto createSecretStatement = - CreateSecretObjectQuery(connectionContent.setting(), - connectionContent.name(), - signer); + auto createSecretStatement = CreateSecretObjectQuery(connectionContent.setting(), + connectionContent.name(), + signer); std::vector statements; if (createSecretStatement) { - statements.push_back( - TSchemaQueryTask{.SQL = *createSecretStatement, - .ShouldSkipStepOnError = withoutRollback ? IsPathExistsIssue : NoSkipOnError()}); + statements.push_back(TSchemaQueryTask{.SQL = *createSecretStatement, + .ShouldSkipStepOnError = + withoutRollback ? IsPathExistsIssue + : NoSkipOnError()}); } TScheduleErrorRecoverySQLGeneration alreadyExistRecoveryActorFactoryMethod = - [&request, requestTimeout, &counters, permissions](TActorId sender, - const TStatus& status) { - if (status.GetStatus() == NYdb::EStatus::ALREADY_EXISTS || + [scope = req->Get()->Scope, + user = req->Get()->User, + token = req->Get()->Token, + cloudId = req->Get()->CloudId, + quotas = req->Get()->Quotas, + tenantInfo = req->Get()->TenantInfo, + connectionName = req->Get()->Request.content().name(), + requestTimeout, + &counters, + permissions](TActorId sender, const TStatus& status) { + if (status.GetStatus() == EStatus::ALREADY_EXISTS || status.GetIssues().ToOneLineString().Contains("error: path exist")) { TActivationContext::ActorSystem()->Register( new TGenerateRecoverySQLIfExternalDataSourceAlreadyExistsActor( sender, - request, + scope, + user, + token, + cloudId, + quotas, + tenantInfo, + connectionName, permissions, requestTimeout, - counters.GetCommonCounters( - RTC_CREATE_CONNECTION_IN_YDB))); // change counter + counters.GetCommonCounters(RTC_CREATE_CONNECTION_IN_YDB))); return true; } return false; @@ -576,28 +604,31 @@ IActor* MakeCreateConnectionActor( .SQL = MakeCreateExternalDataSourceQuery( connectionContent, signer, commonConfig, computeConfig.IsReplaceIfExistsSyntaxSupported()), - .ScheduleErrorRecoverySQLGeneration = - withoutRollback ? NoRecoverySQLGeneration() - : alreadyExistRecoveryActorFactoryMethod, + .ScheduleErrorRecoverySQLGeneration = + withoutRollback + ? NoRecoverySQLGeneration() + : std::move(alreadyExistRecoveryActorFactoryMethod), .ShouldSkipStepOnError = withoutRollback ? IsPathExistsIssue : NoSkipOnError()}); return statements; }; - auto& connectionName = request->Get()->Request.content().name(); - auto errorMessageFactoryMethod = [connectionId, connectionName](const EStatus status, - const NYql::TIssues& issues) -> TString { + auto errorMessageFactoryMethod = + [connectionId, connectionName = request->Get()->Request.content().name()]( + const EStatus status, const NYql::TIssues& issues) -> TString { Y_UNUSED(issues); - TStringBuilder message = TStringBuilder {} << "Synchronization of connection"; + TStringBuilder message = TStringBuilder{} << "Synchronization of connection"; if (connectionId.Defined()) { message << " with id '" << connectionId << "'"; } if (status == NYdb::EStatus::ALREADY_EXISTS) { - message << " failed, because external data source with name '" << connectionName << "' already exists"; + message << " failed, because external data source with name '" + << connectionName << "' already exists"; } else { - message << " failed, because creation of external data source with name '" << connectionName << "' wasn't successful"; + message << " failed, because creation of external data source with name '" + << connectionName << "' wasn't successful"; } - return message; + return TString{message}; }; return new TSchemaQueryYDBActor statements = { + std::vector statements = { TSchemaQueryTask{.SQL = TString{MakeDeleteExternalDataSourceQuery( connectionContent.name())}, .RollbackSQL = MakeCreateExternalDataSourceQuery( @@ -796,36 +827,47 @@ NActors::IActor* MakeDeleteConnectionActor( } /// Bindings actors -NActors::IActor* MakeCreateBindingActor( - const TActorId& proxyActorId, - TEvControlPlaneProxy::TEvCreateBindingRequest::TPtr request, - TDuration requestTimeout, - TCounters& counters, - TPermissions permissions, - const NFq::TComputeConfig& computeConfig, - bool withoutRollback, - TMaybe bindingId) { +IActor* MakeCreateBindingActor(const TActorId& proxyActorId, + TEvControlPlaneProxy::TEvCreateBindingRequest::TPtr request, + TDuration requestTimeout, + TCounters& counters, + TPermissions permissions, + const NFq::TComputeConfig& computeConfig,bool withoutRollback, + TMaybe bindingId) { auto queryFactoryMethod = - [requestTimeout, - &counters, permissions, withoutRollback, computeConfig](const TEvControlPlaneProxy::TEvCreateBindingRequest::TPtr& request) + [requestTimeout, &counters, permissions, withoutRollback, computeConfig]( + const TEvControlPlaneProxy::TEvCreateBindingRequest::TPtr& req) -> std::vector { - auto& bindingContent = request->Get()->Request.content(); - auto& externalSourceName = request->Get()->ConnectionContent->name(); + auto& bindingContent = req->Get()->Request.content(); + auto& externalSourceName = req->Get()->ConnectionContent->name(); std::vector statements; TScheduleErrorRecoverySQLGeneration alreadyExistRecoveryActorFactoryMethod = - [&request, requestTimeout, &counters, permissions](NActors::TActorId sender, - const TStatus& status) { + [scope = req->Get()->Scope, + user = req->Get()->User, + token = req->Get()->Token, + cloudId = req->Get()->CloudId, + quotas = req->Get()->Quotas, + tenantInfo = req->Get()->TenantInfo, + bindingName = req->Get()->Request.content().name(), + requestTimeout, + &counters, + permissions](TActorId sender, const TStatus& status) { if (status.GetStatus() == EStatus::ALREADY_EXISTS || status.GetIssues().ToOneLineString().Contains("error: path exist")) { TActivationContext::ActorSystem()->Register( new TGenerateRecoverySQLIfExternalDataTableAlreadyExistsActor( sender, - request, + scope, + user, + token, + cloudId, + quotas, + tenantInfo, + bindingName, permissions, requestTimeout, - counters.GetCommonCounters( - RTC_CREATE_BINDING_IN_YDB))); // change counter + counters.GetCommonCounters(RTC_CREATE_BINDING_IN_YDB))); return true; } return false; @@ -836,27 +878,28 @@ NActors::IActor* MakeCreateBindingActor( computeConfig.IsReplaceIfExistsSyntaxSupported())}, .ScheduleErrorRecoverySQLGeneration = withoutRollback ? NoRecoverySQLGeneration() - : alreadyExistRecoveryActorFactoryMethod, + : std::move(alreadyExistRecoveryActorFactoryMethod), .ShouldSkipStepOnError = withoutRollback ? IsPathExistsIssue : NoSkipOnError()}); return statements; }; - auto content = request->Get()->Request.content(); - auto bindingName = content.name(); - auto errorMessageFactoryMethod = [bindingId, bindingName](const EStatus status, - const NYql::TIssues& issues) -> TString { + auto errorMessageFactoryMethod = + [bindingId, bindingName = request->Get()->Request.content().name()]( + const EStatus status, const NYql::TIssues& issues) -> TString { Y_UNUSED(issues); - TStringBuilder message = TStringBuilder {} << "Synchronization of binding"; + TStringBuilder message = TStringBuilder{} << "Synchronization of binding"; if (bindingId.Defined()) { message << " with id '" << bindingId << "'"; } - if (status == NYdb::EStatus::ALREADY_EXISTS) { - message << " failed, because external data table with name '" << bindingName << "' already exists"; + if (status == EStatus::ALREADY_EXISTS) { + message << " failed, because external data table with name '" << bindingName + << "' already exists"; } else { - message << " failed, because creation of external data table with name '" << bindingName << "' wasn't successful"; + message << " failed, because creation of external data table with name '" + << bindingName << "' wasn't successful"; } - return message; + return TString{message}; }; return new TSchemaQueryYDBActor std::vector { - return {{.SQL = MakeDeleteExternalDataTableQuery(request->Get()->OldBindingContent->name()), + return {{.SQL = MakeDeleteExternalDataTableQuery( + request->Get()->OldBindingContent->name()), .ShouldSkipStepOnError = IsPathDoesNotExistIssue}}; }; @@ -950,5 +992,5 @@ NActors::IActor* MakeDeleteBindingActor( errorMessageFactoryMethod); } -} // namespace NPrivate -} // namespace NFq +} // namespace NFq::NPrivate +