From 590ce5b80c17dd4070c862e1e5b18daf1189e110 Mon Sep 17 00:00:00 2001 From: Anand Swaminathan Date: Wed, 22 Jul 2020 15:41:26 -0700 Subject: [PATCH] IDL changes for Node-Node relationship refactor (#72) * IDL changes for Node-Node relationship refactor * Ability to provide information of the parent node. * Introduction of group_id to indicate grouping of nodes within the Parent node - (instead of dummy nodes) * Support for querying all nodes under node with group. * Support for node_id to point to original node in the workflow/graph, and node_name --- .../gen/pb-cpp/flyteidl/admin/event.pb.cc | 2 +- .../flyteidl/admin/node_execution.pb.cc | 381 ++- .../pb-cpp/flyteidl/admin/node_execution.pb.h | 225 ++ .../gen/pb-cpp/flyteidl/event/event.pb.cc | 683 ++++- flyteidl/gen/pb-cpp/flyteidl/event/event.pb.h | 452 +++- .../pb-go/flyteidl/admin/node_execution.pb.go | 143 +- .../admin/node_execution.pb.validate.go | 8 + flyteidl/gen/pb-go/flyteidl/event/event.pb.go | 185 +- .../pb-go/flyteidl/event/event.pb.validate.go | 86 + .../pb-go/flyteidl/service/admin.swagger.json | 49 +- .../flyteidl/service/flyteadmin/README.md | 1 + .../service/flyteadmin/api/swagger.yaml | 63 +- .../service/flyteadmin/api_admin_service.go | 5 + .../model_admin_node_execution_meta_data.go | 4 + .../model_event_node_execution_event.go | 7 +- ...el_event_parent_node_execution_metadata.go | 14 + .../gen/pb-go/flyteidl/service/openapi.go | 4 +- .../admin/NodeExecutionOuterClass.java | 706 ++++- .../gen/pb-java/flyteidl/event/Event.java | 2266 +++++++++++++---- flyteidl/gen/pb-js/flyteidl.d.ts | 100 + flyteidl/gen/pb-js/flyteidl.js | 248 ++ .../flyteidl/admin/node_execution.proto.rst | 51 +- .../flyteidl/event/event.proto.rst | 62 +- .../flyteidl/admin/node_execution_pb2.py | 64 +- .../gen/pb_python/flyteidl/event/event_pb2.py | 84 +- .../flyteidl/service/flyteadmin/README.md | 1 + .../service/flyteadmin/flyteadmin/__init__.py | 1 + .../flyteadmin/api/admin_service_api.py | 6 +- .../flyteadmin/flyteadmin/models/__init__.py | 1 + .../models/admin_node_execution_meta_data.py | 84 +- .../models/event_node_execution_event.py | 117 +- .../event_parent_node_execution_metadata.py | 115 + ...st_event_parent_node_execution_metadata.py | 40 + .../flyteidl/admin/node_execution.proto | 14 + flyteidl/protos/flyteidl/event/event.proto | 21 +- 35 files changed, 5581 insertions(+), 712 deletions(-) create mode 100644 flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_event_parent_node_execution_metadata.go create mode 100644 flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/event_parent_node_execution_metadata.py create mode 100644 flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_event_parent_node_execution_metadata.py diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/event.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/event.pb.cc index 2633b3d9d7..373f0d7905 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/event.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/event.pb.cc @@ -18,7 +18,7 @@ extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fevent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_EventErrorAlreadyInTerminalState_flyteidl_2fadmin_2fevent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fevent_2fevent_2eproto ::google::protobuf::internal::SCCInfo<3> scc_info_WorkflowExecutionEvent_flyteidl_2fevent_2fevent_2eproto; -extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fevent_2fevent_2eproto ::google::protobuf::internal::SCCInfo<5> scc_info_NodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fevent_2fevent_2eproto ::google::protobuf::internal::SCCInfo<6> scc_info_NodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fevent_2fevent_2eproto ::google::protobuf::internal::SCCInfo<6> scc_info_TaskExecutionEvent_flyteidl_2fevent_2fevent_2eproto; namespace flyteidl { namespace admin { diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/node_execution.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/node_execution.pb.cc index 8dbd1ae243..cd488b8196 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/node_execution.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/node_execution.pb.cc @@ -265,6 +265,7 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2fnode_5fexecution PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionListRequest, token_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionListRequest, filters_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionListRequest, sort_by_), + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionListRequest, unique_parent_id_), ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionForTaskListRequest, _internal_metadata_), ~0u, // no _extensions_ @@ -289,6 +290,9 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2fnode_5fexecution ~0u, // no _extensions_ ~0u, // no _oneof_case_ ~0u, // no _weak_field_map_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionMetaData, retry_group_), + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionMetaData, is_parent_node_), + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionMetaData, spec_node_id_), ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::admin::NodeExecutionList, _internal_metadata_), ~0u, // no _extensions_ @@ -334,14 +338,14 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2fnode_5fexecution static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SECTION_VARIABLE(protodesc_cold) = { { 0, -1, sizeof(::flyteidl::admin::NodeExecutionGetRequest)}, { 6, -1, sizeof(::flyteidl::admin::NodeExecutionListRequest)}, - { 16, -1, sizeof(::flyteidl::admin::NodeExecutionForTaskListRequest)}, - { 26, -1, sizeof(::flyteidl::admin::NodeExecution)}, - { 35, -1, sizeof(::flyteidl::admin::NodeExecutionMetaData)}, - { 40, -1, sizeof(::flyteidl::admin::NodeExecutionList)}, - { 47, -1, sizeof(::flyteidl::admin::NodeExecutionClosure)}, - { 62, -1, sizeof(::flyteidl::admin::WorkflowNodeMetadata)}, - { 68, -1, sizeof(::flyteidl::admin::NodeExecutionGetDataRequest)}, - { 74, -1, sizeof(::flyteidl::admin::NodeExecutionGetDataResponse)}, + { 17, -1, sizeof(::flyteidl::admin::NodeExecutionForTaskListRequest)}, + { 27, -1, sizeof(::flyteidl::admin::NodeExecution)}, + { 36, -1, sizeof(::flyteidl::admin::NodeExecutionMetaData)}, + { 44, -1, sizeof(::flyteidl::admin::NodeExecutionList)}, + { 51, -1, sizeof(::flyteidl::admin::NodeExecutionClosure)}, + { 66, -1, sizeof(::flyteidl::admin::WorkflowNodeMetadata)}, + { 72, -1, sizeof(::flyteidl::admin::NodeExecutionGetDataRequest)}, + { 78, -1, sizeof(::flyteidl::admin::NodeExecutionGetDataResponse)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -371,49 +375,51 @@ const char descriptor_table_protodef_flyteidl_2fadmin_2fnode_5fexecution_2eproto "uf/timestamp.proto\032\036google/protobuf/dura" "tion.proto\"M\n\027NodeExecutionGetRequest\0222\n" "\002id\030\001 \001(\0132&.flyteidl.core.NodeExecutionI" - "dentifier\"\273\001\n\030NodeExecutionListRequest\022I" + "dentifier\"\325\001\n\030NodeExecutionListRequest\022I" "\n\025workflow_execution_id\030\001 \001(\0132*.flyteidl" ".core.WorkflowExecutionIdentifier\022\r\n\005lim" "it\030\002 \001(\r\022\r\n\005token\030\003 \001(\t\022\017\n\007filters\030\004 \001(\t" - "\022%\n\007sort_by\030\005 \001(\0132\024.flyteidl.admin.Sort\"" - "\272\001\n\037NodeExecutionForTaskListRequest\022A\n\021t" - "ask_execution_id\030\001 \001(\0132&.flyteidl.core.T" - "askExecutionIdentifier\022\r\n\005limit\030\002 \001(\r\022\r\n" - "\005token\030\003 \001(\t\022\017\n\007filters\030\004 \001(\t\022%\n\007sort_by" - "\030\005 \001(\0132\024.flyteidl.admin.Sort\"\306\001\n\rNodeExe" - "cution\0222\n\002id\030\001 \001(\0132&.flyteidl.core.NodeE" - "xecutionIdentifier\022\021\n\tinput_uri\030\002 \001(\t\0225\n" - "\007closure\030\003 \001(\0132$.flyteidl.admin.NodeExec" - "utionClosure\0227\n\010metadata\030\004 \001(\0132%.flyteid" - "l.admin.NodeExecutionMetaData\"\027\n\025NodeExe" - "cutionMetaData\"Z\n\021NodeExecutionList\0226\n\017n" - "ode_executions\030\001 \003(\0132\035.flyteidl.admin.No" - "deExecution\022\r\n\005token\030\002 \001(\t\"\270\003\n\024NodeExecu" - "tionClosure\022\024\n\noutput_uri\030\001 \001(\tH\000\022.\n\005err" - "or\030\002 \001(\0132\035.flyteidl.core.ExecutionErrorH" - "\000\0221\n\005phase\030\003 \001(\0162\".flyteidl.core.NodeExe" - "cution.Phase\022.\n\nstarted_at\030\004 \001(\0132\032.googl" - "e.protobuf.Timestamp\022+\n\010duration\030\005 \001(\0132\031" - ".google.protobuf.Duration\022.\n\ncreated_at\030" - "\006 \001(\0132\032.google.protobuf.Timestamp\022.\n\nupd" - "ated_at\030\007 \001(\0132\032.google.protobuf.Timestam" - "p\022F\n\026workflow_node_metadata\030\010 \001(\0132$.flyt" - "eidl.admin.WorkflowNodeMetadataH\001B\017\n\rout" - "put_resultB\021\n\017target_metadata\"W\n\024Workflo" - "wNodeMetadata\022\?\n\013executionId\030\001 \001(\0132*.fly" - "teidl.core.WorkflowExecutionIdentifier\"Q" - "\n\033NodeExecutionGetDataRequest\0222\n\002id\030\001 \001(" - "\0132&.flyteidl.core.NodeExecutionIdentifie" - "r\"q\n\034NodeExecutionGetDataResponse\022\'\n\006inp" - "uts\030\001 \001(\0132\027.flyteidl.admin.UrlBlob\022(\n\007ou" - "tputs\030\002 \001(\0132\027.flyteidl.admin.UrlBlobB3Z1" - "github.com/lyft/flyteidl/gen/pb-go/flyte" - "idl/adminb\006proto3" + "\022%\n\007sort_by\030\005 \001(\0132\024.flyteidl.admin.Sort\022" + "\030\n\020unique_parent_id\030\006 \001(\t\"\272\001\n\037NodeExecut" + "ionForTaskListRequest\022A\n\021task_execution_" + "id\030\001 \001(\0132&.flyteidl.core.TaskExecutionId" + "entifier\022\r\n\005limit\030\002 \001(\r\022\r\n\005token\030\003 \001(\t\022\017" + "\n\007filters\030\004 \001(\t\022%\n\007sort_by\030\005 \001(\0132\024.flyte" + "idl.admin.Sort\"\306\001\n\rNodeExecution\0222\n\002id\030\001" + " \001(\0132&.flyteidl.core.NodeExecutionIdenti" + "fier\022\021\n\tinput_uri\030\002 \001(\t\0225\n\007closure\030\003 \001(\013" + "2$.flyteidl.admin.NodeExecutionClosure\0227" + "\n\010metadata\030\004 \001(\0132%.flyteidl.admin.NodeEx" + "ecutionMetaData\"Z\n\025NodeExecutionMetaData" + "\022\023\n\013retry_group\030\001 \001(\t\022\026\n\016is_parent_node\030" + "\002 \001(\010\022\024\n\014spec_node_id\030\003 \001(\t\"Z\n\021NodeExecu" + "tionList\0226\n\017node_executions\030\001 \003(\0132\035.flyt" + "eidl.admin.NodeExecution\022\r\n\005token\030\002 \001(\t\"" + "\270\003\n\024NodeExecutionClosure\022\024\n\noutput_uri\030\001" + " \001(\tH\000\022.\n\005error\030\002 \001(\0132\035.flyteidl.core.Ex" + "ecutionErrorH\000\0221\n\005phase\030\003 \001(\0162\".flyteidl" + ".core.NodeExecution.Phase\022.\n\nstarted_at\030" + "\004 \001(\0132\032.google.protobuf.Timestamp\022+\n\010dur" + "ation\030\005 \001(\0132\031.google.protobuf.Duration\022." + "\n\ncreated_at\030\006 \001(\0132\032.google.protobuf.Tim" + "estamp\022.\n\nupdated_at\030\007 \001(\0132\032.google.prot" + "obuf.Timestamp\022F\n\026workflow_node_metadata" + "\030\010 \001(\0132$.flyteidl.admin.WorkflowNodeMeta" + "dataH\001B\017\n\routput_resultB\021\n\017target_metada" + "ta\"W\n\024WorkflowNodeMetadata\022\?\n\013executionI" + "d\030\001 \001(\0132*.flyteidl.core.WorkflowExecutio" + "nIdentifier\"Q\n\033NodeExecutionGetDataReque" + "st\0222\n\002id\030\001 \001(\0132&.flyteidl.core.NodeExecu" + "tionIdentifier\"q\n\034NodeExecutionGetDataRe" + "sponse\022\'\n\006inputs\030\001 \001(\0132\027.flyteidl.admin." + "UrlBlob\022(\n\007outputs\030\002 \001(\0132\027.flyteidl.admi" + "n.UrlBlobB3Z1github.com/lyft/flyteidl/ge" + "n/pb-go/flyteidl/adminb\006proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fadmin_2fnode_5fexecution_2eproto = { false, InitDefaults_flyteidl_2fadmin_2fnode_5fexecution_2eproto, descriptor_table_protodef_flyteidl_2fadmin_2fnode_5fexecution_2eproto, - "flyteidl/admin/node_execution.proto", &assign_descriptors_table_flyteidl_2fadmin_2fnode_5fexecution_2eproto, 1777, + "flyteidl/admin/node_execution.proto", &assign_descriptors_table_flyteidl_2fadmin_2fnode_5fexecution_2eproto, 1870, }; void AddDescriptors_flyteidl_2fadmin_2fnode_5fexecution_2eproto() { @@ -766,6 +772,7 @@ const int NodeExecutionListRequest::kLimitFieldNumber; const int NodeExecutionListRequest::kTokenFieldNumber; const int NodeExecutionListRequest::kFiltersFieldNumber; const int NodeExecutionListRequest::kSortByFieldNumber; +const int NodeExecutionListRequest::kUniqueParentIdFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 NodeExecutionListRequest::NodeExecutionListRequest() @@ -785,6 +792,10 @@ NodeExecutionListRequest::NodeExecutionListRequest(const NodeExecutionListReques if (from.filters().size() > 0) { filters_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.filters_); } + unique_parent_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.unique_parent_id().size() > 0) { + unique_parent_id_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.unique_parent_id_); + } if (from.has_workflow_execution_id()) { workflow_execution_id_ = new ::flyteidl::core::WorkflowExecutionIdentifier(*from.workflow_execution_id_); } else { @@ -804,6 +815,7 @@ void NodeExecutionListRequest::SharedCtor() { &scc_info_NodeExecutionListRequest_flyteidl_2fadmin_2fnode_5fexecution_2eproto.base); token_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); filters_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + unique_parent_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); ::memset(&workflow_execution_id_, 0, static_cast( reinterpret_cast(&limit_) - reinterpret_cast(&workflow_execution_id_)) + sizeof(limit_)); @@ -817,6 +829,7 @@ NodeExecutionListRequest::~NodeExecutionListRequest() { void NodeExecutionListRequest::SharedDtor() { token_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); filters_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + unique_parent_id_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); if (this != internal_default_instance()) delete workflow_execution_id_; if (this != internal_default_instance()) delete sort_by_; } @@ -838,6 +851,7 @@ void NodeExecutionListRequest::Clear() { token_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); filters_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + unique_parent_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); if (GetArenaNoVirtual() == nullptr && workflow_execution_id_ != nullptr) { delete workflow_execution_id_; } @@ -928,6 +942,22 @@ const char* NodeExecutionListRequest::_InternalParse(const char* begin, const ch {parser_till_end, object}, ptr - size, ptr)); break; } + // string unique_parent_id = 6; + case 6: { + if (static_cast<::google::protobuf::uint8>(tag) != 50) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.admin.NodeExecutionListRequest.unique_parent_id"); + object = msg->mutable_unique_parent_id(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } default: { handle_unusual: if ((tag & 7) == 4 || tag == 0) { @@ -1027,6 +1057,21 @@ bool NodeExecutionListRequest::MergePartialFromCodedStream( break; } + // string unique_parent_id = 6; + case 6: { + if (static_cast< ::google::protobuf::uint8>(tag) == (50 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_unique_parent_id())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->unique_parent_id().data(), static_cast(this->unique_parent_id().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.admin.NodeExecutionListRequest.unique_parent_id")); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -1091,6 +1136,16 @@ void NodeExecutionListRequest::SerializeWithCachedSizes( 5, HasBitSetters::sort_by(this), output); } + // string unique_parent_id = 6; + if (this->unique_parent_id().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->unique_parent_id().data(), static_cast(this->unique_parent_id().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.NodeExecutionListRequest.unique_parent_id"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 6, this->unique_parent_id(), output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -1145,6 +1200,17 @@ ::google::protobuf::uint8* NodeExecutionListRequest::InternalSerializeWithCached 5, HasBitSetters::sort_by(this), target); } + // string unique_parent_id = 6; + if (this->unique_parent_id().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->unique_parent_id().data(), static_cast(this->unique_parent_id().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.NodeExecutionListRequest.unique_parent_id"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 6, this->unique_parent_id(), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -1180,6 +1246,13 @@ size_t NodeExecutionListRequest::ByteSizeLong() const { this->filters()); } + // string unique_parent_id = 6; + if (this->unique_parent_id().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->unique_parent_id()); + } + // .flyteidl.core.WorkflowExecutionIdentifier workflow_execution_id = 1; if (this->has_workflow_execution_id()) { total_size += 1 + @@ -1236,6 +1309,10 @@ void NodeExecutionListRequest::MergeFrom(const NodeExecutionListRequest& from) { filters_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.filters_); } + if (from.unique_parent_id().size() > 0) { + + unique_parent_id_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.unique_parent_id_); + } if (from.has_workflow_execution_id()) { mutable_workflow_execution_id()->::flyteidl::core::WorkflowExecutionIdentifier::MergeFrom(from.workflow_execution_id()); } @@ -1276,6 +1353,8 @@ void NodeExecutionListRequest::InternalSwap(NodeExecutionListRequest* other) { GetArenaNoVirtual()); filters_.Swap(&other->filters_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), GetArenaNoVirtual()); + unique_parent_id_.Swap(&other->unique_parent_id_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); swap(workflow_execution_id_, other->workflow_execution_id_); swap(sort_by_, other->sort_by_); swap(limit_, other->limit_); @@ -2361,6 +2440,9 @@ class NodeExecutionMetaData::HasBitSetters { }; #if !defined(_MSC_VER) || _MSC_VER >= 1900 +const int NodeExecutionMetaData::kRetryGroupFieldNumber; +const int NodeExecutionMetaData::kIsParentNodeFieldNumber; +const int NodeExecutionMetaData::kSpecNodeIdFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 NodeExecutionMetaData::NodeExecutionMetaData() @@ -2372,10 +2454,24 @@ NodeExecutionMetaData::NodeExecutionMetaData(const NodeExecutionMetaData& from) : ::google::protobuf::Message(), _internal_metadata_(nullptr) { _internal_metadata_.MergeFrom(from._internal_metadata_); + retry_group_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.retry_group().size() > 0) { + retry_group_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.retry_group_); + } + spec_node_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.spec_node_id().size() > 0) { + spec_node_id_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.spec_node_id_); + } + is_parent_node_ = from.is_parent_node_; // @@protoc_insertion_point(copy_constructor:flyteidl.admin.NodeExecutionMetaData) } void NodeExecutionMetaData::SharedCtor() { + ::google::protobuf::internal::InitSCC( + &scc_info_NodeExecutionMetaData_flyteidl_2fadmin_2fnode_5fexecution_2eproto.base); + retry_group_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + spec_node_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + is_parent_node_ = false; } NodeExecutionMetaData::~NodeExecutionMetaData() { @@ -2384,6 +2480,8 @@ NodeExecutionMetaData::~NodeExecutionMetaData() { } void NodeExecutionMetaData::SharedDtor() { + retry_group_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + spec_node_id_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); } void NodeExecutionMetaData::SetCachedSize(int size) const { @@ -2401,6 +2499,9 @@ void NodeExecutionMetaData::Clear() { // Prevent compiler warnings about cached_has_bits being unused (void) cached_has_bits; + retry_group_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + spec_node_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + is_parent_node_ = false; _internal_metadata_.Clear(); } @@ -2417,7 +2518,47 @@ const char* NodeExecutionMetaData::_InternalParse(const char* begin, const char* ptr = ::google::protobuf::io::Parse32(ptr, &tag); GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); switch (tag >> 3) { + // string retry_group = 1; + case 1: { + if (static_cast<::google::protobuf::uint8>(tag) != 10) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.admin.NodeExecutionMetaData.retry_group"); + object = msg->mutable_retry_group(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } + // bool is_parent_node = 2; + case 2: { + if (static_cast<::google::protobuf::uint8>(tag) != 16) goto handle_unusual; + msg->set_is_parent_node(::google::protobuf::internal::ReadVarint(&ptr)); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + break; + } + // string spec_node_id = 3; + case 3: { + if (static_cast<::google::protobuf::uint8>(tag) != 26) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.admin.NodeExecutionMetaData.spec_node_id"); + object = msg->mutable_spec_node_id(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } default: { + handle_unusual: if ((tag & 7) == 4 || tag == 0) { ctx->EndGroup(tag); return ptr; @@ -2431,6 +2572,13 @@ const char* NodeExecutionMetaData::_InternalParse(const char* begin, const char* } // switch } // while return ptr; +string_till_end: + static_cast<::std::string*>(object)->clear(); + static_cast<::std::string*>(object)->reserve(size); + goto len_delim_till_end; +len_delim_till_end: + return ctx->StoreAndTailCall(ptr, end, {_InternalParse, msg}, + {parser_till_end, object}, size); } #else // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER bool NodeExecutionMetaData::MergePartialFromCodedStream( @@ -2442,12 +2590,60 @@ bool NodeExecutionMetaData::MergePartialFromCodedStream( ::std::pair<::google::protobuf::uint32, bool> p = input->ReadTagWithCutoffNoLastTag(127u); tag = p.first; if (!p.second) goto handle_unusual; - handle_unusual: - if (tag == 0) { - goto success; + switch (::google::protobuf::internal::WireFormatLite::GetTagFieldNumber(tag)) { + // string retry_group = 1; + case 1: { + if (static_cast< ::google::protobuf::uint8>(tag) == (10 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_retry_group())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->retry_group().data(), static_cast(this->retry_group().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.admin.NodeExecutionMetaData.retry_group")); + } else { + goto handle_unusual; + } + break; + } + + // bool is_parent_node = 2; + case 2: { + if (static_cast< ::google::protobuf::uint8>(tag) == (16 & 0xFF)) { + + DO_((::google::protobuf::internal::WireFormatLite::ReadPrimitive< + bool, ::google::protobuf::internal::WireFormatLite::TYPE_BOOL>( + input, &is_parent_node_))); + } else { + goto handle_unusual; + } + break; + } + + // string spec_node_id = 3; + case 3: { + if (static_cast< ::google::protobuf::uint8>(tag) == (26 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_spec_node_id())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->spec_node_id().data(), static_cast(this->spec_node_id().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.admin.NodeExecutionMetaData.spec_node_id")); + } else { + goto handle_unusual; + } + break; + } + + default: { + handle_unusual: + if (tag == 0) { + goto success; + } + DO_(::google::protobuf::internal::WireFormat::SkipField( + input, tag, _internal_metadata_.mutable_unknown_fields())); + break; + } } - DO_(::google::protobuf::internal::WireFormat::SkipField( - input, tag, _internal_metadata_.mutable_unknown_fields())); } success: // @@protoc_insertion_point(parse_success:flyteidl.admin.NodeExecutionMetaData) @@ -2465,6 +2661,31 @@ void NodeExecutionMetaData::SerializeWithCachedSizes( ::google::protobuf::uint32 cached_has_bits = 0; (void) cached_has_bits; + // string retry_group = 1; + if (this->retry_group().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->retry_group().data(), static_cast(this->retry_group().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.NodeExecutionMetaData.retry_group"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 1, this->retry_group(), output); + } + + // bool is_parent_node = 2; + if (this->is_parent_node() != 0) { + ::google::protobuf::internal::WireFormatLite::WriteBool(2, this->is_parent_node(), output); + } + + // string spec_node_id = 3; + if (this->spec_node_id().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->spec_node_id().data(), static_cast(this->spec_node_id().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.NodeExecutionMetaData.spec_node_id"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 3, this->spec_node_id(), output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -2478,6 +2699,33 @@ ::google::protobuf::uint8* NodeExecutionMetaData::InternalSerializeWithCachedSiz ::google::protobuf::uint32 cached_has_bits = 0; (void) cached_has_bits; + // string retry_group = 1; + if (this->retry_group().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->retry_group().data(), static_cast(this->retry_group().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.NodeExecutionMetaData.retry_group"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 1, this->retry_group(), target); + } + + // bool is_parent_node = 2; + if (this->is_parent_node() != 0) { + target = ::google::protobuf::internal::WireFormatLite::WriteBoolToArray(2, this->is_parent_node(), target); + } + + // string spec_node_id = 3; + if (this->spec_node_id().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->spec_node_id().data(), static_cast(this->spec_node_id().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.NodeExecutionMetaData.spec_node_id"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 3, this->spec_node_id(), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -2499,6 +2747,25 @@ size_t NodeExecutionMetaData::ByteSizeLong() const { // Prevent compiler warnings about cached_has_bits being unused (void) cached_has_bits; + // string retry_group = 1; + if (this->retry_group().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->retry_group()); + } + + // string spec_node_id = 3; + if (this->spec_node_id().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->spec_node_id()); + } + + // bool is_parent_node = 2; + if (this->is_parent_node() != 0) { + total_size += 1 + 1; + } + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); SetCachedSize(cached_size); return total_size; @@ -2526,6 +2793,17 @@ void NodeExecutionMetaData::MergeFrom(const NodeExecutionMetaData& from) { ::google::protobuf::uint32 cached_has_bits = 0; (void) cached_has_bits; + if (from.retry_group().size() > 0) { + + retry_group_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.retry_group_); + } + if (from.spec_node_id().size() > 0) { + + spec_node_id_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.spec_node_id_); + } + if (from.is_parent_node() != 0) { + set_is_parent_node(from.is_parent_node()); + } } void NodeExecutionMetaData::CopyFrom(const ::google::protobuf::Message& from) { @@ -2553,6 +2831,11 @@ void NodeExecutionMetaData::Swap(NodeExecutionMetaData* other) { void NodeExecutionMetaData::InternalSwap(NodeExecutionMetaData* other) { using std::swap; _internal_metadata_.Swap(&other->_internal_metadata_); + retry_group_.Swap(&other->retry_group_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); + spec_node_id_.Swap(&other->spec_node_id_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); + swap(is_parent_node_, other->is_parent_node_); } ::google::protobuf::Metadata NodeExecutionMetaData::GetMetadata() const { diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/node_execution.pb.h b/flyteidl/gen/pb-cpp/flyteidl/admin/node_execution.pb.h index 1bf5dcb00d..836949c43c 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/node_execution.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/node_execution.pb.h @@ -344,6 +344,20 @@ class NodeExecutionListRequest final : ::std::string* release_filters(); void set_allocated_filters(::std::string* filters); + // string unique_parent_id = 6; + void clear_unique_parent_id(); + static const int kUniqueParentIdFieldNumber = 6; + const ::std::string& unique_parent_id() const; + void set_unique_parent_id(const ::std::string& value); + #if LANG_CXX11 + void set_unique_parent_id(::std::string&& value); + #endif + void set_unique_parent_id(const char* value); + void set_unique_parent_id(const char* value, size_t size); + ::std::string* mutable_unique_parent_id(); + ::std::string* release_unique_parent_id(); + void set_allocated_unique_parent_id(::std::string* unique_parent_id); + // .flyteidl.core.WorkflowExecutionIdentifier workflow_execution_id = 1; bool has_workflow_execution_id() const; void clear_workflow_execution_id(); @@ -375,6 +389,7 @@ class NodeExecutionListRequest final : ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; ::google::protobuf::internal::ArenaStringPtr token_; ::google::protobuf::internal::ArenaStringPtr filters_; + ::google::protobuf::internal::ArenaStringPtr unique_parent_id_; ::flyteidl::core::WorkflowExecutionIdentifier* workflow_execution_id_; ::flyteidl::admin::Sort* sort_by_; ::google::protobuf::uint32 limit_; @@ -790,11 +805,48 @@ class NodeExecutionMetaData final : // accessors ------------------------------------------------------- + // string retry_group = 1; + void clear_retry_group(); + static const int kRetryGroupFieldNumber = 1; + const ::std::string& retry_group() const; + void set_retry_group(const ::std::string& value); + #if LANG_CXX11 + void set_retry_group(::std::string&& value); + #endif + void set_retry_group(const char* value); + void set_retry_group(const char* value, size_t size); + ::std::string* mutable_retry_group(); + ::std::string* release_retry_group(); + void set_allocated_retry_group(::std::string* retry_group); + + // string spec_node_id = 3; + void clear_spec_node_id(); + static const int kSpecNodeIdFieldNumber = 3; + const ::std::string& spec_node_id() const; + void set_spec_node_id(const ::std::string& value); + #if LANG_CXX11 + void set_spec_node_id(::std::string&& value); + #endif + void set_spec_node_id(const char* value); + void set_spec_node_id(const char* value, size_t size); + ::std::string* mutable_spec_node_id(); + ::std::string* release_spec_node_id(); + void set_allocated_spec_node_id(::std::string* spec_node_id); + + // bool is_parent_node = 2; + void clear_is_parent_node(); + static const int kIsParentNodeFieldNumber = 2; + bool is_parent_node() const; + void set_is_parent_node(bool value); + // @@protoc_insertion_point(class_scope:flyteidl.admin.NodeExecutionMetaData) private: class HasBitSetters; ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + ::google::protobuf::internal::ArenaStringPtr retry_group_; + ::google::protobuf::internal::ArenaStringPtr spec_node_id_; + bool is_parent_node_; mutable ::google::protobuf::internal::CachedSize _cached_size_; friend struct ::TableStruct_flyteidl_2fadmin_2fnode_5fexecution_2eproto; }; @@ -1778,6 +1830,59 @@ inline void NodeExecutionListRequest::set_allocated_sort_by(::flyteidl::admin::S // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.NodeExecutionListRequest.sort_by) } +// string unique_parent_id = 6; +inline void NodeExecutionListRequest::clear_unique_parent_id() { + unique_parent_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& NodeExecutionListRequest::unique_parent_id() const { + // @@protoc_insertion_point(field_get:flyteidl.admin.NodeExecutionListRequest.unique_parent_id) + return unique_parent_id_.GetNoArena(); +} +inline void NodeExecutionListRequest::set_unique_parent_id(const ::std::string& value) { + + unique_parent_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.admin.NodeExecutionListRequest.unique_parent_id) +} +#if LANG_CXX11 +inline void NodeExecutionListRequest::set_unique_parent_id(::std::string&& value) { + + unique_parent_id_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.admin.NodeExecutionListRequest.unique_parent_id) +} +#endif +inline void NodeExecutionListRequest::set_unique_parent_id(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + unique_parent_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.admin.NodeExecutionListRequest.unique_parent_id) +} +inline void NodeExecutionListRequest::set_unique_parent_id(const char* value, size_t size) { + + unique_parent_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.admin.NodeExecutionListRequest.unique_parent_id) +} +inline ::std::string* NodeExecutionListRequest::mutable_unique_parent_id() { + + // @@protoc_insertion_point(field_mutable:flyteidl.admin.NodeExecutionListRequest.unique_parent_id) + return unique_parent_id_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* NodeExecutionListRequest::release_unique_parent_id() { + // @@protoc_insertion_point(field_release:flyteidl.admin.NodeExecutionListRequest.unique_parent_id) + + return unique_parent_id_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void NodeExecutionListRequest::set_allocated_unique_parent_id(::std::string* unique_parent_id) { + if (unique_parent_id != nullptr) { + + } else { + + } + unique_parent_id_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), unique_parent_id); + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.NodeExecutionListRequest.unique_parent_id) +} + // ------------------------------------------------------------------- // NodeExecutionForTaskListRequest @@ -2200,6 +2305,126 @@ inline void NodeExecution::set_allocated_metadata(::flyteidl::admin::NodeExecuti // NodeExecutionMetaData +// string retry_group = 1; +inline void NodeExecutionMetaData::clear_retry_group() { + retry_group_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& NodeExecutionMetaData::retry_group() const { + // @@protoc_insertion_point(field_get:flyteidl.admin.NodeExecutionMetaData.retry_group) + return retry_group_.GetNoArena(); +} +inline void NodeExecutionMetaData::set_retry_group(const ::std::string& value) { + + retry_group_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.admin.NodeExecutionMetaData.retry_group) +} +#if LANG_CXX11 +inline void NodeExecutionMetaData::set_retry_group(::std::string&& value) { + + retry_group_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.admin.NodeExecutionMetaData.retry_group) +} +#endif +inline void NodeExecutionMetaData::set_retry_group(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + retry_group_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.admin.NodeExecutionMetaData.retry_group) +} +inline void NodeExecutionMetaData::set_retry_group(const char* value, size_t size) { + + retry_group_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.admin.NodeExecutionMetaData.retry_group) +} +inline ::std::string* NodeExecutionMetaData::mutable_retry_group() { + + // @@protoc_insertion_point(field_mutable:flyteidl.admin.NodeExecutionMetaData.retry_group) + return retry_group_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* NodeExecutionMetaData::release_retry_group() { + // @@protoc_insertion_point(field_release:flyteidl.admin.NodeExecutionMetaData.retry_group) + + return retry_group_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void NodeExecutionMetaData::set_allocated_retry_group(::std::string* retry_group) { + if (retry_group != nullptr) { + + } else { + + } + retry_group_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), retry_group); + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.NodeExecutionMetaData.retry_group) +} + +// bool is_parent_node = 2; +inline void NodeExecutionMetaData::clear_is_parent_node() { + is_parent_node_ = false; +} +inline bool NodeExecutionMetaData::is_parent_node() const { + // @@protoc_insertion_point(field_get:flyteidl.admin.NodeExecutionMetaData.is_parent_node) + return is_parent_node_; +} +inline void NodeExecutionMetaData::set_is_parent_node(bool value) { + + is_parent_node_ = value; + // @@protoc_insertion_point(field_set:flyteidl.admin.NodeExecutionMetaData.is_parent_node) +} + +// string spec_node_id = 3; +inline void NodeExecutionMetaData::clear_spec_node_id() { + spec_node_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& NodeExecutionMetaData::spec_node_id() const { + // @@protoc_insertion_point(field_get:flyteidl.admin.NodeExecutionMetaData.spec_node_id) + return spec_node_id_.GetNoArena(); +} +inline void NodeExecutionMetaData::set_spec_node_id(const ::std::string& value) { + + spec_node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.admin.NodeExecutionMetaData.spec_node_id) +} +#if LANG_CXX11 +inline void NodeExecutionMetaData::set_spec_node_id(::std::string&& value) { + + spec_node_id_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.admin.NodeExecutionMetaData.spec_node_id) +} +#endif +inline void NodeExecutionMetaData::set_spec_node_id(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + spec_node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.admin.NodeExecutionMetaData.spec_node_id) +} +inline void NodeExecutionMetaData::set_spec_node_id(const char* value, size_t size) { + + spec_node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.admin.NodeExecutionMetaData.spec_node_id) +} +inline ::std::string* NodeExecutionMetaData::mutable_spec_node_id() { + + // @@protoc_insertion_point(field_mutable:flyteidl.admin.NodeExecutionMetaData.spec_node_id) + return spec_node_id_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* NodeExecutionMetaData::release_spec_node_id() { + // @@protoc_insertion_point(field_release:flyteidl.admin.NodeExecutionMetaData.spec_node_id) + + return spec_node_id_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void NodeExecutionMetaData::set_allocated_spec_node_id(::std::string* spec_node_id) { + if (spec_node_id != nullptr) { + + } else { + + } + spec_node_id_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), spec_node_id); + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.NodeExecutionMetaData.spec_node_id) +} + // ------------------------------------------------------------------- // NodeExecutionList diff --git a/flyteidl/gen/pb-cpp/flyteidl/event/event.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/event/event.pb.cc index 004abd8599..2a94a255db 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/event/event.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/event/event.pb.cc @@ -22,6 +22,7 @@ extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fidentifier_2eproto ::google::p extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fidentifier_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_WorkflowExecutionIdentifier_flyteidl_2fcore_2fidentifier_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fidentifier_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_NodeExecutionIdentifier_flyteidl_2fcore_2fidentifier_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fidentifier_2eproto ::google::protobuf::internal::SCCInfo<2> scc_info_TaskExecutionIdentifier_flyteidl_2fcore_2fidentifier_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fevent_2fevent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_ParentNodeExecutionMetadata_flyteidl_2fevent_2fevent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fevent_2fevent_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_ParentTaskExecutionMetadata_flyteidl_2fevent_2fevent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fevent_2fevent_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_WorkflowNodeMetadata_flyteidl_2fevent_2fevent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_google_2fprotobuf_2fstruct_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_ListValue_google_2fprotobuf_2fstruct_2eproto; @@ -49,6 +50,10 @@ class ParentTaskExecutionMetadataDefaultTypeInternal { public: ::google::protobuf::internal::ExplicitlyConstructed _instance; } _ParentTaskExecutionMetadata_default_instance_; +class ParentNodeExecutionMetadataDefaultTypeInternal { + public: + ::google::protobuf::internal::ExplicitlyConstructed _instance; +} _ParentNodeExecutionMetadata_default_instance_; class TaskExecutionEventDefaultTypeInternal { public: ::google::protobuf::internal::ExplicitlyConstructed _instance; @@ -85,13 +90,14 @@ static void InitDefaultsNodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto() { ::flyteidl::event::NodeExecutionEvent::InitAsDefaultInstance(); } -::google::protobuf::internal::SCCInfo<5> scc_info_NodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto = - {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 5, InitDefaultsNodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto}, { +::google::protobuf::internal::SCCInfo<6> scc_info_NodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 6, InitDefaultsNodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto}, { &scc_info_NodeExecutionIdentifier_flyteidl_2fcore_2fidentifier_2eproto.base, &scc_info_Timestamp_google_2fprotobuf_2ftimestamp_2eproto.base, &scc_info_ExecutionError_flyteidl_2fcore_2fexecution_2eproto.base, &scc_info_WorkflowNodeMetadata_flyteidl_2fevent_2fevent_2eproto.base, - &scc_info_ParentTaskExecutionMetadata_flyteidl_2fevent_2fevent_2eproto.base,}}; + &scc_info_ParentTaskExecutionMetadata_flyteidl_2fevent_2fevent_2eproto.base, + &scc_info_ParentNodeExecutionMetadata_flyteidl_2fevent_2fevent_2eproto.base,}}; static void InitDefaultsWorkflowNodeMetadata_flyteidl_2fevent_2fevent_2eproto() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -123,6 +129,20 @@ ::google::protobuf::internal::SCCInfo<1> scc_info_ParentTaskExecutionMetadata_fl {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsParentTaskExecutionMetadata_flyteidl_2fevent_2fevent_2eproto}, { &scc_info_TaskExecutionIdentifier_flyteidl_2fcore_2fidentifier_2eproto.base,}}; +static void InitDefaultsParentNodeExecutionMetadata_flyteidl_2fevent_2fevent_2eproto() { + GOOGLE_PROTOBUF_VERIFY_VERSION; + + { + void* ptr = &::flyteidl::event::_ParentNodeExecutionMetadata_default_instance_; + new (ptr) ::flyteidl::event::ParentNodeExecutionMetadata(); + ::google::protobuf::internal::OnShutdownDestroyMessage(ptr); + } + ::flyteidl::event::ParentNodeExecutionMetadata::InitAsDefaultInstance(); +} + +::google::protobuf::internal::SCCInfo<0> scc_info_ParentNodeExecutionMetadata_flyteidl_2fevent_2fevent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 0, InitDefaultsParentNodeExecutionMetadata_flyteidl_2fevent_2fevent_2eproto}, {}}; + static void InitDefaultsTaskExecutionEvent_flyteidl_2fevent_2fevent_2eproto() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -148,10 +168,11 @@ void InitDefaults_flyteidl_2fevent_2fevent_2eproto() { ::google::protobuf::internal::InitSCC(&scc_info_NodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_WorkflowNodeMetadata_flyteidl_2fevent_2fevent_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_ParentTaskExecutionMetadata_flyteidl_2fevent_2fevent_2eproto.base); + ::google::protobuf::internal::InitSCC(&scc_info_ParentNodeExecutionMetadata_flyteidl_2fevent_2fevent_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_TaskExecutionEvent_flyteidl_2fevent_2fevent_2eproto.base); } -::google::protobuf::Metadata file_level_metadata_flyteidl_2fevent_2fevent_2eproto[5]; +::google::protobuf::Metadata file_level_metadata_flyteidl_2fevent_2fevent_2eproto[6]; constexpr ::google::protobuf::EnumDescriptor const** file_level_enum_descriptors_flyteidl_2fevent_2fevent_2eproto = nullptr; constexpr ::google::protobuf::ServiceDescriptor const** file_level_service_descriptors_flyteidl_2fevent_2fevent_2eproto = nullptr; @@ -182,6 +203,10 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fevent_2fevent_2eproto::o offsetof(::flyteidl::event::NodeExecutionEventDefaultTypeInternal, error_), offsetof(::flyteidl::event::NodeExecutionEventDefaultTypeInternal, workflow_node_metadata_), PROTOBUF_FIELD_OFFSET(::flyteidl::event::NodeExecutionEvent, parent_task_metadata_), + PROTOBUF_FIELD_OFFSET(::flyteidl::event::NodeExecutionEvent, parent_node_metadata_), + PROTOBUF_FIELD_OFFSET(::flyteidl::event::NodeExecutionEvent, retry_group_), + PROTOBUF_FIELD_OFFSET(::flyteidl::event::NodeExecutionEvent, spec_node_id_), + PROTOBUF_FIELD_OFFSET(::flyteidl::event::NodeExecutionEvent, node_name_), PROTOBUF_FIELD_OFFSET(::flyteidl::event::NodeExecutionEvent, output_result_), PROTOBUF_FIELD_OFFSET(::flyteidl::event::NodeExecutionEvent, target_metadata_), ~0u, // no _has_bits_ @@ -197,6 +222,12 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fevent_2fevent_2eproto::o ~0u, // no _weak_field_map_ PROTOBUF_FIELD_OFFSET(::flyteidl::event::ParentTaskExecutionMetadata, id_), ~0u, // no _has_bits_ + PROTOBUF_FIELD_OFFSET(::flyteidl::event::ParentNodeExecutionMetadata, _internal_metadata_), + ~0u, // no _extensions_ + ~0u, // no _oneof_case_ + ~0u, // no _weak_field_map_ + PROTOBUF_FIELD_OFFSET(::flyteidl::event::ParentNodeExecutionMetadata, node_id_), + ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::event::TaskExecutionEvent, _internal_metadata_), ~0u, // no _extensions_ PROTOBUF_FIELD_OFFSET(::flyteidl::event::TaskExecutionEvent, _oneof_case_[0]), @@ -218,9 +249,10 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fevent_2fevent_2eproto::o static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SECTION_VARIABLE(protodesc_cold) = { { 0, -1, sizeof(::flyteidl::event::WorkflowExecutionEvent)}, { 12, -1, sizeof(::flyteidl::event::NodeExecutionEvent)}, - { 28, -1, sizeof(::flyteidl::event::WorkflowNodeMetadata)}, - { 34, -1, sizeof(::flyteidl::event::ParentTaskExecutionMetadata)}, - { 40, -1, sizeof(::flyteidl::event::TaskExecutionEvent)}, + { 32, -1, sizeof(::flyteidl::event::WorkflowNodeMetadata)}, + { 38, -1, sizeof(::flyteidl::event::ParentTaskExecutionMetadata)}, + { 44, -1, sizeof(::flyteidl::event::ParentNodeExecutionMetadata)}, + { 50, -1, sizeof(::flyteidl::event::TaskExecutionEvent)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -228,13 +260,14 @@ static ::google::protobuf::Message const * const file_default_instances[] = { reinterpret_cast(&::flyteidl::event::_NodeExecutionEvent_default_instance_), reinterpret_cast(&::flyteidl::event::_WorkflowNodeMetadata_default_instance_), reinterpret_cast(&::flyteidl::event::_ParentTaskExecutionMetadata_default_instance_), + reinterpret_cast(&::flyteidl::event::_ParentNodeExecutionMetadata_default_instance_), reinterpret_cast(&::flyteidl::event::_TaskExecutionEvent_default_instance_), }; ::google::protobuf::internal::AssignDescriptorsTable assign_descriptors_table_flyteidl_2fevent_2fevent_2eproto = { {}, AddDescriptors_flyteidl_2fevent_2fevent_2eproto, "flyteidl/event/event.proto", schemas, file_default_instances, TableStruct_flyteidl_2fevent_2fevent_2eproto::offsets, - file_level_metadata_flyteidl_2fevent_2fevent_2eproto, 5, file_level_enum_descriptors_flyteidl_2fevent_2fevent_2eproto, file_level_service_descriptors_flyteidl_2fevent_2fevent_2eproto, + file_level_metadata_flyteidl_2fevent_2fevent_2eproto, 6, file_level_enum_descriptors_flyteidl_2fevent_2fevent_2eproto, file_level_service_descriptors_flyteidl_2fevent_2fevent_2eproto, }; const char descriptor_table_protodef_flyteidl_2fevent_2fevent_2eproto[] = @@ -249,7 +282,7 @@ const char descriptor_table_protodef_flyteidl_2fevent_2fevent_2eproto[] = "flowExecution.Phase\022/\n\013occurred_at\030\004 \001(\013" "2\032.google.protobuf.Timestamp\022\024\n\noutput_u" "ri\030\005 \001(\tH\000\022.\n\005error\030\006 \001(\0132\035.flyteidl.cor" - "e.ExecutionErrorH\000B\017\n\routput_result\"\321\003\n\022" + "e.ExecutionErrorH\000B\017\n\routput_result\"\332\004\n\022" "NodeExecutionEvent\0222\n\002id\030\001 \001(\0132&.flyteid" "l.core.NodeExecutionIdentifier\022\023\n\013produc" "er_id\030\002 \001(\t\0221\n\005phase\030\003 \001(\0162\".flyteidl.co" @@ -260,31 +293,36 @@ const char descriptor_table_protodef_flyteidl_2fevent_2fevent_2eproto[] = "\022F\n\026workflow_node_metadata\030\010 \001(\0132$.flyte" "idl.event.WorkflowNodeMetadataH\001\022I\n\024pare" "nt_task_metadata\030\t \001(\0132+.flyteidl.event." - "ParentTaskExecutionMetadataB\017\n\routput_re" - "sultB\021\n\017target_metadata\"X\n\024WorkflowNodeM" - "etadata\022@\n\014execution_id\030\001 \001(\0132*.flyteidl" - ".core.WorkflowExecutionIdentifier\"Q\n\033Par" - "entTaskExecutionMetadata\0222\n\002id\030\001 \001(\0132&.f" - "lyteidl.core.TaskExecutionIdentifier\"\357\003\n" - "\022TaskExecutionEvent\022*\n\007task_id\030\001 \001(\0132\031.f" - "lyteidl.core.Identifier\022H\n\030parent_node_e" - "xecution_id\030\002 \001(\0132&.flyteidl.core.NodeEx" - "ecutionIdentifier\022\025\n\rretry_attempt\030\003 \001(\r" - "\0221\n\005phase\030\004 \001(\0162\".flyteidl.core.TaskExec" - "ution.Phase\022\023\n\013producer_id\030\005 \001(\t\022$\n\004logs" - "\030\006 \003(\0132\026.flyteidl.core.TaskLog\022/\n\013occurr" - "ed_at\030\007 \001(\0132\032.google.protobuf.Timestamp\022" - "\021\n\tinput_uri\030\010 \001(\t\022\024\n\noutput_uri\030\t \001(\tH\000" - "\022.\n\005error\030\n \001(\0132\035.flyteidl.core.Executio" - "nErrorH\000\022,\n\013custom_info\030\013 \001(\0132\027.google.p" - "rotobuf.Struct\022\025\n\rphase_version\030\014 \001(\rB\017\n" - "\routput_resultB3Z1github.com/lyft/flytei" - "dl/gen/pb-go/flyteidl/eventb\006proto3" + "ParentTaskExecutionMetadata\022I\n\024parent_no" + "de_metadata\030\n \001(\0132+.flyteidl.event.Paren" + "tNodeExecutionMetadata\022\023\n\013retry_group\030\013 " + "\001(\t\022\024\n\014spec_node_id\030\014 \001(\t\022\021\n\tnode_name\030\r" + " \001(\tB\017\n\routput_resultB\021\n\017target_metadata" + "\"X\n\024WorkflowNodeMetadata\022@\n\014execution_id" + "\030\001 \001(\0132*.flyteidl.core.WorkflowExecution" + "Identifier\"Q\n\033ParentTaskExecutionMetadat" + "a\0222\n\002id\030\001 \001(\0132&.flyteidl.core.TaskExecut" + "ionIdentifier\".\n\033ParentNodeExecutionMeta" + "data\022\017\n\007node_id\030\001 \001(\t\"\357\003\n\022TaskExecutionE" + "vent\022*\n\007task_id\030\001 \001(\0132\031.flyteidl.core.Id" + "entifier\022H\n\030parent_node_execution_id\030\002 \001" + "(\0132&.flyteidl.core.NodeExecutionIdentifi" + "er\022\025\n\rretry_attempt\030\003 \001(\r\0221\n\005phase\030\004 \001(\016" + "2\".flyteidl.core.TaskExecution.Phase\022\023\n\013" + "producer_id\030\005 \001(\t\022$\n\004logs\030\006 \003(\0132\026.flytei" + "dl.core.TaskLog\022/\n\013occurred_at\030\007 \001(\0132\032.g" + "oogle.protobuf.Timestamp\022\021\n\tinput_uri\030\010 " + "\001(\t\022\024\n\noutput_uri\030\t \001(\tH\000\022.\n\005error\030\n \001(\013" + "2\035.flyteidl.core.ExecutionErrorH\000\022,\n\013cus" + "tom_info\030\013 \001(\0132\027.google.protobuf.Struct\022" + "\025\n\rphase_version\030\014 \001(\rB\017\n\routput_resultB" + "3Z1github.com/lyft/flyteidl/gen/pb-go/fl" + "yteidl/eventb\006proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fevent_2fevent_2eproto = { false, InitDefaults_flyteidl_2fevent_2fevent_2eproto, descriptor_table_protodef_flyteidl_2fevent_2fevent_2eproto, - "flyteidl/event/event.proto", &assign_descriptors_table_flyteidl_2fevent_2fevent_2eproto, 1675, + "flyteidl/event/event.proto", &assign_descriptors_table_flyteidl_2fevent_2fevent_2eproto, 1860, }; void AddDescriptors_flyteidl_2fevent_2fevent_2eproto() { @@ -1001,6 +1039,8 @@ void NodeExecutionEvent::InitAsDefaultInstance() { ::flyteidl::event::WorkflowNodeMetadata::internal_default_instance()); ::flyteidl::event::_NodeExecutionEvent_default_instance_._instance.get_mutable()->parent_task_metadata_ = const_cast< ::flyteidl::event::ParentTaskExecutionMetadata*>( ::flyteidl::event::ParentTaskExecutionMetadata::internal_default_instance()); + ::flyteidl::event::_NodeExecutionEvent_default_instance_._instance.get_mutable()->parent_node_metadata_ = const_cast< ::flyteidl::event::ParentNodeExecutionMetadata*>( + ::flyteidl::event::ParentNodeExecutionMetadata::internal_default_instance()); } class NodeExecutionEvent::HasBitSetters { public: @@ -1009,6 +1049,7 @@ class NodeExecutionEvent::HasBitSetters { static const ::flyteidl::core::ExecutionError& error(const NodeExecutionEvent* msg); static const ::flyteidl::event::WorkflowNodeMetadata& workflow_node_metadata(const NodeExecutionEvent* msg); static const ::flyteidl::event::ParentTaskExecutionMetadata& parent_task_metadata(const NodeExecutionEvent* msg); + static const ::flyteidl::event::ParentNodeExecutionMetadata& parent_node_metadata(const NodeExecutionEvent* msg); }; const ::flyteidl::core::NodeExecutionIdentifier& @@ -1031,6 +1072,10 @@ const ::flyteidl::event::ParentTaskExecutionMetadata& NodeExecutionEvent::HasBitSetters::parent_task_metadata(const NodeExecutionEvent* msg) { return *msg->parent_task_metadata_; } +const ::flyteidl::event::ParentNodeExecutionMetadata& +NodeExecutionEvent::HasBitSetters::parent_node_metadata(const NodeExecutionEvent* msg) { + return *msg->parent_node_metadata_; +} void NodeExecutionEvent::clear_id() { if (GetArenaNoVirtual() == nullptr && id_ != nullptr) { delete id_; @@ -1087,6 +1132,10 @@ const int NodeExecutionEvent::kOutputUriFieldNumber; const int NodeExecutionEvent::kErrorFieldNumber; const int NodeExecutionEvent::kWorkflowNodeMetadataFieldNumber; const int NodeExecutionEvent::kParentTaskMetadataFieldNumber; +const int NodeExecutionEvent::kParentNodeMetadataFieldNumber; +const int NodeExecutionEvent::kRetryGroupFieldNumber; +const int NodeExecutionEvent::kSpecNodeIdFieldNumber; +const int NodeExecutionEvent::kNodeNameFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 NodeExecutionEvent::NodeExecutionEvent() @@ -1106,6 +1155,18 @@ NodeExecutionEvent::NodeExecutionEvent(const NodeExecutionEvent& from) if (from.input_uri().size() > 0) { input_uri_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.input_uri_); } + retry_group_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.retry_group().size() > 0) { + retry_group_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.retry_group_); + } + spec_node_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.spec_node_id().size() > 0) { + spec_node_id_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.spec_node_id_); + } + node_name_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.node_name().size() > 0) { + node_name_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.node_name_); + } if (from.has_id()) { id_ = new ::flyteidl::core::NodeExecutionIdentifier(*from.id_); } else { @@ -1121,6 +1182,11 @@ NodeExecutionEvent::NodeExecutionEvent(const NodeExecutionEvent& from) } else { parent_task_metadata_ = nullptr; } + if (from.has_parent_node_metadata()) { + parent_node_metadata_ = new ::flyteidl::event::ParentNodeExecutionMetadata(*from.parent_node_metadata_); + } else { + parent_node_metadata_ = nullptr; + } phase_ = from.phase_; clear_has_output_result(); switch (from.output_result_case()) { @@ -1154,6 +1220,9 @@ void NodeExecutionEvent::SharedCtor() { &scc_info_NodeExecutionEvent_flyteidl_2fevent_2fevent_2eproto.base); producer_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); input_uri_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + retry_group_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + spec_node_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + node_name_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); ::memset(&id_, 0, static_cast( reinterpret_cast(&phase_) - reinterpret_cast(&id_)) + sizeof(phase_)); @@ -1169,9 +1238,13 @@ NodeExecutionEvent::~NodeExecutionEvent() { void NodeExecutionEvent::SharedDtor() { producer_id_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); input_uri_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + retry_group_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + spec_node_id_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + node_name_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); if (this != internal_default_instance()) delete id_; if (this != internal_default_instance()) delete occurred_at_; if (this != internal_default_instance()) delete parent_task_metadata_; + if (this != internal_default_instance()) delete parent_node_metadata_; if (has_output_result()) { clear_output_result(); } @@ -1230,6 +1303,9 @@ void NodeExecutionEvent::Clear() { producer_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); input_uri_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + retry_group_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + spec_node_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + node_name_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); if (GetArenaNoVirtual() == nullptr && id_ != nullptr) { delete id_; } @@ -1242,6 +1318,10 @@ void NodeExecutionEvent::Clear() { delete parent_task_metadata_; } parent_task_metadata_ = nullptr; + if (GetArenaNoVirtual() == nullptr && parent_node_metadata_ != nullptr) { + delete parent_node_metadata_; + } + parent_node_metadata_ = nullptr; phase_ = 0; clear_output_result(); clear_target_metadata(); @@ -1382,6 +1462,67 @@ const char* NodeExecutionEvent::_InternalParse(const char* begin, const char* en {parser_till_end, object}, ptr - size, ptr)); break; } + // .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + case 10: { + if (static_cast<::google::protobuf::uint8>(tag) != 82) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + parser_till_end = ::flyteidl::event::ParentNodeExecutionMetadata::_InternalParse; + object = msg->mutable_parent_node_metadata(); + if (size > end - ptr) goto len_delim_till_end; + ptr += size; + GOOGLE_PROTOBUF_PARSER_ASSERT(ctx->ParseExactRange( + {parser_till_end, object}, ptr - size, ptr)); + break; + } + // string retry_group = 11; + case 11: { + if (static_cast<::google::protobuf::uint8>(tag) != 90) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.event.NodeExecutionEvent.retry_group"); + object = msg->mutable_retry_group(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } + // string spec_node_id = 12; + case 12: { + if (static_cast<::google::protobuf::uint8>(tag) != 98) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.event.NodeExecutionEvent.spec_node_id"); + object = msg->mutable_spec_node_id(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } + // string node_name = 13; + case 13: { + if (static_cast<::google::protobuf::uint8>(tag) != 106) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.event.NodeExecutionEvent.node_name"); + object = msg->mutable_node_name(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } default: { handle_unusual: if ((tag & 7) == 4 || tag == 0) { @@ -1530,6 +1671,62 @@ bool NodeExecutionEvent::MergePartialFromCodedStream( break; } + // .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + case 10: { + if (static_cast< ::google::protobuf::uint8>(tag) == (82 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_parent_node_metadata())); + } else { + goto handle_unusual; + } + break; + } + + // string retry_group = 11; + case 11: { + if (static_cast< ::google::protobuf::uint8>(tag) == (90 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_retry_group())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->retry_group().data(), static_cast(this->retry_group().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.event.NodeExecutionEvent.retry_group")); + } else { + goto handle_unusual; + } + break; + } + + // string spec_node_id = 12; + case 12: { + if (static_cast< ::google::protobuf::uint8>(tag) == (98 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_spec_node_id())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->spec_node_id().data(), static_cast(this->spec_node_id().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.event.NodeExecutionEvent.spec_node_id")); + } else { + goto handle_unusual; + } + break; + } + + // string node_name = 13; + case 13: { + if (static_cast< ::google::protobuf::uint8>(tag) == (106 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_node_name())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->node_name().data(), static_cast(this->node_name().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.event.NodeExecutionEvent.node_name")); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -1623,6 +1820,42 @@ void NodeExecutionEvent::SerializeWithCachedSizes( 9, HasBitSetters::parent_task_metadata(this), output); } + // .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + if (this->has_parent_node_metadata()) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 10, HasBitSetters::parent_node_metadata(this), output); + } + + // string retry_group = 11; + if (this->retry_group().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->retry_group().data(), static_cast(this->retry_group().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.event.NodeExecutionEvent.retry_group"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 11, this->retry_group(), output); + } + + // string spec_node_id = 12; + if (this->spec_node_id().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->spec_node_id().data(), static_cast(this->spec_node_id().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.event.NodeExecutionEvent.spec_node_id"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 12, this->spec_node_id(), output); + } + + // string node_name = 13; + if (this->node_name().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->node_name().data(), static_cast(this->node_name().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.event.NodeExecutionEvent.node_name"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 13, this->node_name(), output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -1710,6 +1943,46 @@ ::google::protobuf::uint8* NodeExecutionEvent::InternalSerializeWithCachedSizesT 9, HasBitSetters::parent_task_metadata(this), target); } + // .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + if (this->has_parent_node_metadata()) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 10, HasBitSetters::parent_node_metadata(this), target); + } + + // string retry_group = 11; + if (this->retry_group().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->retry_group().data(), static_cast(this->retry_group().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.event.NodeExecutionEvent.retry_group"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 11, this->retry_group(), target); + } + + // string spec_node_id = 12; + if (this->spec_node_id().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->spec_node_id().data(), static_cast(this->spec_node_id().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.event.NodeExecutionEvent.spec_node_id"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 12, this->spec_node_id(), target); + } + + // string node_name = 13; + if (this->node_name().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->node_name().data(), static_cast(this->node_name().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.event.NodeExecutionEvent.node_name"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 13, this->node_name(), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -1745,6 +2018,27 @@ size_t NodeExecutionEvent::ByteSizeLong() const { this->input_uri()); } + // string retry_group = 11; + if (this->retry_group().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->retry_group()); + } + + // string spec_node_id = 12; + if (this->spec_node_id().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->spec_node_id()); + } + + // string node_name = 13; + if (this->node_name().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->node_name()); + } + // .flyteidl.core.NodeExecutionIdentifier id = 1; if (this->has_id()) { total_size += 1 + @@ -1766,6 +2060,13 @@ size_t NodeExecutionEvent::ByteSizeLong() const { *parent_task_metadata_); } + // .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + if (this->has_parent_node_metadata()) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *parent_node_metadata_); + } + // .flyteidl.core.NodeExecution.Phase phase = 3; if (this->phase() != 0) { total_size += 1 + @@ -1838,6 +2139,18 @@ void NodeExecutionEvent::MergeFrom(const NodeExecutionEvent& from) { input_uri_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.input_uri_); } + if (from.retry_group().size() > 0) { + + retry_group_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.retry_group_); + } + if (from.spec_node_id().size() > 0) { + + spec_node_id_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.spec_node_id_); + } + if (from.node_name().size() > 0) { + + node_name_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.node_name_); + } if (from.has_id()) { mutable_id()->::flyteidl::core::NodeExecutionIdentifier::MergeFrom(from.id()); } @@ -1847,6 +2160,9 @@ void NodeExecutionEvent::MergeFrom(const NodeExecutionEvent& from) { if (from.has_parent_task_metadata()) { mutable_parent_task_metadata()->::flyteidl::event::ParentTaskExecutionMetadata::MergeFrom(from.parent_task_metadata()); } + if (from.has_parent_node_metadata()) { + mutable_parent_node_metadata()->::flyteidl::event::ParentNodeExecutionMetadata::MergeFrom(from.parent_node_metadata()); + } if (from.phase() != 0) { set_phase(from.phase()); } @@ -1903,9 +2219,16 @@ void NodeExecutionEvent::InternalSwap(NodeExecutionEvent* other) { GetArenaNoVirtual()); input_uri_.Swap(&other->input_uri_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), GetArenaNoVirtual()); + retry_group_.Swap(&other->retry_group_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); + spec_node_id_.Swap(&other->spec_node_id_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); + node_name_.Swap(&other->node_name_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); swap(id_, other->id_); swap(occurred_at_, other->occurred_at_); swap(parent_task_metadata_, other->parent_task_metadata_); + swap(parent_node_metadata_, other->parent_node_metadata_); swap(phase_, other->phase_); swap(output_result_, other->output_result_); swap(target_metadata_, other->target_metadata_); @@ -2505,6 +2828,303 @@ ::google::protobuf::Metadata ParentTaskExecutionMetadata::GetMetadata() const { } +// =================================================================== + +void ParentNodeExecutionMetadata::InitAsDefaultInstance() { +} +class ParentNodeExecutionMetadata::HasBitSetters { + public: +}; + +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +const int ParentNodeExecutionMetadata::kNodeIdFieldNumber; +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 + +ParentNodeExecutionMetadata::ParentNodeExecutionMetadata() + : ::google::protobuf::Message(), _internal_metadata_(nullptr) { + SharedCtor(); + // @@protoc_insertion_point(constructor:flyteidl.event.ParentNodeExecutionMetadata) +} +ParentNodeExecutionMetadata::ParentNodeExecutionMetadata(const ParentNodeExecutionMetadata& from) + : ::google::protobuf::Message(), + _internal_metadata_(nullptr) { + _internal_metadata_.MergeFrom(from._internal_metadata_); + node_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.node_id().size() > 0) { + node_id_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.node_id_); + } + // @@protoc_insertion_point(copy_constructor:flyteidl.event.ParentNodeExecutionMetadata) +} + +void ParentNodeExecutionMetadata::SharedCtor() { + ::google::protobuf::internal::InitSCC( + &scc_info_ParentNodeExecutionMetadata_flyteidl_2fevent_2fevent_2eproto.base); + node_id_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} + +ParentNodeExecutionMetadata::~ParentNodeExecutionMetadata() { + // @@protoc_insertion_point(destructor:flyteidl.event.ParentNodeExecutionMetadata) + SharedDtor(); +} + +void ParentNodeExecutionMetadata::SharedDtor() { + node_id_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} + +void ParentNodeExecutionMetadata::SetCachedSize(int size) const { + _cached_size_.Set(size); +} +const ParentNodeExecutionMetadata& ParentNodeExecutionMetadata::default_instance() { + ::google::protobuf::internal::InitSCC(&::scc_info_ParentNodeExecutionMetadata_flyteidl_2fevent_2fevent_2eproto.base); + return *internal_default_instance(); +} + + +void ParentNodeExecutionMetadata::Clear() { +// @@protoc_insertion_point(message_clear_start:flyteidl.event.ParentNodeExecutionMetadata) + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + node_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + _internal_metadata_.Clear(); +} + +#if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +const char* ParentNodeExecutionMetadata::_InternalParse(const char* begin, const char* end, void* object, + ::google::protobuf::internal::ParseContext* ctx) { + auto msg = static_cast(object); + ::google::protobuf::int32 size; (void)size; + int depth; (void)depth; + ::google::protobuf::uint32 tag; + ::google::protobuf::internal::ParseFunc parser_till_end; (void)parser_till_end; + auto ptr = begin; + while (ptr < end) { + ptr = ::google::protobuf::io::Parse32(ptr, &tag); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + switch (tag >> 3) { + // string node_id = 1; + case 1: { + if (static_cast<::google::protobuf::uint8>(tag) != 10) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.event.ParentNodeExecutionMetadata.node_id"); + object = msg->mutable_node_id(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } + default: { + handle_unusual: + if ((tag & 7) == 4 || tag == 0) { + ctx->EndGroup(tag); + return ptr; + } + auto res = UnknownFieldParse(tag, {_InternalParse, msg}, + ptr, end, msg->_internal_metadata_.mutable_unknown_fields(), ctx); + ptr = res.first; + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr != nullptr); + if (res.second) return ptr; + } + } // switch + } // while + return ptr; +string_till_end: + static_cast<::std::string*>(object)->clear(); + static_cast<::std::string*>(object)->reserve(size); + goto len_delim_till_end; +len_delim_till_end: + return ctx->StoreAndTailCall(ptr, end, {_InternalParse, msg}, + {parser_till_end, object}, size); +} +#else // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +bool ParentNodeExecutionMetadata::MergePartialFromCodedStream( + ::google::protobuf::io::CodedInputStream* input) { +#define DO_(EXPRESSION) if (!PROTOBUF_PREDICT_TRUE(EXPRESSION)) goto failure + ::google::protobuf::uint32 tag; + // @@protoc_insertion_point(parse_start:flyteidl.event.ParentNodeExecutionMetadata) + for (;;) { + ::std::pair<::google::protobuf::uint32, bool> p = input->ReadTagWithCutoffNoLastTag(127u); + tag = p.first; + if (!p.second) goto handle_unusual; + switch (::google::protobuf::internal::WireFormatLite::GetTagFieldNumber(tag)) { + // string node_id = 1; + case 1: { + if (static_cast< ::google::protobuf::uint8>(tag) == (10 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_node_id())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->node_id().data(), static_cast(this->node_id().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.event.ParentNodeExecutionMetadata.node_id")); + } else { + goto handle_unusual; + } + break; + } + + default: { + handle_unusual: + if (tag == 0) { + goto success; + } + DO_(::google::protobuf::internal::WireFormat::SkipField( + input, tag, _internal_metadata_.mutable_unknown_fields())); + break; + } + } + } +success: + // @@protoc_insertion_point(parse_success:flyteidl.event.ParentNodeExecutionMetadata) + return true; +failure: + // @@protoc_insertion_point(parse_failure:flyteidl.event.ParentNodeExecutionMetadata) + return false; +#undef DO_ +} +#endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + +void ParentNodeExecutionMetadata::SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const { + // @@protoc_insertion_point(serialize_start:flyteidl.event.ParentNodeExecutionMetadata) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // string node_id = 1; + if (this->node_id().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->node_id().data(), static_cast(this->node_id().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.event.ParentNodeExecutionMetadata.node_id"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 1, this->node_id(), output); + } + + if (_internal_metadata_.have_unknown_fields()) { + ::google::protobuf::internal::WireFormat::SerializeUnknownFields( + _internal_metadata_.unknown_fields(), output); + } + // @@protoc_insertion_point(serialize_end:flyteidl.event.ParentNodeExecutionMetadata) +} + +::google::protobuf::uint8* ParentNodeExecutionMetadata::InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const { + // @@protoc_insertion_point(serialize_to_array_start:flyteidl.event.ParentNodeExecutionMetadata) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // string node_id = 1; + if (this->node_id().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->node_id().data(), static_cast(this->node_id().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.event.ParentNodeExecutionMetadata.node_id"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 1, this->node_id(), target); + } + + if (_internal_metadata_.have_unknown_fields()) { + target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( + _internal_metadata_.unknown_fields(), target); + } + // @@protoc_insertion_point(serialize_to_array_end:flyteidl.event.ParentNodeExecutionMetadata) + return target; +} + +size_t ParentNodeExecutionMetadata::ByteSizeLong() const { +// @@protoc_insertion_point(message_byte_size_start:flyteidl.event.ParentNodeExecutionMetadata) + size_t total_size = 0; + + if (_internal_metadata_.have_unknown_fields()) { + total_size += + ::google::protobuf::internal::WireFormat::ComputeUnknownFieldsSize( + _internal_metadata_.unknown_fields()); + } + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + // string node_id = 1; + if (this->node_id().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->node_id()); + } + + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); + SetCachedSize(cached_size); + return total_size; +} + +void ParentNodeExecutionMetadata::MergeFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_merge_from_start:flyteidl.event.ParentNodeExecutionMetadata) + GOOGLE_DCHECK_NE(&from, this); + const ParentNodeExecutionMetadata* source = + ::google::protobuf::DynamicCastToGenerated( + &from); + if (source == nullptr) { + // @@protoc_insertion_point(generalized_merge_from_cast_fail:flyteidl.event.ParentNodeExecutionMetadata) + ::google::protobuf::internal::ReflectionOps::Merge(from, this); + } else { + // @@protoc_insertion_point(generalized_merge_from_cast_success:flyteidl.event.ParentNodeExecutionMetadata) + MergeFrom(*source); + } +} + +void ParentNodeExecutionMetadata::MergeFrom(const ParentNodeExecutionMetadata& from) { +// @@protoc_insertion_point(class_specific_merge_from_start:flyteidl.event.ParentNodeExecutionMetadata) + GOOGLE_DCHECK_NE(&from, this); + _internal_metadata_.MergeFrom(from._internal_metadata_); + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + if (from.node_id().size() > 0) { + + node_id_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.node_id_); + } +} + +void ParentNodeExecutionMetadata::CopyFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_copy_from_start:flyteidl.event.ParentNodeExecutionMetadata) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +void ParentNodeExecutionMetadata::CopyFrom(const ParentNodeExecutionMetadata& from) { +// @@protoc_insertion_point(class_specific_copy_from_start:flyteidl.event.ParentNodeExecutionMetadata) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +bool ParentNodeExecutionMetadata::IsInitialized() const { + return true; +} + +void ParentNodeExecutionMetadata::Swap(ParentNodeExecutionMetadata* other) { + if (other == this) return; + InternalSwap(other); +} +void ParentNodeExecutionMetadata::InternalSwap(ParentNodeExecutionMetadata* other) { + using std::swap; + _internal_metadata_.Swap(&other->_internal_metadata_); + node_id_.Swap(&other->node_id_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); +} + +::google::protobuf::Metadata ParentNodeExecutionMetadata::GetMetadata() const { + ::google::protobuf::internal::AssignDescriptors(&::assign_descriptors_table_flyteidl_2fevent_2fevent_2eproto); + return ::file_level_metadata_flyteidl_2fevent_2fevent_2eproto[kIndexInFileMessages]; +} + + // =================================================================== void TaskExecutionEvent::InitAsDefaultInstance() { @@ -3573,6 +4193,9 @@ template<> PROTOBUF_NOINLINE ::flyteidl::event::WorkflowNodeMetadata* Arena::Cre template<> PROTOBUF_NOINLINE ::flyteidl::event::ParentTaskExecutionMetadata* Arena::CreateMaybeMessage< ::flyteidl::event::ParentTaskExecutionMetadata >(Arena* arena) { return Arena::CreateInternal< ::flyteidl::event::ParentTaskExecutionMetadata >(arena); } +template<> PROTOBUF_NOINLINE ::flyteidl::event::ParentNodeExecutionMetadata* Arena::CreateMaybeMessage< ::flyteidl::event::ParentNodeExecutionMetadata >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::event::ParentNodeExecutionMetadata >(arena); +} template<> PROTOBUF_NOINLINE ::flyteidl::event::TaskExecutionEvent* Arena::CreateMaybeMessage< ::flyteidl::event::TaskExecutionEvent >(Arena* arena) { return Arena::CreateInternal< ::flyteidl::event::TaskExecutionEvent >(arena); } diff --git a/flyteidl/gen/pb-cpp/flyteidl/event/event.pb.h b/flyteidl/gen/pb-cpp/flyteidl/event/event.pb.h index 5931ff66cb..792cc90fee 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/event/event.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/event/event.pb.h @@ -45,7 +45,7 @@ struct TableStruct_flyteidl_2fevent_2fevent_2eproto { PROTOBUF_SECTION_VARIABLE(protodesc_cold); static const ::google::protobuf::internal::AuxillaryParseTableField aux[] PROTOBUF_SECTION_VARIABLE(protodesc_cold); - static const ::google::protobuf::internal::ParseTable schema[5] + static const ::google::protobuf::internal::ParseTable schema[6] PROTOBUF_SECTION_VARIABLE(protodesc_cold); static const ::google::protobuf::internal::FieldMetadata field_metadata[]; static const ::google::protobuf::internal::SerializationTable serialization_table[]; @@ -57,6 +57,9 @@ namespace event { class NodeExecutionEvent; class NodeExecutionEventDefaultTypeInternal; extern NodeExecutionEventDefaultTypeInternal _NodeExecutionEvent_default_instance_; +class ParentNodeExecutionMetadata; +class ParentNodeExecutionMetadataDefaultTypeInternal; +extern ParentNodeExecutionMetadataDefaultTypeInternal _ParentNodeExecutionMetadata_default_instance_; class ParentTaskExecutionMetadata; class ParentTaskExecutionMetadataDefaultTypeInternal; extern ParentTaskExecutionMetadataDefaultTypeInternal _ParentTaskExecutionMetadata_default_instance_; @@ -74,6 +77,7 @@ extern WorkflowNodeMetadataDefaultTypeInternal _WorkflowNodeMetadata_default_ins namespace google { namespace protobuf { template<> ::flyteidl::event::NodeExecutionEvent* Arena::CreateMaybeMessage<::flyteidl::event::NodeExecutionEvent>(Arena*); +template<> ::flyteidl::event::ParentNodeExecutionMetadata* Arena::CreateMaybeMessage<::flyteidl::event::ParentNodeExecutionMetadata>(Arena*); template<> ::flyteidl::event::ParentTaskExecutionMetadata* Arena::CreateMaybeMessage<::flyteidl::event::ParentTaskExecutionMetadata>(Arena*); template<> ::flyteidl::event::TaskExecutionEvent* Arena::CreateMaybeMessage<::flyteidl::event::TaskExecutionEvent>(Arena*); template<> ::flyteidl::event::WorkflowExecutionEvent* Arena::CreateMaybeMessage<::flyteidl::event::WorkflowExecutionEvent>(Arena*); @@ -412,6 +416,48 @@ class NodeExecutionEvent final : ::std::string* release_input_uri(); void set_allocated_input_uri(::std::string* input_uri); + // string retry_group = 11; + void clear_retry_group(); + static const int kRetryGroupFieldNumber = 11; + const ::std::string& retry_group() const; + void set_retry_group(const ::std::string& value); + #if LANG_CXX11 + void set_retry_group(::std::string&& value); + #endif + void set_retry_group(const char* value); + void set_retry_group(const char* value, size_t size); + ::std::string* mutable_retry_group(); + ::std::string* release_retry_group(); + void set_allocated_retry_group(::std::string* retry_group); + + // string spec_node_id = 12; + void clear_spec_node_id(); + static const int kSpecNodeIdFieldNumber = 12; + const ::std::string& spec_node_id() const; + void set_spec_node_id(const ::std::string& value); + #if LANG_CXX11 + void set_spec_node_id(::std::string&& value); + #endif + void set_spec_node_id(const char* value); + void set_spec_node_id(const char* value, size_t size); + ::std::string* mutable_spec_node_id(); + ::std::string* release_spec_node_id(); + void set_allocated_spec_node_id(::std::string* spec_node_id); + + // string node_name = 13; + void clear_node_name(); + static const int kNodeNameFieldNumber = 13; + const ::std::string& node_name() const; + void set_node_name(const ::std::string& value); + #if LANG_CXX11 + void set_node_name(::std::string&& value); + #endif + void set_node_name(const char* value); + void set_node_name(const char* value, size_t size); + ::std::string* mutable_node_name(); + ::std::string* release_node_name(); + void set_allocated_node_name(::std::string* node_name); + // .flyteidl.core.NodeExecutionIdentifier id = 1; bool has_id() const; void clear_id(); @@ -439,6 +485,15 @@ class NodeExecutionEvent final : ::flyteidl::event::ParentTaskExecutionMetadata* mutable_parent_task_metadata(); void set_allocated_parent_task_metadata(::flyteidl::event::ParentTaskExecutionMetadata* parent_task_metadata); + // .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + bool has_parent_node_metadata() const; + void clear_parent_node_metadata(); + static const int kParentNodeMetadataFieldNumber = 10; + const ::flyteidl::event::ParentNodeExecutionMetadata& parent_node_metadata() const; + ::flyteidl::event::ParentNodeExecutionMetadata* release_parent_node_metadata(); + ::flyteidl::event::ParentNodeExecutionMetadata* mutable_parent_node_metadata(); + void set_allocated_parent_node_metadata(::flyteidl::event::ParentNodeExecutionMetadata* parent_node_metadata); + // .flyteidl.core.NodeExecution.Phase phase = 3; void clear_phase(); static const int kPhaseFieldNumber = 3; @@ -500,9 +555,13 @@ class NodeExecutionEvent final : ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; ::google::protobuf::internal::ArenaStringPtr producer_id_; ::google::protobuf::internal::ArenaStringPtr input_uri_; + ::google::protobuf::internal::ArenaStringPtr retry_group_; + ::google::protobuf::internal::ArenaStringPtr spec_node_id_; + ::google::protobuf::internal::ArenaStringPtr node_name_; ::flyteidl::core::NodeExecutionIdentifier* id_; ::google::protobuf::Timestamp* occurred_at_; ::flyteidl::event::ParentTaskExecutionMetadata* parent_task_metadata_; + ::flyteidl::event::ParentNodeExecutionMetadata* parent_node_metadata_; int phase_; union OutputResultUnion { OutputResultUnion() {} @@ -750,6 +809,126 @@ class ParentTaskExecutionMetadata final : }; // ------------------------------------------------------------------- +class ParentNodeExecutionMetadata final : + public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.event.ParentNodeExecutionMetadata) */ { + public: + ParentNodeExecutionMetadata(); + virtual ~ParentNodeExecutionMetadata(); + + ParentNodeExecutionMetadata(const ParentNodeExecutionMetadata& from); + + inline ParentNodeExecutionMetadata& operator=(const ParentNodeExecutionMetadata& from) { + CopyFrom(from); + return *this; + } + #if LANG_CXX11 + ParentNodeExecutionMetadata(ParentNodeExecutionMetadata&& from) noexcept + : ParentNodeExecutionMetadata() { + *this = ::std::move(from); + } + + inline ParentNodeExecutionMetadata& operator=(ParentNodeExecutionMetadata&& from) noexcept { + if (GetArenaNoVirtual() == from.GetArenaNoVirtual()) { + if (this != &from) InternalSwap(&from); + } else { + CopyFrom(from); + } + return *this; + } + #endif + static const ::google::protobuf::Descriptor* descriptor() { + return default_instance().GetDescriptor(); + } + static const ParentNodeExecutionMetadata& default_instance(); + + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY + static inline const ParentNodeExecutionMetadata* internal_default_instance() { + return reinterpret_cast( + &_ParentNodeExecutionMetadata_default_instance_); + } + static constexpr int kIndexInFileMessages = + 4; + + void Swap(ParentNodeExecutionMetadata* other); + friend void swap(ParentNodeExecutionMetadata& a, ParentNodeExecutionMetadata& b) { + a.Swap(&b); + } + + // implements Message ---------------------------------------------- + + inline ParentNodeExecutionMetadata* New() const final { + return CreateMaybeMessage(nullptr); + } + + ParentNodeExecutionMetadata* New(::google::protobuf::Arena* arena) const final { + return CreateMaybeMessage(arena); + } + void CopyFrom(const ::google::protobuf::Message& from) final; + void MergeFrom(const ::google::protobuf::Message& from) final; + void CopyFrom(const ParentNodeExecutionMetadata& from); + void MergeFrom(const ParentNodeExecutionMetadata& from); + PROTOBUF_ATTRIBUTE_REINITIALIZES void Clear() final; + bool IsInitialized() const final; + + size_t ByteSizeLong() const final; + #if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + static const char* _InternalParse(const char* begin, const char* end, void* object, ::google::protobuf::internal::ParseContext* ctx); + ::google::protobuf::internal::ParseFunc _ParseFunc() const final { return _InternalParse; } + #else + bool MergePartialFromCodedStream( + ::google::protobuf::io::CodedInputStream* input) final; + #endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + void SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const final; + ::google::protobuf::uint8* InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const final; + int GetCachedSize() const final { return _cached_size_.Get(); } + + private: + void SharedCtor(); + void SharedDtor(); + void SetCachedSize(int size) const final; + void InternalSwap(ParentNodeExecutionMetadata* other); + private: + inline ::google::protobuf::Arena* GetArenaNoVirtual() const { + return nullptr; + } + inline void* MaybeArenaPtr() const { + return nullptr; + } + public: + + ::google::protobuf::Metadata GetMetadata() const final; + + // nested types ---------------------------------------------------- + + // accessors ------------------------------------------------------- + + // string node_id = 1; + void clear_node_id(); + static const int kNodeIdFieldNumber = 1; + const ::std::string& node_id() const; + void set_node_id(const ::std::string& value); + #if LANG_CXX11 + void set_node_id(::std::string&& value); + #endif + void set_node_id(const char* value); + void set_node_id(const char* value, size_t size); + ::std::string* mutable_node_id(); + ::std::string* release_node_id(); + void set_allocated_node_id(::std::string* node_id); + + // @@protoc_insertion_point(class_scope:flyteidl.event.ParentNodeExecutionMetadata) + private: + class HasBitSetters; + + ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + ::google::protobuf::internal::ArenaStringPtr node_id_; + mutable ::google::protobuf::internal::CachedSize _cached_size_; + friend struct ::TableStruct_flyteidl_2fevent_2fevent_2eproto; +}; +// ------------------------------------------------------------------- + class TaskExecutionEvent final : public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.event.TaskExecutionEvent) */ { public: @@ -794,7 +973,7 @@ class TaskExecutionEvent final : &_TaskExecutionEvent_default_instance_); } static constexpr int kIndexInFileMessages = - 4; + 5; void Swap(TaskExecutionEvent* other); friend void swap(TaskExecutionEvent& a, TaskExecutionEvent& b) { @@ -1742,6 +1921,216 @@ inline void NodeExecutionEvent::set_allocated_parent_task_metadata(::flyteidl::e // @@protoc_insertion_point(field_set_allocated:flyteidl.event.NodeExecutionEvent.parent_task_metadata) } +// .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; +inline bool NodeExecutionEvent::has_parent_node_metadata() const { + return this != internal_default_instance() && parent_node_metadata_ != nullptr; +} +inline void NodeExecutionEvent::clear_parent_node_metadata() { + if (GetArenaNoVirtual() == nullptr && parent_node_metadata_ != nullptr) { + delete parent_node_metadata_; + } + parent_node_metadata_ = nullptr; +} +inline const ::flyteidl::event::ParentNodeExecutionMetadata& NodeExecutionEvent::parent_node_metadata() const { + const ::flyteidl::event::ParentNodeExecutionMetadata* p = parent_node_metadata_; + // @@protoc_insertion_point(field_get:flyteidl.event.NodeExecutionEvent.parent_node_metadata) + return p != nullptr ? *p : *reinterpret_cast( + &::flyteidl::event::_ParentNodeExecutionMetadata_default_instance_); +} +inline ::flyteidl::event::ParentNodeExecutionMetadata* NodeExecutionEvent::release_parent_node_metadata() { + // @@protoc_insertion_point(field_release:flyteidl.event.NodeExecutionEvent.parent_node_metadata) + + ::flyteidl::event::ParentNodeExecutionMetadata* temp = parent_node_metadata_; + parent_node_metadata_ = nullptr; + return temp; +} +inline ::flyteidl::event::ParentNodeExecutionMetadata* NodeExecutionEvent::mutable_parent_node_metadata() { + + if (parent_node_metadata_ == nullptr) { + auto* p = CreateMaybeMessage<::flyteidl::event::ParentNodeExecutionMetadata>(GetArenaNoVirtual()); + parent_node_metadata_ = p; + } + // @@protoc_insertion_point(field_mutable:flyteidl.event.NodeExecutionEvent.parent_node_metadata) + return parent_node_metadata_; +} +inline void NodeExecutionEvent::set_allocated_parent_node_metadata(::flyteidl::event::ParentNodeExecutionMetadata* parent_node_metadata) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + if (message_arena == nullptr) { + delete parent_node_metadata_; + } + if (parent_node_metadata) { + ::google::protobuf::Arena* submessage_arena = nullptr; + if (message_arena != submessage_arena) { + parent_node_metadata = ::google::protobuf::internal::GetOwnedMessage( + message_arena, parent_node_metadata, submessage_arena); + } + + } else { + + } + parent_node_metadata_ = parent_node_metadata; + // @@protoc_insertion_point(field_set_allocated:flyteidl.event.NodeExecutionEvent.parent_node_metadata) +} + +// string retry_group = 11; +inline void NodeExecutionEvent::clear_retry_group() { + retry_group_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& NodeExecutionEvent::retry_group() const { + // @@protoc_insertion_point(field_get:flyteidl.event.NodeExecutionEvent.retry_group) + return retry_group_.GetNoArena(); +} +inline void NodeExecutionEvent::set_retry_group(const ::std::string& value) { + + retry_group_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.event.NodeExecutionEvent.retry_group) +} +#if LANG_CXX11 +inline void NodeExecutionEvent::set_retry_group(::std::string&& value) { + + retry_group_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.event.NodeExecutionEvent.retry_group) +} +#endif +inline void NodeExecutionEvent::set_retry_group(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + retry_group_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.event.NodeExecutionEvent.retry_group) +} +inline void NodeExecutionEvent::set_retry_group(const char* value, size_t size) { + + retry_group_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.event.NodeExecutionEvent.retry_group) +} +inline ::std::string* NodeExecutionEvent::mutable_retry_group() { + + // @@protoc_insertion_point(field_mutable:flyteidl.event.NodeExecutionEvent.retry_group) + return retry_group_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* NodeExecutionEvent::release_retry_group() { + // @@protoc_insertion_point(field_release:flyteidl.event.NodeExecutionEvent.retry_group) + + return retry_group_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void NodeExecutionEvent::set_allocated_retry_group(::std::string* retry_group) { + if (retry_group != nullptr) { + + } else { + + } + retry_group_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), retry_group); + // @@protoc_insertion_point(field_set_allocated:flyteidl.event.NodeExecutionEvent.retry_group) +} + +// string spec_node_id = 12; +inline void NodeExecutionEvent::clear_spec_node_id() { + spec_node_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& NodeExecutionEvent::spec_node_id() const { + // @@protoc_insertion_point(field_get:flyteidl.event.NodeExecutionEvent.spec_node_id) + return spec_node_id_.GetNoArena(); +} +inline void NodeExecutionEvent::set_spec_node_id(const ::std::string& value) { + + spec_node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.event.NodeExecutionEvent.spec_node_id) +} +#if LANG_CXX11 +inline void NodeExecutionEvent::set_spec_node_id(::std::string&& value) { + + spec_node_id_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.event.NodeExecutionEvent.spec_node_id) +} +#endif +inline void NodeExecutionEvent::set_spec_node_id(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + spec_node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.event.NodeExecutionEvent.spec_node_id) +} +inline void NodeExecutionEvent::set_spec_node_id(const char* value, size_t size) { + + spec_node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.event.NodeExecutionEvent.spec_node_id) +} +inline ::std::string* NodeExecutionEvent::mutable_spec_node_id() { + + // @@protoc_insertion_point(field_mutable:flyteidl.event.NodeExecutionEvent.spec_node_id) + return spec_node_id_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* NodeExecutionEvent::release_spec_node_id() { + // @@protoc_insertion_point(field_release:flyteidl.event.NodeExecutionEvent.spec_node_id) + + return spec_node_id_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void NodeExecutionEvent::set_allocated_spec_node_id(::std::string* spec_node_id) { + if (spec_node_id != nullptr) { + + } else { + + } + spec_node_id_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), spec_node_id); + // @@protoc_insertion_point(field_set_allocated:flyteidl.event.NodeExecutionEvent.spec_node_id) +} + +// string node_name = 13; +inline void NodeExecutionEvent::clear_node_name() { + node_name_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& NodeExecutionEvent::node_name() const { + // @@protoc_insertion_point(field_get:flyteidl.event.NodeExecutionEvent.node_name) + return node_name_.GetNoArena(); +} +inline void NodeExecutionEvent::set_node_name(const ::std::string& value) { + + node_name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.event.NodeExecutionEvent.node_name) +} +#if LANG_CXX11 +inline void NodeExecutionEvent::set_node_name(::std::string&& value) { + + node_name_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.event.NodeExecutionEvent.node_name) +} +#endif +inline void NodeExecutionEvent::set_node_name(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + node_name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.event.NodeExecutionEvent.node_name) +} +inline void NodeExecutionEvent::set_node_name(const char* value, size_t size) { + + node_name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.event.NodeExecutionEvent.node_name) +} +inline ::std::string* NodeExecutionEvent::mutable_node_name() { + + // @@protoc_insertion_point(field_mutable:flyteidl.event.NodeExecutionEvent.node_name) + return node_name_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* NodeExecutionEvent::release_node_name() { + // @@protoc_insertion_point(field_release:flyteidl.event.NodeExecutionEvent.node_name) + + return node_name_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void NodeExecutionEvent::set_allocated_node_name(::std::string* node_name) { + if (node_name != nullptr) { + + } else { + + } + node_name_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), node_name); + // @@protoc_insertion_point(field_set_allocated:flyteidl.event.NodeExecutionEvent.node_name) +} + inline bool NodeExecutionEvent::has_output_result() const { return output_result_case() != OUTPUT_RESULT_NOT_SET; } @@ -1860,6 +2249,63 @@ inline void ParentTaskExecutionMetadata::set_allocated_id(::flyteidl::core::Task // ------------------------------------------------------------------- +// ParentNodeExecutionMetadata + +// string node_id = 1; +inline void ParentNodeExecutionMetadata::clear_node_id() { + node_id_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& ParentNodeExecutionMetadata::node_id() const { + // @@protoc_insertion_point(field_get:flyteidl.event.ParentNodeExecutionMetadata.node_id) + return node_id_.GetNoArena(); +} +inline void ParentNodeExecutionMetadata::set_node_id(const ::std::string& value) { + + node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.event.ParentNodeExecutionMetadata.node_id) +} +#if LANG_CXX11 +inline void ParentNodeExecutionMetadata::set_node_id(::std::string&& value) { + + node_id_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.event.ParentNodeExecutionMetadata.node_id) +} +#endif +inline void ParentNodeExecutionMetadata::set_node_id(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.event.ParentNodeExecutionMetadata.node_id) +} +inline void ParentNodeExecutionMetadata::set_node_id(const char* value, size_t size) { + + node_id_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.event.ParentNodeExecutionMetadata.node_id) +} +inline ::std::string* ParentNodeExecutionMetadata::mutable_node_id() { + + // @@protoc_insertion_point(field_mutable:flyteidl.event.ParentNodeExecutionMetadata.node_id) + return node_id_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* ParentNodeExecutionMetadata::release_node_id() { + // @@protoc_insertion_point(field_release:flyteidl.event.ParentNodeExecutionMetadata.node_id) + + return node_id_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void ParentNodeExecutionMetadata::set_allocated_node_id(::std::string* node_id) { + if (node_id != nullptr) { + + } else { + + } + node_id_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), node_id); + // @@protoc_insertion_point(field_set_allocated:flyteidl.event.ParentNodeExecutionMetadata.node_id) +} + +// ------------------------------------------------------------------- + // TaskExecutionEvent // .flyteidl.core.Identifier task_id = 1; @@ -2366,6 +2812,8 @@ inline TaskExecutionEvent::OutputResultCase TaskExecutionEvent::output_result_ca // ------------------------------------------------------------------- +// ------------------------------------------------------------------- + // @@protoc_insertion_point(namespace_scope) diff --git a/flyteidl/gen/pb-go/flyteidl/admin/node_execution.pb.go b/flyteidl/gen/pb-go/flyteidl/admin/node_execution.pb.go index c2712d4cb7..65be31bc79 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/node_execution.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/node_execution.pb.go @@ -80,7 +80,10 @@ type NodeExecutionListRequest struct { Filters string `protobuf:"bytes,4,opt,name=filters,proto3" json:"filters,omitempty"` // Sort ordering. // +optional - SortBy *Sort `protobuf:"bytes,5,opt,name=sort_by,json=sortBy,proto3" json:"sort_by,omitempty"` + SortBy *Sort `protobuf:"bytes,5,opt,name=sort_by,json=sortBy,proto3" json:"sort_by,omitempty"` + // Unique identifier of the parent node in the execution + // +optional + UniqueParentId string `protobuf:"bytes,6,opt,name=unique_parent_id,json=uniqueParentId,proto3" json:"unique_parent_id,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` @@ -146,6 +149,13 @@ func (m *NodeExecutionListRequest) GetSortBy() *Sort { return nil } +func (m *NodeExecutionListRequest) GetUniqueParentId() string { + if m != nil { + return m.UniqueParentId + } + return "" +} + // Represents a request structure to retrieve a list of node execution entities launched by a specific task. type NodeExecutionForTaskListRequest struct { // Indicates the node execution to filter by. @@ -301,6 +311,14 @@ func (m *NodeExecution) GetMetadata() *NodeExecutionMetaData { // Represents additional attributes related to a Node Execution type NodeExecutionMetaData struct { + // Node executions are grouped depending on retries of the parent + // Retry group is unique within the context of a parent node. + RetryGroup string `protobuf:"bytes,1,opt,name=retry_group,json=retryGroup,proto3" json:"retry_group,omitempty"` + // Boolean flag indicating if the node has child nodes under it + IsParentNode bool `protobuf:"varint,2,opt,name=is_parent_node,json=isParentNode,proto3" json:"is_parent_node,omitempty"` + // Node id of the node in the original workflow + // This maps to value of WorkflowTemplate.nodes[X].id + SpecNodeId string `protobuf:"bytes,3,opt,name=spec_node_id,json=specNodeId,proto3" json:"spec_node_id,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` @@ -331,6 +349,27 @@ func (m *NodeExecutionMetaData) XXX_DiscardUnknown() { var xxx_messageInfo_NodeExecutionMetaData proto.InternalMessageInfo +func (m *NodeExecutionMetaData) GetRetryGroup() string { + if m != nil { + return m.RetryGroup + } + return "" +} + +func (m *NodeExecutionMetaData) GetIsParentNode() bool { + if m != nil { + return m.IsParentNode + } + return false +} + +func (m *NodeExecutionMetaData) GetSpecNodeId() string { + if m != nil { + return m.SpecNodeId + } + return "" +} + // Request structure to retrieve a list of node execution entities. type NodeExecutionList struct { NodeExecutions []*NodeExecution `protobuf:"bytes,1,rep,name=node_executions,json=nodeExecutions,proto3" json:"node_executions,omitempty"` @@ -689,52 +728,58 @@ func init() { } var fileDescriptor_f73b3eae493fd736 = []byte{ - // 752 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xc4, 0x55, 0x6d, 0x6f, 0xe3, 0x44, - 0x10, 0x3e, 0xe7, 0x2e, 0x6f, 0x13, 0xb5, 0x51, 0x97, 0x1c, 0x35, 0x29, 0x47, 0x23, 0xf3, 0xa2, - 0x08, 0xe9, 0x6c, 0x5d, 0x4e, 0x87, 0xe0, 0x0b, 0x52, 0xc2, 0xdd, 0x51, 0xa4, 0x16, 0xc1, 0xd2, - 0x0a, 0x09, 0x21, 0xa2, 0x4d, 0xbc, 0x49, 0x57, 0xb1, 0xbd, 0xe9, 0xee, 0x58, 0x21, 0x5f, 0xf9, - 0x09, 0xfc, 0x49, 0x24, 0xbe, 0xf0, 0x17, 0x90, 0x5f, 0x13, 0xbb, 0xa6, 0x95, 0xca, 0x87, 0xfb, - 0xb8, 0x3b, 0xcf, 0x33, 0x33, 0xcf, 0xcc, 0xec, 0x2c, 0x7c, 0xbc, 0xf0, 0xb6, 0xc8, 0x85, 0xeb, - 0x39, 0xcc, 0xf5, 0x45, 0xe0, 0x04, 0xd2, 0xe5, 0x53, 0xfe, 0x3b, 0x9f, 0x87, 0x28, 0x64, 0x60, - 0xaf, 0x95, 0x44, 0x49, 0x0e, 0x33, 0x90, 0x1d, 0x83, 0xfa, 0x27, 0x25, 0xd2, 0x5c, 0xfa, 0x7e, - 0x06, 0xee, 0x3f, 0xcb, 0x8d, 0x73, 0xa9, 0xb8, 0x53, 0xf2, 0xd5, 0xff, 0xa8, 0x68, 0x16, 0x2e, - 0x0f, 0x50, 0x2c, 0x04, 0x57, 0xa9, 0xfd, 0x74, 0x29, 0xe5, 0xd2, 0xe3, 0x4e, 0x7c, 0x9a, 0x85, - 0x0b, 0x07, 0x85, 0xcf, 0x35, 0x32, 0x7f, 0x9d, 0x39, 0x28, 0x03, 0xdc, 0x50, 0xb1, 0x5d, 0x00, - 0xeb, 0x47, 0x38, 0xfe, 0x5e, 0xba, 0xfc, 0x4d, 0x16, 0xf7, 0x5b, 0x8e, 0x94, 0xdf, 0x84, 0x5c, - 0x23, 0xf9, 0x02, 0x6a, 0xc2, 0x35, 0x8d, 0x81, 0x31, 0xec, 0x8c, 0x3e, 0xb3, 0x73, 0x51, 0x51, - 0x22, 0x76, 0x81, 0xf3, 0x5d, 0x9e, 0x15, 0xad, 0x09, 0xd7, 0xfa, 0xc7, 0x00, 0xb3, 0x60, 0x3f, - 0x17, 0x3a, 0x77, 0xfa, 0x1b, 0x3c, 0xdd, 0x48, 0xb5, 0x5a, 0x78, 0x72, 0xb3, 0x2b, 0xdc, 0x34, - 0x8f, 0xf3, 0x79, 0x29, 0xce, 0xcf, 0x29, 0xb6, 0x2a, 0xd6, 0x7b, 0x9b, 0xdb, 0x46, 0xd2, 0x83, - 0xba, 0x27, 0x7c, 0x81, 0x66, 0x6d, 0x60, 0x0c, 0x0f, 0x68, 0x72, 0x88, 0x6e, 0x51, 0xae, 0x78, - 0x60, 0x3e, 0x1e, 0x18, 0xc3, 0x36, 0x4d, 0x0e, 0xc4, 0x84, 0xe6, 0x42, 0x78, 0xc8, 0x95, 0x36, - 0x9f, 0xc4, 0xf7, 0xd9, 0x91, 0x3c, 0x87, 0xa6, 0x96, 0x0a, 0xa7, 0xb3, 0xad, 0x59, 0x8f, 0xf3, - 0xea, 0xd9, 0xc5, 0xa6, 0xda, 0x3f, 0x49, 0x85, 0xb4, 0x11, 0x81, 0x26, 0x5b, 0xeb, 0x6f, 0x03, - 0x4e, 0x0b, 0x8a, 0xdf, 0x4a, 0x75, 0xc9, 0xf4, 0x6a, 0x5f, 0x38, 0x85, 0x23, 0x64, 0x7a, 0x55, - 0x25, 0xba, 0x5c, 0xdc, 0x88, 0x5a, 0x25, 0xb8, 0x8b, 0x45, 0xc3, 0xbb, 0x11, 0xfb, 0x97, 0x01, - 0x07, 0x05, 0xb1, 0x0f, 0x1d, 0x14, 0x72, 0x02, 0x6d, 0x11, 0xac, 0x43, 0x9c, 0x86, 0x4a, 0xc4, - 0x12, 0xda, 0xb4, 0x15, 0x5f, 0x5c, 0x29, 0x41, 0xbe, 0x86, 0xe6, 0xdc, 0x93, 0x3a, 0x54, 0x3c, - 0xd6, 0xd1, 0x19, 0x7d, 0x52, 0xce, 0xaa, 0xe0, 0xfa, 0x9b, 0x04, 0x4b, 0x33, 0x12, 0x19, 0x43, - 0xcb, 0xe7, 0xc8, 0x5c, 0x86, 0x2c, 0x16, 0xdc, 0x19, 0x7d, 0x7a, 0xa7, 0x83, 0x0b, 0x8e, 0xec, - 0x35, 0x43, 0x46, 0x73, 0x9a, 0x75, 0x0c, 0x4f, 0x2b, 0x21, 0xd6, 0x0d, 0x1c, 0xdd, 0x1a, 0x70, - 0xf2, 0x16, 0xba, 0xc5, 0x75, 0xa0, 0x4d, 0x63, 0xf0, 0x78, 0xd8, 0x19, 0x3d, 0xbb, 0x33, 0x2e, - 0x3d, 0x0c, 0xf6, 0x8f, 0x7a, 0xd7, 0xbe, 0xda, 0x5e, 0xfb, 0xac, 0x3f, 0x9f, 0x40, 0xaf, 0x4a, - 0x30, 0x39, 0x05, 0x90, 0x21, 0x66, 0x55, 0x8c, 0x9a, 0xd0, 0x3e, 0x7b, 0x44, 0xdb, 0xc9, 0x5d, - 0x54, 0xc8, 0x57, 0x50, 0xe7, 0x4a, 0x49, 0x15, 0xfb, 0x2b, 0x64, 0x13, 0x37, 0x28, 0x77, 0xf8, - 0x26, 0x02, 0x9d, 0x3d, 0xa2, 0x09, 0x9a, 0x7c, 0x09, 0xf5, 0xf5, 0x35, 0xd3, 0x49, 0xf5, 0x0f, - 0x47, 0xd6, 0x5d, 0x7d, 0xb5, 0x7f, 0x88, 0x90, 0x34, 0x21, 0x90, 0xaf, 0x00, 0x34, 0x32, 0x85, - 0xdc, 0x9d, 0x32, 0x4c, 0x6b, 0xdf, 0xb7, 0x93, 0x3d, 0x64, 0x67, 0x7b, 0xc8, 0xbe, 0xcc, 0x16, - 0x15, 0x6d, 0xa7, 0xe8, 0x31, 0x92, 0x57, 0xd0, 0xca, 0xf6, 0x53, 0x3a, 0x8b, 0x1f, 0xdc, 0x22, - 0xbe, 0x4e, 0x01, 0x34, 0x87, 0x46, 0x11, 0xe7, 0x8a, 0xb3, 0x34, 0x62, 0xe3, 0xfe, 0x88, 0x29, - 0x7a, 0x8c, 0x11, 0x35, 0x5c, 0xbb, 0x19, 0xb5, 0x79, 0x3f, 0x35, 0x45, 0x8f, 0x91, 0xfc, 0x0a, - 0xef, 0xe7, 0xab, 0x2c, 0xee, 0x7c, 0x3e, 0x6f, 0xad, 0xea, 0x81, 0xcd, 0x96, 0x59, 0x54, 0xbb, - 0x8b, 0x14, 0x7b, 0x66, 0xd0, 0xde, 0xa6, 0xe2, 0x7e, 0xd2, 0x85, 0x83, 0xb4, 0xaf, 0x8a, 0xeb, - 0xd0, 0xc3, 0xc9, 0x11, 0x74, 0x91, 0xa9, 0x25, 0xc7, 0x3c, 0x8e, 0xe5, 0x42, 0xaf, 0xca, 0x27, - 0x39, 0x87, 0x0e, 0xdf, 0xbd, 0xb9, 0x07, 0xac, 0xd6, 0x7d, 0xba, 0x75, 0x05, 0x27, 0xe5, 0x2f, - 0x22, 0x7e, 0x28, 0xff, 0xf3, 0x9b, 0xf8, 0xc3, 0x80, 0x0f, 0xab, 0xfd, 0xea, 0xb5, 0x0c, 0x34, - 0x27, 0x0e, 0x34, 0xe2, 0x6d, 0xa0, 0x53, 0xe7, 0xc7, 0xe5, 0x7a, 0x5e, 0x29, 0x6f, 0xe2, 0xc9, - 0x19, 0x4d, 0x61, 0xe4, 0x05, 0x34, 0x93, 0x92, 0xe9, 0x74, 0xd6, 0xff, 0x93, 0x91, 0xe1, 0x26, - 0x2f, 0x7f, 0x79, 0xb1, 0x14, 0x78, 0x1d, 0xce, 0xec, 0xb9, 0xf4, 0x1d, 0x6f, 0xbb, 0x40, 0x27, - 0xff, 0x71, 0x97, 0x3c, 0x70, 0xd6, 0xb3, 0xe7, 0x4b, 0xe9, 0x14, 0x3f, 0xf0, 0x59, 0x23, 0x9e, - 0x8b, 0x97, 0xff, 0x06, 0x00, 0x00, 0xff, 0xff, 0x23, 0x4c, 0x65, 0xda, 0x0e, 0x08, 0x00, 0x00, + // 838 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xc4, 0x56, 0x6d, 0x6f, 0x1b, 0x45, + 0x10, 0xee, 0xb9, 0x8d, 0x5f, 0xc6, 0x8d, 0x43, 0x16, 0x97, 0x9a, 0x84, 0x12, 0xeb, 0x28, 0xc8, + 0x42, 0xea, 0x9d, 0xea, 0xaa, 0x08, 0xbe, 0x20, 0xc5, 0xf4, 0x25, 0x91, 0x5a, 0x54, 0x96, 0x46, + 0x48, 0x08, 0x61, 0xad, 0x7d, 0x6b, 0x77, 0x95, 0xbb, 0xdb, 0xcb, 0xee, 0x9c, 0x82, 0xbf, 0x21, + 0x7e, 0x02, 0xdf, 0xf8, 0x85, 0x48, 0xfc, 0x0a, 0xb4, 0x7b, 0x2f, 0xc9, 0x5d, 0x8e, 0x54, 0x2a, + 0x1f, 0xfa, 0x71, 0x67, 0x9e, 0x79, 0x66, 0x67, 0xe6, 0xd9, 0xb9, 0x83, 0xcf, 0x56, 0xe1, 0x06, + 0xb9, 0x08, 0x42, 0x9f, 0x05, 0x91, 0x88, 0xfd, 0x58, 0x06, 0x7c, 0xce, 0x7f, 0xe3, 0xcb, 0x14, + 0x85, 0x8c, 0xbd, 0x44, 0x49, 0x94, 0x64, 0x50, 0x80, 0x3c, 0x0b, 0xda, 0xdb, 0xaf, 0x05, 0x2d, + 0x65, 0x14, 0x15, 0xe0, 0xbd, 0x7b, 0xa5, 0x73, 0x29, 0x15, 0xf7, 0x6b, 0x5c, 0x7b, 0x9f, 0x56, + 0xdd, 0x22, 0xe0, 0x31, 0x8a, 0x95, 0xe0, 0x2a, 0xf7, 0x1f, 0xac, 0xa5, 0x5c, 0x87, 0xdc, 0xb7, + 0xa7, 0x45, 0xba, 0xf2, 0x51, 0x44, 0x5c, 0x23, 0x8b, 0x92, 0x82, 0xa0, 0x0e, 0x08, 0x52, 0xc5, + 0x2e, 0x12, 0xb8, 0x3f, 0xc0, 0xdd, 0xef, 0x65, 0xc0, 0x9f, 0x16, 0x79, 0x9f, 0x73, 0xa4, 0xfc, + 0x2c, 0xe5, 0x1a, 0xc9, 0x57, 0xd0, 0x12, 0xc1, 0xc8, 0x19, 0x3b, 0x93, 0xfe, 0xf4, 0x0b, 0xaf, + 0x2c, 0xca, 0x5c, 0xc4, 0xab, 0xc4, 0x1c, 0x97, 0xb7, 0xa2, 0x2d, 0x11, 0xb8, 0x7f, 0xb5, 0x60, + 0x54, 0xf1, 0xbf, 0x10, 0xba, 0x24, 0xfd, 0x15, 0xee, 0x9c, 0x4b, 0x75, 0xba, 0x0a, 0xe5, 0xf9, + 0x45, 0xe3, 0xe6, 0x65, 0x9e, 0x2f, 0x6b, 0x79, 0x7e, 0xca, 0xb1, 0x4d, 0xb9, 0x3e, 0x3c, 0xbf, + 0xea, 0x24, 0x43, 0xd8, 0x0a, 0x45, 0x24, 0x70, 0xd4, 0x1a, 0x3b, 0x93, 0x6d, 0x9a, 0x1d, 0x8c, + 0x15, 0xe5, 0x29, 0x8f, 0x47, 0x37, 0xc7, 0xce, 0xa4, 0x47, 0xb3, 0x03, 0x19, 0x41, 0x67, 0x25, + 0x42, 0xe4, 0x4a, 0x8f, 0x6e, 0x59, 0x7b, 0x71, 0x24, 0x0f, 0xa0, 0xa3, 0xa5, 0xc2, 0xf9, 0x62, + 0x33, 0xda, 0xb2, 0xf7, 0x1a, 0x7a, 0xd5, 0xa1, 0x7a, 0x3f, 0x4a, 0x85, 0xb4, 0x6d, 0x40, 0xb3, + 0x0d, 0x99, 0xc0, 0x07, 0x69, 0x2c, 0xce, 0x52, 0x3e, 0x4f, 0x98, 0xe2, 0x31, 0x9a, 0x7a, 0xda, + 0x96, 0x71, 0x90, 0xd9, 0x5f, 0x59, 0xf3, 0x71, 0xe0, 0xfe, 0xe3, 0xc0, 0x41, 0xa5, 0x37, 0xcf, + 0xa4, 0x7a, 0xcd, 0xf4, 0xe9, 0xe5, 0x16, 0x51, 0xd8, 0x45, 0xa6, 0x4f, 0x9b, 0xda, 0x53, 0x1f, + 0x83, 0x09, 0x6d, 0x6a, 0xcd, 0x0e, 0x56, 0x1d, 0xef, 0xa5, 0x2d, 0xee, 0xdf, 0x0e, 0x6c, 0x57, + 0x8a, 0x7d, 0x57, 0x49, 0x91, 0x7d, 0xe8, 0x89, 0x38, 0x49, 0x71, 0x9e, 0x2a, 0x61, 0x4b, 0xe8, + 0xd1, 0xae, 0x35, 0x9c, 0x28, 0x41, 0xbe, 0x85, 0xce, 0x32, 0x94, 0x3a, 0x55, 0xdc, 0xd6, 0xd1, + 0x9f, 0xde, 0xaf, 0xdf, 0xaa, 0x42, 0xfd, 0x5d, 0x86, 0xa5, 0x45, 0x10, 0x39, 0x84, 0x6e, 0xc4, + 0x91, 0x05, 0x0c, 0x99, 0x2d, 0xb8, 0x3f, 0xfd, 0xfc, 0x5a, 0x82, 0x97, 0x1c, 0xd9, 0x13, 0x86, + 0x8c, 0x96, 0x61, 0xee, 0xef, 0x0e, 0xdc, 0x69, 0xc4, 0x90, 0x03, 0xe8, 0x2b, 0x8e, 0x6a, 0x33, + 0x5f, 0x2b, 0x99, 0x26, 0xb6, 0xf4, 0x1e, 0x05, 0x6b, 0x7a, 0x6e, 0x2c, 0xe4, 0x3e, 0x0c, 0x84, + 0x2e, 0x74, 0x63, 0xf6, 0x89, 0xad, 0xaf, 0x4b, 0x6f, 0x0b, 0x9d, 0xa9, 0xc6, 0xf0, 0x92, 0x31, + 0xdc, 0xd6, 0x09, 0x5f, 0x5a, 0x80, 0x91, 0x43, 0x36, 0x30, 0x30, 0x36, 0xe3, 0x3f, 0x0e, 0xdc, + 0x33, 0xd8, 0xbd, 0xf2, 0xe8, 0xc8, 0x33, 0xd8, 0xa9, 0xae, 0x28, 0x3d, 0x72, 0xc6, 0x37, 0x27, + 0xfd, 0xe9, 0xbd, 0x6b, 0x2b, 0xa4, 0x83, 0xf8, 0xf2, 0x51, 0x5f, 0x08, 0xa5, 0x75, 0x49, 0x28, + 0xee, 0x9f, 0xb7, 0x60, 0xd8, 0xd4, 0x5a, 0x72, 0x00, 0x20, 0x53, 0x2c, 0xe6, 0x65, 0x6b, 0x3e, + 0xba, 0x41, 0x7b, 0x99, 0xcd, 0x8c, 0xec, 0x31, 0x6c, 0x71, 0xa5, 0xa4, 0xb2, 0x7c, 0x95, 0xdb, + 0x58, 0x29, 0x94, 0x84, 0x4f, 0x0d, 0xe8, 0xe8, 0x06, 0xcd, 0xd0, 0xe4, 0x6b, 0xd8, 0x4a, 0xde, + 0x30, 0x9d, 0xcd, 0x79, 0x30, 0x75, 0xaf, 0x53, 0x90, 0xf7, 0xca, 0x20, 0x69, 0x16, 0x40, 0xbe, + 0x01, 0xd0, 0xc8, 0x14, 0xf2, 0x60, 0xce, 0x30, 0x9f, 0xf2, 0x9e, 0x97, 0xed, 0x46, 0xaf, 0xd8, + 0x8d, 0xde, 0xeb, 0x62, 0x79, 0xd2, 0x5e, 0x8e, 0x3e, 0x44, 0xf2, 0x18, 0xba, 0xc5, 0xce, 0xcc, + 0x55, 0xff, 0xf1, 0x95, 0xc0, 0x27, 0x39, 0x80, 0x96, 0x50, 0x93, 0x71, 0xa9, 0x38, 0xcb, 0x33, + 0xb6, 0xdf, 0x9e, 0x31, 0x47, 0x1f, 0xa2, 0x09, 0x4d, 0x93, 0xa0, 0x08, 0xed, 0xbc, 0x3d, 0x34, + 0x47, 0x1f, 0x22, 0xf9, 0x05, 0x3e, 0x2a, 0xd7, 0xab, 0x9d, 0x7c, 0xa9, 0xec, 0x6e, 0xf3, 0xd3, + 0x28, 0x16, 0xac, 0xe9, 0xdd, 0xcb, 0x1c, 0x7b, 0xe4, 0xd0, 0xe1, 0x79, 0x83, 0x7d, 0xb6, 0x03, + 0xdb, 0xf9, 0x5c, 0x15, 0xd7, 0x69, 0x88, 0xb3, 0x5d, 0xd8, 0x41, 0xa6, 0xd6, 0x1c, 0xcb, 0x3c, + 0x6e, 0x00, 0xc3, 0x26, 0x4e, 0xf2, 0x02, 0xfa, 0xfc, 0xe2, 0x75, 0xbf, 0xc3, 0xba, 0xbf, 0x1c, + 0xee, 0x9e, 0xc0, 0x7e, 0xfd, 0xb3, 0x65, 0x9f, 0xe4, 0xff, 0xfc, 0x74, 0xfd, 0xe1, 0xc0, 0x27, + 0xcd, 0xbc, 0x3a, 0x91, 0xb1, 0xe6, 0xc4, 0x87, 0xb6, 0xdd, 0x3b, 0x3a, 0x27, 0xbf, 0x5b, 0xef, + 0xe7, 0x89, 0x0a, 0x67, 0xa1, 0x5c, 0xd0, 0x1c, 0x46, 0x1e, 0x42, 0x27, 0x6b, 0x99, 0xce, 0xb5, + 0xfe, 0x9f, 0x11, 0x05, 0x6e, 0xf6, 0xe8, 0xe7, 0x87, 0x6b, 0x81, 0x6f, 0xd2, 0x85, 0xb7, 0x94, + 0x91, 0x1f, 0x6e, 0x56, 0xe8, 0x97, 0x7f, 0x01, 0x6b, 0x1e, 0xfb, 0xc9, 0xe2, 0xc1, 0x5a, 0xfa, + 0xd5, 0x9f, 0x8a, 0x45, 0xdb, 0xea, 0xe2, 0xd1, 0xbf, 0x01, 0x00, 0x00, 0xff, 0xff, 0xd6, 0xd4, + 0x44, 0x9d, 0xa2, 0x08, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/admin/node_execution.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/admin/node_execution.pb.validate.go index 6df2a22a33..254c5ed6fb 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/node_execution.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/node_execution.pb.validate.go @@ -151,6 +151,8 @@ func (m *NodeExecutionListRequest) Validate() error { } } + // no validation rules for UniqueParentId + return nil } @@ -409,6 +411,12 @@ func (m *NodeExecutionMetaData) Validate() error { return nil } + // no validation rules for RetryGroup + + // no validation rules for IsParentNode + + // no validation rules for SpecNodeId + return nil } diff --git a/flyteidl/gen/pb-go/flyteidl/event/event.pb.go b/flyteidl/gen/pb-go/flyteidl/event/event.pb.go index 27b476c0a8..b3a8225468 100644 --- a/flyteidl/gen/pb-go/flyteidl/event/event.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/event/event.pb.go @@ -159,11 +159,20 @@ type NodeExecutionEvent struct { // Types that are valid to be assigned to TargetMetadata: // *NodeExecutionEvent_WorkflowNodeMetadata TargetMetadata isNodeExecutionEvent_TargetMetadata `protobuf_oneof:"target_metadata"` - // Specifies which task (if any) launched this node. - ParentTaskMetadata *ParentTaskExecutionMetadata `protobuf:"bytes,9,opt,name=parent_task_metadata,json=parentTaskMetadata,proto3" json:"parent_task_metadata,omitempty"` - XXX_NoUnkeyedLiteral struct{} `json:"-"` - XXX_unrecognized []byte `json:"-"` - XXX_sizecache int32 `json:"-"` + // [To be deprecated] Specifies which task (if any) launched this node. + ParentTaskMetadata *ParentTaskExecutionMetadata `protobuf:"bytes,9,opt,name=parent_task_metadata,json=parentTaskMetadata,proto3" json:"parent_task_metadata,omitempty"` + // Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node. + ParentNodeMetadata *ParentNodeExecutionMetadata `protobuf:"bytes,10,opt,name=parent_node_metadata,json=parentNodeMetadata,proto3" json:"parent_node_metadata,omitempty"` + // Retry group to indicate grouping of nodes by retries + RetryGroup string `protobuf:"bytes,11,opt,name=retry_group,json=retryGroup,proto3" json:"retry_group,omitempty"` + // Identifier of the node in the original workflow/graph + // This maps to value of WorkflowTemplate.nodes[X].id + SpecNodeId string `protobuf:"bytes,12,opt,name=spec_node_id,json=specNodeId,proto3" json:"spec_node_id,omitempty"` + // Friendly readable name for the node + NodeName string `protobuf:"bytes,13,opt,name=node_name,json=nodeName,proto3" json:"node_name,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } func (m *NodeExecutionEvent) Reset() { *m = NodeExecutionEvent{} } @@ -294,6 +303,34 @@ func (m *NodeExecutionEvent) GetParentTaskMetadata() *ParentTaskExecutionMetadat return nil } +func (m *NodeExecutionEvent) GetParentNodeMetadata() *ParentNodeExecutionMetadata { + if m != nil { + return m.ParentNodeMetadata + } + return nil +} + +func (m *NodeExecutionEvent) GetRetryGroup() string { + if m != nil { + return m.RetryGroup + } + return "" +} + +func (m *NodeExecutionEvent) GetSpecNodeId() string { + if m != nil { + return m.SpecNodeId + } + return "" +} + +func (m *NodeExecutionEvent) GetNodeName() string { + if m != nil { + return m.NodeName + } + return "" +} + // XXX_OneofWrappers is for the internal use of the proto package. func (*NodeExecutionEvent) XXX_OneofWrappers() []interface{} { return []interface{}{ @@ -382,6 +419,47 @@ func (m *ParentTaskExecutionMetadata) GetId() *core.TaskExecutionIdentifier { return nil } +type ParentNodeExecutionMetadata struct { + // Unique identifier of the parent node id within the execution + // This is value of core.NodeExecutionIdentifier.node_id of the parent node + NodeId string `protobuf:"bytes,1,opt,name=node_id,json=nodeId,proto3" json:"node_id,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ParentNodeExecutionMetadata) Reset() { *m = ParentNodeExecutionMetadata{} } +func (m *ParentNodeExecutionMetadata) String() string { return proto.CompactTextString(m) } +func (*ParentNodeExecutionMetadata) ProtoMessage() {} +func (*ParentNodeExecutionMetadata) Descriptor() ([]byte, []int) { + return fileDescriptor_4b035d24120b1b12, []int{4} +} + +func (m *ParentNodeExecutionMetadata) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_ParentNodeExecutionMetadata.Unmarshal(m, b) +} +func (m *ParentNodeExecutionMetadata) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_ParentNodeExecutionMetadata.Marshal(b, m, deterministic) +} +func (m *ParentNodeExecutionMetadata) XXX_Merge(src proto.Message) { + xxx_messageInfo_ParentNodeExecutionMetadata.Merge(m, src) +} +func (m *ParentNodeExecutionMetadata) XXX_Size() int { + return xxx_messageInfo_ParentNodeExecutionMetadata.Size(m) +} +func (m *ParentNodeExecutionMetadata) XXX_DiscardUnknown() { + xxx_messageInfo_ParentNodeExecutionMetadata.DiscardUnknown(m) +} + +var xxx_messageInfo_ParentNodeExecutionMetadata proto.InternalMessageInfo + +func (m *ParentNodeExecutionMetadata) GetNodeId() string { + if m != nil { + return m.NodeId + } + return "" +} + // Plugin specific execution event information. For tasks like Python, Hive, Spark, DynamicJob. type TaskExecutionEvent struct { // ID of the task. In combination with the retryAttempt this will indicate @@ -423,7 +501,7 @@ func (m *TaskExecutionEvent) Reset() { *m = TaskExecutionEvent{} } func (m *TaskExecutionEvent) String() string { return proto.CompactTextString(m) } func (*TaskExecutionEvent) ProtoMessage() {} func (*TaskExecutionEvent) Descriptor() ([]byte, []int) { - return fileDescriptor_4b035d24120b1b12, []int{4} + return fileDescriptor_4b035d24120b1b12, []int{5} } func (m *TaskExecutionEvent) XXX_Unmarshal(b []byte) error { @@ -564,54 +642,61 @@ func init() { proto.RegisterType((*NodeExecutionEvent)(nil), "flyteidl.event.NodeExecutionEvent") proto.RegisterType((*WorkflowNodeMetadata)(nil), "flyteidl.event.WorkflowNodeMetadata") proto.RegisterType((*ParentTaskExecutionMetadata)(nil), "flyteidl.event.ParentTaskExecutionMetadata") + proto.RegisterType((*ParentNodeExecutionMetadata)(nil), "flyteidl.event.ParentNodeExecutionMetadata") proto.RegisterType((*TaskExecutionEvent)(nil), "flyteidl.event.TaskExecutionEvent") } func init() { proto.RegisterFile("flyteidl/event/event.proto", fileDescriptor_4b035d24120b1b12) } var fileDescriptor_4b035d24120b1b12 = []byte{ - // 686 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x55, 0xef, 0x6b, 0xd3, 0x40, - 0x18, 0x5e, 0xbb, 0xb6, 0x5b, 0xdf, 0xec, 0x07, 0x1e, 0x73, 0xc6, 0xce, 0xb9, 0x52, 0x45, 0xca, - 0xc4, 0x04, 0x3b, 0x94, 0x81, 0x7e, 0xd9, 0x60, 0xb0, 0x82, 0x93, 0x11, 0x37, 0x05, 0x51, 0x42, - 0x9a, 0x5c, 0xb2, 0x63, 0x69, 0x2e, 0x5c, 0xde, 0x6c, 0xee, 0x5f, 0xf3, 0x6f, 0xf2, 0xbb, 0x5f, - 0x25, 0x97, 0x1f, 0x5d, 0xd2, 0x52, 0x9d, 0xec, 0x4b, 0xa1, 0xcf, 0x3d, 0xf7, 0xe4, 0xb9, 0xe7, - 0xde, 0x87, 0x83, 0x8e, 0xeb, 0xdf, 0x20, 0x65, 0x8e, 0xaf, 0xd3, 0x2b, 0x1a, 0x60, 0xfa, 0xab, - 0x85, 0x82, 0x23, 0x27, 0x6b, 0xf9, 0x9a, 0x26, 0xd1, 0xce, 0x76, 0xc1, 0xb5, 0xb9, 0xa0, 0x3a, - 0xfd, 0x41, 0xed, 0x18, 0x19, 0x0f, 0x52, 0x7a, 0xe7, 0x69, 0x79, 0x99, 0x39, 0x34, 0x40, 0xe6, - 0x32, 0x2a, 0xb2, 0xf5, 0x1d, 0x8f, 0x73, 0xcf, 0xa7, 0xba, 0xfc, 0x37, 0x8a, 0x5d, 0x1d, 0xd9, - 0x98, 0x46, 0x68, 0x8d, 0xc3, 0x8c, 0xf0, 0xa4, 0x4a, 0x88, 0x50, 0xc4, 0x76, 0xe6, 0xa6, 0xf7, - 0xab, 0x0e, 0x9b, 0x5f, 0xb8, 0xb8, 0x74, 0x7d, 0x7e, 0x7d, 0x94, 0x7f, 0xfa, 0x28, 0x31, 0x46, - 0x4e, 0x60, 0xa5, 0x30, 0x63, 0x32, 0x47, 0xad, 0x75, 0x6b, 0x7d, 0x65, 0xb0, 0xab, 0x15, 0xfe, - 0x13, 0x43, 0xda, 0xd4, 0xe6, 0x61, 0xe1, 0xd0, 0x50, 0xe8, 0x04, 0x24, 0x3b, 0xa0, 0x84, 0x82, - 0x3b, 0xb1, 0x4d, 0x45, 0xa2, 0x56, 0xef, 0xd6, 0xfa, 0x6d, 0x03, 0x72, 0x68, 0xe8, 0x90, 0xf7, - 0xd0, 0x0c, 0x2f, 0xac, 0x88, 0xaa, 0x8b, 0xdd, 0x5a, 0x7f, 0x6d, 0xf0, 0xe2, 0x6f, 0x1f, 0xd2, - 0x4e, 0x13, 0xb6, 0x91, 0x6e, 0x22, 0xef, 0x40, 0xe1, 0xb6, 0x1d, 0x0b, 0x41, 0x1d, 0xd3, 0x42, - 0xb5, 0x21, 0xcd, 0x76, 0xb4, 0xf4, 0xf0, 0x5a, 0x7e, 0x78, 0xed, 0x2c, 0x4f, 0xc7, 0x80, 0x9c, - 0x7e, 0x80, 0x64, 0x07, 0x80, 0xc7, 0x18, 0xc6, 0x68, 0xc6, 0x82, 0xa9, 0xcd, 0xc4, 0xda, 0xf1, - 0x82, 0xd1, 0x4e, 0xb1, 0x73, 0xc1, 0xc8, 0x1b, 0x68, 0x52, 0x21, 0xb8, 0x50, 0x5b, 0x52, 0x77, - 0xbb, 0xe2, 0x6d, 0x92, 0x5c, 0x42, 0x3a, 0x5e, 0x30, 0x52, 0xf6, 0xe1, 0x3a, 0xac, 0x66, 0xba, - 0x82, 0x46, 0xb1, 0x8f, 0xbd, 0x9f, 0x0d, 0x20, 0x1f, 0xb9, 0x43, 0x2b, 0x51, 0xbf, 0x85, 0x7a, - 0x11, 0x70, 0xf5, 0xdc, 0x25, 0xfa, 0xad, 0x70, 0xeb, 0xec, 0x1f, 0x32, 0xdd, 0x2f, 0x67, 0xda, - 0x9b, 0xa7, 0x7d, 0x8f, 0x79, 0x6e, 0x41, 0x9b, 0x05, 0xa5, 0x38, 0x8d, 0x65, 0x09, 0x24, 0x59, - 0x96, 0xc3, 0x6e, 0xcd, 0x09, 0x7b, 0xe9, 0x2e, 0x61, 0x93, 0x6f, 0xb0, 0x79, 0x9d, 0xcd, 0x88, - 0x19, 0x70, 0x87, 0x9a, 0x63, 0x8a, 0x96, 0x63, 0xa1, 0xa5, 0x2e, 0x4b, 0x9d, 0xe7, 0x5a, 0xb9, - 0x79, 0xc5, 0x44, 0x25, 0x29, 0x9c, 0x64, 0xdc, 0xe3, 0x9a, 0xb1, 0x71, 0x3d, 0x03, 0x27, 0xdf, - 0x61, 0x23, 0xb4, 0x04, 0x0d, 0xd0, 0x44, 0x2b, 0xba, 0x9c, 0x68, 0xb7, 0xa5, 0xf6, 0xcb, 0xaa, - 0xf6, 0xa9, 0xe4, 0x9e, 0x59, 0xd1, 0x65, 0x61, 0x37, 0x97, 0x32, 0x48, 0x58, 0x2c, 0xe6, 0xd8, - 0xd4, 0xa4, 0x1c, 0x3e, 0x80, 0x75, 0xb4, 0x84, 0x47, 0xb1, 0xf8, 0x54, 0x8f, 0xc2, 0xc6, 0x2c, - 0xcb, 0xf7, 0x5c, 0xd4, 0xde, 0x39, 0x6c, 0xcd, 0x71, 0x3f, 0x77, 0x56, 0x4b, 0x3b, 0xca, 0xb3, - 0xda, 0xfb, 0xdd, 0x00, 0x52, 0x5a, 0x4f, 0x47, 0x7f, 0x00, 0x4b, 0x32, 0xd0, 0x42, 0xf3, 0x71, - 0x45, 0xf3, 0x96, 0x4c, 0x2b, 0x61, 0x0e, 0x1d, 0x62, 0x82, 0x9a, 0xdd, 0x85, 0xbc, 0xe7, 0xd2, - 0xe1, 0xeb, 0x77, 0x2a, 0xd1, 0xc3, 0x54, 0xa7, 0xb2, 0x4c, 0x9e, 0xc1, 0xaa, 0xa0, 0x28, 0x6e, - 0x4c, 0x0b, 0x91, 0x8e, 0x43, 0x94, 0xf5, 0x59, 0x35, 0x56, 0x24, 0x78, 0x90, 0x62, 0x93, 0x6e, - 0x35, 0x66, 0x76, 0xab, 0x74, 0xd6, 0x72, 0xb7, 0x2a, 0xb5, 0x6d, 0x4e, 0xd5, 0x76, 0x17, 0x1a, - 0x3e, 0xf7, 0x22, 0xb5, 0xd5, 0x5d, 0xec, 0x2b, 0x83, 0xcd, 0x19, 0xca, 0x1f, 0xb8, 0x67, 0x48, - 0x4e, 0xb5, 0xa8, 0x4b, 0xff, 0x5f, 0xd4, 0xe5, 0xb9, 0x45, 0x6d, 0xcf, 0x29, 0x2a, 0xdc, 0xa9, - 0xa8, 0xfb, 0xa0, 0xd8, 0x71, 0x84, 0x7c, 0x6c, 0xb2, 0xc0, 0xe5, 0xaa, 0x22, 0x37, 0x3f, 0x9a, - 0x72, 0xfc, 0x49, 0xbe, 0x53, 0x06, 0xa4, 0xdc, 0x61, 0xe0, 0xf2, 0xe4, 0x5e, 0x64, 0x82, 0xe6, - 0x15, 0x15, 0x11, 0xe3, 0x81, 0xba, 0x92, 0xde, 0x8b, 0x04, 0x3f, 0xa7, 0xd8, 0x74, 0x95, 0xf6, - 0xbe, 0xbe, 0xf6, 0x18, 0x5e, 0xc4, 0x23, 0xcd, 0xe6, 0x63, 0xdd, 0xbf, 0x71, 0x51, 0x2f, 0x1e, - 0x55, 0x8f, 0x06, 0x7a, 0x38, 0x7a, 0xe5, 0x71, 0xbd, 0xfc, 0x64, 0x8f, 0x5a, 0xd2, 0xc7, 0xde, - 0x9f, 0x00, 0x00, 0x00, 0xff, 0xff, 0x06, 0x20, 0xa3, 0x2f, 0xcb, 0x07, 0x00, 0x00, + // 771 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x56, 0xdf, 0x4f, 0xdb, 0x3a, + 0x18, 0xa5, 0xa5, 0x3f, 0xe8, 0x97, 0x16, 0x74, 0x2d, 0x2e, 0xe4, 0x96, 0xcb, 0x6d, 0xd5, 0x7b, + 0x75, 0x55, 0x31, 0x2d, 0xd1, 0x8a, 0x86, 0x90, 0xb6, 0x17, 0x90, 0xd0, 0xa8, 0x34, 0x10, 0xca, + 0x60, 0x93, 0xa6, 0x4d, 0x51, 0x9a, 0xb8, 0x21, 0xa2, 0x89, 0x23, 0xc7, 0x81, 0xf1, 0x3f, 0xef, + 0x7d, 0xda, 0xdb, 0x64, 0xbb, 0x49, 0x71, 0x5a, 0x75, 0x63, 0xe2, 0x05, 0x89, 0xe3, 0xe3, 0xe3, + 0xe3, 0xe3, 0xef, 0xfb, 0x1a, 0x68, 0x8f, 0x27, 0xf7, 0x0c, 0x07, 0xde, 0xc4, 0xc4, 0xb7, 0x38, + 0x62, 0xf2, 0xaf, 0x11, 0x53, 0xc2, 0x08, 0x5a, 0xcf, 0xd6, 0x0c, 0x81, 0xb6, 0x77, 0x73, 0xae, + 0x4b, 0x28, 0x36, 0xf1, 0x17, 0xec, 0xa6, 0x2c, 0x20, 0x91, 0xa4, 0xb7, 0xff, 0x51, 0x97, 0x03, + 0x0f, 0x47, 0x2c, 0x18, 0x07, 0x98, 0x4e, 0xd7, 0x3b, 0x3e, 0x21, 0xfe, 0x04, 0x9b, 0xe2, 0xbf, + 0x51, 0x3a, 0x36, 0x59, 0x10, 0xe2, 0x84, 0x39, 0x61, 0x3c, 0x25, 0xfc, 0x5d, 0x24, 0x24, 0x8c, + 0xa6, 0xee, 0xd4, 0x4d, 0xef, 0x6b, 0x19, 0xb6, 0x3e, 0x10, 0x7a, 0x33, 0x9e, 0x90, 0xbb, 0x93, + 0xec, 0xe8, 0x13, 0x6e, 0x0c, 0x9d, 0x41, 0x33, 0x37, 0x63, 0x07, 0x9e, 0x5e, 0xea, 0x96, 0xfa, + 0xda, 0x60, 0xcf, 0xc8, 0xfd, 0x73, 0x43, 0xc6, 0xdc, 0xe6, 0x61, 0xee, 0xd0, 0xd2, 0xf0, 0x0c, + 0x44, 0x1d, 0xd0, 0x62, 0x4a, 0xbc, 0xd4, 0xc5, 0x94, 0xab, 0x95, 0xbb, 0xa5, 0x7e, 0xc3, 0x82, + 0x0c, 0x1a, 0x7a, 0xe8, 0x35, 0x54, 0xe3, 0x6b, 0x27, 0xc1, 0xfa, 0x6a, 0xb7, 0xd4, 0x5f, 0x1f, + 0xfc, 0xff, 0xb3, 0x83, 0x8c, 0x0b, 0xce, 0xb6, 0xe4, 0x26, 0xf4, 0x0a, 0x34, 0xe2, 0xba, 0x29, + 0xa5, 0xd8, 0xb3, 0x1d, 0xa6, 0x57, 0x84, 0xd9, 0xb6, 0x21, 0x2f, 0x6f, 0x64, 0x97, 0x37, 0x2e, + 0xb3, 0x74, 0x2c, 0xc8, 0xe8, 0x47, 0x0c, 0x75, 0x00, 0x48, 0xca, 0xe2, 0x94, 0xd9, 0x29, 0x0d, + 0xf4, 0x2a, 0xb7, 0x76, 0xba, 0x62, 0x35, 0x24, 0x76, 0x45, 0x03, 0xf4, 0x12, 0xaa, 0x98, 0x52, + 0x42, 0xf5, 0x9a, 0xd0, 0xdd, 0x2d, 0x78, 0x9b, 0x25, 0xc7, 0x49, 0xa7, 0x2b, 0x96, 0x64, 0x1f, + 0x6f, 0x40, 0x6b, 0xaa, 0x4b, 0x71, 0x92, 0x4e, 0x58, 0xef, 0x7b, 0x15, 0xd0, 0x39, 0xf1, 0x70, + 0x21, 0xea, 0x03, 0x28, 0xe7, 0x01, 0x17, 0xef, 0xad, 0xd0, 0x1f, 0x84, 0x5b, 0x0e, 0x7e, 0x21, + 0xd3, 0x43, 0x35, 0xd3, 0xde, 0x32, 0xed, 0x27, 0xcc, 0x73, 0x07, 0x1a, 0x41, 0xa4, 0xc4, 0x69, + 0xad, 0x09, 0x80, 0x67, 0xa9, 0x86, 0x5d, 0x5b, 0x12, 0x76, 0xfd, 0x31, 0x61, 0xa3, 0x4f, 0xb0, + 0x75, 0x37, 0xad, 0x11, 0x3b, 0x22, 0x1e, 0xb6, 0x43, 0xcc, 0x1c, 0xcf, 0x61, 0x8e, 0xbe, 0x26, + 0x74, 0xfe, 0x33, 0xd4, 0xce, 0xcb, 0x2b, 0x8a, 0xa7, 0x70, 0x36, 0xe5, 0x9e, 0x96, 0xac, 0xcd, + 0xbb, 0x05, 0x38, 0xfa, 0x0c, 0x9b, 0xb1, 0x43, 0x71, 0xc4, 0x6c, 0xe6, 0x24, 0x37, 0x33, 0xed, + 0x86, 0xd0, 0x7e, 0x56, 0xd4, 0xbe, 0x10, 0xdc, 0x4b, 0x27, 0xb9, 0xc9, 0xed, 0x66, 0x52, 0x16, + 0x8a, 0xf3, 0xc5, 0x05, 0xf2, 0xaa, 0x75, 0x58, 0x26, 0xaf, 0x3c, 0x5f, 0x51, 0x5e, 0x71, 0xdf, + 0x01, 0x8d, 0x62, 0x46, 0xef, 0x6d, 0x9f, 0x92, 0x34, 0xd6, 0x35, 0x59, 0x28, 0x02, 0x7a, 0xc3, + 0x11, 0xd4, 0x85, 0x66, 0x12, 0x63, 0x57, 0x9e, 0x1e, 0x78, 0x7a, 0x53, 0x32, 0x38, 0xc6, 0x85, + 0x86, 0x1e, 0x7f, 0x53, 0xb1, 0x18, 0x39, 0x21, 0xd6, 0x5b, 0xf2, 0x4d, 0x39, 0x70, 0xee, 0x84, + 0x78, 0xae, 0xd0, 0x8f, 0xff, 0x80, 0x0d, 0xe6, 0x50, 0x1f, 0xb3, 0xfc, 0x2a, 0x3d, 0x0c, 0x9b, + 0x8b, 0x12, 0x7f, 0xe2, 0x39, 0xd3, 0xbb, 0x82, 0x9d, 0x25, 0xe1, 0x2f, 0x6d, 0x35, 0x65, 0x87, + 0xda, 0x6a, 0xbd, 0x83, 0x4c, 0x76, 0x61, 0xe8, 0x68, 0x1b, 0xea, 0x59, 0x74, 0x25, 0x91, 0x4d, + 0x2d, 0x12, 0xb1, 0xf5, 0xbe, 0x55, 0x00, 0x29, 0xba, 0xb2, 0xe3, 0x07, 0x50, 0x17, 0x75, 0x94, + 0x7b, 0xf9, 0xab, 0xe0, 0xe5, 0xc1, 0xf1, 0x35, 0xce, 0x1c, 0x7a, 0xc8, 0x06, 0xfd, 0x61, 0x8d, + 0x28, 0xa1, 0x95, 0x1f, 0x35, 0x3b, 0xfe, 0x8c, 0xe7, 0xaf, 0x32, 0xf4, 0xd0, 0xbf, 0xd0, 0x92, + 0x55, 0xe2, 0x30, 0x86, 0xc3, 0x98, 0x89, 0xa9, 0xd1, 0xb2, 0x9a, 0x02, 0x3c, 0x92, 0xd8, 0x6c, + 0xa4, 0x54, 0x16, 0x8e, 0x14, 0xe5, 0xae, 0xea, 0x48, 0x29, 0x4c, 0xab, 0xea, 0xdc, 0xb4, 0xda, + 0x83, 0xca, 0x84, 0xf8, 0x89, 0x5e, 0xeb, 0xae, 0xf6, 0xb5, 0xc1, 0xd6, 0x02, 0xe5, 0xb7, 0xc4, + 0xb7, 0x04, 0xa7, 0x38, 0x9f, 0xea, 0xbf, 0x3f, 0x9f, 0xd6, 0x96, 0xce, 0xa7, 0xc6, 0x92, 0xf9, + 0x04, 0x8f, 0x9a, 0x4f, 0x87, 0xa0, 0xb9, 0x69, 0xc2, 0x48, 0x68, 0x07, 0xd1, 0x98, 0x88, 0x1e, + 0xd4, 0x06, 0xdb, 0x73, 0x8e, 0xdf, 0x89, 0x9f, 0x67, 0x0b, 0x24, 0x77, 0x18, 0x8d, 0x09, 0x7f, + 0x17, 0x91, 0xa0, 0x7d, 0x8b, 0x69, 0x12, 0x90, 0x48, 0x74, 0x67, 0xcb, 0x6a, 0x0a, 0xf0, 0xbd, + 0xc4, 0xe6, 0x5b, 0x70, 0xff, 0xe3, 0x0b, 0x3f, 0x60, 0xd7, 0xe9, 0xc8, 0x70, 0x49, 0x68, 0x4e, + 0xee, 0xc7, 0xcc, 0xcc, 0xbf, 0x25, 0x7c, 0x1c, 0x99, 0xf1, 0xe8, 0xb9, 0x4f, 0x4c, 0xf5, 0x4b, + 0x65, 0x54, 0x13, 0x3e, 0xf6, 0x7f, 0x04, 0x00, 0x00, 0xff, 0xff, 0x11, 0x9e, 0xe6, 0x40, 0xc2, + 0x08, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/event/event.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/event/event.pb.validate.go index ca47538382..60e146f975 100644 --- a/flyteidl/gen/pb-go/flyteidl/event/event.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/event/event.pb.validate.go @@ -198,6 +198,22 @@ func (m *NodeExecutionEvent) Validate() error { } } + if v, ok := interface{}(m.GetParentNodeMetadata()).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return NodeExecutionEventValidationError{ + field: "ParentNodeMetadata", + reason: "embedded message failed validation", + cause: err, + } + } + } + + // no validation rules for RetryGroup + + // no validation rules for SpecNodeId + + // no validation rules for NodeName + switch m.OutputResult.(type) { case *NodeExecutionEvent_OutputUri: @@ -447,6 +463,76 @@ var _ interface { ErrorName() string } = ParentTaskExecutionMetadataValidationError{} +// Validate checks the field values on ParentNodeExecutionMetadata with the +// rules defined in the proto definition for this message. If any rules are +// violated, an error is returned. +func (m *ParentNodeExecutionMetadata) Validate() error { + if m == nil { + return nil + } + + // no validation rules for NodeId + + return nil +} + +// ParentNodeExecutionMetadataValidationError is the validation error returned +// by ParentNodeExecutionMetadata.Validate if the designated constraints +// aren't met. +type ParentNodeExecutionMetadataValidationError struct { + field string + reason string + cause error + key bool +} + +// Field function returns field value. +func (e ParentNodeExecutionMetadataValidationError) Field() string { return e.field } + +// Reason function returns reason value. +func (e ParentNodeExecutionMetadataValidationError) Reason() string { return e.reason } + +// Cause function returns cause value. +func (e ParentNodeExecutionMetadataValidationError) Cause() error { return e.cause } + +// Key function returns key value. +func (e ParentNodeExecutionMetadataValidationError) Key() bool { return e.key } + +// ErrorName returns error name. +func (e ParentNodeExecutionMetadataValidationError) ErrorName() string { + return "ParentNodeExecutionMetadataValidationError" +} + +// Error satisfies the builtin error interface +func (e ParentNodeExecutionMetadataValidationError) Error() string { + cause := "" + if e.cause != nil { + cause = fmt.Sprintf(" | caused by: %v", e.cause) + } + + key := "" + if e.key { + key = "key for " + } + + return fmt.Sprintf( + "invalid %sParentNodeExecutionMetadata.%s: %s%s", + key, + e.field, + e.reason, + cause) +} + +var _ error = ParentNodeExecutionMetadataValidationError{} + +var _ interface { + Field() string + Reason() string + Key() bool + Cause() error + ErrorName() string +} = ParentNodeExecutionMetadataValidationError{} + // Validate checks the field values on TaskExecutionEvent with the rules // defined in the proto definition for this message. If any rules are // violated, an error is returned. diff --git a/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json b/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json index 906f13dd9d..3cc07b9b80 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json +++ b/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json @@ -1477,6 +1477,13 @@ "ASCENDING" ], "default": "DESCENDING" + }, + { + "name": "unique_parent_id", + "description": "Unique identifier of the parent node in the execution\n+optional.", + "in": "query", + "required": false, + "type": "string" } ], "tags": [ @@ -3673,6 +3680,21 @@ }, "adminNodeExecutionMetaData": { "type": "object", + "properties": { + "retry_group": { + "type": "string", + "description": "Node executions are grouped depending on retries of the parent\nRetry group is unique within the context of a parent node." + }, + "is_parent_node": { + "type": "boolean", + "format": "boolean", + "title": "Boolean flag indicating if the node has child nodes under it" + }, + "spec_node_id": { + "type": "string", + "title": "Node id of the node in the original workflow\nThis maps to value of WorkflowTemplate.nodes[X].id" + } + }, "title": "Represents additional attributes related to a Node Execution" }, "adminNotification": { @@ -5425,7 +5447,32 @@ }, "parent_task_metadata": { "$ref": "#/definitions/eventParentTaskExecutionMetadata", - "description": "Specifies which task (if any) launched this node." + "description": "[To be deprecated] Specifies which task (if any) launched this node." + }, + "parent_node_metadata": { + "$ref": "#/definitions/eventParentNodeExecutionMetadata", + "description": "Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node." + }, + "retry_group": { + "type": "string", + "title": "Retry group to indicate grouping of nodes by retries" + }, + "spec_node_id": { + "type": "string", + "title": "Identifier of the node in the original workflow/graph\nThis maps to value of WorkflowTemplate.nodes[X].id" + }, + "node_name": { + "type": "string", + "title": "Friendly readable name for the node" + } + } + }, + "eventParentNodeExecutionMetadata": { + "type": "object", + "properties": { + "node_id": { + "type": "string", + "title": "Unique identifier of the parent node id within the execution\nThis is value of core.NodeExecutionIdentifier.node_id of the parent node" } } }, diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/README.md b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/README.md index 43e3e2a77f..40dca922c6 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/README.md +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/README.md @@ -239,6 +239,7 @@ Class | Method | HTTP request | Description - [CoreWorkflowTemplate](docs/CoreWorkflowTemplate.md) - [DataLoadingConfigLiteralMapFormat](docs/DataLoadingConfigLiteralMapFormat.md) - [EventNodeExecutionEvent](docs/EventNodeExecutionEvent.md) + - [EventParentNodeExecutionMetadata](docs/EventParentNodeExecutionMetadata.md) - [EventParentTaskExecutionMetadata](docs/EventParentTaskExecutionMetadata.md) - [EventTaskExecutionEvent](docs/EventTaskExecutionEvent.md) - [EventWorkflowExecutionEvent](docs/EventWorkflowExecutionEvent.md) diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api/swagger.yaml b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api/swagger.yaml index 401c29b540..b6576c2da0 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api/swagger.yaml +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api/swagger.yaml @@ -1270,6 +1270,13 @@ paths: - "ASCENDING" x-exportParamName: "SortByDirection" x-optionalDataType: "String" + - name: "unique_parent_id" + in: "query" + description: "Unique identifier of the parent node in the execution\n+optional." + required: false + type: "string" + x-exportParamName: "UniqueParentId" + x-optionalDataType: "String" responses: 200: description: "A successful response." @@ -4991,7 +4998,10 @@ definitions: description: "Request structure to retrieve a list of node execution entities." example: node_executions: - - metadata: {} + - metadata: + retry_group: "retry_group" + is_parent_node: true + spec_node_id: "spec_node_id" input_uri: "input_uri" id: execution_id: @@ -5016,7 +5026,10 @@ definitions: kind: {} message: "message" error_uri: "error_uri" - - metadata: {} + - metadata: + retry_group: "retry_group" + is_parent_node: true + spec_node_id: "spec_node_id" input_uri: "input_uri" id: execution_id: @@ -5044,7 +5057,24 @@ definitions: token: "token" adminNodeExecutionMetaData: type: "object" + properties: + retry_group: + type: "string" + description: "Node executions are grouped depending on retries of the parent\n\ + Retry group is unique within the context of a parent node." + is_parent_node: + type: "boolean" + format: "boolean" + title: "Boolean flag indicating if the node has child nodes under it" + spec_node_id: + type: "string" + title: "Node id of the node in the original workflow\nThis maps to value of\ + \ WorkflowTemplate.nodes[X].id" title: "Represents additional attributes related to a Node Execution" + example: + retry_group: "retry_group" + is_parent_node: true + spec_node_id: "spec_node_id" adminNotification: type: "object" properties: @@ -24078,8 +24108,30 @@ definitions: workflow_node_metadata: $ref: "#/definitions/flyteidleventWorkflowNodeMetadata" parent_task_metadata: - description: "Specifies which task (if any) launched this node." + description: "[To be deprecated] Specifies which task (if any) launched this\ + \ node." $ref: "#/definitions/eventParentTaskExecutionMetadata" + parent_node_metadata: + description: "Specifies the parent node of the current node execution. Node\ + \ executions at level zero will not have a parent node." + $ref: "#/definitions/eventParentNodeExecutionMetadata" + retry_group: + type: "string" + title: "Retry group to indicate grouping of nodes by retries" + spec_node_id: + type: "string" + title: "Identifier of the node in the original workflow/graph\nThis maps to\ + \ value of WorkflowTemplate.nodes[X].id" + node_name: + type: "string" + title: "Friendly readable name for the node" + eventParentNodeExecutionMetadata: + type: "object" + properties: + node_id: + type: "string" + title: "Unique identifier of the parent node id within the execution\nThis\ + \ is value of core.NodeExecutionIdentifier.node_id of the parent node" eventParentTaskExecutionMetadata: type: "object" properties: @@ -24185,7 +24237,10 @@ definitions: \ execution.\nThe same task can be called repeatedly in a single workflow but\ \ each node is unique." example: - metadata: {} + metadata: + retry_group: "retry_group" + is_parent_node: true + spec_node_id: "spec_node_id" input_uri: "input_uri" id: execution_id: diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api_admin_service.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api_admin_service.go index c3c10c1c58..c05069887f 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api_admin_service.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api_admin_service.go @@ -3070,6 +3070,7 @@ Fetch existing node executions matching input filters. * @param "Filters" (optional.String) - Indicates a list of filters passed as string. More info on constructing filters : <Link> +optional. * @param "SortByKey" (optional.String) - Indicates an attribute to sort the response values. TODO(katrogan): Add string validation here. This should never be empty. * @param "SortByDirection" (optional.String) - Indicates the direction to apply sort key for response values. +optional. + * @param "UniqueParentId" (optional.String) - Unique identifier of the parent node in the execution +optional. @return AdminNodeExecutionList */ @@ -3080,6 +3081,7 @@ type ListNodeExecutionsOpts struct { Filters optional.String SortByKey optional.String SortByDirection optional.String + UniqueParentId optional.String } func (a *AdminServiceApiService) ListNodeExecutions(ctx context.Context, workflowExecutionIdProject string, workflowExecutionIdDomain string, workflowExecutionIdName string, localVarOptionals *ListNodeExecutionsOpts) (AdminNodeExecutionList, *http.Response, error) { @@ -3116,6 +3118,9 @@ func (a *AdminServiceApiService) ListNodeExecutions(ctx context.Context, workflo if localVarOptionals != nil && localVarOptionals.SortByDirection.IsSet() { localVarQueryParams.Add("sort_by.direction", parameterToString(localVarOptionals.SortByDirection.Value(), "")) } + if localVarOptionals != nil && localVarOptionals.UniqueParentId.IsSet() { + localVarQueryParams.Add("unique_parent_id", parameterToString(localVarOptionals.UniqueParentId.Value(), "")) + } // to determine the Content-Type header localVarHttpContentTypes := []string{"application/json"} diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_node_execution_meta_data.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_node_execution_meta_data.go index 04593488cc..fd2dff0e7a 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_node_execution_meta_data.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_node_execution_meta_data.go @@ -10,4 +10,8 @@ package flyteadmin type AdminNodeExecutionMetaData struct { + // Node executions are grouped depending on retries of the parent Retry group is unique within the context of a parent node. + RetryGroup string `json:"retry_group,omitempty"` + IsParentNode bool `json:"is_parent_node,omitempty"` + SpecNodeId string `json:"spec_node_id,omitempty"` } diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_event_node_execution_event.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_event_node_execution_event.go index 4a53b7294c..0a09070e0d 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_event_node_execution_event.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_event_node_execution_event.go @@ -24,6 +24,11 @@ type EventNodeExecutionEvent struct { OutputUri string `json:"output_uri,omitempty"` Error_ *CoreExecutionError `json:"error,omitempty"` WorkflowNodeMetadata *FlyteidleventWorkflowNodeMetadata `json:"workflow_node_metadata,omitempty"` - // Specifies which task (if any) launched this node. + // [To be deprecated] Specifies which task (if any) launched this node. ParentTaskMetadata *EventParentTaskExecutionMetadata `json:"parent_task_metadata,omitempty"` + // Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node. + ParentNodeMetadata *EventParentNodeExecutionMetadata `json:"parent_node_metadata,omitempty"` + RetryGroup string `json:"retry_group,omitempty"` + SpecNodeId string `json:"spec_node_id,omitempty"` + NodeName string `json:"node_name,omitempty"` } diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_event_parent_node_execution_metadata.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_event_parent_node_execution_metadata.go new file mode 100644 index 0000000000..80cd096b18 --- /dev/null +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_event_parent_node_execution_metadata.go @@ -0,0 +1,14 @@ +/* + * flyteidl/service/admin.proto + * + * No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen) + * + * API version: version not set + * Generated by: Swagger Codegen (https://github.com/swagger-api/swagger-codegen.git) + */ + +package flyteadmin + +type EventParentNodeExecutionMetadata struct { + NodeId string `json:"node_id,omitempty"` +} diff --git a/flyteidl/gen/pb-go/flyteidl/service/openapi.go b/flyteidl/gen/pb-go/flyteidl/service/openapi.go index d3a431db9f..85cdd04c33 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/openapi.go +++ b/flyteidl/gen/pb-go/flyteidl/service/openapi.go @@ -77,7 +77,7 @@ func (fi bindataFileInfo) Sys() interface{} { return nil } -var _adminSwaggerJson = []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\xff\xec\xbd\xf9\x73\x23\xb9\x95\x27\xfe\xbb\xff\x0a\xac\x66\x23\xba\xca\xa6\x58\x6d\xcf\x11\x5e\x4d\x4c\x7c\x83\x2d\xb1\xaa\x39\xad\x92\x64\x1d\x5d\xd3\xbb\x9c\xa0\xc1\x4c\x90\x84\x95\x04\x68\x00\x29\x15\x3d\xd1\xff\xfb\x37\xf0\x70\x24\x90\x17\x4f\x5d\xd5\x9c\x8d\x75\xab\x48\x26\x12\x78\x78\x78\x78\xe7\xe7\xfd\xcf\xef\x10\x3a\x92\x8f\x78\x3a\x25\xe2\xe8\x04\x1d\xfd\xa9\xfb\xfd\x51\x47\x7f\x46\xd9\x84\x1f\x9d\x20\xfd\x3d\x42\x47\x8a\xaa\x8c\xe8\xef\x27\xd9\x52\x11\x9a\x66\x1f\x24\x11\x0f\x34\x21\x1f\x70\x3a\xa7\xac\xbb\x10\x5c\x71\x78\x10\xa1\xa3\x07\x22\x24\xe5\x4c\xff\xdc\xfe\x89\x18\x57\x48\x12\x75\xf4\x3b\x84\x7e\x85\xe1\x65\x32\x23\x73\x22\x8f\x4e\xd0\xff\x33\x0f\xcd\x94\x5a\xb8\x01\xf4\xdf\x52\xff\xf6\xbf\xe1\xb7\x09\x67\x32\x8f\x7e\x8c\x17\x8b\x8c\x26\x58\x51\xce\x3e\xfc\x4d\x72\x56\xfc\x76\x21\x78\x9a\x27\x6b\xfe\x16\xab\x99\x2c\xd6\xf8\x01\x2f\xe8\x87\x87\x3f\x7e\xc0\x89\xa2\x0f\x64\x94\xe1\x9c\x25\xb3\xd1\x22\xc3\x4c\x7e\xf8\x1f\x9a\xea\x35\xfe\x8d\x24\xea\x57\xf8\x47\xca\xe7\x98\x32\xf3\x37\xc3\x73\xf2\xab\x1f\x07\xa1\xa3\x29\x51\xc1\x3f\x11\x3a\x4a\x89\x4c\x04\x5d\x28\x4b\x95\x6b\xa2\x04\x25\x0f\x04\xa9\x19\x41\xe6\x75\xc8\xbc\x0e\xe9\xd7\x21\x47\x35\xb9\x20\x09\x9d\x50\x92\xa2\xf1\x12\x51\xb6\xc8\x15\x12\xe4\xef\x39\x91\x0a\x4d\x68\xa6\x88\x90\x5d\x4b\x32\x78\x0b\x5f\x10\x01\xeb\x1c\xa4\xfa\x2d\x9f\x88\xea\xc1\xd8\xe7\x30\xf4\x55\x86\x59\xf8\x6b\x41\xe4\x82\x33\x49\x64\x34\x55\x84\x8e\xfe\xf4\xfd\xf7\xa5\x8f\xaa\x2b\xe8\x21\x99\x27\x09\x91\x72\x92\x67\xc8\x8d\x14\x4e\x06\x1e\x82\x4d\xc6\x95\xc1\x10\x3a\xfa\xdf\x82\x4c\xf4\x38\xff\xf4\x21\x25\x13\xca\xa8\x1e\x57\x1a\x5e\x0a\x66\x1b\x3d\xf5\xeb\xef\xea\xfe\xfe\x35\x58\xd1\x02\x0b\x3c\x27\x9a\x2c\x7e\xf7\xcd\xff\x95\xd6\xa2\xf7\x4b\xbf\xbc\xd8\xd3\xf2\xc4\x4b\xab\xbd\xc0\x73\x82\xf8\x04\xb6\xcb\x3e\x01\x7f\x0b\x22\x79\x2e\x12\x82\xc6\x24\xe3\x6c\x2a\x91\xe2\x15\x1a\x50\x18\x41\xb3\x5a\xf9\x1b\xbd\x95\x54\x10\xbd\x57\x4a\xe4\xa4\xf4\xad\x5a\x2e\x60\x92\x52\x09\xca\xa6\x21\x29\x7e\xed\xac\xb5\x34\xc3\xa1\x1b\xac\xcc\x3c\xd0\xb8\xb0\x21\xeb\xb9\x9f\x24\x98\xa1\x31\x41\xfa\x5c\xd2\x94\x08\x92\x22\x2c\x11\x46\x32\x1f\x4b\xa2\xd0\x23\x55\x33\xca\xf4\xbf\x0d\xfb\x26\x8e\x66\xaf\x87\x36\xf0\x67\x3b\x65\xee\x24\x11\x7a\xe2\x0f\x34\x25\x29\x7a\xc0\x59\x4e\xd0\x84\x8b\x88\x3c\xdd\x21\xbb\x9d\x69\x3a\xcc\xc7\x94\xc1\xc9\xd3\xb4\x74\x1c\xf2\x07\x47\xae\x3f\x20\xfd\x3e\x94\x33\xfa\xf7\x9c\x64\x4b\x44\x53\xc2\x94\x3e\xd7\xb2\x3c\xda\x1f\x38\xbc\x1f\x67\xe8\x18\x69\x3a\x13\xa1\x80\xde\x9c\x29\xf2\x55\x49\x74\x8c\x32\x7a\x4f\xd0\x77\xe7\x54\x2a\xd4\xbb\x1a\x7c\xd7\x41\xdf\x9d\x17\x82\x43\x7e\xf7\x0c\x14\xf6\x7f\xff\x77\x70\xf4\x14\x9e\x96\x0f\xdd\x51\x4f\x9f\xe6\x1b\x73\x4d\x14\x23\xfc\xf7\xef\xc2\x71\xec\x7e\xb5\xcb\xde\x42\xf0\x5a\xa9\xbb\x89\xac\xfd\x48\x54\x32\x5b\x21\x68\xe5\x8e\x92\x56\x6f\x47\x59\xd4\xca\xb7\x25\x6b\xf5\x12\x9e\x5a\xde\xee\x22\x6c\xb1\x82\x53\x80\x29\x33\x87\xc6\x9f\xa1\x78\x67\xd0\xcb\x89\x95\x5d\xe4\x6d\xb0\x9a\x40\xe4\x3a\x49\x1a\x50\xe2\x95\xac\x35\xa3\x73\xba\x6a\x1f\x07\x2c\xd5\x6a\x97\x15\x72\x2c\x9f\x8f\x89\xd0\x4b\x77\xe2\x0e\x56\x38\xd6\xe2\x4f\xe5\x82\x91\xb4\x61\x69\x7f\xcf\x89\x58\xb6\xac\x6d\x82\x33\xd9\xb4\x38\xca\x14\xd1\x7a\x6d\xe9\xeb\x09\x17\x73\xac\xec\x0f\xfe\xed\x5f\x36\x5d\xbc\xe2\xf7\x64\xd5\x3e\x0f\xcc\xae\x25\x58\xc2\x76\xcf\xf3\x4c\xd1\x45\x46\xd0\x02\x4f\x89\xb4\x54\xc8\x33\x25\x3b\xf0\x33\xad\x4b\x13\x71\xec\x6f\x1b\x78\x83\xbb\x65\x73\x09\x9f\xa0\x89\x17\x64\x8c\x7c\x55\x30\xd2\x90\xc1\x3d\x0b\x24\x0a\x6f\x8f\x27\x20\xe5\x76\x7c\x22\xb9\x50\xa3\xf1\xb2\x7b\x4f\x2a\xef\x6d\xe4\x16\xcc\x10\x56\x4a\xd0\x71\xae\x88\x5e\xb7\x1e\xc3\xdd\x93\x20\xfa\xcc\x65\x2c\xf5\xe5\x7b\x79\x76\xf9\xee\x1e\x2b\xc1\xa7\x98\xbd\x3f\x41\xbd\x34\x45\x66\xa2\xfa\x37\x34\x35\x57\xf2\x8c\x08\xd2\x45\xb7\x33\x2a\x91\x9c\xf1\x3c\x4b\x11\x23\x0f\x44\x68\xda\x92\xf9\x42\x2d\x5f\x1d\xb5\x52\x2a\x48\x02\x84\xd9\xe4\x84\xf9\xa7\x34\xd1\xb4\xd1\xb3\x34\xa4\xbb\x27\x4b\x50\x5c\xaa\xe4\x7b\x06\x7e\x29\x7d\x4b\x58\x3e\x2f\xdd\x15\xf0\xf9\x59\xff\xe6\xb4\x7f\x71\x36\xb8\xf8\x54\x7a\x42\xab\x11\xfe\xab\xe8\x9b\xff\xae\xd0\x66\x82\xf3\x0c\x4e\x75\x30\xda\xb3\x29\x2e\xc9\x8c\x66\xa9\x20\xec\x83\xc2\xf2\x7e\x44\xbe\x92\x24\x37\xf7\xec\xff\xc4\x1f\x8c\xb4\xf6\xc9\x53\x12\x7f\x12\xfd\xa3\x50\x77\x36\x7e\xd4\x5b\xa5\x1b\x3f\x09\x36\xec\x7a\xcf\xc1\x27\x34\xad\xfd\x35\x7c\xb2\x62\x0d\xee\x37\x2d\x93\x75\x3f\x69\x9c\x95\xfb\x81\x55\xe0\x6a\x7f\x23\x88\x12\xcb\x11\x56\x4a\x9f\xf2\x2d\x74\x46\xd8\x52\xa4\x57\x8b\x8a\xfd\xb4\xea\xa3\x51\x14\x41\x76\x7b\xcd\x51\xcf\xa0\xf8\xe5\x2a\x7d\xf1\x82\xa7\xa4\xef\x87\xfd\xc8\xc5\x2d\x96\xf7\x6f\x41\x67\x8c\x26\xfe\x1c\x6a\xe3\xb6\x07\xe8\x9b\x33\xea\xb7\x14\x07\x07\x17\xc0\xee\x94\x5c\xd7\x61\xc0\x05\x92\x4b\xa9\xc8\x7c\xa5\xeb\xe0\xed\x10\xc2\xca\xfb\xd7\x3a\xe1\xd2\x95\xf3\x1b\x38\xf5\xf1\x05\x7a\x38\xde\x1b\x90\x6c\x5f\x8e\xbf\xd7\xbe\x4e\x17\x82\x69\x5f\xea\x8d\xdb\x3e\x17\x70\xb0\x7c\xf2\xea\x97\x19\xa9\x76\xfb\x9e\xe4\x13\x79\x0d\x1a\xf7\xca\x51\x7b\x04\x13\x58\x61\xf2\xc5\xae\x63\x7f\xfe\xf4\xa3\xa1\x73\xc5\x78\xcc\x94\xb6\x79\xad\x6f\x89\x08\x94\x70\x61\x54\xc1\xb4\x45\xbc\x3d\x9f\xd1\x77\x77\x71\x73\xd5\x3f\x1d\x7c\x1c\xf4\xcf\xaa\x56\xdf\x6d\xef\xe6\xa7\xea\xa7\x5f\x2e\xaf\x7f\xfa\x78\x7e\xf9\xa5\xfa\xcd\x79\xef\xee\xe2\xf4\xc7\xd1\xd5\x79\xef\x62\x6d\x3b\x31\x9c\xc0\x86\xbb\x79\x70\x80\xed\xd3\x01\xd6\xf9\x76\x3d\x60\x36\x7a\xb0\xbe\xf7\x0b\x65\x54\x2a\x4d\x20\xfb\x24\x5a\x60\x29\xcd\xfd\x6b\x66\xd0\x1d\xb2\xcf\x5c\x10\x44\xd9\x84\x23\x0e\xc1\x21\xa9\x44\x9e\x28\xca\xa6\xfe\xa1\x13\x34\xcc\xbf\xff\xfe\x9f\x93\x73\xca\xee\xe1\x2f\xf2\x1a\x89\x73\x70\x0f\x6e\x43\xad\x83\x7b\x30\xfc\xee\x6d\xb8\x07\x53\xac\xf0\x87\xd0\x2b\xf8\x34\xf9\x24\x26\x72\x89\x59\x8a\x78\xae\xf4\x9f\xfa\xbd\x68\x22\xf8\x5c\x9f\x1b\xf2\x95\x4a\x90\x12\x8f\x5c\xdc\x4f\x32\xfe\xb8\x9e\xb7\xea\x13\x51\xde\xdf\x73\x86\x15\x7e\x0b\x4e\xaa\x2f\x76\x85\x7e\xe2\x9f\x88\xd2\x73\xbf\xb6\x6f\x39\xa4\x96\x1c\x52\x4b\x5e\x36\xb5\xe4\x55\x79\x8a\x9e\x5e\xf6\xc5\x6e\x25\x23\x00\x1b\xa2\x1e\x8d\x41\x8d\x86\x98\x45\x10\x92\x78\x4a\xa1\x19\x07\x02\x56\x08\xcc\xc8\x49\xfe\x56\x84\x66\x34\xe9\xe7\x17\x98\xbf\x09\x1f\xfe\xc1\x45\xbf\x25\xa1\xde\xa4\x5c\x5d\xf3\xca\x78\x36\x07\xfb\xd3\xcb\xf9\x4a\xf8\x7b\x93\x78\xf7\x06\x01\xee\xb5\x23\xda\x2b\x42\xd8\xb5\x31\xeb\xba\x20\x75\x35\x2a\x5d\x1b\x86\xde\x29\xee\xbc\xe9\x95\xb4\x7e\xc4\xf9\x13\x51\xb7\x58\xde\xbf\xb9\x2b\x29\x9a\xf4\xf3\x5f\x49\xbf\xd1\x40\xf3\x21\xb2\xfc\x84\xa4\xfb\xd6\x2f\xb2\xd7\x1b\x3b\xfe\x0d\x04\x8b\x0f\xd1\xe1\x8d\x68\xf4\x6d\x85\x83\xbf\xd5\xf8\xef\xdb\x0c\xf8\x1e\x22\xbc\xaf\x37\xc2\xfb\xa4\x76\x10\x79\x20\x4c\x49\xf0\x78\x85\xea\xf4\xd1\x82\xcb\x76\xf5\xff\x54\x10\xac\x08\xc2\x25\x57\x13\x82\x01\x91\x20\x09\x17\xa9\x56\xfb\x31\x5a\xcc\xb0\x24\x48\x09\xcc\x24\x5d\xa5\xfa\x9b\x51\xc1\xb7\xa3\xc7\x79\x0b\x5a\x7f\xe4\x88\x82\x59\x3f\x97\xce\x3f\xe6\x69\xe5\x68\x98\x53\x53\xf7\x4d\xbb\x78\xd9\xdb\xd2\xa1\x0e\x6d\x9d\x95\x3f\x21\x37\x6b\x51\xb6\x25\x37\xc7\x56\xea\x5e\xb8\x19\xcc\xc2\xb7\xc2\xcd\x91\x0d\xfb\xdb\xe2\xe6\xba\xa5\xbf\x06\x6e\x76\x01\xd0\x2d\x39\xba\x1a\x3f\xdd\x0b\x57\xfb\xa0\xe5\x5b\xe1\xec\x4a\x94\xf5\xb7\xc5\xdd\x4d\xcb\x7f\x59\x0e\xf7\xbe\xd7\x7d\xf1\xf6\x6a\xc6\xf5\x04\x78\x0b\x4c\xeb\x27\x6b\xe6\xfe\x9b\xe1\xd6\xca\xba\x5f\x09\x9b\x7e\x10\xc4\xd4\x54\x6d\xc4\xaf\xd7\xf6\xa1\x8d\x39\xd6\x3d\x78\xe0\xd9\xb7\xc4\xb3\x6e\xd7\x5e\x0f\xd7\x36\x65\x70\x6d\x5e\x67\xd8\x92\x96\x25\xd1\x1c\xab\x64\xa6\xbf\x34\x21\xa1\x35\xc1\x28\x8a\xc2\xc2\x37\xc5\xdd\xcf\x51\x4d\xf8\x6d\x3b\x7f\x0f\x4e\xdf\xdf\x20\xe8\xcf\xab\xc9\x50\x3e\x54\x45\xec\xb1\x2a\x82\xca\x43\x55\xc4\xa1\x2a\x62\x5d\x02\x1d\xaa\x22\x0e\x55\x11\xc1\x77\x6f\xa3\x2a\xe2\xe9\x0b\x22\xf6\x53\xf5\xf0\xa6\x94\xe8\x83\x02\x7d\x50\xa0\x0f\xa5\x0d\x7e\x69\xfb\x12\x60\xee\xe9\xa3\x94\x64\x44\x91\x56\xf1\x73\x4b\xc4\x5c\xdb\x06\x11\xc0\x6f\x4d\xd0\xa0\xc0\x0e\xf2\x1c\x04\xee\x8d\x36\xb9\xe4\xc7\x7e\x9b\xd2\xc9\x4f\xff\x50\x89\x75\x10\x57\x07\x71\xb5\xcd\xd2\x5e\x8f\x57\x36\x38\xcc\x2f\xea\x96\x0d\xe0\x82\x47\x34\xdd\x0f\x62\xb0\x57\x1b\x43\xbc\xe0\x82\x14\x11\x64\xeb\x76\x4e\xda\x02\x7c\x77\x90\xbe\x09\x3f\xad\x96\x23\x69\x9f\x29\xaa\x96\x3e\x4b\x4d\x1c\x80\x83\x0f\xc0\xc1\xeb\xaf\xf5\xe0\x21\xdc\xa3\x87\xf0\x00\x1c\x7c\xf0\x81\x1d\x7c\x60\x4f\xef\x03\x7b\x29\x87\xf6\x33\x1f\xcb\xe7\x52\xd1\xb6\x4b\x4c\x62\x29\x12\x64\x4a\xa5\x22\x42\x53\xaf\x56\x29\x5b\x9d\xa9\xf4\x56\x5b\xe1\xac\x9d\xf7\x11\xbe\xf6\xe8\x5f\xd6\x98\xfe\xb5\xbd\x45\xe1\xa8\x8f\x71\xea\xfb\x5e\x80\xea\x34\xc7\x4b\x34\xc3\x0f\x04\x4d\x30\xcd\x8c\x61\x64\xa5\x63\xcb\x0a\xdb\x26\xf4\x7f\x36\x9b\x10\x8e\xa7\x23\xc8\x84\x08\xc2\x12\x23\xed\x8d\xf2\x93\xe0\x0c\x11\x50\x4a\xcd\x6f\x66\xda\x4c\xcd\x04\xc1\xe9\x12\x8d\x09\x61\x9e\x6d\x6a\x34\x85\x86\x39\xef\x45\x69\x7d\x71\x33\xad\xca\x3d\xaf\xc5\x48\x7b\x92\xec\x99\x7a\x91\xb0\xbb\x71\x26\xff\xf4\xb6\x44\xc5\x21\x89\xe6\xe0\x54\x7b\x79\xa7\xda\x21\x89\xe6\x60\x22\xbf\x02\x13\xf9\x90\x44\x73\x48\xa2\x39\x38\x10\xd6\xa6\xd6\xc1\x81\x10\x7e\xf7\x36\x92\x68\x9e\xb0\x4f\xed\x73\x69\xd8\x07\x05\xdb\xfd\xee\xa0\x60\x1f\x14\xec\x6f\x54\xc1\x7e\x1d\x14\x3e\x68\xd7\x07\xed\xfa\xa0\x5d\x1f\xb4\xeb\x83\x76\x7d\xd0\xae\xed\x53\xfb\xd4\xae\xe1\x2f\x87\x06\xba\x73\xc6\xfa\xe6\x51\xae\x4f\x44\xbd\xd5\x10\xd7\x41\xa5\x3e\xa8\xd4\xaf\x5b\xa5\x7e\x35\x0b\xfa\xf6\xd0\xfd\x0e\xf8\x78\x95\xfb\xf1\x5b\xc0\xc7\x73\x4f\x1f\x2d\xf2\xf6\xeb\xef\x6e\x91\xba\x72\x09\xa9\xb0\xca\xc1\xd2\x58\xe3\x2a\x44\x3d\x85\xe6\x5c\xeb\xdd\x8c\x44\xbf\x71\x3c\x6f\x92\x08\xa6\xf4\x81\x30\xe4\xd2\x82\x3b\x56\xb2\x75\xc0\xf8\xfd\xd5\x09\x38\x5b\xa7\x81\x15\xc2\x48\xd1\x39\xe9\xa2\xc1\xc4\x30\x50\x82\xb3\x0c\x49\xa2\x64\x29\xf3\x44\x2b\x64\xf6\x21\x96\x16\x73\x75\xef\xa6\x45\x22\x82\xf9\x59\xc7\x9d\xbf\x3c\x53\xe6\x34\xba\xc1\x1f\x69\x96\xe9\x39\x58\xa6\x05\xe1\x33\x27\x22\x73\x4f\x46\xaf\x75\x3f\x9e\xe3\x54\x5b\x13\xc1\x14\x8a\x82\x92\xf0\xf7\x20\xe6\xa9\xf4\xa9\x14\xd1\xf3\xe6\xe9\x2e\xb2\x76\x9f\xc1\xb1\x5a\x6b\x1a\x33\x9c\x6a\xb1\x9f\xcc\x48\x9a\x67\x04\x61\x29\x79\x42\xb1\x22\x29\xa2\xe6\x5a\x40\x54\x39\x2b\xd1\xfd\xc8\xbd\x3a\xa5\x12\x8f\x33\x92\x5a\x1a\x93\x22\xb3\xa3\x75\xe6\x54\xa2\x31\xd1\x24\xd6\x37\x4f\x4c\xfd\x99\xb9\x94\x6a\x66\x13\x4c\x85\x54\x67\x42\x98\x99\x48\x8b\x52\x65\x98\xf3\xad\xea\x55\x66\xf6\x87\x72\x9b\x83\x96\x75\xd0\xb2\x36\x5a\xd0\x37\xa5\x65\xbd\xa2\x6c\x34\x27\x90\x5e\x34\x1b\x0d\x62\x56\x5a\xf2\x8f\xbc\x53\x4a\x6e\x67\xaf\x7b\xbf\xdf\x67\x37\x64\xcf\x8f\x78\xca\xd9\x84\x4e\x73\x61\x1d\xf0\x63\x7d\x62\x57\x06\xc6\x6a\xc6\x79\x13\x37\x4e\xfd\xd4\x9f\xeb\xe2\xd9\xc4\x86\x40\xc7\x48\x6b\xd7\xa3\xeb\xfe\xcd\xe5\xdd\xf5\x69\xff\x04\xf5\x16\x8b\x8c\x1a\xc7\x7e\x92\x4b\xc5\xe7\xf4\x1f\x7a\x19\x06\xbb\xd6\x4b\x6e\xab\x86\x48\x50\x38\x20\x92\x20\xbb\x43\x86\x8e\xd1\xe9\xf9\xdd\xcd\x6d\xff\xba\x61\x40\xcb\x04\xd0\xb1\x85\xcc\x17\x19\x68\x25\xf7\xf9\x98\x08\x46\x14\x91\x28\xc9\x72\x48\x6b\xf6\xf1\x05\x33\x68\xff\xbf\xfa\xa7\x77\xb7\x83\xcb\x8b\xd1\x5f\xee\xfa\x77\xfd\x13\xe4\xb8\x49\x0f\xab\xe7\xa5\x67\x91\x2e\x19\x9e\x6b\xf3\x27\x06\xd9\xfd\x7b\x4e\x72\x50\x82\xe8\x94\xcd\x09\x53\xe5\x11\xdd\x84\xcf\x7b\x3f\xf4\xcf\xe3\x91\x67\x04\xfd\xf4\xe7\x62\x52\x19\x1e\x93\xcc\x06\x3c\xc0\x9f\xaf\x05\x76\xf1\x22\x1b\x09\xc9\x19\xbc\xe0\x2f\x77\xbd\xf3\xc1\xed\x2f\xa3\xcb\x8f\xa3\x9b\xfe\xf5\xcf\x83\xd3\xfe\xc8\x1a\x18\xa7\x3d\xfd\xde\xe8\x4d\xd6\x0e\x41\x7f\xcf\x71\x46\xd5\x52\x1f\x21\x69\x0e\x31\x7a\x9c\x11\x86\x72\x06\x3c\x66\xaa\xa3\xc1\x16\x08\xeb\xa6\x5f\xdc\x78\x8b\x38\xa8\x6a\x8e\x95\x59\xa2\xfa\x8b\xd2\xfe\xb6\xfd\x20\xda\xae\xea\x0f\x57\x91\x7d\x6d\x7b\x30\x5e\xd3\xb3\x09\x63\x7d\x86\xd3\x11\x24\x71\x53\x22\x3f\xfc\x4f\x74\x96\x7f\x7d\x32\x6c\x10\x14\x14\x34\x5a\xe1\xbc\xaa\xad\x5f\xf1\xc0\x5b\x10\xc9\xe1\x74\x5f\x52\xfc\xee\x49\xe5\x79\x5d\x5e\x95\xcd\x15\xca\x83\x61\x74\x30\x8c\xea\x29\x73\xc8\xe8\x68\xa0\xf0\xbe\xae\x9d\x6d\x1c\x91\x13\x4a\xb2\x54\x56\x3c\x49\xd1\xb5\xb1\xd2\x6b\xf4\x76\x6f\x8c\xe7\xf5\x1b\x6d\xa2\xbe\x5f\x7b\x17\xbf\xf5\xf9\xeb\xdd\x9a\x13\x85\xa1\x4b\xa2\xe2\x28\x87\xa9\x1f\x6e\xa1\x2a\x99\x0f\xb7\xd0\xe1\x16\x6a\xa4\xcc\xe1\x16\x7a\xc3\xfe\xb5\x1a\xc9\xfd\xa2\x0e\xb6\x55\x36\xdd\x4e\x10\x3d\x35\xde\xb7\xaa\x2d\x27\x91\x9c\x61\x61\x9a\xb1\x24\x7c\x3e\xe7\x2c\x08\x0e\x2f\x17\xa4\x83\x7c\x3c\x10\x3c\x29\x30\x8d\x55\xce\xb9\xe2\x35\xf4\x6d\xb8\xe5\x02\xba\x3c\x47\xe2\xfa\xc1\x0e\x5c\x41\xa0\x03\x96\xd1\x01\xcb\xe8\x90\x4a\x7e\xc0\x32\x6a\xe7\x96\x43\xb2\xf4\x21\x59\x3a\xfc\xee\x80\x65\xf4\x8a\xb0\x8c\xe2\x36\xe7\x26\x2d\x3c\xea\x7a\x1e\x05\x2b\x6a\xfa\xe6\xd7\x7c\x51\x64\x8f\xdb\x96\xe9\xbb\x67\x8f\xc7\x5d\x64\x57\x45\x36\xc2\xbe\xa3\xaf\x5c\xaf\x9d\x64\x4b\x45\x68\x9a\x55\x1b\xa6\x3e\x43\x76\x53\xdd\x46\x7f\x8b\xbe\x94\x1a\xb6\x3d\x38\x56\x56\x12\xea\x5b\xc5\x1c\x2e\xe4\xd2\x1b\x72\xfa\xaf\x27\xbc\x1d\x2e\xfb\xa8\x41\x84\xd7\x7f\xef\x05\x79\xfd\xd7\xbb\x96\xda\xc7\xb2\x7b\xdb\x12\xfb\x48\x36\xbe\x0d\x6f\x45\x38\xe3\xe7\xf0\x57\xb4\xee\xfe\x37\x27\xd7\xdb\x78\xf9\x20\xdd\xd7\x24\xd7\xb7\x2a\xe3\x0f\xfe\x8c\x7d\xfa\x33\x3a\xdf\xae\x43\xe3\x50\x1a\xdf\x42\x9c\x83\xb7\x67\x1b\x6a\x1d\xbc\x3d\xe1\x77\x6f\xa3\x34\xde\xde\xd5\x23\x73\xd5\x07\x79\xf4\x1f\xfe\xa7\xf8\x3b\x50\xa4\x83\x0f\x6b\x42\x7e\x1b\x24\xe6\xb8\x0c\x6d\x92\x16\xea\x47\x31\x78\x4d\xc2\x8e\x9d\xc3\xb1\x53\x4a\x8a\xe0\xf5\xca\xfc\x9d\x2b\xf3\xe8\x19\x3c\xf9\xb6\x12\xf2\x1b\xa6\xfe\xbc\x79\x3d\x55\x4e\x58\xa5\x3a\x41\xca\x80\xd7\xa7\xa9\x49\x38\x7f\x9c\x51\xb8\x26\x01\x71\x06\xae\x92\x60\xc3\x5d\x29\x1f\x86\x9c\xfb\x26\x9d\xe3\xb9\xd5\xa9\x0a\xbb\xaf\xb7\x70\xcb\xa3\x6f\x77\xdd\x2f\x9e\x09\xb1\x82\xef\x5f\x34\x2b\xa2\x45\x66\xee\x27\x21\xe2\xf9\xe4\xe3\x27\xa2\xbe\x3d\xe1\xf8\x89\xa8\xe7\x92\x8c\xdb\x8a\xc3\x56\x91\x50\x00\xe4\xbf\x12\x69\xb0\x9d\xe8\x7b\x5b\x6b\x3c\x94\x9e\x1d\x4a\xcf\x0e\xa5\x67\xaf\xbe\xf4\xcc\x3d\xbd\x4e\x07\xd7\x33\xf8\xc9\x33\xde\xa6\xe6\x85\xdf\xde\x85\x6a\xd6\x75\xb8\x53\x0f\x77\xea\x66\x6b\x7c\xad\x56\x84\xe3\xe7\xd7\x60\x45\x6c\x04\x58\x60\x02\x8c\x45\x2f\x24\xc7\xfe\x2b\x83\x88\x57\xee\x65\x6f\x47\x08\xc9\x4d\xe5\xcc\x4e\x15\x65\xab\x3a\x98\x5d\x17\x6d\xcb\x6a\xc2\x5b\x65\x92\xbb\x5f\x5f\x55\x44\xd9\x6b\xa7\xba\x9b\xf9\x73\x09\xfb\xd7\x22\x22\x8a\x75\xbf\xa8\x50\xd0\x6a\x78\x39\x2b\x2d\x4e\x76\x18\xb5\xe6\xa9\xad\xf8\x6d\x54\x73\xdf\xfe\xd3\x52\x2e\x5b\xfc\x9d\xcd\x6e\x83\xaf\x61\xca\xe5\x79\xb8\x0f\xc3\x17\xba\xcf\x8a\x91\xdd\x27\x0e\x6b\x15\x3e\x14\x44\x89\xe5\x08\x2b\x6d\xea\xa8\xdd\x13\xe8\x62\xc3\x66\x45\x02\xdd\x2d\x96\xf7\x6f\x32\x81\x2e\x9e\xf8\x13\x9f\xd9\xb5\x79\xf2\x9b\x4b\xbd\x58\xf7\x84\x1d\xd2\x30\xb6\x20\xdd\xb7\x9a\x92\xd1\x26\x42\x5f\xcd\x0c\x4b\x52\xfc\x5b\x3c\xb9\xf1\x9d\x74\x38\xa2\x6d\x34\xfa\xe6\x70\x00\x4b\xaa\xc6\x8a\xb5\xbd\x11\x3c\xc0\xb2\xb6\xb4\xef\x59\x3d\x4d\x96\x56\xb0\x1b\x07\xcc\xe8\x6f\x14\x33\x7a\x3d\xe3\x66\x6d\xcb\x66\x5d\xb3\x66\x3d\x9b\xa6\xd9\xa0\xd9\x21\xd9\x3b\xb6\x33\xb6\x4d\xf6\x8e\xf4\xf8\x37\xe1\xad\x89\x66\xfc\x1c\xc9\xde\xbf\x51\xd3\xe3\x60\x77\x3c\x09\xdd\xbe\x55\xa3\xe3\x95\x5b\x1c\x87\x34\xf5\x7d\xa6\xa9\x1f\xb2\xd4\x0f\x59\xea\xeb\x12\xe8\x90\xa5\x7e\xc8\x52\x0f\xbe\x7b\x1b\x59\xea\xd6\x5e\xdc\x35\xc1\xb2\x4e\x65\x2f\x14\xda\x08\xbb\x66\x7b\xf5\x7d\x90\xbe\x09\xbd\x3d\x80\x94\xf2\x96\xb5\x78\x0e\xfd\xfd\x80\x9d\x74\xc0\x4e\x3a\x28\x71\xbf\x25\x25\xee\xa0\xa7\x6c\x43\xad\x83\x9e\x12\x7e\x77\xc0\x4e\x7a\x45\xd8\x49\x5a\x71\x8a\xf2\xd6\x56\xa6\x4f\x9d\x0a\x82\x95\xe9\xf1\x26\x8a\x4c\xaa\x92\x02\xd6\xa6\x5d\x99\x01\xb4\x7e\xf5\x16\x94\x2b\x3d\x4f\x33\xe3\x35\xf2\xa8\xc2\x17\x1e\xfd\xcb\x1a\x13\xbf\xb6\x77\x25\x1c\xe8\x31\x4e\x7d\x67\x3d\x50\x90\xe6\x78\x89\x66\xf8\x81\xa0\x09\xa6\x99\x71\x53\x59\x19\xd8\xb2\xb6\xb6\x09\xfd\x9f\xcd\x26\x84\xe3\xe9\x14\x49\xa9\x5a\xa6\x1b\x15\x27\xc1\x19\x22\x06\xe5\x15\x7e\x03\x6d\xff\x6c\x93\xc5\x31\x21\x2c\xc8\x70\x5c\x77\xce\x7b\x51\x4d\x5f\x3c\x19\x2d\xe4\x9b\x17\xcf\x43\x6b\x6e\x95\xbd\x3f\x9b\x6b\x17\x43\x4b\xfe\xe9\xad\x88\x82\xe7\x30\xab\xbe\xe1\xd0\xc7\x21\xbc\xf1\xdb\x04\x85\x7f\x35\x2a\xf9\xc1\xd0\xdd\xa3\xa1\x0b\xa5\x2b\xdf\xa8\xa5\x7b\x08\x57\xb4\x10\xe7\xe0\x06\xd8\x86\x5a\x07\x37\x40\xf8\xdd\xdb\x09\x57\x34\x6b\xcf\xdb\x75\x3c\x7c\x42\x3d\xfa\xa0\x46\x1f\xd4\xe8\x83\x1a\xfd\xcd\xaa\xd1\xaf\x83\xc2\x07\x1d\xfa\xa0\x43\x1f\x74\xe8\x83\x0e\x7d\xd0\xa1\x0f\x3a\xb4\x7d\x6a\x2f\x3a\x34\xfc\xe5\x0a\x88\xf7\x53\x2d\xbc\x5e\x44\xca\x96\x0b\xbf\x15\xe5\xf9\xa0\x38\x1f\x14\xe7\xd7\xad\x38\xbf\x9a\x05\x7d\x7b\x35\x82\x87\x2a\xbb\xca\x2d\xf8\xcd\x56\xd9\xf9\x7e\x07\x5b\x60\x39\x47\x9f\xb9\x81\x9e\x1b\xe1\xb9\xe3\x24\x23\x66\x29\x72\x93\xd8\x08\xef\xf9\x8b\x7d\xe8\x6d\x81\xaf\x55\x67\x7d\x40\x79\x46\xc1\xae\x1d\x50\x9e\x9f\x70\xdd\xee\x9c\xad\x58\xb9\xe3\x51\xe3\xbd\x7a\xa3\xcb\x7e\xf1\x34\x9f\xe6\x93\xfe\xa2\x49\x3f\xb5\x37\x47\xa5\xe0\xa2\xe8\x96\xf5\xfc\xe0\xd6\xbb\x5c\x0d\x9f\x88\xfa\x56\xee\x85\x03\xc0\xf5\x01\x8c\x73\xeb\x3e\x58\x1b\x49\xf8\xb7\xb5\xc4\x03\x86\xf7\x01\xc3\xfb\x80\xe1\x7d\xc0\xf0\xde\x9f\xd2\x60\x5e\xff\xad\xe8\x0d\x07\x1c\xef\x83\xea\x70\x50\x1d\x6a\x97\xf8\x0a\x6d\xc2\x57\x81\x52\xee\x6d\xc2\x7d\x55\xdf\x87\xd1\x36\x2f\x8c\xf7\x5a\x84\xef\x28\x79\x28\xc4\xb7\xff\x77\x28\xc4\x5f\x67\x71\x87\x42\xfc\x43\x6e\xd5\xa1\x10\xff\x90\x3d\x74\xc8\x1e\x3a\x14\xe2\xbf\x95\x42\x7c\xa7\x40\xed\xa3\x18\xbf\x46\x19\x5b\x5d\x90\xff\xa5\x6a\x19\xbc\x5a\x45\xcb\xcd\xf5\x50\x98\x7f\x28\xcc\xdf\x95\x77\x5e\x85\x4d\xf6\x24\x05\xfa\x35\x62\x60\x57\x43\xec\x6d\x14\xea\xbb\xd9\x1e\xaa\x8c\x0e\xc9\x92\xaf\x3f\x59\xf2\xd5\x55\x19\xbd\x1a\xb5\xfd\x60\x0c\xef\xd1\x18\x3e\x14\x1a\x1d\x0a\x8d\x0e\xae\x82\xb5\xa9\x75\x70\x15\x84\xdf\xbd\x8d\x42\xa3\xd5\xda\xf4\x5e\x0a\xf6\x9f\x42\xaf\x3e\xa8\xd5\xe6\x77\x07\xb5\xfa\xa0\x56\x7f\xa3\x6a\xf5\xeb\xa0\xf0\x41\xa7\x3e\xe8\xd4\x07\x9d\xfa\xa0\x53\x1f\x74\xea\x83\x4e\x6d\x9f\xda\x9b\x4e\xbd\xdf\x02\xfe\x0d\xa3\x58\x41\x51\xc8\x5b\x52\xa6\x0f\x8a\xf4\x41\x91\x7e\xdd\x8a\xf4\xab\x59\xd0\xa1\x98\xff\x50\xcc\x5f\xf9\xe6\xf5\x16\xf3\xff\xce\x32\xc2\x51\x20\xfb\xfd\x25\x71\xf4\x43\xc6\xc7\xb7\xcb\x05\xd1\xff\x3d\xa3\x73\xc2\x24\x68\x2c\x54\x2d\xc3\x8b\xb3\x81\xc0\x55\xd2\x1e\xdd\x0c\x2e\x3e\x9d\x87\x55\x27\x47\x9f\xef\xce\x6f\x07\x57\xbd\xeb\x5b\x37\x43\xbf\xaa\x90\x16\xf6\xb9\xe8\xee\x3f\xe5\xf3\x05\x16\x54\x72\xd6\xff\xba\x10\x44\xea\xa9\x5d\xc2\x6d\xcb\xc5\x76\xb3\xeb\xff\x25\x9c\xd9\x45\xfc\xcf\x4f\xb7\xf1\xbf\xa2\x55\x9c\xdf\xc6\xff\xea\xb7\xae\x26\x18\xb8\x7c\x82\x8e\xd1\xa7\xdb\x13\xf4\x09\xa2\xfe\x02\xdd\xce\xb0\xa9\x71\x3a\xbf\x3d\x41\xe7\x44\x4a\xf8\xa4\x78\x58\x51\x95\xc1\xda\x7e\xa0\x0c\x8b\x25\x72\xcb\x37\xf5\x52\x18\xdc\x81\x8e\x34\x65\xe2\xb1\xbf\xe5\x0c\x14\xd6\x82\x7a\xe7\x7c\x4a\x13\x9c\xed\x46\xc4\xde\x45\x78\x5e\x8e\x2e\xaf\x5b\x49\x11\xfe\xba\x4a\x8b\xde\xc5\x19\x54\x6f\xb9\xa9\xd6\xac\xfc\x82\x48\x45\x52\x7d\x01\xa6\x86\x79\xb5\xad\x41\x96\xc1\xc5\xf8\x37\x0e\xf5\x5c\xb9\xd4\xea\x5a\xef\xe2\x0c\x7d\x40\x97\xd7\x43\x76\x29\x52\xe3\x2f\x20\xfa\x46\x31\xb6\x0a\x95\x88\x71\x85\xe8\x7c\xc1\x85\xc2\x4c\xe9\xcb\x54\x0b\x32\x6e\x29\x22\x11\x16\x04\x9d\xf2\xf9\x3c\x57\x58\xd1\x07\x52\x21\x2a\x33\x46\xc0\x0d\x51\x83\x14\x3c\x90\x35\x34\xe4\xe3\x48\xd1\x39\x5a\x08\x3d\xbe\xa2\x25\xed\xef\x88\xa6\x15\x75\xd0\x0d\x81\x85\xc0\xb1\x18\x3c\xa2\x8a\xcc\xcb\xbf\x5f\x33\x53\xec\xd7\x5a\xdd\xfa\x0c\x2b\x7c\xce\x71\x4a\xd9\xd4\x14\xd0\x9d\x53\x45\x04\xce\x3e\xe3\xc5\x47\xe7\xe0\xd8\x82\x3f\xfe\xf3\xe6\xf2\x22\x64\x90\x5f\x7a\x9f\xc3\xea\xb2\xa3\xab\xeb\xcb\xdb\xcb\x56\x9e\x89\x46\xa8\x32\x8d\xfe\xfa\x04\xfe\x17\x7d\x40\x7a\x74\xaf\x2c\xcc\x89\xc2\x29\x56\x18\xbd\x33\xb5\x22\x3e\xa3\x9c\xb2\x0c\x78\x64\x21\xe8\x9c\xea\x7d\xb5\x56\xda\x7b\x60\x26\x24\x88\x3e\x21\x84\x29\xcf\x25\xe6\x01\x53\xf7\x05\x37\x9d\xc2\x2c\xc5\x22\x45\x7f\x93\xb6\x54\x50\xdf\x7b\xe6\xe7\x58\xba\x0f\x48\x8a\x8e\xd1\x4c\xa9\x85\x3c\xf9\xf0\xe1\xf1\xf1\xb1\xab\x7f\xdd\xe5\x62\xfa\x41\xff\x71\x4c\x58\x77\xa6\xe6\x19\x1c\x78\xa0\xc2\x09\xba\x12\x5c\x71\xfd\x42\x8c\x24\x11\x14\x67\x50\x8d\x36\x36\xa7\x9d\x4f\xd0\x5f\x13\x2e\x48\xb7\xd8\x98\xbf\xa2\xa0\x7c\x71\x92\x2d\x15\xa1\x69\xf6\x41\xff\xa8\xe6\xe8\x94\xf7\x13\xa5\x24\xa1\xa9\xbd\xbb\x09\x4b\x78\x0a\x2e\x0f\xf3\x1d\x65\xbe\xc0\x86\xd8\xe8\x81\x27\xa7\xb5\xeb\xc7\x04\xcd\x71\x4a\x10\x7e\xc0\x34\x33\x95\xac\xdc\x78\xa9\x0c\x9d\x89\x90\x5d\x34\x64\x03\xa3\xe9\xe4\x5a\xab\x83\x7c\x2f\xb0\x5d\xdc\x6f\x17\x7a\xc5\x09\xcf\xd0\x38\x9f\x68\xad\x20\xb8\x96\x3a\x88\x2a\x4d\x0b\x41\x12\x3e\x9f\x13\x66\x1c\x59\x7a\x20\x78\x12\x48\x66\xa7\xdb\x1d\x32\x60\x00\xcc\x52\xc3\x02\x29\x87\x93\xcd\x88\xd6\x90\xd9\xd2\xbc\x66\x9c\x4f\xa2\xe8\x88\xe2\x48\x10\x9c\x22\xaa\x86\xac\x97\x69\x5b\x6a\xce\x15\x09\x13\xd7\xc0\x95\x1a\x51\x1c\x24\x82\x20\x8b\x0c\x27\xae\x10\x30\xe3\x09\xce\xd0\x84\x66\xc4\x76\x70\x0e\x06\x78\x07\xea\xbd\x26\x1a\x95\x28\xe5\x8f\x2c\xe3\xd8\xae\xa3\xfc\xd8\xfb\x58\xb8\xf8\x9e\xe7\x7d\x21\xb8\x80\xff\xf9\x89\xb2\x74\xbb\x43\x78\x77\xf1\xd3\xc5\xe5\x97\xe8\x1c\xde\xdd\xf4\xaf\xc3\x7f\xdf\xfc\x72\x73\xdb\xff\xdc\x7a\x10\xcb\xa3\x14\xac\x05\xd3\x03\xb5\xef\x04\xdd\x18\x22\x70\x81\xb4\x22\xdf\xb0\xa8\xcf\x96\x97\x8a\x0f\x78\x4a\xb6\x5b\xdb\xe7\xde\xc5\x5d\x2f\x12\x29\x37\xa7\x3f\xf6\xcf\xee\xce\x23\x45\xce\xad\x2f\xf8\xe4\xba\x6f\xd4\xb4\xf0\xb3\xd3\x1f\x07\xe7\x67\x23\xaf\xd8\xb5\x51\xa3\xf4\xde\xb2\x60\xba\x35\x02\x68\xc6\x53\x34\x5e\x86\xc5\x6a\x45\x89\xf1\x23\x96\x28\x03\x67\x3c\x49\xbb\x43\x73\xf3\x9b\x51\x4f\x40\x0e\xb9\xe2\xe5\xe2\x89\x39\x4f\x49\xc7\xfe\x46\x5f\x5b\xa6\xfc\x5b\x2b\xd7\x51\xed\x72\x38\xb0\x7e\x3b\x66\x88\xb2\x94\x3e\xd0\x34\xc7\x99\x29\xd3\xf6\x34\x3a\x41\x3d\x24\xf5\x0f\x73\x7d\x80\x05\x9d\x4e\xc1\xac\x2c\x4d\xd5\x8c\x66\x1f\x05\x4a\xc2\x73\xbe\x63\x39\x1c\x69\xfd\x5a\xeb\x8f\xa0\x5a\x1c\x68\x39\x6c\x1e\x84\xb2\xf4\x78\x44\x81\xd5\x8c\x88\xba\xa9\xb9\x7d\x39\x31\x5e\xc4\x86\x65\xc1\xd1\x2b\xb2\x4a\x41\x44\x49\x63\x0d\x2f\x04\x79\xa0\x3c\x0f\x1e\xb5\x15\xf4\xd1\xe6\xd6\x0e\x5f\x10\x00\xc8\xc6\x61\x8e\xc5\x30\x31\x37\x0f\x2e\x6f\x94\xc0\x8a\x4c\x97\x67\xf6\x64\x6f\xcf\xc5\x67\x97\x5f\x2e\xce\x2f\x7b\x67\xa3\x7e\xef\x53\x7c\x30\xfd\x37\x37\xb7\xd7\xfd\xde\xe7\xf8\xab\xd1\xc5\xe5\xed\xc8\xfd\xa2\x95\x5d\x1b\x5e\x50\xbd\x4f\xe3\x1f\x9e\x20\x2d\x19\x41\x82\x39\xb0\x9d\x40\x8c\x8d\xc9\x84\x0b\x23\x8e\xe7\x2e\xee\x04\x92\x1f\x79\xca\x92\x14\x68\x5f\x5a\xc5\x09\x3a\x6b\x18\xd2\xf8\x33\x94\x20\x78\x0e\xe2\x1c\x33\xd4\x67\xe9\xf1\xe5\xe4\xf8\xc6\x7c\x38\xc7\xe2\x9e\x08\xff\xe8\xa3\xa0\x4a\x11\x70\xc3\x52\xeb\xa1\x45\xd8\x4d\x59\xdf\x37\x90\x57\x5c\xbc\xa0\x8b\xae\xb5\x78\xd6\xbf\xf7\x77\x8f\x66\xd4\x94\x28\x4c\x33\x69\x27\x1b\xd1\xf5\x04\x9d\x63\x31\x25\xc8\x28\x72\x12\xbd\xe3\x93\x89\x19\xec\xbd\x99\x86\xbe\x6a\xa2\x55\xd4\x88\x48\xcd\x1a\xee\xfa\x82\xf7\xd9\x1f\x7b\x2d\xad\xca\x55\x77\x8b\xdd\x78\xea\xee\x0a\x28\x7e\x79\x31\xea\xff\xd7\x20\xb2\x58\xec\x37\x35\xbc\x06\x0b\x37\x5f\xb7\xdf\x05\xf5\x63\x57\xd9\x29\xfe\x61\x0d\x3b\xe5\x0b\xb7\xf3\x13\x6d\x03\xd5\xf0\x12\xf9\x4a\x95\xd9\x98\x70\xde\x25\x16\x2a\x86\x91\x5a\x6f\xc0\x8b\x05\xc1\x5a\x01\xa9\xee\x76\xac\xae\x35\xec\xbd\x79\x53\xf8\x0e\xbb\xc9\xee\x3d\x1d\xc4\x59\xb6\x0c\xef\xfa\x12\x47\xae\xc1\x03\x66\xac\x0a\x07\xfc\xc5\x80\x55\x5c\x4e\xac\x31\x7f\x4b\xc9\x96\xc6\xd9\xdd\xc5\x59\xff\xe3\xe0\x22\xbe\x09\x7f\x1c\x7c\x8a\xee\xbc\xcf\xfd\xb3\xc1\x5d\x24\x57\x56\x5d\x7d\xd5\x61\x6b\xd0\x4f\xfc\x8f\x4e\xd0\x99\x79\xf4\x04\x31\x5e\x87\xc4\xe1\xd5\xe5\x92\x7c\xbd\x76\x91\x5d\xf7\x47\x9f\x29\x51\xeb\x89\x58\xd7\xc4\xb2\x7e\xae\xc8\xc6\xaa\x77\x87\x57\xde\x7d\x51\x76\x5c\x56\xc3\x05\xd6\xd9\xa5\x5f\xd2\x2d\x2c\xaf\xd0\x4f\x0e\x66\x46\x93\x91\x57\xe3\xaf\x2a\x58\xe7\x67\x70\x83\xce\x73\x09\x4c\x88\x4d\xc4\x0d\xdd\xff\x59\x6a\x82\x42\x45\x45\x17\xdd\x10\x32\x64\xce\xde\x98\x52\x35\xcb\xc7\xdd\x84\xcf\x3f\x14\x30\x30\x1f\xf0\x82\xce\xb1\xbe\x8f\x89\x58\x7e\x18\x67\x7c\xfc\x61\x8e\xa5\x22\xe2\xc3\xe2\x7e\x0a\xc1\x15\xe7\xb2\xfb\xe0\x87\x9d\xf2\x7f\x3a\xff\xe7\xef\x8f\xcf\xff\xfc\xfd\x51\xd5\x82\x6c\xda\xff\x3e\x4b\xf0\x42\xe6\x99\x0d\xc2\x8a\x90\x36\x20\xd6\x81\x12\xab\xf6\xfb\x22\xde\xae\xdd\x14\xde\xd3\xab\xbb\xc8\xa3\x13\xff\xf3\x73\xff\xf3\xe5\xf5\x2f\x91\xc2\x78\x7b\x79\xdd\xfb\xd4\xee\xd9\xa9\x68\xc4\x25\x32\xfc\xc4\xf8\x23\x8b\x57\x2f\xcb\x8b\xce\x99\xa2\x73\xe2\x14\x62\xfb\xcf\x5b\xb3\xd2\x2d\x56\x7e\x79\xfb\x63\x2c\xd3\x3f\x9e\xff\x72\xdb\x1f\xdd\x9c\xfd\xd4\xba\x12\xf3\x58\x34\xb3\x1b\x88\x20\x9d\xf2\x2c\x9f\xb3\xf0\xef\xed\xe7\x36\xb8\xb8\xed\x7f\x2a\xcf\xee\xb2\x77\x1b\x93\xfd\x3a\x0e\x4c\x1e\xfd\x70\x79\x79\xde\xef\x45\x7b\x79\xd6\xbb\xed\xdf\x0e\x3e\x47\x3e\xb9\xb3\xbb\xeb\x08\x88\xa6\x76\x99\x6e\x06\x35\x0b\xd5\xcb\x0a\x97\xb9\x6f\x39\xb3\xd6\x31\xef\xd9\xa4\x1f\x73\x50\x8e\x83\x8a\x70\x13\xcf\x03\x1b\xeb\xd8\x7b\x38\x12\x33\xd3\x5a\x59\xa3\xe2\x6d\x42\xcd\xb2\xae\x75\xa3\xdb\x44\xde\xad\x9f\x02\xcc\xcb\x86\xfd\x71\x96\xf1\x47\x93\x7a\x31\xa7\x8a\xa4\x0e\x9e\x43\xff\x44\xa2\x24\x17\x82\x30\x95\x2d\xbb\x35\xe2\x24\xde\x16\x2e\xd4\x99\x0f\xce\x6f\xa7\x55\xd7\x45\xba\xab\x31\xee\x7a\x85\xb9\x14\xd7\x76\xd3\x82\x4e\x41\x7c\xfa\x99\x48\x89\xa7\x64\x17\xd7\x58\x9d\x90\xba\xf9\x39\xfc\x27\xb8\xbe\xd6\x11\x40\xd1\x0c\x5d\x14\xd7\xc9\x94\x4b\xf6\x11\xd3\x2c\x17\xe4\x8a\x67\x34\xd9\xd2\x95\xff\xb1\x37\x38\x1f\x0d\x3e\x6b\x65\xa1\x77\xdb\x3f\x8f\x44\x25\x7c\xd7\xfb\x78\xdb\xbf\x1e\x19\x3c\xa9\xde\x0f\xe7\xfd\xd1\xc5\xe5\x59\xff\x66\x74\x7a\xf9\xf9\xea\xbc\xbf\xc2\x43\xde\x38\x78\x55\x9f\x2c\xff\xf4\xa4\xf2\x09\xa2\x36\x83\xc7\x46\xa5\x8c\x91\xaa\x38\xd4\x45\x82\x7b\x8e\x1b\x37\x1d\x46\x4c\x2b\x64\xfa\x63\x70\xf5\xe8\x5f\xbb\xf8\x7e\x17\x0d\xd4\x77\x59\x86\x70\xae\xf8\x1c\x83\x8d\x99\x2d\x87\x0c\x8f\xb9\x50\x60\x5f\x78\x3e\x46\x22\x67\x4c\x1b\xb8\x7a\x30\x03\xdb\x96\x64\x04\x33\x94\x2f\x82\xdc\x34\x6b\x29\x4d\x28\xd3\x03\x81\x11\x63\x8c\xe2\xe2\x95\x85\x9d\xa9\xed\xd8\x21\x33\x65\x9c\xc6\x74\x5d\x87\xc2\x27\x6b\xfd\xaa\x91\x3a\x73\x7c\x4f\x34\x55\xe6\x79\x32\xd3\xca\xf2\x54\x68\x9b\xde\x68\xd3\x09\x66\xc6\x35\x6a\x7f\xae\x55\xdd\x21\xd3\x1a\x31\xce\x9c\xd2\x9e\x92\x05\x61\x29\x61\x09\x35\x19\x69\xe0\x55\xf4\xc6\xf5\x54\xe0\xc5\x0c\x49\x0e\xde\x38\x20\x3b\xb8\x2d\xcc\x43\x88\x1b\xe2\xdb\xc2\x55\xf8\x3a\xd4\xb9\x45\xae\x2d\xf8\x4b\x30\xc6\x0d\x95\xe1\x61\xa7\x70\x3b\x43\xd3\x00\xe1\xcd\x17\x19\x81\x57\x5a\x92\xc3\x66\x68\x5a\x47\xfb\xa1\xb7\xa9\x6e\x13\x86\xac\x98\x33\x96\x76\x46\xdd\x1a\x5d\xde\x1e\x29\xf4\x23\x66\x69\xa6\x47\x71\x56\x5b\x7c\x16\x21\xad\xa2\xa7\xb9\xc6\x9d\xc6\x5d\xee\x95\x04\xe7\x72\xa3\x8b\xa5\x3d\x8d\x10\x83\x57\xf6\xb8\x70\x57\x03\x7b\xdb\x1c\x42\xa0\xee\x02\x6b\x1e\xc8\xb8\xa5\x92\xf9\x79\x6e\xd0\x76\x11\xcc\xa6\x41\xd3\x5d\x08\xca\x12\xba\xc0\xd9\x56\xd7\x60\x29\xb0\x6c\x4b\x86\xdf\xd1\x89\x66\x9f\xf7\x15\x27\x93\x22\x62\x0e\xf9\xb4\x76\x9a\x7e\x0b\x57\x5d\x31\x66\x77\x34\x23\xe3\x38\x12\xba\xc5\xde\x98\x10\x42\xd3\x72\x4b\xa3\xd8\xb7\x9b\x18\x16\xce\xae\xea\xc7\xac\x23\x58\xf0\xe5\xaf\x6d\x5b\xfd\x19\x2f\xf4\x16\x1b\x50\x3b\x84\x8b\x35\xda\x34\x59\x0b\x99\xec\xfc\xf0\x81\x63\xce\xa7\x24\xac\xaf\xee\x17\x24\xb4\x91\x94\xea\x4b\x22\x07\x65\x90\xc1\x6c\x59\x72\x92\x2b\x7d\x9a\x30\xb8\x38\xd1\x3b\xd2\x9d\x76\xd1\xe5\xcf\xfd\xeb\xeb\xc1\x59\xbf\x83\x7a\x57\x57\xfd\x8b\xb3\x0e\x22\x2a\x79\xef\x42\x7d\x36\xf2\x31\x64\x8a\x5b\x0b\x72\x89\x66\xfc\x11\x44\x19\x11\x53\x12\xad\xd9\x85\x49\xa0\x2e\x7d\x4a\xa5\x12\x36\x58\xc3\xd2\x10\x68\x92\xce\xcb\x36\x89\xe1\x90\x5c\xcd\x76\x61\x0d\x2c\x65\x3e\xc7\xe3\x8c\x8c\x28\x9e\x8f\x04\xcf\x56\x9d\xe1\xda\x23\x55\x98\x71\x23\x6b\x39\x8f\x70\x92\xf0\x9c\xa9\xb5\x47\x5b\xb5\x8f\x67\x40\x26\x89\x16\xfa\x40\x41\x8c\xb8\x8a\x7b\x18\xdc\x52\x09\xc4\xad\xc1\x57\x0a\x22\x23\x2b\x32\xcb\x2d\x7e\x66\x3d\x2d\xaf\x63\x0a\x1c\xe8\x69\xe8\x59\x47\xae\x53\x03\x91\xea\x2c\xe2\x00\x21\x72\x17\xfa\xd5\x8d\xd2\x36\x12\x7a\x72\x71\x75\x6a\xe4\x54\x1d\xf0\xa6\x89\x9d\x94\xa0\xde\x21\x34\x57\xc2\xb4\x35\xfc\xa8\x0f\xb2\x91\x1f\x7f\xcf\xb9\xc2\xf2\x7d\x77\xc8\xb4\x30\xbc\x27\x4b\x13\xcf\xd7\xe2\xe6\xf7\xfa\x0a\x3c\x96\x84\x49\x88\xff\xfe\xde\x98\xe6\x5a\x60\x3e\x60\x41\x35\x6b\x19\x8d\xd0\x40\xe9\xc6\x98\xa0\x10\xb2\xb3\x83\x5a\x69\x57\x44\x44\x0b\x20\x51\xf7\x9d\x99\xfe\x94\x28\xc8\xd2\x53\x54\x81\xaa\x92\x1a\xac\xde\xca\xd4\x57\x5a\x45\xc0\x15\x67\x26\xc3\x70\xa7\x64\x83\x6d\x8e\xcc\xa6\x76\x6d\xf9\x38\x50\xb9\xc8\xf0\xb2\xe2\x21\x5b\x75\x8c\x2e\xf4\xe6\x2c\x70\x42\x8a\x0c\x47\x97\x0c\x9a\xf0\xf9\x1c\x1c\xb1\xae\xaa\x21\xa5\x13\xf0\xc8\x2a\x7d\xc4\xd0\x98\xa8\x47\xf0\xff\xbb\x4f\xbd\xd3\x51\xab\xc1\x98\x19\x20\x64\xe0\x96\xa1\xa6\x55\x9a\x83\xb5\x39\x3c\xea\xa0\xe1\x51\x4a\x1e\x48\xc6\x17\x73\xc2\x94\xfe\x80\xa8\x5a\x81\xd6\x9f\x63\x9a\x5d\x70\xe5\x5d\xca\xbb\x6c\x8b\x20\x09\x5d\x50\xc2\x94\x1c\x11\x3d\xee\x93\x26\x84\xac\x32\xed\x5d\xe9\x04\xcc\x04\xe1\x34\xd5\x16\x01\x80\x6b\xba\x49\x5a\x47\x84\xc9\xa3\xf1\x04\x58\x8f\x87\x7d\xe8\x77\xbf\x6c\x5c\xef\xe2\x48\xb8\xf0\x58\x42\xfe\xc5\x05\x1c\x62\x2b\xd7\x5a\x70\xd5\x02\xb4\xcf\x59\x37\x55\xc3\xad\x41\x19\xd6\x77\xe1\x7a\xf3\x8c\x29\x73\xa3\x9f\x6b\x9d\x9a\x0c\xab\x7c\x1c\x08\x78\xa1\xda\xd8\xa8\x68\x39\x10\x4b\x56\xce\x38\xc9\xb8\xcc\xc5\x9a\xfe\xa3\x78\xd2\xa7\xf6\xd1\xb6\x79\xf7\x43\x4d\x30\xcf\x94\xdc\x48\xd9\xac\x21\x7c\x91\xb3\x63\xd0\x86\xe0\x70\x2b\x7b\xcb\xda\x5f\x77\x10\x65\x49\x96\x43\x96\x8b\xb6\xe0\x5d\xc8\x98\xa5\xa8\xb8\xda\x86\xcc\xa7\xb9\x60\x89\x1e\x49\x06\x1e\x03\x6d\x55\x82\xd8\xb6\xd3\xb5\x23\x91\x14\x49\x85\x15\xe9\x20\x9e\x2b\x3d\x58\xc7\xe0\xa5\xdb\x2d\x38\x1e\x63\x28\x35\x2a\xba\xa0\x0c\xd9\x9d\x74\x31\x4e\x5f\x21\x62\x78\xdd\x08\x30\xca\xd0\x27\xa2\x60\x14\x28\xd9\x0b\x17\x68\x70\xe1\x6b\x45\x50\x99\xf6\x3b\x9c\x28\xbb\x92\x0d\x76\xbe\x48\x8e\xf9\x21\xe3\xe3\xd6\x7d\xef\xa1\xb9\x31\x4b\xec\x5b\x9c\xd7\xa5\x30\x48\x83\xd2\x86\x55\x3c\x4a\x84\x88\x92\x16\x57\x1c\xff\x38\xa1\xa6\x9d\x3d\x21\x9d\x85\x32\x93\x5c\x04\x39\x60\xe5\x79\x5a\x57\xc5\xaa\x39\x82\x41\x3d\x7a\x3b\x66\xbb\x99\xef\xbc\xea\xaa\x58\xc5\x04\xb1\x8b\xe3\xa9\x17\x03\x07\x44\xcd\x08\x15\x68\xad\x65\xb9\xf3\x3b\x32\x67\x7e\x7d\xa6\x29\x78\xbb\xc9\x53\x61\x84\x88\x17\x10\x7a\x62\xb6\xc4\x30\x6a\x62\xd0\x1d\xb2\xd2\x24\xac\xef\x4b\x22\x60\x2f\x77\x1a\x22\xd9\xdf\x41\x13\xfa\xd5\x0e\xea\x92\x81\x8a\x9f\x06\xd6\x56\x83\x0f\x66\x86\xab\x6c\xb7\xc1\xfd\x78\x05\xcf\xb7\x3a\x19\xb8\xd4\x06\x75\xa2\x15\x2b\x41\x12\x2e\xb4\x48\x84\xd7\xfa\x10\xc5\xca\xbb\x51\x61\xa1\x89\x82\x57\x59\x5d\xd1\x3c\x8a\x92\xdb\x14\x2b\x72\xac\x0d\xf7\x15\xc1\xd9\x05\xd7\xaf\x41\x74\xae\x6d\x8b\x20\xb7\xb1\x90\xb0\x63\x32\xc5\xcc\x79\x73\x1b\x66\xeb\x44\xfb\x0e\x87\x59\x6b\x56\x78\xae\xcd\x4c\xd0\x23\xf4\x84\xe2\x79\xc8\x05\x90\xb3\x75\x1e\xd6\xf2\x7e\x2e\xaa\xa9\x16\xb2\x3d\x62\xef\x08\x68\x98\x6c\x0e\xcd\xa7\x5e\xcd\x64\x33\x2c\x15\xb2\x73\x6a\x98\x71\xa8\xcd\xee\x21\x29\xbb\x0d\x9d\x3b\x34\x1c\x36\x51\xce\xc3\x29\x22\x49\x94\xa2\x16\x45\x3a\x97\xc4\xa6\xd2\xcc\x89\x98\x3a\x85\xcf\x00\x0b\xfa\xa3\x6d\x11\x06\x9d\x1c\x0d\x65\x09\xf8\xf5\xab\x43\x77\x51\x8f\x55\x12\x02\x9d\x0f\x23\xa2\x97\x91\xda\x38\x7b\xc4\x4b\x89\x16\xc2\xe4\xdf\x18\x67\xbf\x5b\x3c\x38\xed\xe2\x87\x9c\x87\x4e\x2b\x54\x26\xda\x02\x2d\x59\xc2\x99\x35\x6c\x56\x00\x21\xbf\xbe\xb0\x5b\x53\xf7\x2f\x39\xa2\xeb\x00\xe5\xbd\x09\x54\x2b\xe9\x2a\xca\x6c\x91\x33\x1b\xa6\x48\xd8\x5a\x30\xd0\x2d\xad\x75\xd1\x8f\x9d\xd8\x4d\x0a\x1f\xb8\x40\xce\xf1\x98\x64\x3b\x3b\xaf\xb7\x72\xd5\xc3\xab\x6d\x95\x9e\x36\xbf\x89\x71\xc6\x43\x7f\x1d\x51\x16\x6d\xce\x89\x23\xf2\xf5\x5c\xf3\xc5\x3a\x23\x5c\xcc\x1d\x16\xea\xca\x4e\xb7\x97\xdf\x4d\x25\xa9\xe1\x45\x52\xd4\xa4\xd6\xdf\x22\x65\xf7\xcd\x2e\x73\x08\x8a\x47\x6b\xa7\x80\xf6\x51\x3e\xba\x17\x6f\x90\xe7\x99\x35\xa1\x52\x06\x13\xc4\x38\x23\x88\xca\xe2\xc7\x2a\x0e\x42\xa2\x29\x61\x44\x40\xce\xa7\xcb\x9c\xa8\x02\x31\x3f\xb3\x51\xde\xf3\xc6\x24\x9a\x50\x92\xa5\x12\x31\xa2\x6d\x1a\x2c\x96\x90\xf7\x6f\x04\xda\x3a\xba\xd1\xbe\xb4\xd5\x9a\xeb\xc3\xaa\x91\xae\x94\x12\xa0\x1f\xb4\x26\x56\x9a\x17\x32\x75\x11\xf6\x47\xf6\x21\x9b\x85\x36\x64\xde\x0a\x06\xfe\xa3\x52\x5b\x77\x5d\x04\xdb\xa6\x8a\xa7\xf4\x1d\xa3\x3f\x70\x7b\xd8\x71\xba\xac\x34\xc0\x09\x9b\xd8\xfe\xee\xde\x2a\xe8\x18\x27\xbe\xbb\x02\x9d\x29\x7d\x20\xac\xb6\x41\x93\x63\x8a\x2c\x72\x43\xb6\x4b\x1d\x8b\xe4\xfc\x0a\xfc\x54\xeb\x53\x4a\x6f\x72\x5e\xf1\x5c\x19\x9c\xe6\xc2\xc8\xce\x96\x3e\x88\x13\x9a\x2a\xb6\x66\xc7\xf4\xd9\xc1\x12\xfd\x9e\x71\xf5\xfb\xa0\xac\xc9\x99\xc3\x06\xe8\xdb\xba\x26\x3a\x51\x85\x2f\x75\x39\xda\x96\x49\x10\xf6\x67\x35\x5d\x4d\xf9\x5d\x6b\xe9\x8a\xa0\xca\x93\x6a\x6f\xfd\x6a\xa0\xb9\x09\x22\xc1\xa0\xfc\xec\xcd\x07\xf0\x1c\x2d\x26\x90\x61\x03\x41\x20\x6c\xc2\x38\x9a\x73\x41\x4a\x48\x43\x46\x78\xfb\x4c\x0c\x83\xf0\xb2\x3e\x97\xd6\xb8\xc3\x0c\x7a\x4a\x71\xcc\x23\x37\x58\xbb\xfb\x6b\x1f\x29\x16\xf3\x38\xdd\xbe\x85\x03\x56\x14\x33\xd5\x9b\xe4\xdb\xa4\x45\x34\xe9\xa4\xde\x11\x1d\x42\xaa\x37\x95\xf0\x74\x87\xec\x23\x17\xf6\xee\x94\xb6\x3c\x76\x8c\x93\xfb\x63\xc2\x52\x84\x73\x35\x33\xa5\x34\xd6\x77\xbc\xb4\x3b\xab\xf5\x02\x60\x01\x5f\xaa\x41\x65\x82\x85\x15\xfa\x13\xfc\xc0\xdd\x2c\x86\x2c\x18\x04\x0a\x70\xa1\xc8\x1f\x80\xc8\x9a\x14\x08\x02\xa0\x2a\x4d\xb4\xa8\x83\xdb\xaa\x80\x6d\xb5\x9f\x99\x10\xb2\x67\x08\xef\x23\x29\x23\x52\x0e\x8f\xcc\xac\x4b\x14\x1a\x38\x7f\x94\xb3\x6f\x64\xd8\xb8\xc0\xff\xb2\x63\x13\x9e\x8c\x47\xc6\xae\x42\xab\x29\xdf\x3b\xd9\x19\x15\x16\x4d\x72\x01\xa9\x4b\x75\x63\xbe\x4b\x66\x34\x2b\x7c\xd4\xef\x3b\xf6\x3c\x9a\x21\x33\xf2\x40\x32\x53\x80\x9a\x08\x32\x27\xcc\x46\xdb\xbf\x47\xff\x61\x60\xa8\xd0\x1f\x87\xec\x13\x88\xd5\x2c\x5b\x76\x10\x9d\x14\x23\x63\x55\x1a\xe6\xbe\x76\x02\x7a\xcb\x8c\x64\x89\x26\x62\xf6\x7b\x86\x1f\xc8\x90\xb9\x61\xfe\x03\xdd\xa3\x3f\xa0\x3f\x36\x39\x72\x6c\x11\xd9\x53\xdb\xf9\xc0\xc5\xee\x5d\x81\x64\xe8\x58\xf5\x11\x24\x87\x73\x03\xc4\x8d\x44\xbd\xa9\xe6\x15\x5c\x5f\xf9\x46\xd9\x03\xaf\x46\xaf\xc2\x93\x8b\x05\x61\x6a\xc4\x78\x4a\x46\xa4\x26\x74\xd5\x22\x28\xf4\xa5\x7e\xc1\x53\xb2\x32\xf0\xe4\x15\xe4\x2f\xe0\xba\x90\xf9\xd8\x6f\x07\xe4\xc4\x79\xa3\x3b\x66\xb0\xfa\x09\xfb\xca\x94\x6d\xa6\xbb\x6d\xac\xec\xd2\x6a\x57\x1d\x90\xe8\x76\x02\xf5\xf1\x1a\xd3\xa2\x16\xd2\x8f\xca\xa7\xb0\xec\x21\xd6\x3f\xd6\x2b\xb7\x77\x4e\x50\x73\x03\xd5\xfa\x82\x4e\xa9\xd6\xb6\xd7\x8f\xc7\x81\x10\xdc\xc6\xcd\x6d\x8a\x5b\xd7\xf2\x73\x17\xa4\x58\x64\x58\x69\x2e\x3f\xf6\x6c\x57\xc4\x98\xc6\x3c\x2f\xeb\xdc\x96\x00\x54\x86\x89\x51\x56\xbd\x5e\x6a\x11\x3c\x35\x49\x37\x64\x46\x4d\x7d\x5c\xef\xf4\x1c\xe9\x43\xc1\xe7\xc4\x80\x90\x69\xa2\xe5\x6a\xc6\x05\xfd\x47\x63\x40\xb6\x59\xc3\x2e\x02\x69\x41\xf3\x53\x98\x67\xac\x6b\x03\x8f\x1a\xcd\x40\x45\x86\x44\x9d\x85\x83\xc6\xfa\x79\x01\xca\xc7\x24\xcf\x4c\xed\x75\xc2\x45\x6a\x20\x31\x65\xdc\x6a\x55\xb8\xbe\xc2\x26\x65\xcb\x0d\x48\x6d\xf1\x88\xad\xee\x4e\x66\x98\x4d\xdb\xf5\xc8\xbf\xe4\x24\xdf\x53\xd2\x8c\x85\x5c\x79\xa1\x70\x3c\x9e\xca\xa2\x35\xb2\xa1\x8d\x16\xc9\xa5\x6e\xcc\x36\x20\x8f\xe5\x7d\xe1\x50\xf3\x35\x04\xc6\x8c\x2e\xdb\xf3\x6b\x38\x5f\xae\xed\xf1\xdb\x83\xfb\xe5\x39\xe2\xf5\x55\xfd\xa8\x46\xfe\x00\xff\xd9\xaa\xe6\x67\xf5\x6e\x78\x19\x5e\xd2\x3b\xf6\xed\xe9\xd8\xc0\x92\x76\x93\xb2\x33\xb4\xc2\xb5\x1a\xdc\xac\xe7\x8e\x9b\xd8\x8f\xb2\x31\x4b\x98\x77\x8f\x20\x8c\xb5\xb3\xfb\x36\x70\x4b\x16\xa9\x88\x26\x17\xd5\x65\x89\x3f\xad\xab\x25\x0e\x0c\xc6\xd9\xb0\x41\x5c\xb0\x29\x4b\x39\x98\xd1\x16\xb7\x53\xd5\x10\xaa\x9f\x9b\xfb\x7a\xdd\xa9\xb4\x86\x43\xd6\x0c\x6e\x80\x45\xdf\x76\x6c\xcf\x6d\xb6\x51\x1c\x16\x30\x29\x14\x3c\x08\x8c\x42\x84\x20\x97\x48\x09\x0c\xd9\x7b\x9c\xc9\x21\xfb\x62\xb4\x58\x2a\x8d\xbd\x68\x81\x7d\xc0\x1c\xb5\x28\x22\x20\x3c\x2d\xe8\x80\x9a\x61\x66\x0b\x11\xea\x42\x10\x1e\x8a\xcf\x9f\x84\x30\x08\x51\xf7\x32\x78\x91\x55\xdd\x6b\x87\x74\x84\x0e\x33\x64\x4b\x19\x8d\x4d\xbe\x62\x2a\x21\xd3\x15\x67\x8d\x36\xe3\x98\xf3\x8c\x60\xd6\xa4\x56\xd7\x7e\x5d\xf1\x16\xd1\x30\x8b\x51\x5b\x7d\x5a\x33\x13\x39\xd1\x36\x05\x36\xa5\x18\xc1\xba\x30\x20\xe6\x2a\x0f\xca\x62\x0c\x43\x3d\xd1\x74\x45\x40\xa4\x13\x9e\xfc\x31\xc9\x36\xca\x34\x31\x0f\xb4\x72\x11\xfc\xa4\x00\x65\x5d\x2b\xbd\x3d\x4c\x80\xa8\x2d\x06\x58\x35\xb1\xb0\x84\xa0\xd5\x35\x1c\xa7\xe1\x6f\x39\xc5\x5c\xcd\x6a\x93\x9e\xdb\x26\xe8\xb2\xae\xd7\xd1\x58\x4f\x40\x7b\x44\xfc\x81\x08\x41\x4d\xc5\xba\x9d\xe9\x3a\xbb\x6a\x0b\xbc\x47\x7c\xe2\xd2\xaa\xd7\x97\xaa\xe5\xca\xf7\x0d\xac\x7b\x61\x0a\x67\xd1\x42\x50\x2e\x6c\x81\x79\xa3\x8f\x7d\xd5\xe5\xd8\x2b\x25\x62\x00\x3c\xd2\x1c\xe4\xb7\x2c\xd0\x25\x9c\x1f\xcd\xdf\x9e\x11\x75\xa0\x5e\x0a\x1e\x4e\x39\x91\x81\xc2\x0a\x84\x35\xd2\x80\x4e\x88\x9e\xf4\x90\x69\x8d\x3d\x54\xae\x4d\xd9\x95\xab\xc2\xd2\x2f\x4d\x04\x97\xd2\xe6\x56\x98\x71\x64\xb7\xf5\x5e\xbe\xb5\x45\x31\xfb\x88\x9a\x3d\x5f\x9a\x65\x15\xed\xbe\x80\x87\x69\xd0\xe3\xc6\xc4\x17\x00\x35\x4a\xd1\x5d\x33\xb0\xdc\xd1\x40\x82\x60\x69\x3d\x09\x90\xa8\x54\x4a\xd1\xd8\x40\xeb\xf2\x73\x36\x09\x8b\xc7\xbe\xe4\x2e\x60\x21\x5b\x50\x6b\x80\xa6\xa9\x44\x54\x08\x02\x08\xa2\xe3\xcc\x06\xc8\x22\xae\xa1\x45\x37\xc5\x82\x22\xde\x68\x36\x6f\x86\x5b\x47\xd2\xb9\x3e\xcf\x80\x24\xc0\xf8\x31\x5f\x80\x15\x56\xfe\x15\xd4\x4b\xd2\x89\xe6\xc4\xb0\x99\xa3\x56\x55\x8f\x01\x10\x99\x30\x55\x17\x36\x70\x83\x40\x98\x81\xa4\x66\x1b\x0d\xe7\x0e\x8f\x7a\x3f\x5c\x5e\xdf\xf6\xcf\x86\x47\x45\x30\xd8\x25\x0e\xb9\x4b\xd2\x97\x73\x71\x36\x64\x3e\xa4\xe3\x3b\x1d\xc0\x5e\x22\x9c\xa6\x45\xf5\x92\x49\x27\x1c\x19\xd7\xf4\xba\xa7\x62\x65\x54\xa7\x3a\xcc\x47\xfa\x95\xa4\xd7\x58\xed\x14\x0b\x6a\x8d\xb5\xaf\xe5\xf3\xac\x65\xf1\x9c\xd1\x8a\xdf\xad\xe5\x46\xf0\x4b\xb9\xd3\xcf\xad\xcf\xc1\xe6\x24\xc0\x5e\x39\xe7\x99\xd4\xc2\x57\xdb\xe9\xd8\x37\xa0\x98\x00\x0f\xb0\x64\xd9\x41\x90\x5c\xaf\xb9\x76\x89\xfe\x84\xe6\x94\x41\x22\x6c\x1b\x6d\xef\xe2\x85\x6c\x02\x05\x36\xb8\xb8\x8b\x81\x3a\x7f\xbc\xbc\x8b\x01\x6e\x7a\xbf\xb4\x83\x7a\xc5\x23\xb4\x39\x47\x8a\x35\x06\xc9\x46\xdc\x90\xc2\x93\xa6\x6e\xa1\xe7\x65\xb5\xe7\xdb\x2a\x35\xcc\xbc\x06\xb6\xef\x2a\xc3\x20\xd5\xe4\x55\x14\x18\xda\x95\xee\x56\x5b\x68\x0c\xd5\xab\xd8\xfa\x7d\xd2\x0b\xba\x36\x9c\xbc\x7d\x62\x44\xb1\x00\xf0\x04\xd4\x5f\xbf\x1b\x97\x13\x14\xa3\xba\x9c\xf6\x0d\xb4\x37\x54\x3c\xed\xfc\x29\xd2\xba\x94\x17\x78\x4c\x01\x7f\x08\x6e\x60\x57\xdd\x55\x57\x83\xdf\x1d\xb2\xb0\x53\x8e\xb9\x33\x35\x0f\xb8\x02\x3e\xca\xa6\x88\x33\x82\xb8\x30\x81\x51\x2f\x0e\x3b\x61\x69\x41\x39\x35\x4e\xcd\xd0\x92\xe7\xc2\xbf\xb1\xf2\x1e\xcb\x7d\x72\x86\x5d\xf2\x84\xd3\x33\x6d\x68\x2f\xac\xc0\x84\xf1\x16\x82\x14\xa6\x2b\xbc\x98\x3c\x10\x86\x1e\xb5\x99\x8a\x83\xca\xf6\x20\x69\x4d\xab\xa4\xec\x3b\xe5\x33\x53\x68\x66\x7b\x47\x63\x1f\xd6\x2a\x1c\x57\x12\x53\x3b\x72\x3b\x03\xef\xa1\xfa\x00\xca\x29\xb6\x63\x3e\x78\xb2\xc9\x17\x63\x81\xe1\x34\x0f\x84\x9e\x21\x93\x21\x5d\xcb\xb2\xe4\xeb\x82\x24\xdb\xa4\x8c\x5f\xb9\x5e\x08\x6d\xbe\xa1\xd0\x72\xb1\xf0\x28\x76\xeb\x14\x77\x9e\xaa\xf2\x6c\x57\xcc\x73\xa3\xc2\x0d\x3d\xd1\x9f\x6d\xa5\xe3\x86\xf3\x74\xa5\x1b\x13\xc1\xe7\xeb\x4d\xf1\x79\x92\x95\x6f\x2b\x69\xbf\x91\xb3\xe5\x95\x64\x29\xaf\x9e\x65\x53\x7a\xf2\x2a\xa9\xf7\xb3\xb9\x17\x7d\x25\x02\x14\x65\x13\x83\x0a\xec\x43\x50\x36\x33\x38\x7c\x67\x78\x67\xf9\x60\x8c\x4b\xda\x29\x9d\x82\x28\xcc\x33\xd6\xc6\x36\x68\x43\x26\x53\xb7\x3e\xc5\x18\xae\xcf\x3a\xff\x72\x10\xa9\xb6\x85\x56\x9a\x78\x52\xe1\xb9\x2f\xab\x2d\x97\x4a\x97\xc8\xb5\x42\x1a\xed\x2b\x65\xf4\x09\xd2\x8a\xeb\x6c\xdd\x28\xd5\xd9\xa6\x74\xec\xa7\x9e\xb0\x74\x43\xb7\x4e\x2c\x2a\x28\x0c\x27\x64\x31\x12\xc3\x22\xba\xea\x56\x46\x37\x9f\x01\x4f\x75\x6e\xec\x2d\xad\x64\xc3\x9d\x44\x94\x32\xc1\x51\x78\xc7\x83\x93\x65\x8e\x97\x41\xaa\x99\x85\x81\x81\xcb\x99\x32\xff\xaf\x58\xd4\x3a\x66\x0e\x59\xb4\x2e\xdd\xa3\x8b\x7e\x58\xfa\x6b\x11\x67\x59\x38\x13\x69\x01\xa1\xcd\x2c\x8d\xf3\x18\x2e\x31\x34\xb8\xe8\x9d\xde\x0e\x7e\xee\x43\x1a\xd5\x92\xe7\xe8\x91\x4a\x6d\x21\x0c\x19\x78\x57\x0d\x8a\xb8\x69\xba\x65\x7e\xd8\x81\x5f\x41\x72\xa5\xcc\xc7\x73\xaa\xed\xa9\x62\x91\x77\x20\x11\xae\x5d\xaa\x9d\x39\xc7\xfa\x01\xb8\xb6\x5d\x12\x5f\x5d\xbe\xfc\x8a\xf3\xb1\x85\x19\x5c\x0c\xb2\x6b\x9e\x5e\x10\xfc\x79\xda\x4c\xbd\x40\xcd\x0e\xcd\x9a\xda\xe3\x75\x48\xd5\xab\x3f\x94\x71\xbd\x2a\x14\x15\x53\xa9\x4a\x97\x49\x73\x95\x6a\xb1\x05\xfb\xc8\xd3\x73\xda\xf6\x26\xc9\x1b\xee\x91\x7a\x6d\xe7\xc6\xa3\x60\xd7\xaa\x60\x57\x8d\xfa\xcd\x6b\xab\x16\x0a\x10\xff\xb7\x0e\xa9\x6d\x62\x6e\x15\xf9\xee\x21\x2b\x04\xf9\x1c\x71\x9e\x38\x29\x8b\x6e\xc6\x15\xc4\xb2\x13\x40\x53\xab\x24\x92\x0c\x59\xbd\xde\xd0\xce\x63\xbb\x86\xa5\xf7\x5a\x55\xe4\x77\xe4\xda\xaf\xc2\x7a\x44\xbe\xf8\x3c\x3c\x63\x8c\xfa\x5e\x49\xa4\x74\xae\x9c\xff\xb5\xc1\x0a\x00\x75\x61\x9b\x8c\xa6\x9a\x53\xb9\x66\xd0\x78\xe5\xb9\xb0\x57\xe6\xd3\x58\x50\x3b\x46\xd7\xa1\xb0\x76\xff\xe5\xc0\xe0\xc4\xec\x80\x87\xdc\x86\xcf\xa0\x31\x46\x80\xc3\xb0\x16\xe5\xd6\x80\x34\x6a\x90\x61\xa6\x1f\x67\x08\x86\x0e\x87\x87\x67\x1e\x78\xba\x24\xdd\xbc\xba\x93\xb3\x94\x08\x46\xb0\x9a\x3d\x5f\xb4\xf6\x74\x57\x97\xe1\xb3\x45\x6e\x4f\xf7\x82\xa3\x56\x8a\xe2\x6e\x18\xc0\xdd\x20\x1a\x5a\x00\x4e\x55\x8c\xa8\x3a\xb8\xc9\x22\x69\xdc\xda\x59\x31\x98\xd7\x53\x04\xa2\x6b\x47\xfc\x16\x62\xc7\x6d\x26\x94\xf7\xbf\x01\x4a\x68\x04\xd7\x62\xfb\xc4\xb6\xdf\x69\xaa\x21\xf4\xb4\x0e\xf4\xb2\x31\x32\x22\x1c\x5c\xf3\x89\xfd\xa0\x01\x2f\xb9\xf4\x58\x79\xb5\xa1\x65\xc4\x96\x65\xc7\x02\x16\x69\x46\x24\xe8\xbc\xc6\xd8\x29\xa9\xb5\x6d\x46\xd7\x90\xfd\xc8\x1f\xc9\x03\x11\x1d\x84\x15\x9a\x73\xad\xca\x30\x12\x36\x50\xc4\x71\xd9\xb2\xf1\xe9\x63\x74\x81\xe7\x24\xed\xc3\x85\x18\xa4\x02\x5a\xd3\xcf\xba\x55\xeb\x2a\xc3\xa0\xda\xc9\x36\x82\xb2\x13\x1d\x32\x9c\x40\x7f\x28\x08\x6e\x01\x8f\x50\xb7\x30\x10\x00\xbf\xf7\x4e\xdf\xdf\x77\xd1\xad\xbe\xb9\xa9\x8c\xe7\x1b\x64\x98\x37\xcd\x6d\xc8\xa6\x82\xe7\x0b\xaf\x9a\xf3\x31\xd8\x04\xc6\xf9\x5b\xe3\xf4\x85\xc9\x38\x8f\x6f\x82\x53\xad\x17\xb4\x33\x4e\x64\x3c\xbe\x32\x5f\x48\x9c\xae\x19\x32\x90\xbe\x2e\x7d\x5c\xcd\xe6\x4e\x00\x1b\x35\x43\x49\xec\xcf\x79\x5c\x41\xf2\x93\xa0\x95\x7a\x9b\x3d\xca\xdd\x69\x90\x95\x1b\xf8\x39\x9c\x4f\xa0\x3e\xe9\xac\x78\xad\xed\xaf\x05\x82\x83\xd4\xc3\xe8\x37\xec\xfd\xfa\x45\x8c\xa5\x59\x5e\xe5\x62\xc1\x21\x6b\x3b\x5b\xba\x4c\x37\x9b\x89\xbe\xe0\x8b\xdc\xe4\xf1\xd3\x30\xca\x56\x3b\x21\x2a\xd5\x67\xac\x92\x99\x56\x88\x8a\x8c\xec\x7d\x14\x57\x46\x82\xf4\x69\x0d\xb0\x9a\x15\x9c\x86\x6f\x6f\x70\x2e\xac\x6d\x5b\x9b\xfa\x4c\x97\x40\x01\xff\xca\x32\x34\xd7\x6f\x8d\xe0\x02\x03\x4c\xa9\x5a\x5a\x47\x88\x4c\x7b\x8f\x34\xef\xa0\x20\x43\x3f\x15\xca\x50\xd0\x51\xcd\xba\xd0\x6b\x8f\x74\x2e\xe8\x56\x7a\xb0\x75\xc1\x90\x07\xc2\x54\x61\x51\xcd\xf1\x02\x51\x2d\xb7\xf5\xcd\x23\xa6\xa4\x83\x1e\xf5\x89\x53\xb9\xd0\xb2\x39\x17\xd4\x9d\x30\x30\x83\x5a\xb6\x2f\xb6\x43\x3e\x98\x90\x88\x49\x0a\x4b\x70\x00\x46\x66\xfb\x48\x25\x2a\xc7\x3e\x70\x0d\x3b\x9c\x51\x76\xaf\x5f\x66\x40\x12\x9c\xbb\x5b\x68\xf9\xc6\x85\xcb\x51\x8e\xf6\x74\x25\xe7\xed\xb0\xcb\xcd\x78\xa0\xab\x8e\x02\x65\xd3\xa0\xba\xa2\xde\x0a\x5c\x07\xec\xa0\xf6\xc9\xf5\xb0\x1a\x6a\x1f\x75\xfa\xc4\x36\xcf\xb6\x24\xa4\x6f\x0d\x04\x1b\x25\x8e\xd8\x44\x09\xab\x91\x84\x75\x2f\xd6\x96\x80\xaa\x35\x6a\xfa\xa3\x59\x0d\xe5\xdf\xfd\x5f\x06\x62\xca\x90\xe6\xdf\x11\x17\x43\x66\x3e\xef\x78\x34\x0a\xfd\x83\xa2\x70\xac\xa1\xd4\xda\xf3\x93\x83\x96\xdd\x4e\xaf\xbc\xed\xdd\xfc\x34\xba\xee\xdf\x5c\xde\x5d\x9f\x46\xca\xe5\xe9\xf9\xdd\xcd\x6d\xff\xba\xf6\x3b\x03\x4e\x3f\xb8\xbc\x18\xfd\xe5\xae\x7f\xd7\xf0\x95\x1b\xe0\xbc\xf7\x43\x3f\x6a\xef\xf7\x97\xbb\xde\xf9\xe0\xf6\x97\xd1\xe5\xc7\xd1\x4d\xff\xfa\xe7\xc1\x69\x7f\x64\x3b\x27\x9f\xae\x6e\x00\x52\x3f\xdf\x26\xdc\x5e\x5c\x6a\x61\x5d\xe0\x67\xb8\x0b\x78\xbc\xb4\xdb\x49\xff\x01\x96\xfe\x95\xd9\x83\xe3\x8e\xfb\xcb\x40\xb5\x1e\xeb\x63\xef\x7c\x3d\xc5\x89\x19\x32\xef\x8c\xf3\x32\x5e\xe1\xa9\x74\xdd\x00\xa3\xd9\x9e\xa0\xde\xc2\x76\xfc\xe3\xf1\x4b\x15\x96\xf7\xc5\x4c\x9d\x0f\x16\xf8\x00\x7a\x70\x48\xdb\xff\xae\xb4\x25\xf1\x80\x76\x4d\x30\x05\xeb\x8b\x4a\x51\x81\x91\x5c\x41\xdb\xb5\x83\x96\xf6\x12\xfa\xf7\x1a\xe2\x48\x33\x2f\x28\xd8\x5a\x32\x3c\xa7\x89\xf9\xa0\x54\xb3\x64\xab\x99\xe6\x84\xa9\xf2\x88\x11\x0b\xc4\x23\xcf\x08\xfa\xe9\xcf\xc5\xa4\xc0\x83\x60\x2d\xf2\xbc\x02\xbe\x66\xbf\x10\xb9\xa1\xea\x2a\x06\x8a\xde\xe4\xac\x9b\x9a\xbe\x55\x90\x60\x91\xb3\xa0\x6c\x20\xca\x41\x6a\x42\xc0\xae\x11\x9c\x3b\x95\xa5\xc9\xfb\x91\x6f\xda\xbe\x95\x24\xbf\xc5\xf2\xbe\x06\x60\xba\x56\x38\x5a\x82\xef\xf8\xc6\x66\x54\xeb\xda\x97\x7a\x9a\x8e\x80\x63\xb6\x7b\x67\x63\x4d\xe0\x8a\x57\xba\x15\x67\x25\x8c\xa5\xb5\xdf\x17\x61\x34\x3d\xbd\xdb\x63\xfd\x4b\x09\x0a\xc7\x69\x12\x74\xda\x83\x53\xe3\x71\xa9\x1c\x50\xaa\x69\xdc\x63\x7d\x22\x78\xcc\x1f\xa2\x62\xcd\xb9\x69\x84\x53\xab\x88\x06\xe6\xee\x2e\x3c\xee\x99\x6d\xfd\x9e\x46\x9a\x34\x8e\xbd\xa0\x8f\x51\x2d\xe1\xd7\x35\x67\xcb\x8b\x59\x95\x42\xb7\x85\x1f\x3e\x18\xdd\x3b\xe2\xd7\xd1\x40\xcf\x60\x4f\xc7\x10\x65\x29\xf0\x4a\x0d\x2c\x36\xd8\xa9\xa1\xcf\xa1\x53\x24\x1c\x18\xcd\xd4\xeb\x0c\x1f\x9c\x1a\x81\x3e\x18\x47\xc8\x87\xe0\xea\x5b\x2e\xf4\x9d\x37\x1f\xdb\xa4\xec\xf6\x8d\x0e\x68\xb3\xc3\x96\x3f\x1d\x4e\x97\x5f\xd6\x8b\xc1\x74\xd5\xcd\xe0\xcd\x82\x74\x99\x1e\x60\x9e\x37\xf4\x72\x1d\xb5\xff\xe0\x56\xf4\x07\xc3\x52\x79\x43\x85\x47\x30\x9a\xaf\x64\x45\xc7\x80\xf0\x6f\xd3\xc9\x2d\x8c\x88\x44\xc7\x28\xa3\xf7\x04\x7d\x07\x91\xcd\xde\xd5\xe0\xbb\x0e\xfa\x2e\xcc\x9e\xfc\x6e\x03\xf1\x57\x00\xf0\xd9\x79\x5b\xb4\x2e\xd0\xf4\xa2\xc4\x9c\x8f\x90\x43\x15\x4c\xb3\x17\x00\xf7\x43\xf5\x86\x22\xc2\x60\x4a\x41\x36\x86\x8f\xf8\x5b\x67\xe5\x2a\xd9\x58\x1c\x99\x9d\x71\x8f\xf4\x78\xd5\xdc\xee\x3d\x47\xa1\xdb\x05\xe1\x8a\x6c\xf1\x9e\xc7\x95\x2f\x90\xa2\x64\x03\xf3\x1e\x32\x31\xea\x56\x15\x19\x93\x8e\x98\xb5\x9b\xb2\x8a\xf1\xde\x1a\xbb\xad\x91\xf3\xd0\xab\xa3\x88\x6b\xdd\x7c\xe0\xb2\x97\xe0\xb2\x7d\xa4\xfb\xc4\x93\xdb\xfc\x36\x3b\x35\x0a\x51\x30\x8c\x2b\xa9\xd4\x1a\xae\x93\xd3\x31\xa0\xd6\x6a\x08\xc9\x0d\x03\x0e\x01\x4d\x56\x47\x1c\x6e\x4c\xa4\xca\x78\xfe\xab\x73\x2d\x4f\xb5\xa7\x2c\xc4\x07\xa7\x26\x21\x57\xd1\x39\xb1\x4d\xaa\x8b\xe8\x9a\x3d\xaf\xc0\x6e\x70\x55\x59\x10\x75\xf3\x12\x91\xcc\xe8\x43\x7d\xd6\x71\xeb\x06\xef\x10\x97\xbc\xe8\x7d\xee\x9f\x8d\xfa\x17\xb7\xda\x20\xaf\x86\x28\xe3\xaf\xaf\x4f\x7f\x1c\xfc\x1c\x37\xb3\xbe\xf9\xe5\xe6\xb6\xff\x79\xf4\xa9\x7f\xd1\xbf\xee\xdd\xf6\xdb\x9b\x96\xb7\xbd\xac\x0e\x3f\xd1\xa6\x45\xf1\x02\x0d\x31\x75\x58\x6b\x0e\x51\xc0\x78\x4e\x94\xe0\x19\xa2\x4a\xa2\x07\x2a\xa9\x2d\x30\xb1\xca\xde\xdd\xc0\x39\x73\x6a\xde\x7e\x12\x64\x96\x76\x4c\x99\x7d\xf1\x12\x6a\x5d\xc2\xa1\x22\x68\xa3\x91\x2c\x35\xe9\x1a\x28\x68\x51\xd3\xad\x79\x89\x25\xd8\x09\xea\xd9\xad\xad\x1b\x9f\x71\xa4\xd5\x50\x22\xcc\xec\x4d\xa8\xd2\x4f\x1d\x1d\xa3\x32\x8d\x4f\x90\x81\x41\x0a\x00\x1d\xfd\x80\xa0\x3c\x61\x41\xd8\x77\x0a\x91\xaf\x8b\x8c\x26\x54\x05\x20\x93\x5c\xa0\x39\x66\x78\xea\xcc\x8f\x5c\x12\xb1\x42\x7a\xec\x2d\x76\xb9\x0f\x2b\xb2\x29\xab\x2b\xb4\x94\x2c\xbb\x78\x8c\x27\xc5\x6d\x3a\xff\x93\xd9\xa0\x0d\x31\x90\x0a\x0e\xce\xba\x53\xda\x93\xf9\xba\x22\x8f\xcc\xe6\x91\xda\xe0\x27\x96\xf6\xba\x7b\x34\x17\xd7\xeb\x08\xa3\xd6\xf0\xe1\x0b\xc7\x51\x23\x20\xb9\xbd\xf5\x7b\x19\xad\x0e\xb4\xd5\xbb\xc9\xf6\xd7\x83\xa5\x00\x46\xaf\x74\x5f\x71\x66\xe7\x45\x33\xae\xe6\x66\xad\x2e\x22\x22\xae\x6e\x73\x01\xcd\xb0\xb0\x6c\xe8\x71\x01\x60\x33\xe9\x6b\xe9\x74\x51\x2d\x30\x8a\x27\xf7\xc2\x6d\x2e\x4a\x93\x79\x3d\xbd\x2e\x56\xd2\xed\xf5\x56\x90\xd5\x4c\x74\x8d\x1e\x17\x3e\xc1\x19\x20\x2d\x37\x13\xf9\x50\x54\x46\xd3\x0c\x24\x92\x0b\x6b\xe9\x43\xb5\x8e\xeb\xb2\x9c\x59\x19\x79\x9f\x4b\x6b\xb1\x55\x47\xa0\xf1\xc4\xad\xc2\x9a\x85\x62\xff\x81\x30\xb5\x17\x7d\x01\x86\xa8\x49\x00\x5f\xcf\x7f\x66\x40\xda\x06\x67\x85\x98\xf0\xb0\xc6\x41\x2c\x51\x09\x9c\x00\x9a\xa3\x69\x54\x68\xfd\xff\x4d\x51\x09\xbd\xb4\xf5\xb6\x08\x7e\x5a\xa5\xcb\x8a\x24\x27\x4b\xed\x02\x95\xb2\x48\xa0\xe0\x09\xb4\x3c\xdf\xa8\x26\x31\xba\x99\x59\x0a\xd8\x21\x41\x6f\x11\xa3\x2c\x96\xf7\xdc\xbc\x73\x86\x65\xf9\x95\x2b\xb7\x7c\x8b\x52\xa6\x68\x98\x4f\x44\x9d\x61\x85\xf7\x02\xf8\xbe\x41\x66\x39\x4c\xe4\x4e\x64\x2b\xdb\xa7\xdd\x18\x44\xcc\x5c\x64\x85\x8f\x00\x23\x7d\xa1\x75\x83\x7c\x1a\x28\xf8\x88\x28\x6a\x26\xd3\x20\x07\x36\x6f\xf8\xf6\x94\x53\xb5\xb3\xd9\xaa\x30\xc9\xf4\xb5\xcf\x85\xb9\x98\xeb\x77\xd6\xc2\xdb\x80\xec\xb4\x71\x2f\x19\x15\x2d\xba\xea\x66\x48\xd3\xa9\xbd\xd7\x9b\xf9\x67\x57\x77\x5a\x0c\x2e\xfc\x64\x5e\xb5\x48\x7a\x47\x0b\x38\xd4\xc6\x6d\xeb\x2b\xb3\x88\x47\x9e\x03\xa1\x74\x55\x09\x4a\x00\x53\x21\xf3\x85\x58\xb1\xa4\xb3\x56\xf3\x4a\xc6\xd2\xd7\xea\xd9\x9a\x1e\xb4\xc0\x2a\x2d\x1c\x78\x45\x89\x56\x10\xb9\x0d\x30\x98\x31\x1c\x97\xd6\x9e\x43\xfb\x6a\x71\x0b\xaa\xf3\x93\xf1\x76\x4b\x23\xbb\x90\xb7\xd7\x0b\x50\x98\xa9\x9a\x3c\x3d\x2d\x30\x72\x49\x84\xf1\x9d\xf9\xa2\x8a\x1a\xcc\xc7\xc6\x78\x62\x6d\x47\xdf\xb6\x0c\x82\x4a\x67\xe1\x7a\x4d\xc3\x38\x29\xd1\xbb\x07\x9c\x51\xad\xf1\x75\x5d\x0d\xdd\x7b\xf4\x1f\x80\xe1\xf8\xef\x0d\x46\x13\x9e\x12\x31\x4a\xf3\x28\x38\xbf\x6a\x52\x57\xfa\xa1\xb3\x5c\x2d\xeb\x6b\x11\x23\x83\x27\xc3\xc9\xfd\x26\xf5\x99\xfa\xf7\x0d\xc3\xae\x3e\x81\x81\xb7\x3a\xbe\x08\x1a\xaa\x1f\x49\xa9\xfa\xd1\xc6\x32\xc3\xf7\x9b\xb8\x23\x03\x88\xcf\xc0\x5b\x60\x43\xb0\x3d\x3d\xe7\x2e\xfa\x68\x80\x85\xe0\x52\x33\xaf\x48\x78\x9e\xa5\x43\x46\xbe\x6a\x73\x3f\x4a\xac\xaa\x01\x83\xb1\xc9\x80\xf6\x4d\xf5\x92\xa0\x84\xa2\xba\xd3\x0d\xf3\xe2\xa5\xaa\xd5\x3d\xad\x2e\xb9\x9e\xc9\x76\xd2\xe5\x5f\x49\x5f\xed\x53\xad\xd0\x32\x95\x2d\x3b\xc8\x2f\xb2\xc4\x16\x19\x79\x20\x02\x4f\x89\xed\xbb\x1d\x00\xff\xe0\x2d\xda\x6c\x5f\x55\x12\x29\xde\x76\xaf\xf8\x4a\x7e\xc6\xd3\xb2\xb1\x49\xdf\x5c\xad\x17\xad\x1f\x9f\x5a\x5f\xa6\xdd\xf2\xc5\xb1\x69\xdd\xc1\x7c\x03\x7c\x1f\x74\xc8\xb0\x94\x74\xb2\x0c\x3a\xdb\x7b\x1f\x3c\xa4\x48\x78\x7c\xa9\x18\x87\xac\x56\xd7\x88\x52\x55\xf7\x93\x96\xb8\x7b\xfe\x8e\xb5\x9f\x5d\x32\x09\x4d\xc3\x7a\x20\x80\x2b\xae\xe4\x4f\xaf\x89\xa8\xbc\x6b\x5a\x8f\x9d\x99\x4d\x6e\xd9\xdf\xc4\x5c\x0a\xf0\x76\xf9\x8d\xad\xf9\xf8\x2b\xe5\x43\x79\xef\xcf\x48\x46\x5e\x49\xc3\xc5\x2a\x23\xb4\xd2\xba\x28\x95\x7f\xb6\xfd\xdf\x6d\x3e\x5b\xc4\xa5\x1a\x32\xf8\xf7\xb0\xdf\x2f\x1c\xdd\x68\x98\xdd\x27\xb2\x8e\x77\x67\x25\x2f\x6e\x75\xae\x9a\x84\xe3\x0e\xc4\xde\x5b\x48\xf3\x89\x17\xd4\xb4\xd7\x37\x44\x49\xa7\xb8\x06\x9c\x6e\x7c\x26\xf6\x9c\x1e\xbb\x6c\xc6\x22\x37\x70\x83\x0d\x7f\x25\xc1\x36\x3b\xbb\x6b\x0b\xef\xf4\x74\xe2\x70\xf5\x76\x6d\xc2\x6f\xc5\x7c\xb7\xf0\x88\xda\x31\xf6\x71\xfb\x3f\xad\x6a\x56\x21\xcc\x9a\xc6\xc5\x4d\x15\x39\x68\xf3\x92\x53\xc1\xd9\x88\x7c\xd5\x36\xa7\xdc\x36\x25\xe9\x4e\x12\x89\x7a\x5f\x6e\x90\x5c\x32\x85\xbf\x9e\xa0\xe1\xd1\x67\x03\x8f\x8c\x7e\xe4\xb9\x90\xe8\x0c\x2f\x8f\xf9\xe4\x78\xce\x99\x9a\xa1\xcf\xf0\xbf\xf6\xa3\x47\x42\xee\xd1\x2f\x04\x8b\xe1\xd1\x90\x41\xd9\xbb\x6d\xec\xe9\x21\x8c\x66\x18\xc2\x6a\xd2\x22\x2f\xff\xf1\x5f\x1d\xf4\xb2\x7e\xcd\xf7\x1f\xfe\xf8\xaf\xe8\xf7\xf0\xff\xfe\x3f\xf4\xfb\xe1\x51\xc3\xbd\xb4\x59\x72\x53\x81\x8d\x5d\x3b\xda\x3d\x4d\xee\xf9\x64\x32\x52\x74\x4e\x0c\xee\xca\x08\x8b\xc6\xd6\x7f\x1b\x26\x57\x53\x0b\x07\x63\x00\x2d\x8b\x82\x4f\xfb\x52\x13\x7e\x74\x4a\x98\xcc\x0b\xc8\x8e\x47\xd7\xfd\xce\xa7\x48\x51\x09\x4f\x91\x14\xf1\xc9\x64\x13\x1f\xa0\xab\x19\xab\x82\xcd\x15\x81\xec\x10\xdc\xc8\x1b\x75\xa1\x2b\x82\xaf\x02\x8f\xae\xfa\x48\xbe\x31\xab\x18\x16\xf8\xa4\x16\xf1\x0d\x17\x3b\x89\xf0\x7b\x52\xf1\x97\x6d\xe4\x00\x77\xc8\x23\x21\x46\x16\x44\xc8\xb8\xf0\x15\x0a\x26\xa0\x61\x31\x41\x86\xec\xf6\xf2\xec\xf2\xdd\x3d\x56\x82\x4f\x31\x7b\x7f\x82\x7a\x69\x6a\xbb\x3f\x21\xeb\xf4\xd3\xcc\x33\x23\x82\x74\x51\xd8\xca\x85\x69\xc2\xd5\x7a\xb4\x43\x7d\x98\x0a\x92\xd4\x19\xae\xf5\x87\x5d\x93\xef\xcc\x3f\xd2\x90\x7a\x14\xc1\xab\xf8\x17\x14\xb8\x09\xb0\xd6\x7b\xb2\xb4\xdd\x5e\xcb\xeb\xdd\xa6\xa1\xd5\xcd\x82\x24\xda\xfa\x35\x1d\xf0\x44\x4a\x80\x3c\x10\x07\x00\x7f\xae\x0d\xbe\xd6\x1e\xaa\xb8\xab\xdf\x2e\x09\xd1\xe5\xb2\xb1\x1d\x38\xc5\x34\x81\x2c\x64\x83\xab\x75\x2c\x75\x17\x15\x58\x8b\x8d\x2d\x33\x7b\x6d\x83\xb1\xb0\x2f\x52\x2e\x89\x38\x9e\xe0\x44\x53\xaf\xd4\xa7\x30\x14\x55\x75\x74\xbc\xc5\xf2\x7e\xbf\x8e\xa6\x9d\xd1\x45\x68\x5a\x54\xe3\x1b\x6e\xac\x36\xc5\xb6\x97\x88\xc2\xf2\xbe\x29\x05\x65\x63\xfc\x72\x4d\x0a\x97\x9d\xd5\x36\x3f\x3b\x72\x50\x75\x67\x3b\xcc\x80\x62\x1a\x14\xa4\xcc\xf1\xc2\xf4\x0c\x82\x0b\x86\x66\x24\x2d\x67\x02\x97\xe7\xbf\x8a\x0d\x4c\x55\x4b\xe0\x27\x82\x5c\xd3\xb9\x56\x9b\x53\x88\xcd\x61\xb6\x34\x07\x49\x5f\x58\x58\xde\x4b\x0f\x71\x83\xe4\x1c\x67\x59\x07\x09\x92\x43\xd3\xa7\x0e\x92\x24\x9b\x1c\xbb\x42\xc2\x14\x65\x7c\x4a\x13\x9c\xa1\x71\xc6\x93\x7b\x39\x64\xfa\x06\x61\x53\x73\xf1\x2d\x04\x4f\x88\x94\xc1\x95\x5b\x84\x5f\x17\x82\xa7\x79\x62\x60\xc8\x4d\x1b\x10\x2a\x15\x4d\x4a\xd8\xd3\x5a\x22\x42\x8f\xc3\x04\x83\x81\x01\x19\xab\x73\xd3\xb4\x58\x50\x62\x12\x51\x73\xd7\x77\x0b\x0a\xa5\x70\x46\xff\x61\x9a\x66\xe2\x07\xca\x6b\x73\x4e\xc3\x2d\xdb\x45\x35\xb4\xdb\x33\x52\xf1\x69\x58\xc1\xcf\xa7\xf6\x31\x38\x43\x6d\x1c\x73\x1d\xb3\xb3\xe7\x06\xcf\xe6\xbe\x9e\xc9\x31\x45\x01\xd5\xed\x6a\xc6\xcc\x4f\x5c\x58\xf5\x95\xe5\x5d\xc1\x94\x1b\xb2\xad\x56\xf1\xf4\xa9\x41\xbf\xb6\x95\xe7\x81\x03\x0e\x46\x77\xf8\xc0\x16\x6f\x43\x5f\x11\x0f\x9a\x49\x1c\x79\x34\xed\xf5\x35\xd2\xf1\x90\xd4\x58\xa2\x45\x96\x4f\x29\x2b\x7a\xb7\x6a\x79\x38\x64\x00\xcd\xa4\x5f\x52\xc2\x37\xae\x72\xd4\x2b\x86\xa1\xde\x8f\x70\xdc\x10\x8d\xda\x11\x79\x13\x26\x8f\xf9\xd6\xf5\x38\xdd\xba\x9a\x45\xd4\x85\xeb\x0d\xb7\xc1\xb7\x0f\xb4\x80\x18\x0b\x5e\xd4\xb8\xb7\x5b\x7b\x29\x4a\xb3\xaa\xe4\xb1\xd0\x89\x61\x32\x98\x1b\x84\x2a\x6d\x4b\xa5\xa6\x19\xbd\x48\x66\x70\xdb\x46\x5e\x61\x65\xda\xe2\x90\x39\x57\x06\x58\xc7\x60\xdc\x58\xe8\x1b\x0b\x9d\x33\xce\xf8\x18\xee\x15\x80\xbf\x81\x75\x47\x60\x8a\x76\xdd\x24\x45\xef\x82\x6b\xc2\xa7\xeb\xbc\x6f\x8a\xb8\xef\x2f\x3d\xb9\x5c\x3c\xda\x98\xa4\x1c\x63\x5c\x74\xd1\x55\xe1\x6e\x2a\xaf\x6a\x82\xb5\xe4\x6e\x6a\x38\xbe\x59\x4a\x73\xb4\xfb\x7b\x48\x69\x2e\x2d\xa3\x01\x2a\x87\xef\xa3\x27\x72\xfb\xa2\xce\xf9\xfa\x76\xa4\x49\x60\x34\xfa\x47\xb4\x39\x8e\xcd\x96\x75\x5b\xf4\xba\xd2\xb5\x4b\x18\x29\x2f\x9b\xae\x5d\x9a\xcc\x6b\x4e\xd7\x2e\x4d\xf5\xf5\xa6\x6b\xd7\x4c\x74\x8d\x74\x6d\xe3\x6e\x1f\x69\xa6\x5e\x4f\x28\x2c\x04\x57\x7c\x9c\x4f\x6e\xe0\x36\x59\x07\xdc\xd6\x08\x67\xa7\xe7\xd8\x2a\x19\x98\xad\xd1\x81\x36\x53\xc4\xc2\xac\xee\xd2\x92\xd7\xcc\xea\x8e\x44\xda\x21\xab\xdb\x67\x75\x57\xe9\xf2\x1a\xb3\xba\x4b\x7b\xbe\x5e\x56\x77\xdd\x96\x6f\x11\xc3\x88\x86\xf9\x66\xb2\xba\x4b\x14\x7d\xcd\x59\xdd\xa5\xa9\xee\x2f\xab\xbb\x7e\x67\x37\xcb\xea\xae\xbd\xfe\x9b\xf9\x67\xd7\x9c\x3b\x40\xe8\x7a\xe6\xac\xee\x68\x01\x87\xac\xee\x1d\x3b\x9e\xc4\x2c\x68\x67\x00\xf8\xd5\x36\x51\xb8\x2c\xeb\x5a\xf2\xba\x41\xa5\xdd\x03\x47\x3d\x6d\x6c\x15\xbc\x50\xeb\x6a\xdd\xbd\x88\x0e\xd2\x22\xaa\xea\xeb\xcf\xe5\xda\x06\x5d\x81\x0f\x48\x2f\xbb\x62\x70\x94\x88\xec\xbd\x57\xb0\x71\x4d\x2c\x57\x03\xb5\xb7\x03\x03\x5a\xc8\x82\x6d\x41\x06\x9b\x1b\x85\x1a\xb8\xca\xfd\x0c\xfb\xbb\xf0\xbf\x8d\x04\xd9\xb5\x4f\x4c\xb2\xc8\xb7\xc9\x8e\x9d\x6e\xf7\xd8\x9c\xcc\xb9\x58\x15\x7e\x6c\x30\x67\xb9\xc0\xd3\x55\x19\xb9\xeb\x52\x6f\x57\xaa\x39\x84\xd1\xcd\xfc\x1b\xb7\xee\xa9\x56\x83\xcb\x35\xd2\x09\x3d\xe0\xa0\x93\xd6\xc6\x58\x7c\x88\x6b\xcb\x28\x4a\x43\xe1\x41\xf5\x85\xe0\x5e\x95\x44\x1c\x07\x95\x04\xb1\x5f\xb3\x3a\x83\x88\xee\x4e\x41\xdb\x81\xec\xb9\x68\x8c\xf1\xaf\x21\x63\x7b\x06\xc7\x5a\x6b\x7f\x21\x60\x42\x99\xd3\xc6\xcb\x9a\x7c\xb4\xf5\x4c\x6a\xd3\xde\x7c\x13\xc7\x30\xfd\x87\xdf\xe8\x09\xcd\x08\xc2\x49\x42\xa4\x41\x31\xb1\x39\x20\x06\xb0\x32\x17\xd9\x2e\xbb\x4a\xd9\x14\xd6\xad\x95\xc9\xa0\xa1\x8a\x67\x1e\x73\x67\xcc\x04\xcf\xa7\x33\x67\x65\xb9\x9e\x9b\x75\x7b\xf9\xa5\x8a\x4f\xfd\xc6\x02\x02\xa5\x2e\x5c\x65\x26\xd8\x3c\x62\xea\x48\xf2\xcc\x51\xd3\xba\x75\x6c\xc0\x1d\x51\xee\x50\x71\xfc\x9d\x1f\xdb\x68\x25\x50\x29\x34\x64\xbd\x28\xcb\xc8\x41\xe2\x8c\x97\x45\xb6\x82\xb9\xda\x43\x26\x83\x26\xd3\xd6\x7a\x81\xae\x4e\xfa\x2f\x50\x43\xe0\x21\x1b\x4f\x75\x31\x53\x48\xb4\x20\xe9\x31\x4e\x96\x49\x46\x93\x40\x25\x9d\x0a\xbc\x98\xb5\x71\xe2\x21\xed\xff\xa5\xd2\xfe\xd7\xc4\xaa\x6f\x4d\x15\x09\xd1\xde\xdf\x74\x39\x42\x95\x1d\x0f\x95\x08\x1b\xb0\xe4\x6e\xf3\xd9\x3b\x27\xbe\xa5\xc2\x88\x66\xce\x7b\xe1\x24\xf4\xea\xc4\x5e\xb2\x1c\xa2\xe6\xbe\xd8\x8e\xba\x2f\x5b\x04\xb1\xd6\x32\x1a\x53\x0d\xd7\xa8\x7f\x88\x5a\x8b\xf9\x7b\x7f\x45\x35\x44\x33\x95\x5e\x09\x0f\xee\x33\x3f\xaa\x49\xda\xac\xce\x91\xda\x44\x55\xdc\x2c\x5d\xca\x6f\xd4\xdb\x4a\x99\xf2\xd3\xde\x32\x6d\xaa\x17\xf4\x00\x98\xf1\x0c\xba\xbb\x47\xd4\xf2\x2f\xf0\x99\x17\x9e\x40\x6e\x33\xa0\x95\x2f\xa8\xae\x05\xd8\x44\x5b\x72\x94\xdf\xc4\x6f\x23\x41\x6a\x85\x3d\xb4\x61\x92\x54\x48\xd4\xdd\x12\xa5\x76\xb4\x6f\x36\x4b\x96\x6a\x6b\xcd\x5c\xde\xef\x2d\xc2\x7a\x15\x60\x8f\x43\x50\xd8\x07\x85\xeb\x69\xf3\x1a\x03\xc3\xd5\x5e\x9f\x6b\x06\x87\x9b\xb6\x7f\x1f\x9c\xb4\xc7\x20\xf1\x0b\x87\x5e\x5b\xa3\xae\x01\x83\xbd\x6c\x2c\xbb\x2d\x8c\xbd\x9a\xcd\x6a\xe3\x72\xcd\x7b\xba\x51\x78\x78\x45\x8d\x83\x7b\xcb\xae\x31\x3c\x9f\x77\xff\xa4\x71\x3c\xef\x67\x0c\x9e\x58\x33\x96\x57\x14\x06\x1c\xe2\x79\x4f\x1a\xcf\xab\x21\xf4\xea\x98\x5e\xa4\x20\x3c\x6b\x20\xc6\xbd\xf9\x39\x82\x31\xab\x94\xaa\x7c\x3c\x7a\xf2\x73\x54\xbb\xe6\x75\x8f\xd3\x17\xbf\xb7\x0e\x18\x1d\x91\xf9\x98\xa4\x29\x18\x5d\x8a\x23\x0e\x85\x57\x05\x0b\x30\x62\x98\x55\x9b\x67\x58\x6a\xce\xc5\xd0\x23\x88\xa6\x26\x21\x73\x81\x01\xeb\xc5\xdf\xa1\x26\x4b\x6f\xc8\x60\x7f\xb3\x8c\x08\xa7\xb3\x0b\xf4\x4e\x52\x96\x90\x50\x8f\x17\x28\xe5\x44\xb2\xef\x94\xc1\xfe\xc7\x6c\x89\xee\x19\x7f\xcc\x48\x3a\x85\x1d\x2a\x4f\xe6\x18\x51\xd2\x41\x54\xf9\xc7\x04\xc1\xc9\x4c\x8b\xcb\xa1\x9e\x3b\xb8\xb5\xcd\x65\x4f\xec\xb3\xc2\x56\x9e\x07\x26\x83\x7c\xdf\x45\x68\xc0\xd0\x04\x6b\xa3\x58\xe6\xe3\x62\xfc\x94\x6b\x05\x01\x6e\xff\x70\xe1\xc5\x20\x4f\x16\x88\xab\x0d\xbc\x35\x68\xaf\x9a\x01\x7a\x19\xc5\x3b\x39\xc6\x1f\xf0\x2e\xa5\x80\x9f\x73\xa9\x4c\x87\x48\xe8\x29\x6e\xe7\x6b\x93\x9a\x7d\xd9\x33\xa0\x04\x99\x12\x62\xc6\xd3\xa6\xf0\x1c\x2e\x2d\x65\xd3\xb9\x14\x51\x0c\x0b\x4e\x64\x4d\x22\x18\xd7\x90\x3b\xe5\x8f\x4c\x2a\x41\xf0\x1c\x26\x22\x6d\x53\xdc\x89\x89\x57\x18\x67\x03\x15\xe6\x06\xde\x64\x8b\xcf\x29\xbb\xd7\xbb\x5b\x14\x7a\x73\xa8\xa2\xd5\x6f\xae\xd9\xb4\x1f\x28\xc3\x62\xa7\xc6\x73\x06\x89\x7e\x2b\x53\x7e\xbc\x6c\xaa\x84\x57\x78\x55\xd9\xfb\x26\x86\xbb\xa4\x73\x7d\x2f\xea\xd7\x21\x10\x75\x06\x56\x0e\x23\x85\xa7\x9a\x3e\x33\x92\x2d\x02\x90\xa8\x05\x16\xca\x77\xb4\xb0\xd5\x9f\x09\x9f\xcf\x73\x06\x05\xbb\xd6\x16\x78\xb4\x65\x7e\xd6\x2f\x54\x0c\xde\x1d\xb2\x81\xfa\x4e\xea\xf3\xc5\xd9\x34\x5b\x22\x9c\x3e\x50\x59\x14\xdd\x27\x9c\xc9\x7c\x4e\x84\x7d\x05\x95\xa6\x25\x82\x69\x91\x89\xb0\xe3\x15\x3d\x37\xad\x78\x39\xc4\x42\x7b\x37\x4c\xd1\x98\x4c\xf4\xa5\xbb\xc0\x42\x3a\x1f\x44\x8d\xff\xc0\x6e\x6e\xaa\x69\xf5\x62\x67\xf2\xe7\xf0\xd8\xa1\x79\x71\x42\xb1\xd5\x69\x3f\x94\xcf\xa7\xeb\x23\xd2\x7c\x36\xc7\x95\x45\xa1\xf6\x8b\xc9\x52\xe1\xac\xd2\x6e\xa1\x6c\xea\xb9\xae\x0f\x12\x0e\x8d\x7e\x8f\x53\x68\xcc\xe4\x36\xf2\x16\x95\x16\x68\x67\x6d\x5c\x00\xe1\xd9\xb4\x3d\x8c\xa5\xc2\x8a\x26\x56\x77\x2a\x70\x75\xcd\xd3\xcd\x5b\xbb\x2e\xe0\x69\xd3\xf6\xca\x04\x67\xd5\x1d\x6e\xa6\xe5\x8d\xf9\x7d\xbb\xec\xb3\xc7\xcd\x8c\xdd\x9a\x06\x91\xf0\x2c\xdb\xa4\xae\xbe\xb4\xf2\xd3\xe2\xf1\xf6\x19\x15\xef\xd1\x1b\xe0\xf6\x02\x4e\x8d\xc1\x02\xc0\x99\xd5\x2c\xa4\xb2\xbb\x14\xfe\xc8\xc8\xd0\x25\x62\xf9\x7c\x4c\xc4\x90\xf1\x09\xc0\x2d\x64\x4d\x66\xe3\x42\xf0\x39\xdd\xa4\x30\xe9\x12\xb6\xf9\xda\x05\x7b\x56\x78\xb3\x5c\x48\x48\x9f\x22\xcb\x5e\xf6\x8d\xa6\x63\x0c\x33\x7a\x46\xcb\x19\x9a\xe3\xc5\x56\x04\xaf\xf4\xac\xaf\x50\x7a\x6e\x4c\x57\x4b\x3d\xa8\x86\x26\x00\x62\x00\x44\x7e\xc4\xcb\x22\x59\x64\x93\xe3\x74\x63\x74\x11\x22\x8b\x9e\xdf\x96\xcb\x82\x13\xe3\x83\x65\x66\xbf\x0c\x15\xd6\x39\x41\xa7\x75\x6c\xb8\xf1\x59\x72\x6b\x7e\x4a\x25\x3b\x3c\xf6\xa1\x7e\xbd\xc9\x6d\x18\x1f\x86\x60\x44\x04\xd3\x69\x27\xd5\xe7\x88\x73\xf6\x4e\xa3\xd2\x38\xc8\xd8\x72\xce\x57\x7e\x55\x3f\xea\x33\xd0\xcc\xb2\xf5\x5a\xc4\xda\x31\xff\x6c\xb3\x2e\x13\xee\x8d\x35\x4d\x25\x82\xf3\xbe\x49\xe7\x9a\xd5\x36\xc4\x44\xeb\x2e\x46\xad\xe4\x93\x49\xc6\xb1\xb6\xd4\x6c\xec\x7a\x42\x33\x22\xbb\x68\x50\x63\x4f\x84\x8d\x9f\x4c\x79\x2b\x44\x42\x9c\xbe\x93\x0b\x6a\xb3\x32\x88\x20\x5e\xab\x41\xd4\x82\x0e\x17\x2e\x07\x41\xf4\x9c\x81\x81\x41\x93\x9f\x69\x13\x6f\x66\x06\xa0\xe0\xa0\x9a\x63\xa5\xf4\x94\xc0\xb6\xa3\xca\xf8\x22\x52\xb2\x20\x2c\xf5\x0f\x70\xd3\x91\x14\x27\xa6\x5d\x6c\x31\xab\x86\x2d\xdd\x07\xf2\xc9\xfa\x31\x7a\xf7\xd6\x52\x5b\xe6\xdf\x85\xff\x2d\xcf\xf0\x36\x1e\x7d\xe3\xd9\x79\xbd\x7c\x73\xe7\xfe\x47\x78\xd4\x39\x93\x30\x9a\x08\x02\xfe\xc6\xb9\xcf\x0b\x64\x29\x11\x52\x71\x0e\x37\xd4\xcd\xd9\x4f\x1f\xee\x06\x88\xa8\x04\x70\x58\x87\x2c\x91\x0f\x1d\xad\xd0\xfe\x3d\x27\x4a\x7f\xdc\x04\xc2\x33\x27\x4c\x82\x24\xa0\xeb\xe2\x71\x3b\xc2\xe8\xff\x9e\xc5\xcf\xb7\xb0\x7c\xd0\x39\xda\x00\x56\x01\xef\x3a\x60\x0c\x60\x53\xa8\xc6\x8e\x5a\x66\x46\xfb\xc1\x79\x46\x30\xeb\xd7\xa1\x9f\x6d\x11\x0d\x66\x7f\xcb\xd9\x86\x6a\xd2\x69\xf1\x50\x30\x8b\x06\x2d\x6c\xbe\xc0\x82\xca\xcd\x86\x77\xcf\xd4\x8e\xbe\x4a\x88\x38\xba\x62\x34\x36\x94\x42\x05\x50\x1c\x52\x82\x10\x10\x21\x9e\x9f\xec\x5d\x0f\xb7\x7c\x40\x8d\xe0\xa1\xee\x90\x7d\x76\xfe\xcf\xe2\x53\x59\x34\x8a\x9e\x8f\x01\x74\x25\x07\x9b\x29\x1e\x05\x86\x4d\xa9\xf4\x1f\x40\x2d\xbe\xcc\x33\x65\xa0\x91\x26\x94\xe1\xcc\x4f\xd4\x7c\x53\x27\x25\x04\x66\xc9\x0c\xfa\x6f\xed\x12\xa1\x9d\x8c\x48\xb6\x89\xee\x38\x98\xf4\x33\xa9\xf9\x3b\xb9\x6f\x38\x9d\x7f\x70\x90\x6a\x1b\x6c\x50\xb1\x18\xd0\xdc\x1c\x40\x8c\xb1\x4a\x8c\x9f\x2e\x33\x40\x4b\x04\x81\x93\xad\x9c\x1c\x60\x92\x29\xf5\x2e\x5a\xdd\xda\xb6\x93\x83\x36\x90\xce\x2d\x37\x86\xb7\x20\xac\x86\x4c\xe4\x0c\x2a\xaa\xbd\xff\x1c\x23\x49\x04\x35\x8e\xec\x84\x33\xa3\x03\x58\xe7\xc9\x54\x8b\x09\xad\xf9\x99\x86\x89\x0c\x2c\x2a\x9e\x4b\x2d\x43\xf0\x9c\x28\x7d\x41\xbd\x03\xcc\x3f\x13\xc1\xe8\xa0\x85\xa0\x73\x45\x1f\x88\x87\x41\x08\x77\xae\x96\x99\x77\x89\x6e\x2d\x88\xc0\x6a\x5d\x54\x85\xba\xb7\x5f\xba\x11\x6a\x0f\x6c\x46\x26\x6a\x54\xeb\x77\x69\x31\x31\xf4\x88\x2c\x6d\xc8\x22\xa3\xd3\xd9\x1e\x46\x5c\xff\xd4\xff\xc9\xfa\xc5\xf4\x51\x0f\x6e\x7c\xc1\xb9\x32\xfc\x56\xc8\x24\xe4\xa8\x09\xea\x82\x7d\xa9\x41\x62\xd2\x9b\x4a\x61\x57\xf5\x19\xbe\x67\xfc\x91\x79\xdb\x5a\xab\x0d\x7d\x0c\xe0\x60\x5e\xb0\xd8\x38\x85\x39\xd5\x2b\xcf\x73\x84\x36\xf4\x4a\xea\x38\xc2\x5e\xbd\x80\xa0\x98\x2d\x51\x81\x28\x15\x3d\xb7\xce\xf5\x66\xec\x4e\x77\x76\xcd\x82\x2d\x88\x8a\x22\x0b\x6b\x1b\xdb\x1e\x94\x3e\xc9\x03\xdc\xab\xfa\x55\x5d\xf4\xc5\x69\x72\x10\x06\x2a\x90\xd0\x6c\x9f\xdd\x0c\x2f\x5d\xd3\xf3\x3a\xc2\xee\x23\xc1\x7f\xdf\xb1\x99\x76\x02\xfb\xcc\xcd\x1a\x2a\x47\x17\x2a\x63\xc6\xc2\x5a\x33\x76\x6c\x2f\x6c\xfb\xd0\x0d\x69\xcf\x49\xf8\x08\xa8\x2a\xa6\x9d\x3e\x78\xab\x38\xcb\x96\xff\xcb\x6c\x16\x24\xf6\xfb\xce\xbb\x16\xcb\xc3\xfa\x30\xf5\xf9\x01\x1f\x1c\xe3\x4a\x5f\x8a\x13\x9a\x65\x10\x63\xe9\xa2\x1e\xe0\x82\x01\xe2\x93\x56\xe4\x5d\xf0\x8e\x4e\x19\x5f\x15\x62\x68\x60\xa6\x24\x60\xa6\x9b\x66\x66\x92\xc0\x4d\x3e\xaa\xb0\x27\x8e\xda\x43\x0a\x9e\x96\x2d\xb8\x5a\x46\xb6\x7e\xe2\xdd\x06\x97\xf1\x4b\x84\xeb\x2a\xd3\x0d\x4d\xe3\xfa\xa9\x7f\xca\xb1\xc0\x4c\x41\x10\xca\xa2\xc7\x0a\x1b\xe8\x85\x16\xda\xe4\x2b\x44\x6b\x99\x31\xec\xe0\xa3\x70\x73\x9d\xd3\x7d\x4a\x1f\x08\x43\x34\xed\x20\xda\x25\xdd\x8e\x45\xdf\x95\xf9\xb8\xf8\xe5\x0c\x4b\x84\x87\xac\x92\x48\xd6\x45\xbd\x4c\x72\xfb\x04\x61\x49\x06\x38\x7c\x41\xbc\xcc\x73\xbe\x75\x13\x41\x03\x65\xbb\x95\xc5\xf0\xdc\x7e\x11\x3c\x38\x64\x58\x1a\xaf\x74\x06\x27\xbd\xf8\x7c\x45\x7f\xf3\x27\xad\x33\xae\x5c\x43\x4f\xb6\x49\x06\x50\xae\x6d\x83\xe0\x17\xb0\x31\x45\x82\xdf\x90\x79\x76\x46\xef\xb0\xca\x08\x96\x0a\xfd\xf1\xfd\x46\xc1\x19\xb7\xbe\x42\xb8\xda\xd3\x5b\xa4\xa1\xb8\xd0\x77\x13\x4c\x30\xc0\x10\x21\x0c\x8d\x91\x7d\x62\x4a\x47\x6f\xb3\xe2\xe8\x81\xca\x1c\x90\x0d\x83\xb4\x2a\x83\x4d\x47\x95\x74\x30\x2b\xc6\x4f\xd9\x20\x46\x1c\x52\xac\xf5\x5f\xda\x69\xd5\x30\x56\xc7\x90\x9c\x1a\x65\x17\x32\x9b\x8b\x20\xf4\x4c\x6b\xb9\x56\xb0\xba\xb8\x4d\x00\x81\xd5\xcb\xb2\x38\xf0\xab\x15\x9c\x94\x30\xbd\x60\xc0\x65\xec\xa2\xb0\x89\xa8\x2c\x62\x85\x31\x34\xb3\x3f\x2b\x5a\x71\x1e\x32\x9f\x9d\x1a\x8e\x5d\xab\xec\xd4\x99\x8b\xcf\xa8\x03\xd7\xbc\xfe\xdc\x00\x64\xae\xa1\x0b\x37\xa3\x8c\xb7\xb8\x57\x2a\x26\x7a\x8b\x6a\xbc\xef\x17\xac\xaf\x29\xd7\x9b\xbb\x70\xcb\x3e\xf2\x1a\xeb\xb9\x61\x73\x03\xd5\x62\x87\x4d\x2d\x82\xd6\xcf\xe5\xc0\x8d\xa6\x3e\x48\x21\xa3\x6c\xb5\x10\x2c\x32\xb4\x9c\xe8\x00\xbb\x95\xa6\x41\x8e\x49\x10\x80\x87\x54\x22\x27\xf7\xec\x2f\x9b\xf0\xb0\xde\xf6\xf2\x3b\xc5\xfa\xdd\x52\x7c\x14\xba\xba\xf0\x66\x5d\xaf\x97\xfe\x0d\x27\x84\x25\x4b\xf3\x26\x87\xeb\x57\xe8\x71\xa0\xec\x05\x15\x9c\x18\x6c\xf3\x5a\xed\xd0\x62\xdd\x76\x51\x1f\xee\x19\x07\x7d\x8b\x27\xce\xbf\x10\xfc\x78\xc8\xb4\x61\xa2\xaf\x78\x69\x26\xed\xc6\x8f\x59\xbc\xee\x04\x98\xd4\xfd\x9d\x5c\x33\xf3\xd5\xe0\x00\x4d\xc6\x84\xab\x1c\x80\x31\xa0\xd2\x1a\xf5\xa7\x27\x28\xe5\xc9\x3d\x11\x1f\x04\x49\xa9\x3c\x01\x57\xb9\x6a\xf4\xd1\xcd\xb5\xb1\xbd\xb3\xa2\xb1\x2d\xfa\xbc\x79\xbf\xcd\x3e\x32\xf7\x16\xd1\x1a\xc2\x04\xac\x09\x97\x55\x68\x52\x0d\x2d\xf4\x05\x22\x4c\x89\xe5\x82\x53\xa6\x5c\x96\x44\x52\x22\x84\x33\x34\xb4\xce\xd6\x94\x8b\x23\xf6\x11\x52\xdb\x72\xd9\xb7\x33\x22\x89\x8b\x1f\x98\x45\x29\x8e\x0c\x2a\xb4\x11\x17\x0b\xac\x66\x12\xf2\x22\x63\x1a\x58\x9b\x0b\x1e\xd5\x14\xc2\x0b\x08\x3f\x18\x27\x45\xf1\x90\x4f\xf8\x93\x8a\x66\xd9\x90\x31\x42\x52\x89\x00\xa7\xe8\xbb\xda\xfc\x5b\xfd\x68\x07\xe1\x34\x45\xff\xfb\xdd\xc7\xf3\x5f\x6e\xfb\xa3\xc1\xc5\xd5\xdd\xed\xe8\xe3\xe0\xbc\xff\xbe\xe3\x3f\xbc\xbc\xbb\xf5\x9f\x1a\x07\xcb\x03\x11\x68\x8e\xef\xc1\xc2\x63\xd2\xa8\x7f\x90\x16\x17\xce\xd4\x95\x3b\xe9\x6f\x24\x71\xa9\x26\x56\x4d\xf1\x05\x2f\x76\x0f\x57\x94\x24\x6e\x60\xfb\x5e\xfb\x47\xda\x79\xd0\x31\x8f\x7f\x85\x53\x03\xe7\x84\x29\x2d\x63\x6c\xce\x5a\x61\xfa\x16\x0c\x47\xd8\x94\xb2\xa6\x80\x38\x61\x0f\x4f\xa9\xc3\xff\x44\x96\x3f\x6b\xeb\xfa\x0a\x53\xb1\x36\xef\xf5\xd9\x03\x15\x9c\xc1\xd2\xbc\x57\xab\xe8\xd0\x41\x60\xc1\xa5\x43\x25\x8d\x2e\x0c\x21\x97\x45\x63\xd2\x05\x9b\xd0\xc6\xf4\xaa\x17\x5b\x6e\xcf\xb8\x89\xc9\x57\x25\xb0\x6d\x08\x2a\xad\xb8\xc1\x0f\x98\x66\x90\x30\xe3\x2e\x9a\x82\x07\x4d\xe3\x87\x13\x44\x32\x3c\xe6\x02\xd2\x68\x4d\x84\xcf\x0d\x61\x09\x06\x10\xe8\x7e\xa0\xa6\xc4\x0d\x2e\x9e\xae\x21\x4f\x74\x0f\x5d\x71\xb1\xce\x4d\xae\x7f\x06\x54\xe0\x0b\x6d\x92\x95\x84\xa8\xbd\x66\x27\x04\x1b\x24\x64\x09\x92\x46\xe6\x0b\xbd\x0e\x9b\x0c\x92\x65\x11\xe8\x96\x3e\x03\xb2\x6b\x9d\xe3\xc5\x2f\x39\x43\x3f\xfd\x59\xa2\x71\xae\x86\x2c\x1e\x83\x33\xe8\xbf\xf3\x03\x56\xc9\xec\xfd\x90\x5d\x6a\x83\xf1\xa7\x3f\x37\x14\xe4\xa4\x58\xe1\x51\x3d\x7f\x35\xd3\xe4\x0c\x2b\x7c\xce\x71\x4a\xd9\xf4\xd4\x3c\x5a\x4f\x8b\x1f\xfa\xb7\xbd\x13\x74\x69\xad\x71\xdf\x33\xb6\x28\xe3\x0a\x06\x02\xd9\x0a\x0b\x71\x02\x01\xa4\x32\xf3\x52\xdc\x3a\xbb\x40\x11\xd2\x77\xcf\x90\x01\x29\x8d\x80\xa4\x0a\x2d\xb8\x45\x48\xd1\x06\x16\x47\x22\x67\xd6\x29\x6d\x7d\x82\x9a\x3a\xc0\x91\x7e\x33\xac\x6a\x05\xaa\x49\x55\x6e\x0f\x19\x98\xda\x3e\x69\x3d\xe3\x09\xce\x20\x5a\x7e\x1c\x78\xe7\xb4\x01\xce\x73\x48\x3d\x86\x30\x15\x5b\xc6\x49\x2d\x0e\xbf\xae\xd0\xaf\xc2\x8d\x02\x53\x1e\xf6\xd1\xc2\xba\xcc\xb9\x16\x1e\xdd\x21\x1b\x4c\x4c\x30\x3d\x33\xd4\xd1\x0f\x12\xa6\xa7\xef\xc9\xa2\xbf\x75\xa2\x05\x20\x6e\x4d\xc5\x2b\x4e\xc0\x11\xcf\x96\x90\x0a\x05\xd0\x19\x1c\x82\x32\x85\xa0\xb5\x4c\x59\xd9\x45\x7f\xbd\x85\x8f\x0d\x99\x09\xe2\x47\x1b\x63\xa9\x55\x7e\x3d\x67\x90\x63\x50\x5c\x7d\x5e\x59\x58\xd8\x9c\x03\xab\xb7\x2f\x04\x39\x76\xad\x10\xf4\xa7\x01\x51\xf5\x6d\xd9\x45\xd7\xa1\xa9\x9c\xf2\x24\x9f\xbb\x9a\x56\xc8\xd1\xb6\xc1\x69\x7b\x21\x7a\x16\x31\x97\x74\x2d\xcb\xff\x2e\xfc\x6f\xad\x9e\x79\xb5\x63\x03\x1d\xcf\x56\xa3\x45\x3c\x52\x34\x1a\x65\x8a\x4c\xcb\xf5\x99\x9b\x40\x05\x5d\x40\x46\x1b\xf4\xf1\x86\xce\x3a\x1c\xd9\x8e\xcc\xb6\x80\x65\xc1\xd3\xef\x24\x1a\x5c\x69\x85\x43\x1b\x98\xfe\x9c\xe4\x52\x99\xd0\x2c\xa4\xa7\x9a\xa7\x4d\x7a\x5c\x07\x7d\x8f\x86\xf9\xf7\xdf\xff\x73\x82\xbe\xba\x3f\xfe\xed\x5f\xff\xf5\x9f\xff\x6d\x9b\x46\x51\x30\x6e\x41\x23\x5b\x3e\x5e\xd6\x40\xc2\x1d\xa8\x4a\x93\x1d\x76\xc1\x1e\x92\x26\xf2\x5b\xeb\xbb\x31\xbd\xb9\xee\xeb\x22\x67\x22\xc3\x53\x7b\x0a\x65\x78\x7a\x50\x74\x7c\xcc\x29\x87\x03\x43\x54\x27\x3e\xc5\x5e\xb7\xb4\x0a\xf4\xff\x6a\x29\x62\x1b\x69\x6e\xde\x2e\xb7\x83\x66\x5e\x9b\xd5\x83\xa0\x77\xd6\xdd\xa6\x20\x5c\xf7\xde\x5d\x42\x3c\x4b\x89\x30\x73\xf2\x1e\x32\xef\xb7\x83\xf3\x4b\xbe\x2e\x32\x9e\xba\x66\xfa\x92\x2c\x30\xdc\xd7\xfa\xbc\x76\xd1\x90\xf5\xbf\x62\x2d\x5e\x3b\x0e\x03\xde\x34\x2c\x83\x40\xc7\x04\x27\x04\x19\xd5\xf8\xdd\xd7\x13\xfd\x59\x07\x2d\x4f\x20\x07\xa3\x83\xfe\x71\x62\x4b\x9f\xb0\x50\x23\xfd\xd1\x7b\xa7\xdb\xda\x21\x60\xd6\x54\xa2\xe1\xd1\x87\x07\x2c\x0c\x08\xe8\x07\x8b\x12\x74\x64\x05\xa0\x07\xc7\x0a\xb5\xe1\x8c\xf3\x7b\x9b\xa1\x52\x79\xd2\xfe\xa7\x6b\x38\xdc\x07\x2a\xcc\xee\xdb\x64\x23\xad\xb9\x1d\xc3\x0f\x08\xea\x2e\xc6\xa8\xfb\x37\xc9\x19\xea\x2e\xf1\x3c\xb3\x9f\xba\x6f\x6d\x02\x0d\x96\x36\x0d\x3c\xd5\x42\xed\x81\xf2\x5c\x66\x4b\xe3\x9b\xfc\x21\xe3\x63\x58\xd7\x67\xb7\x56\x93\x82\x02\x13\x2d\x2e\x89\xe2\x5e\xb1\x0b\xa1\xda\x62\xc6\xa9\x29\x07\x83\xfe\x02\xfa\x27\x26\x96\x5e\xb7\xac\xaf\x7e\x4e\xff\x65\x22\xb1\x40\x15\x97\xb8\x6e\xfc\xb1\x9a\x58\x36\xef\x72\x82\xbe\xa2\x77\x56\x0c\xbd\xd7\x77\x81\x4d\xf8\x31\x74\xa8\x7b\xc1\xd2\xbf\xe0\x97\xe0\x05\x94\x21\x53\x8a\xd0\xf2\xe4\x3f\x3e\x74\xbb\x5d\xff\xf4\x85\x5e\xcb\xff\x45\x54\x49\x92\x4d\xcc\x48\xee\xa6\x59\x0e\xd9\x67\x6d\xb7\x84\xfe\xe2\xa2\x80\x17\x40\xbf\x13\x9e\xa1\xe3\xc2\x87\x9a\xf2\x44\xa2\x7f\xd2\x9a\x64\x40\x4b\xf8\x50\x9b\x4e\xf5\xe7\xca\xf6\x7e\x78\xa6\x83\x65\x7d\xd0\xe5\xa3\x15\x96\x65\x7a\x5b\x12\x6b\x0d\x24\xa5\x0f\x34\xcd\x1d\x33\x68\xd6\xf9\x60\x4b\x37\xa1\x2d\x83\x22\x5f\x15\x7c\x55\xbf\xb8\xfa\x64\xb0\x7a\x25\xae\x22\x72\x8b\x32\x56\xc3\xd7\x0d\x04\xb0\xf5\x8b\x56\x3a\x98\x75\x76\xc2\x80\x85\xbe\x60\x58\x88\x95\x20\xf3\xf9\x1c\x8b\xe5\x87\xe2\xb8\x55\x99\xb3\x80\xcc\x01\x39\x93\x39\x02\x40\xd0\x34\xb3\x67\xcb\xe6\x0d\x04\xdd\xe3\x66\x3e\x75\x10\xa5\x24\xa1\xa9\x4d\x5a\xc4\x06\xcf\x8f\xb0\x84\xa7\x96\xaf\x8b\x8a\x8b\x58\xb1\xf0\xbf\xa9\xaa\x14\xae\x94\x4a\x16\xfe\x2f\xa6\x4c\x19\x96\xfd\x85\x7b\xb8\x41\x84\xf3\x91\x54\x5a\x58\x4e\x37\x08\x48\x0e\x2e\x6f\xdc\x33\xeb\x5f\xbc\x40\x87\x58\xb5\xc6\xce\x30\x73\x4e\x00\x81\x1f\x8b\x2b\x18\xb2\x29\x8c\x43\x24\xf7\xf5\x28\xe6\xdf\xa7\xfc\x8a\x66\xfa\xe6\x02\x1e\xef\x0e\x59\xf4\x71\x07\x91\x8c\xce\x29\xf3\xf9\xa1\x46\xbe\xf3\x89\xd1\x72\xef\xa9\xd2\x5b\x26\xd3\x7b\x2d\xc2\x5c\x69\x5f\x60\xfa\xf4\xd8\xd2\xb1\x8e\x8f\x05\x59\xa3\x3f\x97\x7a\x5e\x85\x59\xac\x75\x4e\x3d\xc4\xb1\xd5\x1b\x69\xc0\x78\x70\x7e\x87\x4c\x8f\xe6\xce\xd2\x94\x30\x22\x1c\xee\x9c\x1b\x2f\x18\xee\x18\xf4\x74\xea\x92\xef\x61\x04\x78\x07\xce\x15\xd7\xe2\x26\xc1\x59\xb6\xf4\x6a\x6a\x8d\x92\xd2\x2f\xf5\x5c\xd9\x3c\x57\x13\x5a\x78\x8c\x18\x4f\xc9\x86\x80\x0c\x35\x3d\x2d\xac\xe3\xd7\xc5\x0b\x05\x31\xf9\xb4\x20\x27\x9a\x0a\x08\x88\x94\x1b\x3a\x43\x6b\x9b\xc3\xd8\x71\x00\x16\xf2\x71\xdb\x06\x7d\x85\x4c\x83\x51\x9c\x59\x10\xd4\x3f\x44\xb4\x8f\x1b\xd8\xec\xa4\xa3\xa7\xdb\xb9\x83\xcd\xda\x13\x20\x7b\xd1\xea\x12\x4d\x05\xcf\x17\xbe\x48\xc8\xa5\x4b\x9b\x6d\xb0\x37\xda\x80\x4d\xf8\x89\xd5\xaa\xcf\x29\xbb\x37\x77\xe1\x53\xed\x91\x6f\x15\x13\x7c\xee\x24\x98\xa1\xf8\xb1\xed\x17\xa6\x67\x2d\x15\x4e\xee\x0d\x80\x47\x5b\xab\xa1\x4d\x9b\x25\x15\xf7\x65\x9e\x65\xf6\xb5\x85\xf8\x2c\xa0\x4c\x1f\x28\x46\x18\xdd\x5d\x0f\xea\xdf\x7d\x4f\xab\xde\xf3\x7a\xd9\x19\x33\x08\xfc\xcf\x4f\x74\xa3\x3c\xb7\x12\xe0\x0c\x89\x58\xdd\xbb\x00\x9a\x20\x14\x4a\xb2\x7b\xc7\x70\x9d\x96\x41\xa3\x79\x0d\xa7\xd6\x2f\xbe\x78\xf1\x99\x7d\xf8\xb3\x7e\xb6\x7e\x47\x3e\x43\x32\xa8\xaf\x98\x9b\x63\xa6\x17\xe8\xde\xda\xe0\x23\x32\x62\x71\xab\x29\xdd\x2d\xb6\x9a\x90\x79\x63\x2b\x78\x99\x1f\xc1\xbd\xca\x8d\xf2\x68\x9c\x46\x38\x33\x06\x97\x9a\x81\x22\xde\x41\x37\xc9\x8c\xcc\x31\xe4\x18\xcc\x63\x85\x1c\xf4\x92\x77\x19\x16\x53\xa3\x25\x48\xa2\xe4\xfb\x9a\x1d\x2e\xd0\x95\x76\xd8\xe1\x2d\xe0\xff\x42\x7f\x3b\x94\x0c\xb4\x49\x00\x3f\xcb\xb8\x24\xdc\x0b\x27\xf7\x7e\x77\x77\x68\x73\xd5\x3c\x02\x37\xa6\x30\xfd\xda\x52\xad\x8a\x35\xd7\xca\xed\x88\x38\x19\x36\xb9\x76\xb0\x93\x06\x7c\xc3\xce\x6d\x4c\x00\x1e\xa0\x79\x0e\x3b\x63\x4c\x86\x53\xb0\x90\x76\x4d\x33\x18\xb2\x9e\xfb\x89\xcf\x4d\x07\xfd\x46\x98\x28\x29\x64\x25\x99\x1c\x3c\xd0\x31\x82\x6e\x43\x76\x71\x0d\x8b\x60\x78\xbe\x8b\xac\xbf\xd3\x3a\x8e\x07\x07\x31\xd6\x9d\x53\x76\xdd\x3a\x1a\xde\x6c\xd1\x82\x77\x78\xf9\x8d\x5b\x62\x09\x78\xb8\xee\xc5\xab\x84\x6f\xdf\xd7\x1d\xd9\x81\x42\xac\x63\x93\xb9\x94\x2d\x8b\x3c\x19\x4d\x71\xa3\x97\x96\x5e\x16\x1d\xd6\x89\xc9\xaf\xdf\xcd\xa1\x67\xcc\x98\xbd\x67\xa8\xa8\x19\x61\xa0\x09\xae\x3f\x32\x14\x29\x6c\xee\x8d\xc3\x45\x22\x7e\x61\xb8\xf8\xe0\x42\xce\xa8\xc5\xc5\xb2\xb6\x6a\x10\x28\x76\x3e\x9d\xe2\x79\x2a\x91\xc4\x8a\xca\x09\xad\xd5\x90\xc3\xaa\x86\x5d\xa8\xbe\x51\x7f\x40\xb7\xcd\x6d\xac\xea\x13\xde\xba\xe8\x23\x15\x52\x05\x4b\x52\xdc\x17\x25\x34\x75\x1c\xd2\xc6\xed\x53\xc6\x97\xdc\x0a\x82\xdf\xb7\x06\xdd\x7c\x72\x63\x17\xf5\x0a\x33\xdb\x94\x65\x18\x03\x7a\xc5\x8a\x48\x26\xc9\x36\xcc\xb7\x96\x4d\x02\xee\x68\x60\x20\x04\xe2\x52\xea\xcf\x0b\x6c\x0f\x3f\xcd\x47\xa8\x1f\xc0\xf7\xa4\xa9\x4f\xe1\xa6\x3d\x2e\x57\xb6\xb6\xec\x79\x93\x83\x1b\xab\x63\x9b\x09\xae\x7f\xec\x8a\x4a\x18\x3a\xf9\xa0\x49\x6e\x9b\x46\x1b\xd7\xe0\x04\xf8\xd0\xd6\xd2\x3c\xce\xb8\x0c\xcf\x99\xdb\x3f\xd8\x4c\x25\x72\xe2\xd2\x13\x21\xeb\xd3\x13\xd8\x04\x89\x18\x0f\x4b\x6d\x60\xd6\xfe\x90\x9a\xb4\x06\xbf\xdf\xc8\xde\x0d\x86\x0c\xe0\xae\x71\x43\x55\x4f\x73\x14\x10\xde\xe1\x38\xdf\x93\x55\x7d\x3d\xda\x36\xcd\x9f\xdc\x86\x6b\x6c\x53\x20\x93\xc6\xb3\xb4\x51\xfe\x2b\x78\x1b\x68\x02\x45\xf2\xe6\xda\x5d\x60\x5a\x17\xd9\xb0\x5e\xb5\xd7\x0a\xf7\xb0\x6f\x9c\x07\xbb\xdc\x2d\x31\x1e\x32\xf3\xb4\xf3\x01\xf2\x47\x87\xed\xb0\x0f\x44\x84\xc2\xbf\xb9\x1e\x1a\x82\x61\x1e\x69\xba\x61\x99\x79\x6d\xc6\x23\x11\x89\x8d\x5b\xd8\x06\x7e\x25\x04\x89\x4d\x31\x15\x9f\x78\x00\x0b\x13\xdf\x37\x58\x37\x7c\x52\xf3\x87\xb6\x62\xe4\xfb\xb0\x87\xb7\x7d\x47\x51\x53\xd5\xcc\x82\xfb\xc1\x4b\x70\xa4\x78\xca\xfb\xd0\x9d\x99\xf0\x3e\xdc\x84\xf0\xf5\x4c\x55\x84\xdf\x4d\x4a\x39\x16\x3c\x67\xae\xde\x9c\x33\xc2\x27\xe0\x15\x85\x40\x83\xb3\xfb\xa1\x14\x95\x71\x15\xa4\x8f\x0b\xb2\x30\xc9\x8b\xa0\xa1\x36\x93\x7b\x47\xcc\x85\x55\x74\x7e\x0a\xcc\x85\x5d\xe9\x6e\x0f\xce\x0b\x11\x7c\xd7\x4a\x7a\x73\x94\x36\x10\xb3\xf0\xfb\x95\xc6\xb8\x97\x03\x60\x7d\x87\xa8\xb9\xa6\x5a\x12\x72\x26\xc8\xb1\xe2\xc7\x50\x76\x03\xc5\x1c\x06\x05\xa5\x09\x1b\x10\x9c\x18\x9b\x5c\x07\xfa\xf7\x6b\xcc\xd3\x24\xca\x7c\x0d\x26\x6a\xef\x5e\x89\x5c\xc7\x0c\x50\x66\x18\x34\xbf\x05\xfb\x6c\xe5\xcd\xb1\xa1\x8b\x23\xdc\xca\x76\x1f\xa7\xad\xf0\x2f\x21\x54\xf8\xf8\x26\x0e\x84\x40\x17\x41\x32\xc8\x8c\xcf\xb9\xbe\xb6\x79\x2e\x83\x2f\x4d\x36\x11\x5c\x36\x2d\xfd\x42\x16\xa6\xcc\xf6\xe5\x56\xa3\x8f\x96\xfe\xca\xe8\x8e\xe1\x8f\x56\xc3\xf4\x04\x2b\x19\xc7\x30\x27\x2b\xe6\xef\xf1\x29\xda\xf9\x06\x1c\x68\x73\x3a\x9d\x59\xf4\x45\x5b\x75\x4e\xff\xa1\x2d\x48\xcd\x52\x3e\x71\xc7\xf7\x47\x36\x91\x76\x60\x28\x56\xd7\x76\xaa\x31\x80\xb1\x09\xca\xca\x06\x7d\xa2\x83\x2a\xcc\x22\x5e\xae\x89\xec\x63\x96\xae\x46\xc8\x3f\xf8\x50\x40\x7f\x2e\x17\xa4\x83\xc6\x39\x7c\x7f\x71\x79\x1b\xfa\x86\x28\x83\xaf\x8f\x93\x19\x49\xee\x21\xc5\xcd\x08\x45\x43\x2e\x87\xe1\x3a\x5e\x0e\x59\x01\x30\xa7\xb8\x73\x74\x2c\x7d\x05\xbf\x47\xb1\xe0\x02\xa5\x54\x2e\x32\xbc\x44\xe4\xab\x22\xcc\x44\xc6\x6a\x9a\xf5\x6b\x66\xd9\xce\x6c\x01\x04\x3c\x2b\x05\x9c\x1e\x06\xff\x72\x8b\xf0\x40\xdf\x3e\xcd\xa3\x4e\xed\xd8\x19\x53\x61\x97\x08\x59\x13\x96\x63\x00\x6f\x6f\x76\x34\x74\x95\xfa\x72\x0a\x56\xaa\x8b\x18\x1e\xb9\xc4\x13\xf0\xa0\x0c\x1d\x12\xb6\xfe\xb7\x41\xd2\x25\xe2\x81\xa4\x43\x16\x17\xac\xd8\xab\xac\xd8\x65\x54\x60\x7c\x35\x89\xce\xcd\x81\x84\x34\x9d\x3d\xce\x4d\x6b\xf0\x0e\x92\x74\x8b\xea\x5c\x9f\x5b\xd1\x82\x39\x56\x8f\xa5\xfd\x04\xe0\x58\x6b\x3b\x3f\x0a\x50\x31\x8b\x08\x64\x21\xff\x88\x09\xdf\x67\x90\xf4\xe8\x19\xd3\xa7\xe3\x9b\x5a\x3d\x1f\x73\xb6\x31\xe8\x4a\x42\x64\xdd\x18\x43\xe6\x12\xe7\x26\x79\x96\x99\xfa\xeb\xc6\xce\xfb\xa6\x3c\xc7\xc5\x78\x5f\xae\x06\xc2\xdb\xb5\x28\x40\x61\x0b\xfa\xd4\x2f\x52\x48\x75\x4a\x96\x05\xb2\x3f\x30\x2f\x61\x32\x87\x5c\x20\x87\xc0\x04\x19\xaa\x53\xa2\x90\xd6\x3b\xd2\x3c\x33\x99\x60\x90\x5a\x0b\xb5\x3e\x38\xcb\x10\x55\x72\xc8\x7c\x69\x92\x41\x46\x85\xab\xc0\xe5\xde\xa6\x56\x17\x84\x57\xc0\xb0\x16\xa7\x17\x2e\x08\x9a\x50\x15\x4d\x09\x3c\x95\xcb\x10\xb6\x64\xb1\x20\xd8\x64\x2d\xb8\x46\x71\xa1\x36\x58\xde\x06\x1b\xe2\x07\xf8\xd4\xe6\x8e\x8d\xfb\xe0\x5e\x03\x9f\xbb\xf1\xa6\x74\x51\xcf\xac\x4e\xab\x82\x0e\x43\xd4\xcc\xd6\x66\x4b\xda\x78\x82\xd6\xb7\x94\xf4\x80\xf7\x5e\xa3\x5e\x60\xa1\x68\x92\x67\x58\x64\x4b\x2d\x5d\x26\x79\x86\xe8\x24\x80\x43\x85\x4d\x30\x95\x29\xd0\xd6\x82\xc3\x1d\xe1\xb2\x5e\x24\x9e\x93\x20\x49\xcf\x1a\x9e\x59\xe0\x44\x34\x68\x1b\xc6\x3b\xa5\xc7\x7a\xdf\x45\x67\x65\xf0\x5b\x38\x16\x41\x45\x2b\x95\x46\x02\xfa\xf9\x06\xc9\x25\x06\x44\x97\x4e\xb4\xb2\xfb\x5d\x70\xf0\x9a\x50\xd6\xb1\xbc\xdf\xd0\x43\x79\x8b\xe5\xfd\x4a\x2f\xe5\xa0\x36\xb9\xec\x16\xc0\xbb\x23\xbf\xa5\x3f\x11\x2b\x3a\x8a\x6d\x38\xc9\xb0\x1a\x78\x8b\x89\x7e\x09\xd0\xb1\xcb\x93\x9d\xb7\xa0\xaf\xc2\x3e\x6e\x38\xd5\x00\x19\x69\xf3\x89\x06\x9c\x13\xfa\xa3\x1b\x29\xbb\xda\xb8\xfc\x12\x61\x14\x21\x3d\x2f\xad\xd8\x13\x13\xc1\x28\x35\x5e\x80\x39\x58\x30\x23\xc0\x93\xf1\x87\x6d\x4c\x50\x46\xd9\xbd\xcb\x67\xd5\x3b\xdf\x41\xb8\x18\x1d\x0e\x9f\x99\xbd\x61\xe6\x06\xcd\xc6\xe7\x1b\xec\x27\x24\xbc\x5e\x4e\x50\xed\xe6\xfa\x75\xd7\x3c\xbf\x9a\x11\xeb\xd6\xb1\xfe\xb6\xb4\x86\xed\xbc\x12\xeb\x62\x75\xe6\x82\x89\x9b\xc9\x2f\x57\xd1\xf7\x6a\x86\xeb\xbb\x96\x94\xb4\xc0\x23\xc2\xf2\xf9\xd1\x09\xfa\x7f\x05\x65\xee\x2e\xce\xfa\x1f\x07\x17\xfd\xb3\x80\x81\x8f\xfe\x72\xd7\xbf\x8b\x3f\xb9\xbe\xbb\xb8\x18\x5c\x7c\x0a\x3f\xba\xb9\x3b\x3d\xed\xf7\xcf\xe2\xdf\x7d\xec\x0d\xce\x4b\xbf\xd3\x1f\xc5\x3f\xea\xfd\x70\x79\x7d\x1b\x7f\x74\xf3\xd3\xe0\xea\x2a\xfe\xe8\x76\xf0\xb9\x7f\x36\xba\xbc\xbb\x75\xb4\xfe\xef\x80\xc2\x50\xc8\x00\xd1\x5d\x3f\xff\x5a\x12\xed\x03\xdc\x70\xd3\xf8\x73\x50\xad\x3c\x11\x94\xb0\x34\x5b\x16\xad\x39\xf5\xa1\x2b\x05\x29\x43\x91\x4e\xe7\x84\xe7\xbb\xe4\x0c\x68\xd3\x97\x3f\x68\x93\x3a\x43\x76\x34\x9b\x75\x55\x6a\x6d\x1d\xbc\x55\x10\x25\xaa\x6e\xb0\xd6\x2c\x0b\x25\x96\x3e\x8f\xa7\x35\x7f\xc0\x97\x61\xd8\x97\xa0\x85\xbe\x09\x9b\xe7\x02\x17\xae\xc8\x17\x8a\x8e\xab\x8e\xa6\x0d\xcb\x13\x36\xb7\xec\x4c\x8d\x5e\x7d\x76\xf5\x45\xbd\xa0\x73\x60\x61\x3b\x22\xf2\x80\x67\x7a\xfd\x1d\xb8\xf2\x8f\xd4\xb3\xde\xa9\x03\x18\xd4\x26\xb3\xc2\xac\xa1\xf8\x7a\x43\x10\xf4\x02\x11\x49\x14\xad\x08\xec\x4d\xe5\xac\x88\xa2\xa2\x73\x1b\xcb\xda\x82\xa2\xb1\xb4\xe8\xdb\x6c\xc1\xd2\x02\x44\xc4\x9a\x4d\x28\xc1\x4c\x3f\xf9\x2d\xd3\xca\xf3\x36\xeb\x14\x54\x3f\x83\x4a\x63\xcb\xd6\xcc\xb5\x0c\x50\x4f\x8d\xa1\xba\x3d\xa3\xd2\x7b\xd5\xb3\x80\xd4\xf6\x20\xed\x4e\x1e\x6d\xae\x68\x94\x00\xa9\x03\xb0\x6e\xd3\x1f\x10\x40\x88\x60\xd8\xc2\x17\x67\x35\x0b\x23\x07\x1e\x48\x8a\x8e\xc3\x26\x00\xe9\x31\xe4\x0f\x0e\x59\x93\x85\x59\x03\xa0\x1f\x72\xc0\x95\xc3\x47\xdc\x65\xef\x6b\xa8\xdf\x7c\x04\x1d\xb1\xd7\x4b\xaa\x40\xee\xe7\x5d\xd4\xec\xca\xb4\xfb\x32\xc6\xc6\x85\x04\x67\xcb\x03\x3f\x36\xa5\x78\xf9\xbb\x70\x33\x8f\xeb\x5a\xde\x56\x1c\x97\x95\x1a\x9d\x65\x86\xa5\xc9\x41\x74\x1d\x95\x0a\xd4\xff\xa2\xdd\x43\x93\xd1\xe2\x41\xc2\xf6\x58\x79\xd6\x64\x41\x76\x4c\x46\x80\xef\xdc\x14\x22\x2b\x79\x94\xb8\xcd\x18\xdf\xef\x86\xc7\xe3\xc2\x4e\xee\x81\xc0\xca\x70\xae\x75\xfa\x45\x86\x4d\x22\xd1\x0c\x4b\xc3\xd2\xce\x49\x89\xc7\x34\xa3\x0a\xb2\x30\x8d\x79\x5f\xa2\x30\x17\x68\x8e\xc5\xbd\xab\xfe\xc1\x45\x0d\x40\x1b\xd3\xef\x18\x48\x2b\xc0\x45\x9f\x33\x94\x56\x1c\xd9\x75\x7d\x03\x05\x5b\xda\x30\x5a\xb1\x1d\xa6\xfd\x8d\xe2\x01\x50\xea\x66\x3b\x6b\x47\xbc\x2a\x3f\x1e\xd1\xbb\xe6\xa2\xde\xdc\x67\x6b\x4b\x5b\x37\x10\xf3\xe5\xc2\xd7\xda\x93\x35\xc9\x38\x6e\x80\x3a\x75\x63\x9b\x3a\xd6\xa6\xb1\x53\x9e\x8f\x9b\xaa\xa6\xcc\xac\xda\x47\x6f\x33\xc0\xdc\xb9\xdd\x97\x42\x17\x0a\x40\xac\x08\x74\xcd\xdd\x8a\xa0\x45\xd3\xdd\xfa\xc1\x6d\xad\xd0\xda\x6b\xae\x30\x5a\x81\x78\xe0\x6b\xb3\x6e\x97\x0b\x52\x03\xad\xfd\x97\x1c\xe0\xbb\x2f\x27\x37\xa6\x37\xe8\x2e\x4c\xa6\x68\x95\xc3\xea\x4f\x62\xf9\xad\xb7\xb1\x75\x1b\xf2\xc0\xda\x5d\x6c\xeb\x56\x03\xbd\xea\xd6\x3f\x90\x03\x5f\x3e\x62\xb2\x9f\x29\x17\x5a\x6c\x6a\x53\xa6\xb9\x47\x63\xe3\x7b\x77\xa0\xe4\xdf\x73\x92\x13\xcd\xfb\xe3\x3c\x9d\x92\x5d\x4c\xb3\x62\x49\x33\xfe\x88\xe6\x79\x32\x43\x6e\x70\x94\x92\x0c\x2f\xa3\xa5\x81\xbe\xa4\x78\x06\x05\x5b\x5b\xd6\x0f\x99\x2e\xe5\x10\x64\x2c\xc6\x15\x39\x03\x86\x0f\x9a\x97\xd7\x90\x31\x4a\xa4\xdf\xd2\xb3\x70\x73\xd5\x3f\x1d\x7c\x1c\x94\xcc\xfa\xde\xcd\x4f\xe1\xbf\xbf\x5c\x5e\xff\xf4\xf1\xfc\xf2\x4b\xf8\xd9\x79\xef\xee\xe2\xf4\xc7\xd1\xd5\x79\xef\x62\x85\xf1\x5f\x7d\x45\x33\xd5\x71\x90\xd4\xaf\x15\x15\x9b\x87\x0e\x7e\x97\x16\x0a\xec\xd4\xf9\xcd\xf6\xc9\x7c\x32\xff\xba\x9f\xa4\xfb\xa3\xcf\x94\x58\x6e\x82\x02\x85\x52\x22\x41\x29\xb2\xae\xf4\x18\x81\x88\x48\x08\x4c\xb8\xd1\x2f\xe0\x96\x75\xa1\x1e\x1b\x2f\xb4\x74\x04\xf0\x0f\xda\xd8\x13\x34\xd3\xd2\xef\xb5\xd2\x21\x4c\x48\x05\x2a\x8c\x79\xce\x52\x07\xb5\x3e\xa7\xec\xc3\x1c\x7f\x7d\xef\x56\x5a\xb4\x5e\x87\xa2\x64\xd3\xdf\x2e\xd3\x2a\xf0\x52\x9f\xae\x76\x72\x0d\x59\x0b\xbd\x56\xab\x29\xee\x48\x83\xbe\x5d\x18\x47\x26\x7c\xf1\x40\x96\x75\xfb\x57\x01\x97\x30\x21\x12\x6b\x90\xc1\x20\x0b\x41\xa0\xb3\x88\x0f\x8e\x64\x26\xe8\xe5\xff\x0d\xc1\xf7\x08\x70\xaa\x5e\x6a\x84\x8e\xa1\x9d\xce\x4d\xad\x4b\xea\x09\xe0\x41\xec\x9b\xf4\xa6\x19\x07\x95\x2b\xd0\xb6\xc9\x06\xa9\xa9\x94\xd2\xbb\xf5\x37\x3e\x46\x13\xc8\xcd\xb0\x78\xb2\x82\x24\xe0\x6b\xd3\x7b\xe1\xaa\x19\x21\xc7\xbb\xe2\xf5\x72\x3c\x90\x11\x09\x9e\x5f\xe8\xcd\x40\xfe\x9e\xdb\x44\xce\x3f\x7e\xbf\x99\x84\x57\x62\x89\x5c\xdd\x74\x98\x1b\x62\x53\xa3\xac\xb4\x87\x79\xe5\x8c\xd6\x61\xc0\x5f\x9b\xae\x04\xcf\xdb\xfc\xa5\xf4\x52\xfb\xcf\x95\xe9\x33\xb7\xae\x26\xcb\xfc\xfe\xc9\x8a\x75\x7e\x2e\xd5\xe8\xd8\xd7\x41\x54\xdc\x8e\x2e\x83\x12\x10\x6d\xa6\x3f\x62\x91\x1a\x2f\x15\x38\x2c\xbb\xe8\x47\xfe\x48\x1e\x88\xe8\xa0\x84\x08\x85\x6d\xee\xbc\x3e\x6b\x59\x06\x07\xca\x8e\x33\x64\x90\x28\x62\x0a\x11\x18\x60\xf1\x2a\x3a\x9d\x69\x4b\xc6\x7a\x44\x6c\xff\x0e\x49\x14\xe4\xbd\x92\xaf\x0b\x92\x98\x0c\xa1\xa6\xb4\x88\x49\x86\x1f\xaa\xc5\x00\xdb\xe4\x79\x07\x2d\x4a\x5c\xff\x64\x5b\x40\xd5\xea\x21\x75\x9d\x2e\x8c\xd4\x5c\x2c\xd5\x8c\xb3\x0e\x9a\xf2\x0c\xb3\x69\xb7\xdb\x45\x44\x25\xdd\xf7\x1b\x31\xba\x1d\x30\x78\x5d\x11\xde\xcd\xb8\x24\xd9\xd2\xc3\x8a\xf8\x34\x1c\x4d\x65\x48\xfb\x91\xd4\xd8\xda\x35\xdc\x7f\x53\x4e\x17\x7f\x5e\x9f\x6d\xbd\x89\xb4\x71\xde\x59\xc3\x38\xe5\xc6\xa7\xab\x46\x32\xbf\xaf\x57\xf9\x37\xc8\xa3\x74\x10\x5e\x45\x3e\x65\x43\x39\x1f\x67\x9b\x26\x09\xfe\xcc\x9b\x60\x6b\xb7\xaa\x7f\xa9\x1d\xc9\x56\x2b\x6c\x95\x36\x57\xe5\xe8\x1a\x8e\xf3\x19\xa6\x3b\xd5\xda\x65\xf9\xbc\xda\x7b\x61\x5f\x5a\x54\x31\x49\xf3\xd7\x29\xbc\x6e\x7d\xa0\x43\x8f\xce\xcb\x85\x49\xed\xb3\xf3\x35\x4e\x38\xc3\x4c\x20\x2d\x05\x95\x50\xf5\xb3\x4d\xf6\x9d\x1f\xc6\x0c\x0d\xb1\x02\x6d\x50\x1b\xbc\x74\xdb\x99\x16\x12\x0a\x7d\x83\x59\xf3\x88\x34\xaa\x0e\x04\x18\x9a\x25\x43\x91\xb1\xbc\x95\xd5\x73\x71\x79\xd1\x0f\x4d\x99\xc1\xc5\x6d\xff\x53\xff\x3a\x0a\x88\x9e\x5f\xf6\x6e\xa3\xe0\xe7\xed\x75\x29\x66\xfa\xc3\xe5\xe5\x79\xbf\x77\x11\x7e\x74\xd6\xbb\xed\xdf\x0e\x3e\x47\x83\x9f\xdd\x5d\xf7\x6e\x07\x97\xd1\xef\x7e\x18\x5c\xf4\xae\x7f\x09\x3f\xe9\x5f\x5f\x5f\x5e\x97\xde\x77\x77\xda\x1e\x56\x8d\x96\x51\xbf\x13\x85\xb2\x1c\x24\x6f\xd7\x29\x85\xb7\x58\xde\xef\x39\x15\x00\x52\x5f\x36\x09\xe5\xd7\x46\xee\x23\xa1\x94\x92\xd1\x76\x59\x02\x4d\x99\x0e\xb5\xef\xd1\xfa\xe0\x72\x84\x95\x22\xf3\xc5\x6e\xe0\x77\xeb\x1f\x9c\xcd\x12\x10\xc0\xa4\x59\x23\x01\x21\xda\xd5\xd7\x93\x80\x50\x93\x5b\x50\x4d\x40\x18\x5c\x0c\x6e\x07\xbd\xf3\xc1\xff\x2d\x8d\xf8\xa5\x37\xb8\x1d\x5c\x7c\x1a\x7d\xbc\xbc\x1e\x5d\xf7\x6f\x2e\xef\xae\x4f\xfb\x37\x6b\xa6\x1f\x54\x1d\x7e\xc7\x28\x7c\xcf\x09\xba\xe5\x1e\x14\xc5\x6a\x85\xb6\x3f\x94\xa6\x38\xf4\xdb\xa6\x0a\x72\xc2\x29\x9b\x76\x00\x9d\xed\x04\xf5\x85\x18\xcc\xf1\x94\x5c\xe5\x59\xd6\x41\x1e\x84\xf1\x54\x10\xac\xe0\x67\x57\x3c\x1d\x04\xcf\x0d\x19\x3a\x46\xb5\xcb\x80\xf7\x5b\xb0\x43\xf3\xfa\x8e\x7d\x7f\x10\x6d\xf3\x0e\x12\x0b\xcd\xe7\x61\x65\x4f\xd0\x0f\x38\xb9\xe7\x13\x8b\xda\xd2\xf1\x26\x2e\xfa\x7b\xce\x15\x46\xe4\x6b\x42\x48\xea\x7a\xbf\x94\xf9\xe4\x9c\xef\x04\x56\xb8\x49\x93\xcf\xf0\x4c\xaf\xce\xdb\xa8\x7d\xce\x96\xd9\x8c\x36\x41\x0a\xb3\xab\xfc\x6c\x1e\xb5\xe0\x60\xb5\xa3\x2b\x95\xed\xc1\x99\x7c\xce\xa7\xf5\x29\xed\x90\xa5\x67\xf3\xf0\x0b\x50\x0b\x08\x4d\xf1\x29\x92\x94\xdd\x0f\xd9\x17\x6d\xd0\xf2\x5c\x98\x8f\x14\x17\x50\x1d\x31\xc9\x72\x39\x23\x00\x4a\xda\x41\x8f\x04\xcd\xf1\xd2\x84\xa8\xe2\x86\x45\xc0\x32\x9a\x39\xe1\xe9\x8c\x32\x2d\x2d\x16\xd4\x69\x90\xe5\xad\xdf\x87\x81\x99\x52\xe9\xed\xec\x27\x8c\x1b\x16\x9e\xc2\xc7\x19\x81\x24\xf4\x00\xee\xdc\x75\x4a\x31\x92\x1b\x0a\x1e\x39\xbf\xcf\x17\xb6\xcf\x3d\x96\xf7\xdf\xb9\x94\x4e\x20\xf7\x03\xa7\x29\x4a\xf3\x45\x46\x13\x2f\x77\x1f\xb9\x68\x4c\xc1\x31\x96\xce\x06\x29\x38\x25\xfb\xbd\x6d\x61\x35\x66\x54\x60\xb5\xb5\x24\xe3\x3c\x71\x3a\x52\x00\xb1\x94\x4b\x22\x8e\x95\xa0\xd3\x29\xe8\x8d\xce\x29\xf3\xfa\xf3\x95\x1c\x6f\x2e\x47\xbb\xfb\x1f\x42\x57\x75\x66\x5a\xc4\x78\xdc\x10\xcd\x53\x8b\x45\xb6\x74\x59\xc4\x86\x80\xee\xd8\x2f\x72\x61\xc0\x6d\x27\xc8\x4f\xa8\x31\x5f\x60\x21\x88\x7e\x4b\x3a\x32\xa8\x55\xbb\xa3\x69\x0d\x26\x06\xc3\xd5\xa0\xe4\x04\x81\x1b\x87\x9c\xe3\x6e\xb8\xe2\xdd\xae\xc6\xc7\x94\xd7\x03\x56\x2c\xe2\x8f\xcc\x34\xf7\x81\xdf\x83\x3e\xcf\x38\xe8\x26\xbe\xee\x07\x3a\xd4\x1b\x54\xc1\xd4\x96\xda\xd9\x72\x61\xeb\xe3\x34\xad\x0b\x5e\x3e\xbf\xcc\x0b\x6a\x48\x9b\x8e\x7b\x58\x97\x45\xe4\xae\x45\x40\x3e\x19\x67\x5b\x8d\xb8\xdd\xa6\x9b\x66\x7c\x6c\x60\xff\x2a\xe5\x41\xe1\xad\xb3\x99\x03\xd3\x75\xda\x8e\xef\x2c\x97\x66\x07\x79\x1b\xbc\x05\x76\x21\xea\x07\xb9\xd7\xfa\xa9\xdd\x09\x96\x2b\x1e\x00\x2d\xea\xc5\x0d\x4a\xfd\x0a\xbb\x26\x99\x7e\x90\xd6\xa2\xf6\x14\x27\xc6\x51\xbe\x49\x3a\xd7\xf8\x50\x36\x2a\xff\x5a\x08\xe2\xbc\x67\x4b\xa2\xbc\xd3\x2c\x73\xc9\xfe\xcb\x45\xdc\xa2\x2e\x8c\x1a\x38\xbf\xa0\x0f\x31\x42\x35\x4a\xd0\x04\x87\x33\xc2\x94\xb4\x70\xf5\x43\x66\x07\x77\xc5\xa4\x1e\x8f\xc9\x06\x42\x0c\x61\x3a\xd6\x06\xb1\xd0\xbf\x92\x67\x0f\x06\x1d\xb3\xa0\x89\xe2\x50\xec\xa1\x27\x78\xaa\xc5\xb9\x56\x5e\x30\x4b\x8b\x26\x26\x33\x32\x64\xa5\x8a\x4a\x41\xa6\x54\x2a\xb8\x58\x1c\xc7\x86\xcf\xef\xad\xca\x2c\xd2\x77\xda\x48\xdf\x58\x65\xb6\x4a\x70\x4d\x70\xb2\x49\xb5\xc7\x72\x41\xd2\x81\x7f\xae\x9d\x19\x22\xd7\x49\x1a\x84\x96\xa2\x43\x6e\x78\xc0\x81\x7b\x43\xa9\x9e\xf4\xb8\x74\x7e\x93\x3c\xc2\x97\xef\xde\xa6\xb7\x68\x8a\x5d\x07\x3f\xe9\xdb\xb7\x99\x48\x74\xe8\xf2\x2e\x75\x5b\xf6\xba\x54\xc2\xa5\x32\xf1\x35\x78\x64\x82\x69\x96\x8b\x46\x15\xc1\xb0\xe5\xde\x6b\x60\x4f\x61\x58\x54\xb7\x6b\xde\x2f\x1d\x1c\x23\xef\x93\xf6\x5d\x9c\xb3\x7c\x4a\x99\x8c\xb9\xbe\xb9\x9b\x49\xa5\xb3\xd3\x8a\x0d\x2f\x9a\x41\xad\x2f\x8b\x7b\xe6\xb0\x4b\x58\x3c\xc4\x21\x9a\xe1\xc4\xac\xd2\x16\xcc\x7d\xc8\x6e\xe1\xae\x36\x25\x9e\xfe\x98\x61\x03\x7f\x2d\xa4\x82\x7e\xbb\xb5\xeb\x8d\xe4\x79\xcc\xa9\x3b\x65\x57\xd5\x15\x63\xae\xce\xe2\xfc\x8c\x17\x6d\x75\x72\x3b\x8f\xb8\x6a\x1b\xbc\x77\xb3\x7c\x0c\xcb\xfd\x36\x6a\xa8\xe7\x33\x51\x9f\x25\x88\xb7\x49\xd5\xbe\x4f\x48\xb6\x78\x17\x95\x92\xeb\x48\x31\x0d\x1f\xdd\x3c\x27\xbd\x88\x5e\x59\xa4\x76\x33\xe0\xd8\x64\x11\x87\x89\xcf\x3b\x94\x7c\xfb\x8d\x71\x63\xb5\x6c\xc7\x8e\x49\x99\x45\x1e\xfd\x33\xe6\x64\xfe\x5c\x21\xd1\xa6\x29\x99\x0f\x61\x0e\x3a\xdc\x0d\x45\xe3\xf2\xb5\x34\x66\x9f\x8a\xf9\x73\x5c\x48\x10\x91\x98\xd3\xb5\x2a\x2e\xaa\x50\x90\xa0\xb4\xa4\x84\x71\x45\x10\x46\x8c\x66\x1f\x58\x9e\x65\x1f\x2e\xa0\x6f\xac\x94\x74\x6a\xda\x52\x99\x46\x0e\x10\x25\x2c\xc0\x89\x22\x57\x59\x70\x04\xe0\x8a\xd4\x53\x32\x5e\x3c\xa5\x25\xa6\xde\x82\x6c\x39\x64\xfa\x09\xa3\x62\x19\x4c\x17\xea\x23\xab\xe6\x6d\xbe\x69\x84\x79\x17\xe4\xb7\x2d\xc3\xc1\x6b\x18\xac\xad\x2e\x6d\xa7\x90\xe6\x01\xb0\xf4\xd5\x00\x96\x72\xe1\x3b\x28\xac\x0f\x5d\xda\x7c\xa8\xb6\xc6\x0e\xf5\x8a\x98\x0f\x09\xac\xc1\x8f\x2f\x19\x0e\x78\xca\x2a\xc5\x9d\x4b\x12\x1d\xa5\xf6\xe1\x15\xfd\xbb\x49\x74\x1d\xf1\xc9\x48\x56\x12\x86\x51\xbb\x98\xaf\xa4\x1a\xaf\xe7\x96\x0a\x93\x3c\xc2\x94\xdc\x2a\x93\x34\xe9\xe5\x9c\x8d\xac\xe6\xbe\xde\x64\xcb\x04\xbb\x64\x1f\xcd\xe3\x57\x3c\xa3\x49\xbb\x2f\xcf\x5d\x4d\x80\x81\x51\xf1\xe4\x02\x5a\x8c\x85\xc1\xc6\xce\x9c\x30\x4e\x2a\x45\x12\x55\x98\xa6\xd5\xc5\x6d\xe2\xea\xf8\x1c\xf4\xcf\xb1\x9e\x2b\x45\x45\x08\x9c\x52\xd4\x1e\xba\x98\x9b\x07\xb2\x81\xd3\x99\x72\x62\x82\x31\xc9\x0c\xb3\x29\xb1\x0d\x7d\xb4\x9e\xe3\x10\x04\x4a\x36\x53\xcb\x8d\xe1\x66\x73\x66\xb8\x75\xa7\xd4\xd6\x7d\x7a\xd2\x5a\xd9\xcf\x45\x28\x9d\x57\x3e\x6c\x89\x1f\x4d\xc2\x66\xdf\x19\x39\x09\x6d\x24\x55\xbc\x83\x06\xe6\xc6\x25\xf8\xd9\x96\x68\x39\xf6\xc5\x37\xe0\xd4\xd0\x1b\x65\x91\x21\x72\x06\xf9\x7a\xe4\xab\xc1\xdf\xc8\x96\xe1\xa8\x50\xa9\x0d\x23\x6e\x98\xc5\x00\x7e\x0a\x5f\x4c\xbf\x92\x41\x9a\x77\x73\x57\xc7\xa1\x29\x56\x5a\x64\x98\x8d\xcc\xe1\x7b\x01\xd7\x61\x50\x30\xd5\x84\xe5\x96\x8f\x47\x1e\x49\x62\x2f\xf3\xf4\xb7\xe2\x75\x54\xc6\x18\x76\x92\xef\x94\xf1\x9e\x9d\x16\x07\x19\x96\x45\xef\x66\xdb\x3e\x85\x7c\xad\x4b\x02\x5a\xed\xfe\xc4\x25\x67\x87\xef\x59\xb2\xc2\xff\xe9\x38\xe0\xb5\xfa\x40\xd7\xd9\xf9\x12\x83\x97\xb7\x7d\x73\xf7\x5b\xe5\x72\xdd\xca\x05\xb7\x62\x5a\x4f\xeb\x86\x6b\x34\x37\xab\xee\xb8\x2f\x71\x47\x72\xad\xc1\x9a\x70\x1a\x41\x92\x6b\x1d\xd8\x59\xc3\xf5\x05\x71\xa5\xdc\x97\x27\x05\x00\x8a\xf1\x0e\xd6\x4e\x22\x33\x10\x60\x68\x50\x34\xca\xea\xa0\xe1\x91\xe1\x2c\x39\x3c\x32\xa0\x99\xae\xae\xd2\xe1\x8b\xc5\x3d\x7f\xca\xce\x6a\x13\x47\x0a\x6e\x10\x16\xb8\x54\xca\x74\x69\xf0\xfc\xbc\x24\xb0\x57\x90\x61\x67\x42\xcd\x63\x33\x80\x55\xe4\x8d\x7d\xb2\x74\xa8\x5f\x50\xfb\x2f\xf2\x44\x15\x0b\xf6\x20\x49\x3f\xb8\x07\x35\x89\x16\x39\xf4\x5b\x4c\x8b\xae\x6b\x5c\x0c\x99\x1b\xad\xc0\x2a\xed\x65\x59\x65\xa8\x2a\x3e\x58\xc0\xab\x80\x16\xe8\x72\xdf\xa1\xa6\x42\xff\x08\xb2\x03\x2b\x72\x00\x3a\x96\x8e\x49\x51\x11\xde\x45\x05\x42\x1d\x14\x1d\x97\xa0\xb0\x42\x24\xac\x2c\x73\x30\x50\x06\x5c\x29\xc0\xfe\x91\x39\xb4\xd2\x99\xe4\x5a\x1c\xf9\xb7\x2b\x3e\x64\x80\x8a\x16\xa9\x52\xd0\x8d\x48\xba\x66\xfe\x92\x54\x3a\xb4\x5a\xb2\x7d\xe7\x4b\x00\xec\x07\x67\x5a\x88\xe8\xa7\x96\x0b\x82\x4a\x68\x04\x10\xeb\x84\x8c\x8c\x0e\x5a\xf2\x3c\x50\x60\x12\xcc\x86\xec\x6f\x9a\x3c\x0e\xea\xcb\x6e\x2b\x9f\x98\x43\xec\xd0\x1b\xd0\xbb\xbf\x9a\x41\xdf\xfd\xeb\xfb\xbf\xbe\x37\x40\x8a\xb9\xcc\xb5\x84\xed\xc4\x57\x88\x9b\xa8\xde\x52\xc8\x07\xf2\x7d\xf4\x5c\x77\x9e\xe2\x15\xad\xa0\x20\x56\x23\xde\x37\x04\x7e\xe1\xa5\xeb\xa1\x04\xab\x64\x76\x8c\x2d\xef\x85\xf0\x67\x54\x16\x0d\x16\xb4\x86\x0e\x3d\xde\xe3\xa6\x0c\xa6\x08\x05\xf9\xf6\xb8\x32\xa6\x83\xe6\x17\xd3\x4b\xcc\x6a\x85\x25\x20\x01\xf7\x26\x60\xce\xa2\x94\xfd\x4b\x21\x19\xdc\xcf\x5d\x4d\x45\xd0\xad\xcf\xb8\x13\xb5\x99\x9f\xa2\xa1\xc9\x41\x1e\x1e\xb9\xed\x1f\xb2\xc5\xb8\x9b\x2d\x27\xaa\x0b\x19\xd1\x5d\x4d\x96\x6e\xbf\xb5\xe5\x98\xb9\x84\x46\x69\x55\x2b\x5f\x41\xee\x46\xbd\xbe\x5e\xdf\xf1\xd4\xf1\x6f\x5a\x5f\x69\x31\xee\x00\x4f\x9f\x9b\x38\x5e\x40\xbc\x7f\x81\x98\x18\x50\xc7\xc1\x5b\x61\x96\x86\x8a\x55\x71\x3e\x01\x6b\x4d\x5f\x74\xbe\xaf\x1c\x66\x38\x5b\x42\x65\x53\x67\xc8\x4c\xcb\x4b\x92\x22\x9c\x2c\x93\x8c\x26\x16\xaa\x2a\xd6\x85\xc8\x03\x61\x2a\x4a\xc0\xec\xeb\x4f\x9e\x4b\x1d\x6a\x4a\xfd\xac\xa7\xfe\x5d\x83\x2a\xe4\x61\x05\x63\x0f\x4b\x99\x4d\x2c\xb8\x86\xd8\x10\x9c\xc4\xbf\x1e\x44\x73\xea\x8c\x45\x2e\xe8\x94\x32\xac\xb8\x40\xef\xc0\x55\x9c\x65\x44\xbc\xf7\x3d\xd0\x80\x8a\xf5\xd3\x98\x6d\xd4\x79\xa4\x06\xa7\xaa\xfe\xb2\x4d\x92\x5c\x08\x92\x8e\xaa\x19\x77\x9b\x16\x72\xb7\xe7\x23\x69\xd5\x9a\xce\x89\x54\x78\xbe\x40\xa2\xa8\x95\xf5\x55\x5e\x96\x32\x99\x21\x02\x72\x13\xeb\x20\x0a\x49\x75\x3e\xb4\x3f\x64\x36\xa8\x6f\xf6\x8d\x8b\x1a\x84\x92\xf2\x2a\x4d\x63\xc6\x2d\xf3\x19\x2d\x62\xe3\x86\x5d\xe6\xca\xce\xc5\xeb\x73\x97\x77\x51\x5c\x04\x91\x64\x85\x85\x42\xd7\x4e\xad\x88\xfa\x46\xc7\x3e\x75\x6c\xc8\x8a\xb4\xad\xd3\x8c\xe7\x29\xb2\xae\x55\xeb\xa8\x14\x5d\x44\x49\xb7\x83\xe4\x3f\x9f\x7c\xf8\xd0\xed\xee\xa9\x71\x49\xdc\xdb\xb0\x9e\xc3\x4d\xf7\xc1\xba\xb4\xc8\x15\x47\x2b\x02\x2a\x1c\x6d\x66\x79\xb8\xb2\x17\xe0\x96\xd0\x32\x8f\x93\x7e\xca\xaf\x5c\x60\x41\x98\x1a\x41\x22\xfb\x66\x2f\x84\x17\x5d\xc1\xe3\x51\x0e\xf6\x5a\x66\x4f\x01\x74\x6a\x8b\x58\xb1\xbc\x47\xef\x28\x44\x1d\xde\x5b\x63\x5c\xeb\xca\x6d\xf8\x83\x55\x09\xdc\x36\x9b\x67\x12\xc5\x4d\x45\x06\xeb\x4c\x3f\x7a\x76\xe7\x0b\x64\x97\xda\x84\x56\x3f\xd8\x99\x07\xd3\x86\x7c\x83\x01\x43\x09\x9f\x8f\xb5\x10\xd7\xac\xee\x1d\x13\x50\x62\xd0\x73\x79\xaa\x3e\xc9\xce\xe5\xe5\x19\x38\x9a\x52\x96\xbf\x8f\x00\x84\x59\x74\x86\x45\x4b\x77\x53\x53\xb3\x3b\xc3\xce\x4f\x50\x46\x51\x7f\xd4\x7b\xe5\x15\x14\xf0\xee\xf7\x34\xb9\x27\xfa\x9e\x9b\x14\x30\x54\xa1\x74\xf3\xf7\x9b\x4f\x2b\x1c\x32\xa0\x90\xc9\x61\x21\x76\xdd\x23\x6a\x40\x7c\x89\xd6\x69\x82\x3c\x35\x8e\xa8\xfa\x4e\xd6\x13\xe7\xa9\x6b\x3e\xea\x69\x01\xe3\xfb\xcc\x64\x5b\x7b\xec\x55\x0b\xa3\x8c\x81\x44\xfe\x93\x97\x87\x92\x24\x9c\xf9\x6c\xe6\xbd\x5c\xf4\x35\xf5\x20\xf5\xd3\x85\xef\x2a\x45\xcb\xab\xb4\x8e\x1d\x95\x9f\x42\xf1\x59\x08\x9e\xd8\x22\x6c\x85\x24\xc4\x7a\x21\xa5\x49\xbf\xbb\x83\xe6\x98\x32\x7b\x0c\xa0\xdf\x2b\x4a\xc9\x38\x9f\x4e\x1b\xef\xe4\x8c\x4f\x9f\xd4\x41\xe0\xaa\x27\x1a\x1d\x04\x7e\x85\x59\x5b\x45\xc0\x0a\x0e\xfd\x86\x94\xaf\xd6\x0c\xba\x7d\xa8\x4f\x03\xf7\x26\x63\x04\x4e\x68\x46\x9e\x47\x63\xda\x93\xfa\x37\x58\x47\xfd\x73\x5e\x04\x88\x7a\xdb\xe6\xf1\xce\xce\xfb\x0d\xe9\x85\x26\x8b\x70\xa4\x9f\x7c\xd2\x54\x42\x9f\xfc\x0c\x87\xd5\x24\x09\x6a\xd9\x94\x4a\x00\x19\xd8\x7f\x6e\x21\xc8\xf6\x55\x15\x0b\x3b\x83\x6c\xdc\xf0\x39\x41\xf0\x2a\x69\xea\xd9\x90\x0d\xdb\x77\xc0\xeb\xa8\x17\x68\x7b\x0c\x67\x56\xf8\x5b\xb7\x9a\x89\x74\x16\xad\x4e\xd0\x3b\x46\x1e\x91\x96\xb5\x9d\xd0\x0d\x13\x6c\x4f\x07\x11\x95\xbc\xd7\xba\x4d\x14\xb5\x11\x24\xe1\x22\x85\x82\x92\x29\x16\x29\x44\xf3\x2c\xc3\x67\x38\xb9\x07\x08\x39\xb8\x8e\xcc\x1b\x5d\x00\xd1\xd6\x5c\x18\xf7\x65\x31\x1a\x65\x89\x80\xb4\x62\x07\x0a\xe2\xe7\x67\x1e\x97\x08\x27\x82\x4b\xe3\x89\x72\xc8\x61\x16\xb2\x4a\xab\x5f\x0f\x34\xcd\x71\x66\xde\xb8\x49\xcc\xf0\xca\x32\x84\xcb\x3e\x09\x9c\x60\x20\x25\x23\x78\x84\x8f\x5c\xd8\xfa\x09\xa0\xf8\x95\x45\x61\xf8\x91\x3e\x90\x0e\xba\x59\x60\x71\xdf\x41\x67\x4b\x86\xe7\x34\xf9\x4f\x3e\xae\xf3\xa7\x54\xd2\x39\x76\x56\x89\xf7\x0f\xbf\x5d\x7f\xd0\xbf\x54\x42\xf5\xa8\x09\x38\xe0\x6d\x7a\x53\x1a\x32\x6d\xbe\xf5\x4b\x7d\x45\x4c\xee\xe0\x18\xd9\xeb\x05\x58\x6b\x28\x3b\x37\x07\x4e\xe7\x94\x45\xb6\xda\xab\x72\xb6\x96\x37\xb5\x2e\xb3\x2d\x12\xc6\x6b\x59\xb7\xfb\xd0\x1c\xaf\xb0\xb6\x72\xb4\x41\x39\xe7\xca\x34\xd0\x87\xda\x5b\x62\xab\xb0\x8d\x3a\x09\x7d\xc2\xa8\x34\xdf\x34\x61\xe8\x26\x19\x97\x6b\x67\x50\x55\x37\xec\xd4\x3e\xde\xaa\x9d\xf0\xf9\x02\xa2\x2f\x82\xc8\x3c\x53\xb2\xc6\x5e\xab\xb8\xad\xf7\x12\xc8\xaf\x4e\xf7\x33\x51\xf8\xac\xe2\xd7\xf2\xbc\x1d\xe5\xcf\x40\xf1\x58\xbf\x85\xa7\x9b\xae\xd8\x7e\x18\xbf\xd0\x67\xdb\x75\x61\xb3\x9d\x66\x28\x9b\x66\x4d\xcd\x19\x86\xcc\x36\xaa\x09\x64\x1f\x2e\x6a\xa0\x9c\x42\xe6\xca\x60\x1f\xa3\x26\x1d\xbe\xcb\x8d\x4d\x84\xc1\xd6\x60\xf7\x7a\x11\xdc\xe5\x1d\x00\xf5\x32\x89\x41\x0c\x30\xdd\x86\x4c\xe6\xe3\xe3\x22\x5d\x85\x0b\x90\xae\x00\xca\xb1\xc0\x02\x30\x06\x66\x34\x4b\x8f\x6b\xd2\xd7\x8c\x96\x03\xfd\x6d\x3c\x80\xdd\x98\x00\x46\x15\xec\xb8\xe9\x25\x69\xa2\xa5\x7e\xed\x7e\x9c\x71\xae\x10\xf1\xfd\x42\xa8\xb4\xce\xa3\x92\x26\x11\xc9\x8b\xc8\x37\xf0\xd2\x1e\xc1\xd5\xf2\xa2\xa9\xc4\xf1\xdb\x97\x13\x11\xcd\xd6\x91\x13\xb7\xb1\x17\xce\x9d\x1a\xcc\xbc\xe4\x68\x22\x95\x1c\x19\x17\xda\x13\x66\x0e\x7e\xf1\x65\xfc\xae\x30\x4d\x2e\xf0\x23\xb3\x49\x22\x1b\xe1\x43\xaf\x27\x1f\xea\xb1\x53\xb4\x7c\x28\x7d\x13\x4a\x0a\x7d\x1d\x41\x90\x9f\xfa\x82\xd1\x4e\x50\x19\x0f\xbd\xc3\x8a\x2a\xa0\xc2\xfc\x19\xb2\x22\x7b\xa9\x68\x76\x9c\x94\x05\xb7\x4d\x0a\x4a\x21\xd0\x4a\x3a\x2e\xa3\xa1\x63\xaa\x26\xad\x91\x72\x3c\xc6\x80\x65\xde\x84\x08\x1b\x9d\xe6\xda\x20\xc7\x3e\xac\x83\xc1\xd3\xf7\xe6\xa9\xbf\x36\x8a\xde\x46\x45\xaa\x52\x79\xe9\x01\xac\xd9\xf3\x43\x99\x6c\x56\x9d\x15\x60\x8d\xad\xcf\xe1\x95\x0a\x50\x8b\xb3\x65\x72\x90\x83\x96\x05\x51\x22\x05\x90\xb0\x68\xe9\xe0\x93\x4c\x82\x42\x19\x2d\xa2\xf0\x94\xa0\x39\x49\x69\x5e\x2e\xfe\x5b\x1d\x3d\x7b\x55\x66\xe7\x3a\x9c\xa5\x0d\x70\x6f\x88\x5e\x80\xb1\xf0\xa8\x6f\x6d\x93\x82\x06\x4e\x8f\x7a\x20\x8e\x20\x0d\x14\xab\xef\xa4\x8f\xc6\xc5\x14\x73\x2e\xa6\x73\x2a\xd5\xcf\x25\x38\xf6\x2d\x6a\xcc\xb2\xfc\xe9\x72\xff\xdc\x54\xcd\x34\x83\x27\x5a\x73\xdc\xae\xa3\x5e\xd6\xc0\x64\xc6\x5d\x01\x39\x22\xae\xfa\x4e\xcf\x7b\x13\x01\xfe\x57\x4f\xaf\xbf\xda\x6e\xdb\x02\x2f\x16\x44\x20\xdb\x71\xbb\xdc\x43\xdb\x94\xb2\xc1\x5b\x86\xcc\x28\x4c\xff\x79\x73\x79\x51\x48\xee\xc2\x8e\x2a\x0d\x0d\x3f\x03\xd2\x75\xeb\x77\xee\x22\xcf\xb2\xc6\x9d\x5b\x03\x61\xee\xee\xfc\x7c\xf4\x73\xef\xfc\xae\xdf\x8e\xe0\x56\xfc\xac\x91\x26\x7e\x26\x96\x26\xe6\x1a\x53\x70\x75\xe5\x73\x62\x1d\x58\xa0\x8c\xd8\x55\x9b\x04\x87\x3c\xcb\xe2\x6a\xa4\x21\xfb\xab\x1d\x07\x12\xe0\x72\x66\xd4\xcc\x21\x43\xad\x84\x8b\xdf\x0f\x3f\xfb\xab\x1e\xfc\xaf\xe6\xd9\x63\x54\x2c\xe2\x04\x5d\xf8\xb7\x36\xd0\xd5\x3a\x5d\x77\x38\x0e\xa6\x28\xea\xb9\xea\x2d\xb7\x3b\x1e\x77\xcc\x81\x2b\xda\x32\xc9\xbd\x9c\x0e\x43\xbb\xbf\xc6\x26\x8c\xaf\x09\x4f\x8d\x9c\x87\x71\x3b\xa6\x4a\x4e\x2a\x8b\xbf\x62\x68\x36\x64\x26\x9f\x00\x7a\x70\xf3\xe6\x39\xa1\x01\x33\x99\x8d\x19\x66\xd3\x1c\x4f\x89\xec\x20\xf7\xf2\x21\xf3\x1d\x9f\x2d\xa8\x8b\xef\x24\x84\xa1\x6f\x42\xcc\x42\xc6\xd5\x49\xbe\xe2\xf9\x02\x42\x30\x6c\xc8\xec\x9a\xd8\xb4\x18\xde\x78\x41\xff\xf3\xc6\x2f\x47\x73\x9a\x1f\xc8\x16\xfa\xb1\x21\x33\x9b\x6b\xaa\x3c\x9d\x6e\x07\x0e\x20\x68\xf1\x1e\xb1\x2e\x16\xc4\xd5\x16\x83\x4c\x9f\x82\x96\x69\x70\xbd\x5d\x88\x51\x4b\xfa\x00\x98\xc6\x38\x9c\xcd\x94\x56\xcb\x13\xb7\x19\xee\x4c\xd8\xb9\xd5\x73\xfd\xce\x77\x80\x3e\x70\xf5\x8d\x3d\xda\xd9\xb6\x10\x63\x2b\xa4\x79\xc1\x50\xac\x7c\x84\x51\x39\x15\x1d\x82\xd7\x7b\x68\x62\xb2\xf6\x94\xcc\xef\x5b\x27\xb5\x41\xef\x93\xb5\x5f\x6b\x4b\xd4\xdb\x5e\xab\x2d\x9c\xf6\x97\xee\xc1\x44\x8a\x26\x65\x1f\x58\x45\x8c\x3c\x69\x68\x33\xb3\x73\x4c\xac\x4c\x22\x27\x7d\xda\x26\x94\x51\xb9\xd5\x74\x0a\xfd\x69\xed\x19\x79\x0d\xc1\x5e\x76\x1b\x49\x58\x7b\xcf\x45\x02\xb6\x41\x4c\xda\xdc\x2c\xeb\x96\x21\xd4\x88\x17\x06\x10\x90\xd8\x26\x78\x74\x3c\x13\x75\x8a\x9d\xeb\x18\x4c\xfa\x5c\x48\x2d\x2e\xad\xbc\xb3\x52\x5b\x9b\x39\x43\xe6\xca\x07\x9c\x38\xee\xb9\x9e\x6d\xc2\x7f\x6a\xe2\x8c\x0b\x93\x7c\x0b\x1a\xab\x2a\x9a\xfd\x61\x35\x64\x50\xcf\xcf\xc0\x84\x1c\x4b\xa8\x9e\xb2\x55\xeb\xf6\x8b\x00\x02\x0c\x33\x8f\x8b\xbf\x42\xe6\x95\xd4\x80\xe8\x9e\xff\x9d\xfe\xff\xbf\xfe\xee\xff\x0f\x00\x00\xff\xff\x11\xf5\x90\x7b\x89\x18\x03\x00") +var _adminSwaggerJson = []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\xff\xec\xbd\xfb\x73\x23\xb9\x91\x27\xfe\xbb\xff\x0a\x9c\xee\x22\xba\xdb\xa6\xa8\xb1\xf7\x11\x3e\x6d\x6c\x7c\x83\x23\xb1\x7b\xb4\xa3\x96\x64\x3d\xa6\x77\x6e\xe9\xa0\xc1\x2a\x90\x84\x55\x04\x38\x00\x4a\x6a\xda\x31\xff\xfb\x37\x90\x09\xa0\x50\xc5\x2a\xbe\xf5\xea\xe1\x5e\x9c\x47\x4d\xb2\x50\x40\x22\x91\xc8\xe7\x27\xff\xf9\x3b\x42\x0e\xf4\x23\x1d\x8d\x98\x3a\x38\x26\x07\x7f\x6a\x7f\x77\xd0\xb2\x9f\x71\x31\x94\x07\xc7\xc4\x7e\x4f\xc8\x81\xe1\x26\x63\xf6\xfb\x61\x36\x33\x8c\xa7\xd9\x91\x66\xea\x81\x27\xec\x88\xa6\x13\x2e\xda\x53\x25\x8d\x84\x07\x09\x39\x78\x60\x4a\x73\x29\xec\xcf\xdd\x9f\x44\x48\x43\x34\x33\x07\xbf\x23\xe4\x57\x18\x5e\x27\x63\x36\x61\xfa\xe0\x98\xfc\x0f\x3e\x34\x36\x66\xea\x07\xb0\x7f\x6b\xfb\xdb\xbf\xc2\x6f\x13\x29\x74\x5e\xfa\x31\x9d\x4e\x33\x9e\x50\xc3\xa5\x38\xfa\xbb\x96\xa2\xf8\xed\x54\xc9\x34\x4f\x56\xfc\x2d\x35\x63\x5d\xac\xf1\x88\x4e\xf9\xd1\xc3\x1f\x8f\x68\x62\xf8\x03\xeb\x67\x34\x17\xc9\xb8\x3f\xcd\xa8\xd0\x47\xff\xe4\xa9\x5d\xe3\xdf\x59\x62\x7e\x85\x7f\xa4\x72\x42\xb9\xc0\xbf\x05\x9d\xb0\x5f\xc3\x38\x84\x1c\x8c\x98\x89\xfe\x49\xc8\x41\xca\x74\xa2\xf8\xd4\x38\xaa\x5c\x33\xa3\x38\x7b\x60\xc4\x8c\x19\xc1\xd7\x11\x7c\x1d\xb1\xaf\x23\x9e\x6a\x7a\xca\x12\x3e\xe4\x2c\x25\x83\x19\xe1\x62\x9a\x1b\xa2\xd8\x2f\x39\xd3\x86\x0c\x79\x66\x98\xd2\x6d\x47\x32\x78\x8b\x9c\x32\x05\xeb\x3c\x4b\xed\x5b\x3e\x31\xd3\x81\xb1\xcf\x61\xe8\xab\x8c\x8a\xf8\xd7\x8a\xe9\xa9\x14\x9a\xe9\xd2\x54\x09\x39\xf8\xd3\x77\xdf\x55\x3e\x9a\x5f\x41\x87\xe8\x3c\x49\x98\xd6\xc3\x3c\x23\x7e\xa4\x78\x32\xf0\x10\x6c\x32\x9d\x1b\x8c\x90\x83\xff\xa3\xd8\xd0\x8e\xf3\xbf\x8f\x52\x36\xe4\x82\xdb\x71\x35\xf2\x52\x34\xdb\xd2\x53\xbf\xfe\xae\xee\xef\x5f\xa3\x15\x4d\xa9\xa2\x13\x66\xc9\x12\x76\x1f\xff\xaf\xb2\x16\xbb\x5f\xf6\xe5\xc5\x9e\x56\x27\x5e\x59\xed\x05\x9d\x30\x22\x87\xb0\x5d\xee\x09\xf8\x5b\x31\x2d\x73\x95\x30\x32\x60\x99\x14\x23\x4d\x8c\x9c\xa3\x01\x87\x11\x2c\xab\x55\xbf\xb1\x5b\xc9\x15\xb3\x7b\x65\x54\xce\x2a\xdf\x9a\xd9\x14\x26\xa9\x8d\xe2\x62\x14\x93\xe2\xd7\xd6\x4a\x4b\x43\x0e\x5d\x63\x65\xf8\x40\xe3\xc2\x7a\xa2\xe3\x7f\x92\x50\x41\x06\x8c\xd8\x73\xc9\x53\xa6\x58\x4a\xa8\x26\x94\xe8\x7c\xa0\x99\x21\x8f\xdc\x8c\xb9\xb0\xff\x46\xf6\x4d\x3c\xcd\x5e\x0f\x6d\xe0\xcf\xc5\x94\xb9\xd3\x4c\xd9\x89\x3f\xf0\x94\xa5\xe4\x81\x66\x39\x23\x43\xa9\x4a\xe4\x69\xf7\xc4\xed\xd8\xd2\x61\x32\xe0\x02\x4e\x9e\xa5\xa5\xe7\x90\x3f\x78\x72\xfd\x81\xd8\xf7\x91\x5c\xf0\x5f\x72\x96\xcd\x08\x4f\x99\x30\xf6\x5c\xeb\xea\x68\x7f\x90\xf0\x7e\x9a\x91\x43\x62\xe9\xcc\x94\x01\x7a\x4b\x61\xd8\x57\xa3\xc9\x21\xc9\xf8\x3d\x23\xef\xce\xb9\x36\xa4\x73\x75\xf6\xae\x45\xde\x9d\x17\x82\x43\xbf\x7b\x06\x0a\x87\xbf\xff\x1a\x1d\x3d\x43\x47\xd5\x43\x77\xd0\xb1\xa7\xf9\x06\xaf\x89\x62\x84\xbf\xfe\x2e\x1e\xc7\xed\xd7\x62\xd9\x5b\x08\x5e\x27\x75\xd7\x91\xb5\x1f\x99\x49\xc6\x4b\x04\xad\xde\x52\xd2\xda\xed\xa8\x8a\x5a\xfd\xb6\x64\xad\x5d\xc2\x53\xcb\xdb\x6d\x84\x2d\x35\x70\x0a\x28\x17\x78\x68\xc2\x19\x2a\xef\x0c\x79\x39\xb1\xb2\x8d\xbc\x8d\x56\x13\x89\x5c\x2f\x49\x23\x4a\xbc\x92\xb5\x66\x7c\xc2\x97\xed\xe3\x99\x48\xad\xda\xe5\x84\x9c\xc8\x27\x03\xa6\xec\xd2\xbd\xb8\x83\x15\x0e\xac\xf8\x33\xb9\x12\x2c\x6d\x58\xda\x2f\x39\x53\xb3\x05\x6b\x1b\xd2\x4c\x37\x2d\x8e\x0b\xc3\xac\x5e\x5b\xf9\x7a\x28\xd5\x84\x1a\xf7\x83\x7f\xff\xd7\x75\x17\x6f\xe4\x3d\x5b\xb6\xcf\x67\xb8\x6b\x09\xd5\xb0\xdd\x93\x3c\x33\x7c\x9a\x31\x32\xa5\x23\xa6\x1d\x15\xf2\xcc\xe8\x16\xfc\xcc\xea\xd2\x4c\x1d\x86\xdb\x06\xde\xe0\x6f\xd9\x5c\xc3\x27\x64\x18\x04\x99\x60\x5f\x0d\x8c\xd4\x13\x70\xcf\x02\x89\xe2\xdb\xe3\x09\x48\xb9\x19\x9f\x68\xa9\x4c\x7f\x30\x6b\xdf\xb3\xb9\xf7\x36\x72\x0b\x15\x84\x1a\xa3\xf8\x20\x37\xcc\xae\xdb\x8e\xe1\xef\x49\x10\x7d\x78\x19\x6b\x7b\xf9\x5e\x9e\x5e\xbe\xbf\xa7\x46\xc9\x11\x15\x1f\x8e\x49\x27\x4d\x09\x4e\xd4\xfe\x86\xa7\x78\x25\x8f\x99\x62\x6d\x72\x3b\xe6\x9a\xe8\xb1\xcc\xb3\x94\x08\xf6\xc0\x94\xa5\x2d\x9b\x4c\xcd\xec\xd5\x51\x2b\xe5\x8a\x25\x40\x98\x75\x4e\x58\x78\xca\x12\xcd\x1a\x3d\x33\x24\xdd\x3d\x9b\x81\xe2\x32\x4f\xbe\x67\xe0\x97\xca\xb7\x4c\xe4\x93\xca\x5d\x01\x9f\x9f\x76\x6f\x4e\xba\x17\xa7\x67\x17\x9f\x2a\x4f\x58\x35\x22\x7c\x55\xfa\xe6\xaf\x73\xb4\x19\xd2\x3c\x83\x53\x1d\x8d\xf6\x6c\x8a\x4b\x32\xe6\x59\xaa\x98\x38\x32\x54\xdf\xf7\xd9\x57\x96\xe4\x78\xcf\xfe\xb3\xfc\x41\xdf\x6a\x9f\x32\x65\xe5\x4f\x4a\xff\x28\xd4\x9d\xb5\x1f\x0d\x56\xe9\xda\x4f\x82\x0d\xbb\xda\x73\xf0\x09\x4f\x6b\x7f\x0d\x9f\x2c\x59\x83\xff\xcd\x82\xc9\xfa\x9f\x34\xce\xca\xff\xc0\x29\x70\xb5\xbf\x51\xcc\xa8\x59\x9f\x1a\x63\x4f\xf9\x06\x3a\x23\x6c\x29\xb1\xab\x25\xc5\x7e\x3a\xf5\x11\x15\x45\x90\xdd\x41\x73\xb4\x33\x28\x7e\xb9\x4c\x5f\xbc\x90\x29\xeb\x86\x61\x3f\x4a\x75\x4b\xf5\xfd\x5b\xd0\x19\x4b\x13\x7f\x0e\xb5\x71\xd3\x03\xf4\xcd\x19\xf5\x1b\x8a\x83\xbd\x0b\x60\x7b\x4a\xae\xea\x30\x90\x8a\xe8\x99\x36\x6c\xb2\xd4\x75\xf0\x76\x08\xe1\xe4\xfd\x6b\x9d\x70\xe5\xca\xf9\x0d\x9c\xfa\xf2\x05\xba\x3f\xde\x6b\x90\x6c\x57\x8e\xbf\xd7\xbe\x4e\x1f\x82\x59\xbc\xd4\x1b\xbf\x7d\x3e\xe0\xe0\xf8\xe4\xd5\x2f\xb3\xa4\xda\xed\x7a\x92\x4f\xe4\x35\x68\xdc\x2b\x4f\xed\x3e\x4c\x60\x89\xc9\x57\x76\x1d\x87\xf3\x67\x1f\x8d\x9d\x2b\xe8\x31\x33\xd6\xe6\x75\xbe\x25\xa6\x48\x22\x15\xaa\x82\xe9\x02\xf1\xf6\x7c\x46\xdf\xdd\xc5\xcd\x55\xf7\xe4\xec\xe3\x59\xf7\x74\xde\xea\xbb\xed\xdc\xfc\x38\xff\xe9\x97\xcb\xeb\x1f\x3f\x9e\x5f\x7e\x99\xff\xe6\xbc\x73\x77\x71\xf2\x43\xff\xea\xbc\x73\xb1\xb2\x9d\x18\x4f\x60\xcd\xdd\xdc\x3b\xc0\x76\xe9\x00\x6b\x7d\xbb\x1e\x30\x17\x3d\x58\xdd\xfb\x45\x32\xae\x8d\x25\x90\x7b\x92\x4c\xa9\xd6\x78\xff\xe2\x0c\xda\x3d\xf1\x59\x2a\x46\xb8\x18\x4a\x22\x21\x38\xa4\x8d\xca\x13\xc3\xc5\x28\x3c\x74\x4c\x7a\xf9\x77\xdf\xfd\x4b\x72\xce\xc5\x3d\xfc\xc5\x5e\x23\x71\xf6\xee\xc1\x4d\xa8\xb5\x77\x0f\xc6\xdf\xbd\x0d\xf7\x60\x4a\x0d\x3d\x8a\xbd\x82\x4f\x93\x4f\x82\x91\x4b\x2a\x52\x22\x73\x63\xff\xb4\xef\x25\x43\x25\x27\xf6\xdc\xb0\xaf\x5c\x83\x94\x78\x94\xea\x7e\x98\xc9\xc7\xd5\xbc\x55\x9f\x98\x09\xfe\x9e\x53\x6a\xe8\x5b\x70\x52\x7d\x71\x2b\x0c\x13\xff\xc4\x8c\x9d\xfb\xb5\x7b\xcb\x3e\xb5\x64\x9f\x5a\xf2\xb2\xa9\x25\xaf\xca\x53\xf4\xf4\xb2\xaf\xec\x56\x42\x01\xd8\x10\xf5\x68\x0c\x6a\x34\xc4\x2c\xa2\x90\xc4\x53\x0a\xcd\x72\x20\x60\x89\xc0\x2c\x39\xc9\xdf\x8a\xd0\x2c\x4d\xfa\xf9\x05\xe6\x6f\xc2\x87\xbf\x77\xd1\x6f\x48\xa8\x37\x29\x57\x57\xbc\x32\x9e\xcd\xc1\xfe\xf4\x72\x7e\x2e\xfc\xbd\x4e\xbc\x7b\x8d\x00\xf7\xca\x11\xed\x25\x21\xec\xda\x98\x75\x5d\x90\x7a\x3e\x2a\x5d\x1b\x86\xde\x2a\xee\xbc\xee\x95\xb4\x7a\xc4\xf9\x13\x33\xb7\x54\xdf\xbf\xb9\x2b\xa9\x34\xe9\xe7\xbf\x92\x7e\xa3\x81\xe6\x7d\x64\xf9\x09\x49\xf7\xad\x5f\x64\xaf\x37\x76\xfc\x1b\x08\x16\xef\xa3\xc3\x6b\xd1\xe8\xdb\x0a\x07\x7f\xab\xf1\xdf\xb7\x19\xf0\xdd\x47\x78\x5f\x6f\x84\xf7\x49\xed\x20\xf6\xc0\x84\xd1\xe0\xf1\x8a\xd5\xe9\x83\xa9\xd4\x8b\xd5\xff\x13\xc5\xa8\x61\x84\x56\x5c\x4d\x04\x06\x24\x8a\x25\x52\xa5\x56\xed\xa7\x64\x3a\xa6\x9a\x11\xa3\xa8\xd0\x7c\x99\xea\x8f\xa3\x82\x6f\xc7\x8e\xf3\x16\xb4\xfe\x92\x23\x0a\x66\xfd\x5c\x3a\xff\x40\xa6\x73\x47\x03\x4f\x4d\xdd\x37\x8b\xc5\xcb\xce\x96\x0e\x75\x68\xab\xac\xfc\x09\xb9\xd9\x8a\xb2\x0d\xb9\xb9\x6c\xa5\xee\x84\x9b\xc1\x2c\x7c\x2b\xdc\x5c\xb2\x61\x7f\x5b\xdc\x5c\xb7\xf4\xd7\xc0\xcd\x3e\x00\xba\x21\x47\xcf\xc7\x4f\x77\xc2\xd5\x21\x68\xf9\x56\x38\x7b\x2e\xca\xfa\xdb\xe2\xee\xa6\xe5\xbf\x2c\x87\x07\xdf\xeb\xae\x78\x7b\x39\xe3\x06\x02\xbc\x05\xa6\x0d\x93\xc5\xb9\xff\x66\xb8\x75\x6e\xdd\xaf\x84\x4d\x8f\x14\xc3\x9a\xaa\xb5\xf8\xf5\xda\x3d\xb4\x36\xc7\xfa\x07\xf7\x3c\xfb\x96\x78\xd6\xef\xda\xeb\xe1\xda\xa6\x0c\xae\xf5\xeb\x0c\x17\xa4\x65\x69\x32\xa1\x26\x19\xdb\x2f\x31\x24\xb4\x22\x18\x45\x51\x58\xf8\xa6\xb8\xfb\x39\xaa\x09\xbf\x6d\xe7\xef\xde\xe9\xfb\x1b\x04\xfd\x79\x35\x19\xca\xfb\xaa\x88\x1d\x56\x45\x70\xbd\xaf\x8a\xd8\x57\x45\xac\x4a\xa0\x7d\x55\xc4\xbe\x2a\x22\xfa\xee\x6d\x54\x45\x3c\x7d\x41\xc4\x6e\xaa\x1e\xde\x94\x12\xbd\x57\xa0\xf7\x0a\xf4\xbe\xb4\x21\x2c\x6d\x57\x02\xcc\x3f\x7d\x90\xb2\x8c\x19\xb6\x50\xfc\xdc\x32\x35\xb1\xb6\x41\x09\xe0\xb7\x26\x68\x50\x60\x07\x05\x0e\x02\xf7\xc6\x22\xb9\x14\xc6\x7e\x9b\xd2\x29\x4c\x7f\x5f\x89\xb5\x17\x57\x7b\x71\xb5\xc9\xd2\x5e\x8f\x57\x36\x3a\xcc\x2f\xea\x96\x8d\xe0\x82\xfb\x3c\xdd\x0d\x62\x70\x50\x1b\x63\xbc\xe0\x82\x14\x25\xc8\xd6\xcd\x9c\xb4\x05\xf8\xee\x59\xfa\x26\xfc\xb4\x56\x8e\xa4\x5d\x61\xb8\x99\x85\x2c\x35\xb5\x07\x0e\xde\x03\x07\xaf\xbe\xd6\xbd\x87\x70\x87\x1e\xc2\x3d\x70\xf0\xde\x07\xb6\xf7\x81\x3d\xbd\x0f\xec\xa5\x1c\xda\xcf\x7c\x2c\x9f\x4b\x45\xdb\x2c\x31\x49\xa4\x44\xb1\x11\xd7\x86\x29\x4b\xbd\x5a\xa5\x6c\x79\xa6\xd2\x5b\x6d\x85\xb3\x72\xde\x47\xfc\xda\x83\x7f\x5d\x61\xfa\xd7\xee\x16\x85\xa3\x3e\xa0\x69\xe8\x7b\x01\xaa\xd3\x84\xce\xc8\x98\x3e\x30\x32\xa4\x3c\x43\xc3\xc8\x49\xc7\x05\x2b\x5c\x34\xa1\xff\xbb\xde\x84\x68\x79\x3a\x8a\x0d\x99\x62\x22\x41\x69\x8f\xca\x4f\x42\x33\xc2\x40\x29\xc5\xdf\x8c\xad\x99\x9a\x29\x46\xd3\x19\x19\x30\x26\x02\xdb\xd4\x68\x0a\x0d\x73\xde\x89\xd2\xfa\xe2\x66\xda\x3c\xf7\xbc\x16\x23\xed\x49\xb2\x67\xea\x45\xc2\xf6\xc6\x99\xfe\xd3\xdb\x12\x15\xfb\x24\x9a\xbd\x53\xed\xe5\x9d\x6a\xfb\x24\x9a\xbd\x89\xfc\x0a\x4c\xe4\x7d\x12\xcd\x3e\x89\x66\xef\x40\x58\x99\x5a\x7b\x07\x42\xfc\xdd\xdb\x48\xa2\x79\xc2\x3e\xb5\xcf\xa5\x61\xef\x15\x6c\xff\xbb\xbd\x82\xbd\x57\xb0\xbf\x51\x05\xfb\x75\x50\x78\xaf\x5d\xef\xb5\xeb\xbd\x76\xbd\xd7\xae\xf7\xda\xf5\x5e\xbb\x76\x4f\xed\x52\xbb\x86\xbf\x3c\x1a\xe8\xd6\x19\xeb\xeb\x47\xb9\x3e\x31\xf3\x56\x43\x5c\x7b\x95\x7a\xaf\x52\xbf\x6e\x95\xfa\xd5\x2c\xe8\xdb\x43\xf7\xdb\xe3\xe3\xcd\xdd\x8f\xdf\x02\x3e\x9e\x7f\xfa\x60\x9a\x2f\xbe\xfe\xee\xa6\xa9\x2f\x97\xd0\x86\x9a\x1c\x2c\x8d\x15\xae\x42\xd2\x31\x64\x22\xad\xde\x2d\x58\xe9\x37\x9e\xe7\x31\x89\x60\xc4\x1f\x98\x20\x3e\x2d\xb8\xe5\x24\x5b\x0b\x8c\xdf\x5f\xbd\x80\x73\x75\x1a\xd4\x10\x4a\x0c\x9f\xb0\x36\x39\x1b\x22\x03\x25\x34\xcb\x88\x66\x46\x57\x32\x4f\xac\x42\xe6\x1e\x12\x69\x31\x57\xff\x6e\x5e\x24\x22\xe0\xcf\x5a\xfe\xfc\xe5\x99\xc1\xd3\xe8\x07\x7f\xe4\x59\x66\xe7\xe0\x98\x16\x84\xcf\x84\xa9\xcc\x3f\x59\x7a\xad\xff\xf1\x84\xa6\xd6\x9a\x88\xa6\x50\x14\x94\xc4\xbf\x07\x31\xcf\x75\x48\xa5\x28\x3d\x8f\x4f\xb7\x89\xb3\xfb\x10\xc7\x6a\xa5\x69\x8c\x69\x6a\xc5\x7e\x32\x66\x69\x9e\x31\x42\xb5\x96\x09\xa7\x86\xa5\x84\xe3\xb5\x40\xb8\xf1\x56\xa2\xff\x91\x7f\x75\xca\x35\x1d\x64\x2c\x75\x34\x66\x45\x66\xc7\xc2\x99\x73\x4d\x06\xcc\x92\xd8\xde\x3c\x65\xea\x8f\xf1\x52\xaa\x99\x4d\x34\x15\x36\x3f\x13\x26\x70\x22\x0b\x94\x2a\x64\xce\xb7\xaa\x57\xe1\xec\xf7\xe5\x36\x7b\x2d\x6b\xaf\x65\xad\xb5\xa0\x6f\x4a\xcb\x7a\x45\xd9\x68\x5e\x20\xbd\x68\x36\x1a\xc4\xac\xac\xe4\xef\x07\xa7\x94\xde\xcc\x5e\x0f\x7e\xbf\xcf\x7e\xc8\x4e\x18\xf1\x44\x8a\x21\x1f\xe5\xca\x39\xe0\x07\xf6\xc4\x2e\x0d\x8c\xd5\x8c\xf3\x26\x6e\x9c\xfa\xa9\x3f\xd7\xc5\xb3\x8e\x0d\x41\x0e\x89\xd5\xae\xfb\xd7\xdd\x9b\xcb\xbb\xeb\x93\xee\x31\xe9\x4c\xa7\x19\x47\xc7\x7e\x92\x6b\x23\x27\xfc\x1f\x76\x19\x88\x5d\x1b\x24\xb7\x53\x43\x34\x28\x1c\x10\x49\xd0\xed\x9e\x20\x87\xe4\xe4\xfc\xee\xe6\xb6\x7b\xdd\x30\xa0\x63\x02\xe8\xd8\xc2\x26\xd3\x0c\xb4\x92\xfb\x7c\xc0\x94\x60\x86\x69\x92\x64\x39\xa4\x35\x87\xf8\x02\x0e\xda\xfd\xef\xee\xc9\xdd\xed\xd9\xe5\x45\xff\x2f\x77\xdd\xbb\xee\x31\xf1\xdc\x64\x87\xb5\xf3\xb2\xb3\x48\x67\x82\x4e\xac\xf9\x53\x06\xd9\xfd\x25\x67\x39\x28\x41\x7c\x24\x26\x4c\x98\xea\x88\x7e\xc2\xe7\x9d\xef\xbb\xe7\xe5\x91\xc7\x8c\xfc\xf8\xe7\x62\x52\x19\x1d\xb0\xcc\x05\x3c\xc0\x9f\x6f\x05\x76\xf1\x22\x17\x09\xc9\x05\xbc\xe0\x2f\x77\x9d\xf3\xb3\xdb\x9f\xfb\x97\x1f\xfb\x37\xdd\xeb\x9f\xce\x4e\xba\x7d\x67\x60\x9c\x74\xec\x7b\x4b\x6f\x72\x76\x08\xf9\x25\xa7\x19\x37\x33\x7b\x84\x34\x1e\x62\xf2\x38\x66\x82\xe4\x02\x78\x0c\xab\xa3\xc1\x16\x88\xeb\xa6\x5f\xdc\x78\x2b\x71\xd0\xbc\x39\x56\x65\x89\xf9\x5f\x54\xf6\x77\xd1\x0f\x4a\xdb\x35\xff\xc3\x65\x64\x5f\xd9\x1e\x2c\xaf\xe9\xd9\x84\xb1\x3d\xc3\x69\x1f\x92\xb8\x39\xd3\x47\xff\x2c\x9d\xe5\x5f\x9f\x0c\x1b\x84\x44\x05\x8d\x4e\x38\x2f\x6b\xeb\x57\x3c\xf0\x16\x44\x72\x3c\xdd\x97\x14\xbf\x3b\x52\x79\x5e\x97\x57\x65\x7d\x85\x72\x6f\x18\xed\x0d\xa3\x7a\xca\xec\x33\x3a\x1a\x28\xbc\xab\x6b\x67\x13\x47\xe4\x90\xb3\x2c\xd5\x73\x9e\xa4\xd2\xb5\xb1\xd4\x6b\xf4\x76\x6f\x8c\xe7\xf5\x1b\xad\xa3\xbe\x5f\x07\x17\xbf\xf3\xf9\xdb\xdd\x9a\x30\x43\xa1\x4b\xa2\x91\x24\x87\xa9\xef\x6f\xa1\x79\x32\xef\x6f\xa1\xfd\x2d\xd4\x48\x99\xfd\x2d\xf4\x86\xfd\x6b\x35\x92\xfb\x45\x1d\x6c\xcb\x6c\xba\xad\x20\x7a\x6a\xbc\x6f\xf3\xb6\x9c\x26\x7a\x4c\x15\x36\x63\x49\xe4\x64\x22\x45\x14\x1c\x9e\x4d\x59\x8b\x84\x78\x20\x78\x52\x60\x1a\xcb\x9c\x73\xc5\x6b\xf8\xdb\x70\xcb\x45\x74\x79\x8e\xc4\xf5\xbd\x1d\xb8\x84\x40\x7b\x2c\xa3\x3d\x96\xd1\x3e\x95\x7c\x8f\x65\xb4\x98\x5b\xf6\xc9\xd2\xfb\x64\xe9\xf8\xbb\x3d\x96\xd1\x2b\xc2\x32\x2a\xb7\x39\xc7\xb4\xf0\x52\xd7\xf3\x52\xb0\xa2\xa6\x6f\x7e\xcd\x17\x45\xf6\xb8\x6b\x99\xbe\x7d\xf6\x78\xb9\x8b\xec\xb2\xc8\x46\xdc\x77\xf4\x95\xeb\xb5\xc3\x6c\x66\x18\x4f\xb3\xf9\x86\xa9\xcf\x90\xdd\x54\xb7\xd1\xdf\xa2\x2f\xa5\x86\x6d\xf7\x8e\x95\xa5\x84\xfa\x56\x31\x87\x0b\xb9\xf4\x86\x9c\xfe\xab\x09\x6f\x8f\xcb\xde\x6f\x10\xe1\xf5\xdf\x07\x41\x5e\xff\xf5\xb6\xa5\xf6\x65\xd9\xbd\x69\x89\x7d\x49\x36\xbe\x0d\x6f\x45\x3c\xe3\xe7\xf0\x57\x2c\xdc\xfd\x6f\x4e\xae\x2f\xe2\xe5\xbd\x74\x5f\x91\x5c\xdf\xaa\x8c\xdf\xfb\x33\x76\xe9\xcf\x68\x7d\xbb\x0e\x8d\x7d\x69\xfc\x02\xe2\xec\xbd\x3d\x9b\x50\x6b\xef\xed\x89\xbf\x7b\x4e\x6f\x0f\x86\x68\xfb\x53\xaa\x98\x30\x35\xfa\x7d\xf5\x66\x83\x9f\x47\xbe\xfa\xa0\x00\xc1\x00\xa8\xb8\x3a\xdd\x20\xdc\x9a\xdf\x96\xfb\xc7\xe9\x28\x7d\x54\x71\xa2\xfa\x81\xa3\x7f\x16\x7f\x47\x06\x44\xf4\x61\x4d\xa8\x73\x8d\x84\x24\x9f\x99\xce\xd2\x42\xed\x2a\x06\xaf\x49\x54\x72\x73\x38\xf4\xca\x58\x11\xb4\x5f\x9a\xb7\x74\x85\x8f\x9e\xc2\x93\x6f\xab\x10\xa1\x61\xea\xcf\x9b\xcf\x34\xcf\x09\xab\x1d\x2c\x6f\x47\x70\x4c\xb4\x7f\x1c\x73\x50\x0f\x00\x69\x07\xae\xd0\x68\xc3\x7d\x09\x23\x85\x5a\x83\x26\x5d\xeb\xb9\xd5\xc8\x39\x76\x5f\x6d\xe1\x8e\x47\xdf\xee\xba\x5f\x3c\x03\x64\x09\xdf\xbf\x68\x36\xc8\x02\x99\xb9\x9b\x44\x90\xe7\x93\x8f\x9f\x98\xf9\xf6\x84\xe3\x27\x66\x9e\x4b\x32\x6e\x2a\x0e\x17\x8a\x84\xa2\x31\xc0\x2b\x91\x06\x9b\x89\xbe\xb7\xb5\xc6\x7d\xc9\xdd\xbe\xe4\x6e\x5f\x72\xf7\xea\x4b\xee\xfc\xd3\xab\x74\xae\x3d\x85\x9f\x3c\xe3\x6d\x8a\x2f\xfc\xf6\x2e\x54\x5c\xd7\xfe\x4e\xdd\xdf\xa9\xeb\xad\xf1\xb5\x5a\x11\x9e\x9f\x5f\x83\x15\xb1\x16\x50\x03\x06\x56\x8b\x1e\x50\x9e\xfd\x97\x06\x4f\xaf\xfc\xcb\xde\x8e\x10\xd2\xeb\xca\x99\xad\x2a\xe9\x96\x75\x6e\xbb\x2e\xda\xb5\xd5\x84\xf5\xaa\x24\xf7\xbf\xbe\x9a\x13\x65\xaf\x9d\xea\x7e\xe6\xcf\x25\xec\x5f\x8b\x88\x28\xd6\xfd\xa2\x42\xc1\xaa\xe1\xd5\x6c\xbc\x72\x92\x47\x7f\x61\x7e\xde\x92\xdf\x96\xb0\x06\x16\xff\xb4\x92\xc3\x57\xfe\xce\x65\xf5\xc1\xd7\x30\xe5\xea\x3c\xfc\x87\xf1\x0b\xfd\x67\xc5\xc8\xfe\x13\x8f\x31\x0b\x1f\x2a\x66\xd4\xac\x4f\x8d\x35\x75\xcc\xf6\x89\x83\x65\xc3\x66\x49\xe2\xe0\x2d\xd5\xf7\x6f\x32\x71\xb0\x3c\xf1\x27\x3e\xb3\x2b\xf3\xe4\x37\x97\x72\xb2\xea\x09\xdb\xa7\x9f\x6c\x40\xba\x6f\x35\x15\x65\x91\x08\x7d\x35\x33\xac\x48\xf1\x6f\xf1\xe4\x96\xef\xa4\xfd\x11\x5d\x44\xa3\x6f\x0e\xff\xb0\xa2\x6a\x2c\x59\xdb\x1b\xc1\x41\xac\x6a\x4b\xbb\x9e\xd5\xd3\x64\xa7\x45\xbb\xb1\xc7\xca\xfe\x46\xb1\xb2\x57\x33\x6e\x56\xb6\x6c\x56\x35\x6b\x56\xb3\x69\x9a\x0d\x9a\x2d\x92\xdc\xcb\x76\xc6\xa6\x49\xee\x25\x3d\xfe\x4d\x78\x6b\x4a\x33\x7e\x8e\x24\xf7\xdf\xa8\xe9\xb1\xb7\x3b\x9e\x84\x6e\xdf\xaa\xd1\xf1\xca\x2d\x8e\x7d\x7a\xfe\x2e\xd3\xf3\xf7\xd9\xf9\xfb\xec\xfc\x55\x09\xb4\xcf\xce\xdf\x67\xe7\x47\xdf\xbd\x8d\xc6\x75\xce\x5e\xdc\x36\xc1\xb2\x4e\x65\x2f\x14\xda\x12\x66\xcf\xe6\xea\xfb\x59\xfa\x26\xf4\xf6\x08\x4a\x2b\x58\xd6\xea\x39\xf4\xf7\x3d\x66\xd4\x1e\x33\x6a\xaf\xc4\xfd\x96\x94\xb8\xbd\x9e\xb2\x09\xb5\xf6\x7a\x4a\xfc\xdd\x1e\x33\xea\x15\x15\x0d\x5a\xc5\xa9\x94\xb7\xb6\x34\x7d\xea\x44\x31\x6a\xb0\xb7\x9d\x2a\x32\xa9\x2a\x0a\xd8\x22\xed\x0a\x07\xb0\xfa\xd5\x5b\x50\xae\xec\x3c\x71\xc6\x2b\xe4\x51\xc5\x2f\x3c\xf8\xd7\x15\x26\x7e\xed\xee\x4a\x38\xd0\x03\x9a\x86\x8e\x82\xa0\x20\x4d\xe8\x8c\x8c\xe9\x03\x23\x43\xca\x33\x74\x53\x39\x19\xb8\x60\x6d\x8b\x26\xf4\x7f\xd7\x9b\x10\x2d\x4f\xa7\x48\x4a\xb5\x32\x1d\x55\x9c\x84\x66\x84\x21\xba\x2d\xfc\x06\xda\x1d\xba\xe6\x92\x03\xc6\x44\x94\xe1\xb8\xea\x9c\x77\xa2\x9a\xbe\x78\x32\x5a\xcc\x37\x2f\x9e\x87\xd6\xdc\x22\x7c\x77\x36\xd7\x36\x86\x96\xfe\xd3\x5b\x11\x05\xcf\x61\x56\x7d\xc3\xa1\x8f\x7d\x78\xe3\xb7\x09\x86\xff\x6a\x54\xf2\xbd\xa1\xbb\x43\x43\x17\x4a\x57\xbe\x51\x4b\x77\x1f\xae\x58\x40\x9c\xbd\x1b\x60\x13\x6a\xed\xdd\x00\xf1\x77\x6f\x27\x5c\xd1\xac\x3d\x6f\xd6\xe9\xf1\x09\xf5\xe8\xbd\x1a\xbd\x57\xa3\xf7\x6a\xf4\x37\xab\x46\xbf\x0e\x0a\xef\x75\xe8\xbd\x0e\xbd\xd7\xa1\xf7\x3a\xf4\x5e\x87\xde\xeb\xd0\xee\xa9\x9d\xe8\xd0\xf0\x97\x2f\x20\xde\x4d\xb5\xf0\x6a\x11\x29\x57\x2e\xfc\x56\x94\xe7\xbd\xe2\xbc\x57\x9c\x5f\xb7\xe2\xfc\x6a\x16\xf4\xed\xd5\x08\xee\xab\xec\xe6\x6e\xc1\x6f\xb6\xca\x2e\xf4\x79\xd8\x00\xcb\xb9\xf4\x99\x1f\xe8\xb9\x11\x9e\x5b\x5e\x32\x52\x91\x12\x3f\x89\xb5\xf0\x9e\xbf\xb8\x87\xde\x16\xf8\xda\xfc\xac\xf7\x28\xcf\x24\xda\xb5\x3d\xca\xf3\x13\xae\xdb\x9f\xb3\x25\x2b\xf7\x3c\x8a\xde\xab\x37\xba\xec\x17\x4f\xf3\x69\x3e\xe9\x2f\x9a\xf4\x53\x7b\x73\xcc\x15\x5c\x14\x5d\xc2\x9e\x1f\xdc\x7a\x9b\xab\xe1\x13\x33\xdf\xca\xbd\xb0\x07\xb8\xde\x83\x71\x6e\xdc\xff\x6b\x2d\x09\xff\xb6\x96\xb8\xc7\xf0\xde\x63\x78\xef\x31\xbc\xf7\x18\xde\xbb\x53\x1a\xf0\xf5\xdf\x8a\xde\xb0\xc7\xf1\xde\xab\x0e\x7b\xd5\xa1\x76\x89\xaf\xd0\x26\x7c\x15\x28\xe5\xc1\x26\xdc\x55\xf5\x7d\x1c\x6d\x0b\xc2\x78\xa7\x45\xf8\x9e\x92\xfb\x42\x7c\xf7\x7f\xfb\x42\xfc\x55\x16\xb7\x2f\xc4\xdf\xe7\x56\xed\x0b\xf1\xf7\xd9\x43\xfb\xec\xa1\x7d\x21\xfe\x5b\x29\xc4\xf7\x0a\xd4\x2e\x8a\xf1\x6b\x94\xb1\xe5\x05\xf9\x5f\xe6\x2d\x83\x57\xab\x68\xf9\xb9\xee\x0b\xf3\xf7\x85\xf9\xdb\xf2\xce\xab\xb0\xc9\x9e\xa4\x40\xbf\x46\x0c\x6c\x6b\x88\xbd\x8d\x42\x7d\x3f\xdb\x7d\x95\xd1\x3e\x59\xf2\xf5\x27\x4b\xbe\xba\x2a\xa3\x57\xa3\xb6\xef\x8d\xe1\x1d\x1a\xc3\xfb\x42\xa3\x7d\xa1\xd1\xde\x55\xb0\x32\xb5\xf6\xae\x82\xf8\xbb\xb7\x51\x68\xb4\x5c\x9b\xde\x49\xc1\xfe\x53\xe8\xd5\x7b\xb5\x1a\x7f\xb7\x57\xab\xf7\x6a\xf5\x37\xaa\x56\xbf\x0e\x0a\xef\x75\xea\xbd\x4e\xbd\xd7\xa9\xf7\x3a\xf5\x5e\xa7\xde\xeb\xd4\xee\xa9\x9d\xe9\xd4\xbb\x2d\xe0\x5f\x33\x8a\x15\x15\x85\xbc\x25\x65\x7a\xaf\x48\xef\x15\xe9\xd7\xad\x48\xbf\x9a\x05\xed\x8b\xf9\xf7\xc5\xfc\x73\xdf\xbc\xde\x62\xfe\xdf\x39\x46\x38\x88\x64\x7f\xb8\x24\x0e\xbe\xcf\xe4\xe0\x76\x36\x65\xf6\xbf\xa7\x7c\xc2\x84\x06\x8d\x85\x9b\x59\x7c\x71\x36\x10\x78\x9e\xb4\x07\x37\x67\x17\x9f\xce\xe3\xaa\x93\x83\xcf\x77\xe7\xb7\x67\x57\x9d\xeb\x5b\x3f\xc3\xb0\xaa\x98\x16\xee\xb9\xd2\xdd\x7f\x22\x27\x53\xaa\xb8\x96\xa2\xfb\x75\xaa\x98\xb6\x53\xbb\x84\xdb\x56\xaa\xcd\x66\xd7\xfd\x4b\x3c\xb3\x8b\xf2\x3f\x3f\xdd\x96\xff\x55\x5a\xc5\xf9\x6d\xf9\x5f\xdd\x85\xab\x89\x06\xae\x9e\xa0\x43\xf2\xe9\xf6\x98\x7c\x82\xa8\xbf\x22\xb7\x63\x8a\x35\x4e\xe7\xb7\xc7\xe4\x9c\x69\x0d\x9f\x14\x0f\x1b\x6e\x32\x58\xdb\xf7\x5c\x50\x35\x23\x7e\xf9\x58\x2f\x45\xc1\x1d\xe8\x49\x53\x25\x9e\xf8\x7b\x2e\x40\x61\x2d\xa8\x77\x2e\x47\x3c\xa1\xd9\x76\x44\xec\x5c\xc4\xe7\xe5\xe0\xf2\x7a\x21\x29\xe2\x5f\xcf\xd3\xa2\x73\x71\x0a\xd5\x5b\x7e\xaa\x35\x2b\xbf\x60\xda\xb0\xd4\x5e\x80\x29\x32\xaf\xb5\x35\xd8\x2c\xba\x18\xff\x2e\xa1\x9e\x2b\xd7\x56\x5d\xeb\x5c\x9c\x92\x23\x72\x79\xdd\x13\x97\x2a\x45\x7f\x01\xb3\x37\x0a\xda\x2a\x5c\x13\x21\x0d\xe1\x93\xa9\x54\x86\x0a\x63\x2f\x53\x2b\xc8\xa4\xa3\x88\x26\x54\x31\x72\x22\x27\x93\xdc\x50\xc3\x1f\xd8\x1c\x51\x05\x1a\x01\x37\xcc\x9c\xa5\xe0\x81\xac\xa1\xa1\x1c\x94\x14\x9d\x83\xa9\xb2\xe3\x1b\x5e\xd1\xfe\x0e\x78\x3a\xa7\x0e\xfa\x21\xa8\x52\xb4\x2c\x06\x0f\xb8\x61\x93\xea\xef\x57\xcc\x14\xfb\xb5\x56\xb7\x3e\xa5\x86\x9e\x4b\x9a\x72\x31\xc2\x02\xba\x73\x6e\x98\xa2\xd9\x67\x3a\xfd\xe8\x1d\x1c\x1b\xf0\xc7\x7f\xdd\x5c\x5e\xc4\x0c\xf2\x73\xe7\x73\x5c\x5d\x76\x70\x75\x7d\x79\x7b\xb9\x90\x67\x4a\x23\xcc\x33\x8d\xfd\xfa\x18\xfe\x97\x1c\x11\x3b\x7a\x50\x16\x26\xcc\xd0\x94\x1a\x4a\xde\x63\xad\x48\xc8\x28\xe7\x22\x03\x1e\x99\x2a\x3e\xe1\x76\x5f\x9d\x95\xf6\x01\x98\x89\x28\x66\x4f\x08\x13\x26\x70\x09\x3e\x80\x75\x5f\x70\xd3\x19\x2a\x52\xaa\x52\xf2\x77\xed\x4a\x05\xed\xbd\x87\x3f\xa7\xda\x7f\xc0\x52\x72\x48\xc6\xc6\x4c\xf5\xf1\xd1\xd1\xe3\xe3\x63\xdb\xfe\xba\x2d\xd5\xe8\xc8\xfe\x71\xc8\x44\x7b\x6c\x26\x19\x1c\x78\xa0\xc2\x31\xb9\x52\xd2\x48\xfb\x42\x4a\x34\x53\x9c\x66\x50\x8d\x36\xc0\xd3\x2e\x87\xe4\x6f\x89\x54\xac\x5d\x6c\xcc\xdf\x48\x54\xbe\x38\xcc\x66\x86\xf1\x34\x3b\xb2\x3f\xaa\x39\x3a\xd5\xfd\x24\x29\x4b\x78\xea\xee\x6e\x26\x12\x99\x82\xcb\x03\xbf\xe3\x22\x14\xd8\x30\x17\x3d\x08\xe4\x74\x76\xfd\x80\x91\x09\x4d\x19\xa1\x0f\x94\x67\x58\xc9\x2a\xd1\x4b\x85\x74\x66\x4a\xb7\x49\x4f\x9c\xa1\xa6\x93\x5b\xad\x0e\xf2\xbd\xc0\x76\xf1\xbf\x9d\xda\x15\x27\x32\x23\x83\x7c\x68\xb5\x82\xe8\x5a\x6a\x11\x6e\x2c\x2d\x14\x4b\xe4\x64\xc2\x04\x3a\xb2\xec\x40\xf0\x24\x90\xcc\x4d\xb7\xdd\x13\xc0\x00\x54\xa4\xc8\x02\xa9\x84\x93\x2d\x98\xd5\x90\xc5\x0c\x5f\x33\xc8\x87\xa5\xe8\x88\x91\x44\x31\x9a\x12\x6e\x7a\xa2\x93\x59\x5b\x6a\x22\x0d\x8b\x13\xd7\xc0\x95\x5a\xa2\x38\x48\x04\xc5\xa6\x19\x4d\x7c\x21\x60\x26\x13\x9a\x91\x21\xcf\x98\xeb\xe0\x1c\x0d\xf0\x1e\xd4\x7b\x4b\x34\xae\x49\x2a\x1f\x45\x26\xa9\x5b\x47\xf5\xb1\x0f\x65\xe1\x12\x7a\x9e\x77\x95\x92\x0a\xfe\xe7\x47\x2e\xd2\xcd\x0e\xe1\xdd\xc5\x8f\x17\x97\x5f\x4a\xe7\xf0\xee\xa6\x7b\x1d\xff\xfb\xe6\xe7\x9b\xdb\xee\xe7\x85\x07\xb1\x3a\x4a\xc1\x5a\x30\x3d\x50\xfb\x8e\xc9\x0d\x12\x41\x2a\x62\x15\xf9\x86\x45\x7d\x76\xbc\x54\x7c\x20\x53\xb6\xd9\xda\x3e\x77\x2e\xee\x3a\x25\x91\x72\x73\xf2\x43\xf7\xf4\xee\xbc\xa4\xc8\xf9\xf5\x45\x9f\x5c\x77\x51\x4d\x8b\x3f\x3b\xf9\xe1\xec\xfc\xb4\x1f\x14\xbb\x45\xd4\xa8\xbc\xb7\x2a\x98\x6e\x51\x00\x8d\x65\x4a\x06\xb3\xb8\x58\xad\x28\x31\x7e\xa4\x9a\x64\xe0\x8c\x67\x69\xbb\x87\x37\x3f\x8e\x7a\x0c\x72\xc8\x17\x2f\x17\x4f\x4c\x64\xca\x5a\xee\x37\xf6\xda\xc2\xf2\x6f\xab\x5c\x97\x6a\x97\xe3\x81\xed\xdb\xa9\x20\x5c\xa4\xfc\x81\xa7\x39\xcd\xb0\x4c\x3b\xd0\xe8\x98\x74\x88\xb6\x3f\xcc\xed\x01\x56\x7c\x34\x02\xb3\xb2\x32\x55\x1c\xcd\x3d\x0a\x94\x84\xe7\x42\xc7\x72\x38\xd2\xf6\xb5\xce\x1f\xc1\xad\x38\xb0\x72\x18\x1f\x84\xb2\xf4\xf2\x88\x8a\x9a\x31\x53\x75\x53\xf3\xfb\x72\x8c\x5e\xc4\x86\x65\xc1\xd1\x2b\xb2\x4a\x41\x44\x69\xb4\x86\xa7\x8a\x3d\x70\x99\x47\x8f\xba\x0a\xfa\xd2\xe6\xd6\x0e\x5f\x10\x00\xc8\x26\x61\x8e\xc5\x30\x65\x6e\x3e\xbb\xbc\x31\x8a\x1a\x36\x9a\x9d\xba\x93\xbd\x39\x17\x9f\x5e\x7e\xb9\x38\xbf\xec\x9c\xf6\xbb\x9d\x4f\xe5\x83\x19\xbe\xb9\xb9\xbd\xee\x76\x3e\x97\xbf\xea\x5f\x5c\xde\xf6\xfd\x2f\x16\xb2\x6b\xc3\x0b\xe6\xef\xd3\xf2\x0f\x8f\x89\x95\x8c\x20\xc1\x3c\xd8\x4e\x24\xc6\x06\x6c\x28\x15\x8a\xe3\x89\x8f\x3b\x81\xe4\x27\x81\xb2\x2c\x05\xda\x57\x56\x71\x4c\x4e\x1b\x86\x44\x7f\x86\x51\x8c\x4e\x40\x9c\x53\x41\xba\x22\x3d\xbc\x1c\x1e\xde\xe0\x87\x13\xaa\xee\x99\x0a\x8f\x3e\x2a\x6e\x0c\x03\x37\x2c\x77\x1e\x5a\x42\xfd\x94\xed\x7d\x03\x79\xc5\xc5\x0b\xda\xe4\xda\x8a\x67\xfb\xfb\x70\xf7\x58\x46\x4d\x99\xa1\x3c\xd3\x6e\xb2\x25\xba\x1e\x93\x73\xaa\x46\x8c\xa0\x22\xa7\xc9\x7b\x39\x1c\xe2\x60\x1f\x70\x1a\xf6\xaa\x29\xad\xa2\x46\x44\x5a\xd6\xf0\xd7\x17\xbc\xcf\xfd\x38\x68\x69\xf3\x5c\x75\x37\xdd\x8e\xa7\xee\xae\x80\xe2\x97\x17\xfd\xee\x7f\x9f\x95\x2c\x16\xf7\x4d\x0d\xaf\xc1\xc2\xf1\xeb\xc5\x77\x41\xfd\xd8\xf3\xec\x54\xfe\x61\x0d\x3b\xe5\x53\xbf\xf3\x43\x6b\x03\xd5\xf0\x12\xfb\xca\x0d\x6e\x4c\x3c\xef\x0a\x0b\x15\xc3\x68\xab\x37\xd0\xe9\x94\x51\xab\x80\xcc\xef\x76\x59\x5d\x6b\xd8\x7b\x7c\x53\xfc\x0e\xb7\xc9\xfe\x3d\x2d\x22\x45\x36\x8b\xef\xfa\x0a\x47\xae\xc0\x03\x38\xd6\x1c\x07\xfc\x05\xc1\x2a\x2e\x87\xce\x98\xbf\xe5\x6c\x43\xe3\xec\xee\xe2\xb4\xfb\xf1\xec\xa2\x7c\x13\xfe\x70\xf6\xa9\x74\xe7\x7d\xee\x9e\x9e\xdd\x95\xe4\xca\xb2\xab\x6f\x7e\xd8\x1a\xf4\x93\xf0\xa3\x63\x72\x8a\x8f\x1e\x13\x21\xeb\x90\x38\x82\xba\x5c\x91\xaf\xd7\x3e\xb2\xeb\xff\xe8\x0a\xa3\x6a\x3d\x11\xab\x9a\x58\xce\xcf\x55\xb2\xb1\xea\xdd\xe1\x73\xef\xbe\xa8\x3a\x2e\xe7\xc3\x05\xce\xd9\x65\x5f\xd2\x2e\x2c\xaf\xd8\x4f\x0e\x66\x46\x93\x91\x57\xe3\xaf\x2a\x58\xe7\x27\x70\x83\x4e\x72\x0d\x4c\x48\x31\xe2\x46\xee\xff\xac\x2d\x41\xa1\xa2\xa2\x4d\x6e\x18\xeb\x09\x6f\x6f\x8c\xb8\x19\xe7\x83\x76\x22\x27\x47\x05\x0c\xcc\x11\x9d\xf2\x09\xb5\xf7\x31\x53\xb3\xa3\x41\x26\x07\x47\x13\xaa\x0d\x53\x47\xd3\xfb\x11\x04\x57\xbc\xcb\xee\x28\x0c\x3b\x92\xff\xfb\xfc\x5f\xbe\x3b\x3c\xff\xf3\x77\x07\xf3\x16\x64\xd3\xfe\x77\x45\x42\xa7\x3a\xcf\x5c\x10\x56\xc5\xb4\x01\xb1\x0e\x94\x58\xb6\xdf\x17\xe5\xed\xda\x4e\xe1\x3d\xb9\xba\x2b\x79\x74\xca\xff\xfc\xdc\xfd\x7c\x79\xfd\x73\x49\x61\xbc\xbd\xbc\xee\x7c\x5a\xec\xd9\x99\xd3\x88\x2b\x64\xf8\x51\xc8\x47\x51\x5e\xbd\xae\x2e\x3a\x17\x86\x4f\x98\x57\x88\xdd\x3f\x6f\x71\xa5\x1b\xac\xfc\xf2\xf6\x87\xb2\x4c\xff\x78\xfe\xf3\x6d\xb7\x7f\x73\xfa\xe3\xc2\x95\xe0\x63\xa5\x99\xdd\x40\x04\xe9\x44\x66\xf9\x44\xc4\x7f\x6f\x3e\xb7\xb3\x8b\xdb\xee\xa7\xea\xec\x2e\x3b\xb7\x65\xb2\x5f\x97\x03\x93\x07\xdf\x5f\x5e\x9e\x77\x3b\xa5\xbd\x3c\xed\xdc\x76\x6f\xcf\x3e\x97\x7c\x72\xa7\x77\xd7\x25\x20\x9a\xda\x65\xfa\x19\xd4\x2c\xd4\x2e\x2b\x5e\xe6\xae\xe5\xcc\x4a\xc7\xbc\xe3\x92\x7e\xf0\xa0\x1c\x46\x15\xe1\x18\xcf\x03\x1b\xeb\x30\x78\x38\x12\x9c\x69\xad\xac\x31\xe5\x6d\x22\xcd\xb2\x6e\xe1\x46\x2f\x12\x79\xb7\x61\x0a\x30\x2f\x17\xf6\xa7\x59\x26\x1f\x31\xf5\x62\xc2\x0d\x4b\x3d\x3c\x87\xfd\x89\x26\x49\xae\x14\x13\x26\x9b\xb5\x6b\xc4\x49\x79\x5b\xa4\x32\xa7\x21\x38\xbf\x99\x56\x5d\x17\xe9\x9e\x8f\x71\xd7\x2b\xcc\x95\xb8\xb6\x9f\x16\x74\x0a\x92\xa3\xcf\x4c\x6b\x3a\x62\xdb\xb8\xc6\xea\x84\xd4\xcd\x4f\xf1\x3f\xc1\xf5\xb5\x8a\x00\x2a\xcd\xd0\x47\x71\xbd\x4c\xb9\x14\x1f\x29\xcf\x72\xc5\xae\x64\xc6\x93\x0d\x5d\xf9\x1f\x3b\x67\xe7\xfd\xb3\xcf\x56\x59\xe8\xdc\x76\xcf\x4b\xa2\x12\xbe\xeb\x7c\xbc\xed\x5e\xf7\x11\x4f\xaa\xf3\xfd\x79\xb7\x7f\x71\x79\xda\xbd\xe9\x9f\x5c\x7e\xbe\x3a\xef\x2e\xf1\x90\x37\x0e\x3e\xaf\x4f\x56\x7f\x7a\x3c\xf7\x09\xe1\x2e\x83\xc7\x45\xa5\xd0\x48\x35\x12\xea\x22\xc1\x3d\x27\xd1\x4d\x47\x89\xb0\x0a\x99\xfd\x18\x5c\x3d\xf6\xd7\x3e\xbe\xdf\x26\x67\xe6\x5d\x96\x11\x9a\x1b\x39\xa1\x60\x63\x66\xb3\x9e\xa0\x03\xa9\x0c\xd8\x17\x81\x8f\x89\xca\x85\xb0\x06\xae\x1d\x0c\x61\xdb\x92\x8c\x51\x41\xf2\x69\x94\x9b\xe6\x2c\xa5\x21\x17\x76\x20\x30\x62\xd0\x28\x2e\x5e\x59\xd8\x99\xd6\x8e\xed\x09\x2c\xe3\x44\xd3\x75\x15\x0a\x1f\xaf\xf4\xab\x46\xea\x4c\xe8\x3d\xb3\x54\x99\xe4\xc9\xd8\x2a\xcb\x23\x65\x6d\x7a\xd4\xa6\x13\x2a\xd0\x35\xea\x7e\x6e\x55\xdd\x9e\xb0\x1a\x31\xcd\xbc\xd2\x9e\xb2\x29\x13\x29\x13\x09\xc7\x8c\x34\xf0\x2a\x06\xe3\x7a\xa4\xe8\x74\x4c\xb4\x04\x6f\x1c\x90\x1d\xdc\x16\xf8\x10\x91\x48\x7c\x57\xb8\x0a\x5f\xc7\x3a\xb7\xca\xad\x05\x7f\x09\xc6\x38\x52\x19\x1e\xf6\x0a\xb7\x37\x34\x11\x08\x6f\x32\xcd\x18\xbc\xd2\x91\x1c\x36\xc3\xd2\xba\xb4\x1f\x76\x9b\xea\x36\xa1\x27\x8a\x39\x53\xed\x66\xd4\xae\xd1\xe5\xdd\x91\x22\x3f\x50\x91\x66\x76\x14\x6f\xb5\x95\xcf\x22\xa4\x55\x74\x2c\xd7\xf8\xd3\xb8\xcd\xbd\x92\xd0\x5c\xaf\x75\xb1\x2c\x4e\x23\xa4\xe0\x95\x3d\x2c\xdc\xd5\xc0\xde\x2e\x87\x10\xa8\x3b\xa5\x96\x07\x32\xe9\xa8\x84\x3f\xcf\x11\x6d\x97\xc0\x6c\x1a\x34\xdd\xa9\xe2\x22\xe1\x53\x9a\x6d\x74\x0d\x56\x02\xcb\xae\x64\xf8\x3d\x1f\x5a\xf6\xf9\x30\xe7\x64\x32\x4c\x4d\x20\x9f\xd6\x4d\x33\x6c\xe1\xb2\x2b\x06\x77\xc7\x32\x32\x2d\x47\x42\x37\xd8\x1b\x0c\x21\x34\x2d\xb7\x32\x8a\x7b\x3b\xc6\xb0\x68\x76\x55\x3f\x66\x1d\xc1\xa2\x2f\x7f\x5d\xb4\xd5\x9f\xe9\xd4\x6e\x31\x82\xda\x11\x5a\xac\xd1\xa5\xc9\x3a\xc8\x64\xef\x87\x8f\x1c\x73\x21\x25\x61\x75\x75\xbf\x20\xa1\x8b\xa4\xcc\xbf\xa4\xe4\xa0\x8c\x32\x98\x1d\x4b\x0e\x73\x63\x4f\x13\x05\x17\x27\x79\xcf\xda\xa3\x36\xb9\xfc\xa9\x7b\x7d\x7d\x76\xda\x6d\x91\xce\xd5\x55\xf7\xe2\xb4\x45\x98\x49\x3e\xf8\x50\x9f\x8b\x7c\xf4\x84\x91\xce\x82\x9c\x91\xb1\x7c\x04\x51\xc6\xd4\x88\x95\xd6\xec\xc3\x24\x50\x97\x3e\xe2\xda\x28\x17\xac\x11\x69\x0c\x34\xc9\x27\x55\x9b\x04\x39\x24\x37\xe3\x6d\x58\x83\x6a\x9d\x4f\xe8\x20\x63\x7d\x4e\x27\x7d\x25\xb3\x65\x67\xb8\xf6\x48\x15\x66\x5c\xdf\x59\xce\x7d\x9a\x24\x32\x17\x66\xe5\xd1\x96\xed\xe3\x29\x90\x49\x93\xa9\x3d\x50\x10\x23\x9e\xc7\x3d\x8c\x6e\xa9\x04\xe2\xd6\xe0\x2b\x05\x91\x91\x15\x99\xe5\x0e\x3f\xb3\x9e\x96\xd7\x65\x0a\xec\xe9\x89\xf4\xac\x23\xd7\x09\x42\xa4\x7a\x8b\x38\x42\x88\xdc\x86\x7e\x75\xa3\x2c\x1a\x89\x3c\xb9\xb8\x3a\x41\x39\x55\x07\xbc\x89\xb1\x93\x0a\xd4\x3b\x84\xe6\x2a\x98\xb6\xc8\x8f\xf6\x20\xa3\xfc\xf8\x25\x97\x86\xea\x0f\xed\x9e\xb0\xc2\xf0\x9e\xcd\x30\x9e\x6f\xc5\xcd\xef\xed\x15\x78\xa8\x99\xd0\x10\xff\xfd\x3d\x9a\xe6\x56\x60\x3e\x50\xc5\x2d\x6b\xa1\x46\x88\x50\xba\x65\x4c\x50\x08\xd9\xb9\x41\x9d\xb4\x2b\x22\xa2\x05\x90\xa8\xff\x0e\xa7\x3f\x62\x06\xb2\xf4\x0c\x37\xa0\xaa\xa4\x88\xd5\x3b\x37\xf5\xa5\x56\x11\x70\xc5\x29\x66\x18\x6e\x95\x6c\xb0\xc9\x91\x59\xd7\xae\xad\x1e\x07\xae\xa7\x19\x9d\xcd\x79\xc8\x96\x1d\xa3\x0b\xbb\x39\x53\x9a\xb0\x22\xc3\xd1\x27\x83\x26\x72\x32\x01\x47\xac\xaf\x6a\x48\xf9\x10\x3c\xb2\xc6\x1e\x31\x32\x60\xe6\x11\xfc\xff\xfe\xd3\xe0\x74\xb4\x6a\x30\x15\x08\x84\x0c\xdc\xd2\xb3\xb4\x4a\x73\xb0\x36\x7b\x07\x2d\xd2\x3b\x48\xd9\x03\xcb\xe4\x74\xc2\x84\xb1\x1f\x30\x53\x2b\xd0\xba\x13\xca\xb3\x0b\x69\x82\x4b\x79\x9b\x6d\x51\x2c\xe1\x53\xce\x84\xd1\x7d\x66\xc7\x7d\xd2\x84\x90\x65\xa6\xbd\x2f\x9d\x80\x99\x10\x9a\xa6\xd6\x22\x00\x70\x4d\x3f\x49\xe7\x88\xc0\x3c\x9a\x40\x80\xd5\x78\x38\x84\x7e\x77\xcb\xc6\xf5\x2e\x8e\x44\xaa\x80\x25\x14\x5e\x5c\xc0\x21\x2e\xe4\x5a\x07\xae\x5a\x80\xf6\x79\xeb\x66\xde\x70\x6b\x50\x86\xed\x5d\xb8\xda\x3c\xcb\x94\xb9\xb1\xcf\x2d\x9c\x9a\x8e\xab\x7c\x3c\x08\x78\xa1\xda\xb8\xa8\x68\x35\x10\xcb\x96\xce\x38\xc9\xa4\xce\xd5\x8a\xfe\xa3\xf2\xa4\x4f\xdc\xa3\x8b\xe6\xdd\x8d\x35\xc1\x3c\x33\x7a\x2d\x65\xb3\x86\xf0\x45\xce\x0e\xa2\x0d\xc1\xe1\x36\xee\x96\x75\xbf\x6e\x11\x2e\x92\x2c\x87\x2c\x17\x6b\xc1\xfb\x90\xb1\x48\x49\x71\xb5\xf5\x44\x48\x73\xa1\x9a\x3c\xb2\x0c\x3c\x06\xd6\xaa\x04\xb1\xed\xa6\xeb\x46\x62\x29\xd1\x86\x1a\xd6\x22\x32\x37\x76\xb0\x16\xe2\xa5\xbb\x2d\x38\x1c\x50\x28\x35\x2a\xba\xa0\xf4\xc4\x9d\xf6\x31\xce\x50\x21\x82\xbc\x8e\x02\x8c\x0b\xf2\x89\x19\x18\x05\x4a\xf6\xe2\x05\x22\x2e\x7c\xad\x08\xaa\xd2\x7e\x8b\x13\xe5\x56\xb2\xc6\xce\x17\xc9\x31\xdf\x67\x72\xb0\x70\xdf\x3b\x64\x82\x66\x89\x7b\x8b\xf7\xba\x14\x06\x69\x54\xda\xb0\x8c\x47\x99\x52\xa5\xa4\xc5\x25\xc7\xbf\x9c\x50\xb3\x98\x3d\x21\x9d\x85\x0b\x4c\x2e\x82\x1c\xb0\xea\x3c\x9d\xab\x62\xd9\x1c\xc1\xa0\xee\xbf\x1d\xb3\x1d\xe7\x3b\x99\x77\x55\x2c\x63\x82\xb2\x8b\xe3\xa9\x17\x03\x07\xc4\x8c\x19\x57\x64\xa5\x65\xf9\xf3\xdb\xc7\x33\xbf\x3a\xd3\x14\xbc\xdd\xe4\xa9\x40\x21\x12\x04\x84\x9d\x98\x2b\x31\x2c\x35\x31\x68\xf7\x44\x65\x12\xce\xf7\xa5\x09\xb0\x97\x3f\x0d\x25\xd9\xdf\x22\x43\xfe\xd5\x0d\xea\x93\x81\x8a\x9f\x46\xd6\x56\x83\x0f\x66\x4c\xe7\xd9\x6e\x8d\xfb\xf1\x0a\x9e\x5f\xe8\x64\x90\xda\x1a\xd4\x89\x55\xac\x14\x4b\xa4\xb2\x22\x11\x5e\x1b\x42\x14\x4b\xef\x46\x43\x95\x25\x0a\x5d\x66\x75\x95\xe6\x51\x94\xdc\xa6\xd4\xb0\x43\x6b\xb8\x2f\x09\xce\x4e\xa5\x7d\x0d\xe1\x13\x6b\x5b\x44\xb9\x8d\x85\x84\x1d\xb0\x11\x15\xde\x9b\xdb\x30\x5b\x2f\xda\xb7\x38\xcc\x56\xb3\xa2\x13\x6b\x66\x82\x1e\x61\x27\x54\x9e\x87\x9e\x02\x39\x17\xce\xc3\x59\xde\xcf\x45\x35\xb3\x80\x6c\x8f\x34\x38\x02\x1a\x26\x9b\x43\xf3\xa9\x57\x33\xd9\x8c\x6a\x43\xdc\x9c\x1a\x66\x1c\x6b\xb3\x3b\x48\xca\x5e\x84\xce\x1d\x1b\x0e\xeb\x28\xe7\xf1\x14\x89\x66\xc6\x70\x87\x22\x9d\x6b\xe6\x52\x69\x26\x4c\x8d\xbc\xc2\x87\xc0\x82\xe1\x68\x3b\x84\x41\x2f\x47\x63\x59\x02\x7e\xfd\xf9\xa1\xdb\xa4\x23\xe6\x12\x02\xbd\x0f\xa3\x44\x2f\x94\xda\x34\x7b\xa4\x33\x4d\xa6\x0a\xf3\x6f\xd0\xd9\xef\x17\x0f\x4e\xbb\xf2\x43\xde\x43\x67\x15\x2a\x8c\xb6\x40\x4b\x96\x78\x66\x0d\x9b\x15\x41\xc8\xaf\x2e\xec\x56\xd4\xfd\x2b\x8e\xe8\x3a\x40\xf9\x60\x02\xd5\x4a\xba\x39\x65\xb6\xc8\x99\x8d\x53\x24\x5c\x2d\x18\xe8\x96\xce\xba\xe8\x96\x9d\xd8\x4d\x0a\x1f\xb8\x40\xce\xe9\x80\x65\x5b\x3b\xaf\x37\x72\xd5\xc3\xab\x5d\x95\x9e\x35\xbf\x19\x3a\xe3\xa1\xbf\x8e\xaa\x8a\x36\xef\xc4\x51\xf9\x6a\xae\xf9\x62\x9d\x25\x5c\xcc\x2d\x16\xea\xcb\x4e\x37\x97\xdf\x4d\x25\xa9\xf1\x45\x52\xd4\xa4\xd6\xdf\x22\x55\xf7\xcd\x36\x73\x88\x8a\x47\x6b\xa7\x40\x76\x51\x3e\xba\x13\x6f\x50\xe0\x99\x15\xa1\x52\xce\x86\x44\x48\xc1\x08\xd7\xc5\x8f\x4d\x39\x08\x49\x46\x4c\x30\x05\x39\x9f\x3e\x73\x62\x1e\x88\xf9\x99\x8d\xf2\x4e\x30\x26\xc9\x90\xb3\x2c\xd5\x44\x30\x6b\xd3\x50\x35\x83\xbc\x7f\x14\x68\xab\xe8\x46\xbb\xd2\x56\x6b\xae\x0f\xa7\x46\xfa\x52\x4a\x80\x7e\xb0\x9a\x58\x65\x5e\x04\xeb\x22\xdc\x8f\xdc\x43\x2e\x0b\xad\x27\x82\x15\x0c\xfc\xc7\xb5\xb5\xee\xda\x04\xb6\xcd\x14\x4f\xd9\x3b\xc6\x7e\xe0\xf7\xb0\xe5\x75\x59\x8d\xc0\x09\xeb\xd8\xfe\xfe\xde\x2a\xe8\x58\x4e\x7c\xf7\x05\x3a\x23\xfe\xc0\x44\x6d\x83\x26\xcf\x14\x59\xc9\x0d\xb9\x58\xea\x38\x24\xe7\x57\xe0\xa7\x5a\x9d\x52\x76\x93\xf3\x39\xcf\x15\xe2\x34\x17\x46\x76\x36\x0b\x41\x9c\xd8\x54\x71\x35\x3b\xd8\x67\x87\x6a\xf2\x7b\x21\xcd\xef\xa3\xb2\x26\x6f\x0e\x23\xd0\xb7\x73\x4d\xb4\x4a\x15\xbe\xdc\xe7\x68\x3b\x26\x21\x34\x9c\xd5\x74\x39\xe5\xb7\xad\xa5\x2b\x82\x2a\x4f\xaa\xbd\x75\xe7\x03\xcd\x4d\x10\x09\x88\xf2\xb3\x33\x1f\xc0\x73\xb4\x98\x20\xc8\x06\x8a\x41\xd8\x44\x48\x32\x91\x8a\x55\x90\x86\x50\x78\x87\x4c\x0c\x44\x78\x59\x9d\x4b\x6b\xdc\x61\x88\x9e\x52\x1c\xf3\x92\x1b\x6c\xb1\xfb\x6b\x17\x29\x16\x93\x72\xba\xfd\x02\x0e\x58\x52\xcc\x54\x6f\x92\x6f\x92\x16\xd1\xa4\x93\x06\x47\x74\x0c\xa9\xde\x54\xc2\xd3\xee\x89\x8f\x52\xb9\xbb\x53\xbb\xf2\xd8\x01\x4d\xee\x0f\x99\x48\x09\xcd\xcd\x18\x4b\x69\x9c\xef\x78\xe6\x76\xd6\xea\x05\xc0\x02\xa1\x54\x83\xeb\x84\x2a\x27\xf4\x87\xf4\x41\xfa\x59\xf4\x44\x34\x08\x14\xe0\x42\x91\x3f\x00\x91\x35\x29\x10\x0c\x40\x55\x9a\x68\x51\x07\xb7\x35\x07\xb6\xb5\xf8\xcc\xc4\x90\x3d\x3d\x78\x1f\x4b\x05\xd3\xba\x77\x80\xb3\xae\x50\xe8\xcc\xfb\xa3\xbc\x7d\xa3\xe3\xc6\x05\xe1\x97\x2d\x97\xf0\x84\x1e\x19\xb7\x0a\xab\xa6\x7c\xe7\x65\x67\xa9\xb0\x68\x98\x2b\x48\x5d\xaa\x1b\xf3\x7d\x32\xe6\x59\xe1\xa3\xfe\xd0\x72\xe7\x11\x87\xcc\xd8\x03\xcb\xb0\x00\x35\x51\x6c\xc2\x84\x8b\xb6\x7f\x47\xfe\x13\x61\xa8\xc8\x1f\x7b\xe2\x13\x88\xd5\x2c\x9b\xb5\x08\x1f\x16\x23\x53\x53\x19\xe6\xbe\x76\x02\x76\xcb\x50\xb2\x94\x26\x82\xfb\x3d\xa6\x0f\xac\x27\xfc\x30\xff\x49\xee\xc9\x1f\xc8\x1f\x9b\x1c\x39\xae\x88\xec\xa9\xed\x7c\xe0\x62\xff\xae\x48\x32\xb4\x9c\xfa\x08\x92\xc3\xbb\x01\xca\x8d\x44\x83\xa9\x16\x14\xdc\x50\xf9\xc6\xc5\x83\x9c\x8f\x5e\xc5\x27\x97\x2a\x26\x4c\x5f\xc8\x94\xf5\x59\x4d\xe8\x6a\x81\xa0\xb0\x97\xfa\x85\x4c\xd9\xd2\xc0\x53\x50\x90\xbf\x80\xeb\x42\xe7\x83\xb0\x1d\x90\x13\x17\x8c\xee\x32\x83\xd5\x4f\x38\x54\xa6\x6c\x32\xdd\x4d\x63\x65\x97\x4e\xbb\x6a\x81\x44\x77\x13\xa8\x8f\xd7\x60\x8b\x5a\x48\x3f\xaa\x9e\xc2\xaa\x87\xd8\xfe\xd8\xae\xdc\xdd\x39\x51\xcd\x0d\x54\xeb\x2b\x3e\xe2\x56\xdb\x5e\x3d\x1e\x07\x42\x70\x13\x37\x37\x16\xb7\xae\xe4\xe7\x2e\x48\x31\xcd\xa8\xb1\x5c\x7e\x18\xd8\xae\x88\x31\x0d\x64\x5e\xd5\xb9\x1d\x01\xb8\x8e\x13\xa3\x9c\x7a\x3d\xb3\x22\x78\x84\x49\x37\x6c\xcc\xb1\x3e\xae\x73\x72\x4e\xec\xa1\x90\x13\x86\x20\x64\x96\x68\xb9\x19\x4b\xc5\xff\xd1\x18\x90\x6d\xd6\xb0\x8b\x40\x5a\xd4\xfc\x14\xe6\x59\xd6\xb5\x81\x47\x51\x33\x30\x25\x43\xa2\xce\xc2\x21\x03\xfb\xbc\x02\xe5\x63\x98\x67\x58\x7b\x9d\x48\x95\x22\x24\xa6\x2e\xb7\x5a\x55\xbe\xaf\x30\xa6\x6c\xf9\x01\xb9\x2b\x1e\x71\xd5\xdd\xc9\x98\x8a\xd1\x62\x3d\xf2\x2f\x39\xcb\x77\x94\x34\xe3\x20\x57\x5e\x28\x1c\x4f\x47\xba\x68\x8d\x8c\xb4\xb1\x22\xb9\xd2\x8d\xd9\x05\xe4\xa9\xbe\x2f\x1c\x6a\xa1\x86\x00\xcd\xe8\xaa\x3d\xbf\x82\xf3\xe5\xda\x1d\xbf\x1d\xb8\x5f\x9e\x23\x5e\x3f\xaf\x1f\xd5\xc8\x1f\xe0\x3f\x57\xd5\xfc\xac\xde\x8d\x20\xc3\x2b\x7a\xc7\xae\x3d\x1d\x6b\x58\xd2\x7e\x52\x6e\x86\x4e\xb8\xce\x07\x37\xeb\xb9\xe3\xa6\xec\x47\x59\x9b\x25\xf0\xdd\x7d\x08\x63\x6d\xed\xbe\x8d\xdc\x92\x45\x2a\x22\xe6\xa2\xfa\x2c\xf1\xa7\x75\xb5\x94\x03\x83\xe5\x6c\xd8\x28\x2e\xd8\x94\xa5\x1c\xcd\x68\x83\xdb\x69\xde\x10\xaa\x9f\x9b\xff\x7a\xd5\xa9\x2c\x0c\x87\xac\x18\xdc\x00\x8b\x7e\xd1\xb1\x3d\x77\xd9\x46\xe5\xb0\x00\xa6\x50\xc8\x28\x30\x0a\x11\x82\x5c\x13\xa3\x28\x64\xef\x49\xa1\x7b\xe2\x0b\x6a\xb1\x5c\xa3\xbd\xe8\x80\x7d\xc0\x1c\x75\x28\x22\x20\x3c\x1d\xe8\x80\x19\x53\xe1\x0a\x11\xea\x42\x10\x01\x8a\x2f\x9c\x84\x38\x08\x51\xf7\x32\x78\x91\x53\xdd\x6b\x87\xf4\x84\x8e\x33\x64\x2b\x19\x8d\x4d\xbe\x62\xae\x21\xd3\x95\x66\x8d\x36\xe3\x40\xca\x8c\x51\xd1\xa4\x56\xd7\x7e\x3d\xe7\x2d\xe2\x71\x16\xa3\xb5\xfa\xac\x66\xa6\x72\x66\x6d\x0a\x8a\xa5\x18\xd1\xba\x28\x20\xe6\x9a\x00\xca\x82\x86\xa1\x9d\x68\xba\x24\x20\xd2\x8a\x4f\xfe\x80\x65\x6b\x65\x9a\xe0\x03\x0b\xb9\x08\x7e\x52\x80\xb2\xae\x94\xde\x1e\x27\x40\xd4\x16\x03\x2c\x9b\x58\x5c\x42\xb0\xd0\x35\x5c\x4e\xc3\xdf\x70\x8a\xb9\x19\xd7\x26\x3d\x2f\x9a\xa0\xcf\xba\x5e\x45\x63\x3d\x06\xed\x91\xc8\x07\xa6\x14\xc7\x8a\x75\x37\xd3\x55\x76\xd5\x15\x78\xf7\xe5\xd0\xa7\x55\xaf\x2e\x55\xab\x95\xef\x6b\x58\xf7\x0a\x0b\x67\xc9\x54\x71\xa9\x5c\x81\x79\xa3\x8f\x7d\xd9\xe5\xd8\xa9\x24\x62\x00\x3c\xd2\x04\xe4\xb7\x2e\xd0\x25\xbc\x1f\x2d\xdc\x9e\x25\xea\x40\xbd\x14\x3c\x9c\x4a\xa6\x23\x85\x15\x08\x8b\xd2\x80\x0f\x99\x9d\x74\x4f\x58\x8d\x3d\x56\xae\xb1\xec\xca\x57\x61\xd9\x97\x26\x4a\x6a\xed\x72\x2b\x70\x1c\xdd\x5e\x78\x2f\xdf\xba\xa2\x98\x5d\x44\xcd\x9e\x2f\xcd\x72\x1e\xed\xbe\x80\x87\x69\xd0\xe3\x06\x2c\x14\x00\x35\x4a\xd1\x6d\x33\xb0\xfc\xd1\x20\x8a\x51\xed\x3c\x09\x90\xa8\x54\x49\xd1\x58\x43\xeb\x0a\x73\xc6\x84\xc5\xc3\x50\x72\x17\xb1\x90\x2b\xa8\x45\xa0\x69\xae\x09\x57\x8a\x01\x82\xe8\x20\x73\x01\xb2\x12\xd7\xf0\xa2\x9b\x62\x41\x91\x60\x34\xe3\x9b\xe1\xd6\xd1\x7c\x62\xcf\x33\x20\x09\x08\x79\x28\xa7\x60\x85\x55\x7f\x05\xf5\x92\x7c\x68\x39\x31\x6e\xe6\x68\x55\xd5\x43\x00\x44\x66\xc2\xd4\x85\x0d\xfc\x20\x10\x66\x60\x29\x6e\x23\x72\x6e\xef\xa0\xf3\xfd\xe5\xf5\x6d\xf7\xb4\x77\x50\x04\x83\x7d\xe2\x90\xbf\x24\x43\x39\x97\x14\x3d\x11\x42\x3a\xa1\xd3\x01\xec\x25\xa1\x69\x5a\x54\x2f\x61\x3a\x61\x1f\x5d\xd3\xab\x9e\x8a\xa5\x51\x9d\xf9\x61\x3e\xf2\xaf\x2c\xbd\xa6\x66\xab\x58\xd0\xc2\x58\xfb\x4a\x3e\xcf\x5a\x16\xcf\x05\x9f\xf3\xbb\x2d\xb8\x11\xc2\x52\xee\xec\x73\xab\x73\x30\x9e\x04\xd8\x2b\xef\x3c\xd3\x56\xf8\x5a\x3b\x9d\x86\x06\x14\x43\xe0\x01\x91\xcc\x5a\x04\x92\xeb\x2d\xd7\xce\xc8\x9f\xc8\x84\x0b\x48\x84\x5d\x44\xdb\xbb\xf2\x42\xd6\x81\x02\x3b\xbb\xb8\x2b\x03\x75\xfe\x70\x79\x57\x06\xb8\xe9\xfc\xbc\x18\xd4\xab\x3c\xc2\x22\xe7\x48\xb1\xc6\x28\xd9\x48\x22\x29\x02\x69\xea\x16\x7a\x5e\x55\x7b\xbe\xad\x52\xc3\x2c\x68\x60\xbb\xae\x32\x8c\x52\x4d\x5e\x45\x81\xa1\x5b\xe9\x76\xb5\x85\x68\xa8\x5e\x95\xad\xdf\x27\xbd\xa0\x6b\xc3\xc9\x9b\x27\x46\x14\x0b\x00\x4f\x40\xfd\xf5\xbb\x76\x39\x41\x31\xaa\xcf\x69\x5f\x43\x7b\x23\xc5\xd3\xde\x9f\xa2\x9d\x4b\x79\x4a\x07\x1c\xf0\x87\xe0\x06\xf6\xd5\x5d\x75\x35\xf8\xed\x9e\x88\x3b\xe5\xe0\x9d\x69\x79\xc0\x17\xf0\x71\x31\x22\x52\x30\x22\x15\x06\x46\x83\x38\x6c\xc5\xa5\x05\xd5\xd4\x38\x33\x26\x33\x99\xab\xf0\xc6\xb9\xf7\x38\xee\xd3\x63\xea\x93\x27\xbc\x9e\xe9\x42\x7b\x71\x05\x26\x8c\x37\x55\xac\x30\x5d\xe1\xc5\xec\x81\x09\xf2\x68\xcd\x54\x1a\x55\xb6\x47\x49\x6b\x56\x25\x15\xef\x4c\xc8\x4c\xe1\x99\xeb\x1d\x4d\x43\x58\xab\x70\x5c\x69\xca\xdd\xc8\x8b\x19\x78\x07\xd5\x07\x50\x4e\xb1\x19\xf3\xc1\x93\x4d\xbe\x18\x07\x0c\x67\x79\x20\xf6\x0c\x61\x86\x74\x2d\xcb\xb2\xaf\x53\x96\x6c\x92\x32\x7e\xe5\x7b\x21\x2c\xf2\x0d\xc5\x96\x8b\x83\x47\x71\x5b\x67\xa4\xf7\x54\x55\x67\xbb\x64\x9e\x6b\x15\x6e\xd8\x89\xfe\xe4\x2a\x1d\xd7\x9c\xa7\x2f\xdd\x18\x2a\x39\x59\x6d\x8a\xcf\x93\xac\x7c\x3b\x97\xf6\x5b\x72\xb6\xbc\x92\x2c\xe5\xe5\xb3\x6c\x4a\x4f\x5e\x26\xf5\x7e\xc2\x7b\x31\x54\x22\x40\x51\x36\x43\x54\xe0\x10\x82\x72\x99\xc1\xf1\x3b\xe3\x3b\x2b\x04\x63\x7c\xd2\x4e\xe5\x14\x94\xc2\x3c\x03\x6b\x6c\x83\x36\x84\x99\xba\xf5\x29\xc6\x70\x7d\xd6\xf9\x97\xa3\x48\xb5\x2b\xb4\xb2\xc4\xd3\x86\x4e\x42\x59\x6d\xb5\x54\xba\x42\xae\x25\xd2\x68\x57\x29\xa3\x4f\x90\x56\x5c\x67\xeb\x96\x52\x9d\x5d\x4a\xc7\x6e\xea\x09\x2b\x37\xf4\xc2\x89\x95\x0a\x0a\xe3\x09\x39\x8c\xc4\xb8\x88\x6e\x7e\x2b\x4b\x37\x1f\x82\xa7\x7a\x37\xf6\x86\x56\x32\x72\x27\x53\x95\x4c\x70\x12\xdf\xf1\xe0\x64\x99\xd0\x59\x94\x6a\xe6\x60\x60\xe0\x72\xe6\x22\xfc\xab\x2c\x6a\x3d\x33\xc7\x2c\x5a\x97\xee\xd1\x26\xdf\xcf\xc2\xb5\x48\xb3\x2c\x9e\x89\x76\x80\xd0\x38\x4b\x74\x1e\xc3\x25\x46\xce\x2e\x3a\x27\xb7\x67\x3f\x75\x21\x8d\x6a\x26\x73\xf2\xc8\xb5\xb5\x10\x7a\x02\xbc\xab\x88\x22\x8e\x4d\xb7\xf0\x87\x2d\xf8\x15\x24\x57\xea\x7c\x30\xe1\xd6\x9e\x2a\x16\x79\x07\x12\xe1\xda\xa7\xda\xe1\x39\xb6\x0f\xc0\xb5\xed\x93\xf8\xea\xf2\xe5\x97\x9c\x8f\x0d\xcc\xe0\x62\x90\x6d\xf3\xf4\xa2\xe0\xcf\xd3\x66\xea\x45\x6a\x76\x6c\xd6\xd4\x1e\xaf\x7d\xaa\x5e\xfd\xa1\x2c\xd7\xab\x42\x51\x31\xd7\xa6\x72\x99\x34\x57\xa9\x16\x5b\xb0\x8b\x3c\x3d\xaf\x6d\xaf\x93\xbc\xe1\x1f\xa9\xd7\x76\x6e\x02\x0a\x76\xad\x0a\x76\xd5\xa8\xdf\xbc\xb6\x6a\xa1\x08\xf1\x7f\xe3\x90\xda\x3a\xe6\x56\x91\xef\x1e\xb3\x42\x94\xcf\x51\xce\x13\x67\x55\xd1\x2d\xa4\x81\x58\x76\x02\x68\x6a\x73\x89\x24\x3d\x51\xaf\x37\x2c\xe6\xb1\x6d\xc3\xd2\x3b\xad\x2a\x0a\x3b\x72\x1d\x56\xe1\x3c\x22\x5f\x42\x1e\x1e\x1a\xa3\xa1\x57\x12\xab\x9c\x2b\xef\x7f\x6d\xb0\x02\x40\x5d\xd8\x24\xa3\xa9\xe6\x54\xae\x18\x34\x5e\x7a\x2e\xdc\x95\xf9\x34\x16\xd4\x96\xd1\x75\x28\xac\xdd\x7d\x39\x30\x38\x31\x5b\xe0\x21\x77\xe1\x33\x68\x8c\x11\xe1\x30\xac\x44\xb9\x15\x20\x8d\x1a\x64\x18\xf6\xe3\x8c\xc1\xd0\xe1\xf0\xc8\x2c\x00\x4f\x57\xa4\x5b\x50\x77\x72\x91\x32\x25\x18\x35\xe3\xe7\x8b\xd6\x9e\x6c\xeb\x32\x7c\xb6\xc8\xed\xc9\x4e\x70\xd4\x2a\x51\xdc\x35\x03\xb8\x6b\x44\x43\x0b\xc0\xa9\x39\x23\xaa\x0e\x6e\xb2\x48\x1a\x77\x76\x56\x19\xcc\xeb\x29\x02\xd1\xb5\x23\x7e\x0b\xb1\xe3\x45\x26\x54\xf0\xbf\x01\x4a\x68\x09\xae\xc5\xf5\x89\x5d\x7c\xa7\x99\x86\xd0\xd3\x2a\xd0\xcb\x68\x64\x94\x70\x70\xf1\x13\xf7\x41\x03\x5e\x72\xe5\xb1\xea\x6a\x63\xcb\x48\xcc\xaa\x8e\x05\xaa\xd2\x8c\x69\xd0\x79\xd1\xd8\xa9\xa8\xb5\x8b\x8c\xae\x9e\xf8\x41\x3e\xb2\x07\xa6\x5a\x84\x1a\x32\x91\x56\x95\x11\x2c\x6e\xa0\x48\xcb\x65\xcb\xe8\xd3\xa7\xe4\x82\x4e\x58\xda\x85\x0b\x31\x4a\x05\x74\xa6\x9f\x73\xab\xd6\x55\x86\x41\xb5\x93\x6b\x04\xe5\x26\xda\x13\x34\x81\xfe\x50\x10\xdc\x02\x1e\xe1\x7e\x61\x20\x00\x7e\x1f\x9c\xbe\xbf\x6f\x93\x5b\x7b\x73\x73\x5d\x9e\x6f\x94\x61\xde\x34\xb7\x9e\x18\x29\x99\x4f\x83\x6a\x2e\x07\x60\x13\xa0\xf3\xb7\xc6\xe9\x0b\x93\xf1\x1e\xdf\x84\xa6\x56\x2f\x58\xcc\x38\x25\xe3\xf1\x95\xf9\x42\xca\xe9\x9a\x31\x03\xd9\xeb\x32\xc4\xd5\x5c\xee\x04\xb0\x51\x33\x94\xc4\xee\x9c\xc7\x73\x48\x7e\x1a\xb4\xd2\x60\xb3\x97\x72\x77\x1a\x64\xe5\x1a\x7e\x0e\xef\x13\xa8\x4f\x3a\x2b\x5e\xeb\xfa\x6b\x81\xe0\x60\xf5\x30\xfa\x0d\x7b\xbf\x7a\x11\x63\x65\x96\x57\xb9\x9a\x4a\xc8\xda\xce\x66\x3e\xd3\xcd\x65\xa2\x4f\xe5\x34\xc7\x3c\x7e\x1e\x47\xd9\x6a\x27\xc4\xb5\xf9\x4c\x4d\x32\xb6\x0a\x51\x91\x91\xbd\x8b\xe2\xca\x92\x20\x7d\x5a\x03\xac\x66\x05\x27\xf1\xdb\x1b\x9c\x0b\x2b\xdb\xd6\x58\x9f\xe9\x13\x28\xe0\x5f\x59\x46\x26\xf6\xad\x25\xb8\xc0\x08\x53\xaa\x96\xd6\x25\x44\xa6\x9d\x47\x9a\xb7\x50\x90\xa1\x9f\x0a\x17\x24\xea\xa8\xe6\x5c\xe8\xb5\x47\x3a\x57\x7c\x23\x3d\xd8\xb9\x60\xd8\x03\x13\xa6\xb0\xa8\x26\x74\x4a\xb8\x95\xdb\xf6\xe6\x51\x23\xd6\x22\x8f\xf6\xc4\x99\x5c\x59\xd9\x9c\x2b\xee\x4f\x18\x98\x41\x0b\xb6\xaf\x6c\x87\x1c\x61\x48\x04\x93\xc2\x12\x1a\x81\x91\xb9\x3e\x52\x89\xc9\x69\x08\x5c\xc3\x0e\x67\x5c\xdc\xdb\x97\x21\x48\x82\x77\x77\x2b\x2b\xdf\xa4\xf2\x39\xca\xa5\x3d\x5d\xca\x79\x5b\xec\x72\x33\x1e\xe8\xb2\xa3\xc0\xc5\x28\xaa\xae\xa8\xb7\x02\x57\x01\x3b\xa8\x7d\x72\x35\xac\x86\xda\x47\xbd\x3e\xb1\xc9\xb3\x0b\x12\xd2\x37\x06\x82\x2d\x25\x8e\xb8\x44\x09\xa7\x91\xc4\x75\x2f\xce\x96\x80\xaa\x35\x8e\xfd\xd1\x9c\x86\xf2\x1f\xe1\x2f\x84\x98\x42\xd2\xfc\x07\x91\xaa\x27\xf0\xf3\x56\x40\xa3\xb0\x3f\x28\x0a\xc7\x1a\x4a\xad\x03\x3f\x79\x68\xd9\xcd\xf4\xca\xdb\xce\xcd\x8f\xfd\xeb\xee\xcd\xe5\xdd\xf5\x49\x49\xb9\x3c\x39\xbf\xbb\xb9\xed\x5e\xd7\x7e\x87\xe0\xf4\x67\x97\x17\xfd\xbf\xdc\x75\xef\x1a\xbe\xf2\x03\x9c\x77\xbe\xef\x96\xda\xfb\xfd\xe5\xae\x73\x7e\x76\xfb\x73\xff\xf2\x63\xff\xa6\x7b\xfd\xd3\xd9\x49\xb7\xef\x3a\x27\x9f\x2c\x6f\x00\x52\x3f\xdf\x26\xdc\x5e\x5a\x69\x61\x5d\xe0\x67\xf8\x0b\x78\x30\x73\xdb\xc9\xff\x01\x96\xfe\x15\xee\xc1\x61\xcb\xff\x85\x50\xad\x87\xf6\xd8\x7b\x5f\x4f\x71\x62\x7a\x22\x38\xe3\x82\x8c\x37\x74\xa4\x7d\x37\xc0\xd2\x6c\x8f\x49\x67\xea\x3a\xfe\xc9\xf2\x4b\x0d\xd5\xf7\xc5\x4c\xbd\x0f\x16\xf8\x00\x7a\x70\x68\xd7\xff\xae\xb2\x25\xe5\x01\xdd\x9a\x60\x0a\xce\x17\x95\x92\x02\x23\x79\x0e\x6d\xd7\x0d\x5a\xd9\x4b\xe8\xdf\x8b\xc4\xd1\x38\x2f\x28\xd8\x9a\x09\x3a\xe1\x09\x7e\x50\xa9\x59\x72\xd5\x4c\x13\x26\x4c\x75\xc4\x12\x0b\x94\x47\x1e\x33\xf2\xe3\x9f\x8b\x49\x81\x07\xc1\x59\xe4\xf9\x1c\xf8\x9a\xfb\x42\xe5\x48\xd5\x65\x0c\x54\x7a\x93\xb7\x6e\x6a\xfa\x56\x41\x82\x45\x2e\xa2\xb2\x81\x52\x0e\x52\x13\x02\x76\x8d\xe0\xdc\xaa\x2c\x4d\xdf\xf7\x43\xd3\xf6\x8d\x24\xf9\x2d\xd5\xf7\x35\x00\xd3\xb5\xc2\xd1\x11\x7c\xcb\x37\x36\xa3\x5a\xd7\xbe\x34\xd0\xb4\x0f\x1c\xb3\xd9\x3b\x1b\x6b\x02\x97\xbc\xd2\xaf\x38\xab\x60\x2c\xad\xfc\xbe\x12\x46\xd3\xd3\xbb\x3d\x56\xbf\x94\xa0\x70\x9c\x27\x51\xa7\x3d\x38\x35\x01\x97\xca\x03\xa5\x62\xe3\x1e\xe7\x13\xa1\x03\xf9\x50\x2a\xd6\x9c\x60\x23\x9c\x5a\x45\x34\x32\x77\xb7\xe1\xf1\xc0\x6c\xab\xf7\x34\xb2\xa4\xf1\xec\x05\x7d\x8c\x6a\x09\xbf\xaa\x39\x5b\x5d\xcc\xb2\x14\xba\x0d\xfc\xf0\xd1\xe8\xc1\x11\xbf\x8a\x06\x7a\x0a\x7b\x3a\x80\x28\x4b\x81\x57\x8a\xb0\xd8\x60\xa7\xc6\x3e\x87\x56\x91\x70\x80\x9a\x69\xd0\x19\x8e\xbc\x1a\x41\x8e\xd0\x11\x72\x14\x5d\x7d\xb3\xa9\xbd\xf3\x26\x03\x97\x94\xbd\x78\xa3\x23\xda\x6c\xb1\xe5\x4f\x87\xd3\x15\x96\xf5\x62\x30\x5d\x75\x33\x78\xb3\x20\x5d\xd8\x03\x2c\xf0\x86\x5d\xae\xa7\xf6\x1f\xfc\x8a\xfe\x80\x2c\x95\x37\x54\x78\x44\xa3\x85\x4a\x56\x72\x08\x08\xff\x2e\x9d\xdc\xc1\x88\x68\x72\x48\x32\x7e\xcf\xc8\x3b\x88\x6c\x76\xae\xce\xde\xb5\xc8\xbb\x38\x7b\xf2\xdd\x1a\xe2\xaf\x00\xe0\x73\xf3\x76\x68\x5d\xa0\xe9\x95\x12\x73\x3e\x42\x0e\x55\x34\xcd\x4e\x04\xdc\x0f\xd5\x1b\x86\x29\xc4\x94\x82\x6c\x8c\x10\xf1\x77\xce\xca\x65\xb2\xb1\x38\x32\x5b\xe3\x1e\xd9\xf1\xe6\x73\xbb\x77\x1c\x85\x5e\x2c\x08\x97\x64\x8b\x77\x02\xae\x7c\x81\x14\xa5\x1b\x98\x77\x9f\x89\x51\xb7\xaa\x92\x31\xe9\x89\x59\xbb\x29\xcb\x18\xef\xad\xb1\xdb\x0a\x39\x0f\x9d\x3a\x8a\xf8\xd6\xcd\x7b\x2e\x7b\x09\x2e\xdb\x45\xba\x4f\x79\x72\xeb\xdf\x66\x27\xa8\x10\x45\xc3\xf8\x92\x4a\xab\xe1\x7a\x39\x5d\x06\xd4\x5a\x0e\x21\xb9\x66\xc0\x21\xa2\xc9\xf2\x88\xc3\x0d\x46\xaa\xd0\xf3\x3f\x3f\xd7\xea\x54\x3b\xc6\x41\x7c\x48\x8e\x09\xb9\x86\x4f\x98\x6b\x52\x5d\x44\xd7\xdc\x79\x05\x76\x83\xab\xca\x81\xa8\xe3\x4b\x54\x32\xe6\x0f\xf5\x59\xc7\x0b\x37\x78\x8b\xb8\xe4\x45\xe7\x73\xf7\xb4\xdf\xbd\xb8\xb5\x06\xf9\x7c\x88\xb2\xfc\xf5\xf5\xc9\x0f\x67\x3f\x95\x9b\x59\xdf\xfc\x7c\x73\xdb\xfd\xdc\xff\xd4\xbd\xe8\x5e\x77\x6e\xbb\x8b\x9b\x96\x2f\x7a\x59\x1d\x7e\xa2\x4b\x8b\x92\x05\x1a\x62\xea\xb1\xd6\x3c\xa2\x00\x7a\x4e\x8c\x92\x19\xe1\x46\x93\x07\xae\xb9\x2b\x30\x71\xca\xde\xdd\x99\x77\xe6\xd4\xbc\xfd\x38\xca\x2c\x6d\x61\x99\x7d\xf1\x12\xee\x5c\xc2\xb1\x22\xe8\xa2\x91\x22\xc5\x74\x0d\x12\xb5\xa8\x69\xd7\xbc\xc4\x11\xec\x98\x74\xdc\xd6\xd6\x8d\x2f\x24\xb1\x6a\x28\x53\x38\x7b\x0c\x55\x86\xa9\x93\x43\x52\xa5\xf1\x31\x41\x18\xa4\x08\xd0\x31\x0c\x08\xca\x13\x55\x4c\xbc\x33\x84\x7d\x9d\x66\x3c\xe1\x26\x02\x99\x94\x8a\x4c\xa8\xa0\x23\x6f\x7e\xe4\x9a\xa9\x25\xd2\x63\x67\xb1\xcb\x5d\x58\x91\x4d\x59\x5d\xb1\xa5\xe4\xd8\x25\x60\x3c\x19\xe9\xd2\xf9\x9f\xcc\x06\x6d\x88\x81\xcc\xe1\xe0\xac\x3a\xa5\x1d\x99\xaf\x4b\xf2\xc8\x5c\x1e\xa9\x0b\x7e\x52\xed\xae\xbb\x47\xbc\xb8\x5e\x47\x18\xb5\x86\x0f\x5f\x38\x8e\x5a\x02\x92\xdb\x59\xbf\x97\xfe\xf2\x40\x5b\xbd\x9b\x6c\x77\x3d\x58\x0a\x60\xf4\xb9\xee\x2b\xde\xec\xbc\x68\xc6\xd5\x5c\xaf\xd5\x45\x89\x88\xcb\xdb\x5c\x40\x33\x2c\xaa\x1b\x7a\x5c\x00\xd8\x4c\xfa\x5a\x3a\x5d\xcc\x17\x18\x95\x27\xf7\xc2\x6d\x2e\x2a\x93\x79\x3d\xbd\x2e\x96\xd2\xed\xf5\x56\x90\xd5\x4c\x74\x85\x1e\x17\x21\xc1\x19\x20\x2d\xd7\x13\xf9\x50\x54\xc6\xd3\x0c\x24\x92\x0f\x6b\xd9\x43\xb5\x8a\xeb\xb2\x9a\x59\x59\xf2\x3e\x57\xd6\xe2\xaa\x8e\x40\xe3\x29\xb7\x0a\x6b\x16\x8a\xdd\x07\x26\xcc\x4e\xf4\x05\x18\xa2\x26\x01\x7c\x35\xff\x19\x82\xb4\x9d\x9d\x16\x62\x22\xc0\x1a\x47\xb1\x44\xa3\x68\x02\x68\x8e\xd8\xa8\xd0\xf9\xff\x9b\xa2\x12\x76\x69\xab\x6d\x11\xfc\x74\x9e\x2e\x4b\x92\x9c\x1c\xb5\x0b\x54\xca\x22\x81\x42\x26\xd0\xf2\x7c\xad\x9a\xc4\xd2\xcd\x2c\x52\xc0\x0e\x89\x7a\x8b\xa0\xb2\x58\xdd\x73\x7c\xe7\x98\xea\xea\x2b\x97\x6e\xf9\x06\xa5\x4c\xa5\x61\x3e\x31\x73\x4a\x0d\xdd\x09\xe0\xfb\x1a\x99\xe5\x30\x91\x3b\x95\x2d\x6d\x9f\x76\x83\x88\x98\xb9\xca\x0a\x1f\x01\x25\xf6\x42\x6b\x47\xf9\x34\x50\xf0\x51\xa2\x28\x4e\xa6\x41\x0e\xac\xdf\xf0\xed\x29\xa7\xea\x66\xb3\x51\x61\x12\xf6\xb5\xcf\x15\x5e\xcc\xf5\x3b\xeb\xe0\x6d\x40\x76\xba\xb8\x97\x2e\x15\x2d\xfa\xea\x66\x48\xd3\xa9\xbd\xd7\x9b\xf9\x67\x5b\x77\x5a\x19\x5c\xf8\xc9\xbc\x6a\x25\xe9\x5d\x5a\xc0\xbe\x36\x6e\x53\x5f\x99\x43\x3c\x0a\x1c\x08\xa5\xab\x46\x71\x06\x98\x0a\x59\x28\xc4\x2a\x4b\x3a\x67\x35\x2f\x65\x2c\x7b\xad\x9e\x6e\xe9\x41\xb3\xd3\x99\xf5\x21\xd3\x78\x9b\x90\x56\x69\x05\xe8\x40\x80\x31\x59\xea\x1a\xda\x21\x2c\x86\x5b\x7d\x70\x9e\x20\x7c\x76\x4f\x5c\xdb\x59\xe0\x13\xe0\x43\xc1\x4b\x32\x60\xd4\x32\x1f\xea\xc1\xfc\x6e\x7c\x0a\xc8\xd6\xd4\x22\x45\xf7\x23\x64\xee\xa6\x85\x6d\x82\x90\x18\x2e\xf2\xef\xf1\x5b\x32\xcc\xe8\xc8\x97\xd5\x00\xde\xfb\xb0\xd0\xbe\xec\x6d\x85\x00\xea\xf6\x9f\xda\x79\x67\x78\x43\x56\xa3\x9e\xb2\x04\xd5\xae\x0d\x75\x0b\xd8\x05\x9e\x06\xcf\x14\xfc\x53\xd4\xa3\x61\x3b\x64\xaf\x09\x9d\x42\x9e\x0f\x72\xba\x1c\x86\x6c\xa4\x5b\x97\xec\xd3\x86\x99\xff\xcf\x7f\xff\xb5\xcd\xd3\x95\x22\xcf\xb1\x83\xb8\x28\x01\x8c\x32\x03\x22\x8c\x6f\x0a\xe2\x78\x61\x4f\xab\x5d\xb5\x50\x06\xd3\xec\xc9\x64\xe7\x82\x46\x89\xb1\xec\x5c\x2d\x00\x86\x53\xc5\x3c\x50\x7b\x21\xe5\x9a\x29\xf4\xcd\x86\xa2\x9d\x1a\x4c\xd1\xc6\x78\x75\x6d\xc7\xe8\x45\x19\x2a\x73\x9d\xab\xeb\xb9\x0d\x9d\xe0\xe4\xfd\x03\xcd\xb8\xb5\x28\xda\xbe\x46\xf3\x03\xf9\x4f\xc0\x08\xfd\x8f\x06\xa3\x9c\x8e\x98\xea\xa7\x79\x29\xf9\x63\xd9\xa4\xae\xec\x43\xa7\xb9\x99\xd5\xd7\xba\x96\x8e\x51\x46\x93\xfb\x75\xea\x7f\xed\xef\x1b\x86\x5d\x2e\xe1\xa3\x68\x48\x59\xd1\x68\xa8\xae\x65\x95\xea\x5a\x17\x2b\x8f\xdf\x8f\xc2\x4e\x00\x84\x6c\xe4\x8d\x72\xd2\xb0\x63\xe7\xdc\x26\x1f\x11\xb8\x0a\x94\x26\x7c\x45\x22\xf3\x2c\xed\x09\xf6\x75\x2a\x35\x2b\x25\xee\xd5\x80\x0d\xb9\x64\x53\xf7\xa6\xfa\x9b\xa6\x82\xd2\xbb\x95\x06\xf3\xe2\xa5\xd0\xf3\x7b\x3a\xbf\xe4\x7a\x26\xdb\xea\x72\x7d\x25\x7d\xdb\x4f\xac\xc1\x24\x4c\x36\x6b\x91\xb0\xc8\x0a\x5b\x64\xec\x81\x29\x3a\x62\xae\xaf\x7b\x04\x2c\x45\x37\x68\xe3\x7e\x35\x97\xa8\xb3\x83\xa2\xa2\x55\x5c\x8f\xeb\x26\xb6\x54\x6d\x5d\xae\xa7\x19\x2d\x35\x01\xab\xbe\x01\xb3\x57\x9e\x96\x8d\x31\x3d\x78\xb9\xde\xbd\x7a\xfc\x73\x75\x99\x76\x2b\xa7\x87\xd8\x1a\xc6\x12\x41\x4f\x69\x52\x28\xd5\x49\x46\xb5\xe6\xc3\x19\x49\xf9\x10\x5c\xe9\xa6\x88\xf1\x40\x0a\x4e\xc0\x2f\x2b\xe3\xdc\xd5\xea\xb2\xa5\x54\xe8\xdd\xa4\xbd\x6e\x9f\x1f\xe6\xfc\x33\x3e\x59\x89\xa7\x71\xbd\x19\xc0\x61\xcf\xe5\xe7\xaf\x88\xd8\xbd\x6d\xda\x98\x9b\x99\x4b\x9e\xda\xdd\xc4\x7c\x8a\xf9\x66\xf9\xb3\x0b\xeb\x3d\x96\xca\x87\xea\xde\x9f\xb2\x8c\xbd\x92\x86\x9e\xf3\x8c\xb0\x90\xd6\x05\x14\xc3\xb3\xed\xff\x76\xf3\xd9\x20\xee\xd9\x50\x21\xb2\x83\xfd\x7e\xe1\xe8\x59\xc3\xec\x3e\xb1\x55\xbc\x87\x4b\x79\x71\xa3\x73\xd5\x24\x1c\xb7\x20\xf6\xce\x42\xe6\x4f\xbc\xa0\xa6\xbd\xbe\x61\x46\x7b\xc5\x35\xe2\x74\xf4\xc9\xb9\x73\x7a\xe8\xb3\x65\x8b\xdc\xd3\x35\x36\xfc\x95\x04\x73\xdd\xec\xae\x1d\x7c\xd8\xd3\x89\xc3\xe5\xdb\xb5\x0e\xbf\x15\xf3\xdd\xc0\xe3\xee\xc6\xd8\xc5\xed\xff\xb4\xaa\xd9\x1c\x61\x56\x34\x2e\x6e\xe6\x91\xa9\xd6\x2f\x69\x56\x52\xf4\xd9\x57\x6b\x73\xea\x4d\x53\xde\xee\x34\xd3\xa4\xf3\xe5\x86\xe8\x99\x30\xf4\xeb\x31\xe9\x1d\x7c\x46\xf8\x6d\xf2\x83\xcc\x95\x26\xa7\x74\x76\x28\x87\x87\x13\x29\xcc\x98\x7c\x86\xff\x75\x1f\x3d\x32\x76\x4f\x7e\x66\x54\xf5\x0e\x7a\x02\x60\x15\x5c\xe3\xd8\x00\x91\x35\xa6\x10\xb6\xd5\x0e\xd9\xfb\x8f\xff\xe6\xa1\xbd\xed\x6b\xbe\x3b\xfa\xe3\xbf\x91\xdf\xc3\xff\xfb\xff\xc8\xef\x7b\x07\x0d\xf7\xd2\x7a\xc9\x73\x05\xf6\x7a\xed\x68\xf7\x3c\xb9\x97\xc3\x61\xdf\xf0\x09\x43\x5c\x9f\x3e\x55\x8d\xad\x25\xd7\x4c\xde\xe7\x0e\x6e\x08\x01\x53\x8b\x82\x62\xf7\x52\x0c\x6f\x7b\x25\x4c\xe7\x05\x24\xcc\xa3\xef\xae\x18\x52\xf0\xb8\x86\xa7\x58\x4a\xe4\x70\xb8\x8e\x8f\xd9\xd7\x24\xce\x83\x19\x16\x89\x12\x31\x78\x56\x30\xea\x62\x57\x84\x5c\x06\x4e\x3e\xef\x23\xf9\xc6\xac\x62\x58\xe0\x93\x5a\xc4\x37\x52\x6d\x25\xc2\xef\xd9\x9c\xbf\x6c\xad\x00\x8b\x47\xb6\x89\x31\xd8\x20\x02\x2b\x55\xa8\x80\xc1\x80\x99\xc3\x9c\xe9\x89\xdb\xcb\xd3\xcb\xf7\xf7\xd4\x28\x39\xa2\xe2\xc3\x31\xe9\xa4\xa9\xeb\x2e\x46\x9c\xd3\xcf\x32\xcf\x98\x29\xd6\x26\x71\xab\x20\x61\x09\x57\x1b\x31\x89\xf5\x61\xae\x58\x52\x67\xb8\xd6\x1f\x76\x4b\xbe\xd3\xf0\x48\x43\x6a\x5b\x09\xbe\x27\xbc\xa0\xc0\xe5\x80\xb5\xde\xb3\x99\xeb\x26\x5c\x5d\xef\x26\x0d\xd3\x6e\xa6\x2c\xb1\xd6\x2f\x76\x58\x54\x29\x03\xf2\x40\x9c\x09\xfc\xb9\x2e\xb8\x5f\x7b\xa8\xca\x5d\x23\xb7\x49\xb8\xaf\x96\x25\x6e\xc1\x29\xd8\x64\xb4\x90\x0d\xbe\x96\xb6\xd2\xbd\x56\x51\x2b\x36\x36\xcc\x1c\x77\x0d\xec\xe2\xbe\x5b\xb9\x66\xea\x70\x48\x13\x4b\xbd\x4a\x1f\xcc\x58\x54\xd5\xd1\xf1\x96\xea\xfb\xdd\x3a\x9a\xb6\x46\xaf\xe1\x69\x81\xf6\x80\xdc\x38\xdf\x74\xdd\x5d\x22\x86\xea\xfb\xa6\x14\xa7\xb5\xf1\xf1\x2d\x29\x7c\xf6\xdf\xa2\xf9\xb9\x91\xa3\xaa\x4e\xd7\xc1\x08\x14\xd3\xa8\xe0\xc9\xc7\x87\x10\x3b\x97\x67\x2c\xad\x66\x9a\x57\xe7\xbf\x8c\x0d\xb0\x6a\x2a\xf2\x13\x41\x2e\xf3\xc4\xaa\xcd\x10\xb9\x9a\x50\x31\xc3\x83\x64\x2f\x2c\xaa\xef\x75\x80\x50\x22\x7a\x42\xb3\xac\x45\x14\xcb\xa1\xa9\x58\x8b\x68\x96\x0d\x0f\x7d\xa1\x6a\x4a\x32\x39\xe2\x09\xcd\xc8\x20\x93\xc9\xbd\xee\x09\x7b\x83\x88\x11\x5e\x7c\x53\x25\x13\xa6\x75\x74\xe5\x16\xe1\xfd\xa9\x92\x69\x9e\x20\xcc\x3d\xb6\x99\xe1\xda\xf0\xa4\x82\x6d\x6e\x25\x22\xf4\xd0\x4c\x28\x18\x18\x10\x5c\x9b\x60\x53\x6c\xc5\x19\x26\x3a\xe7\xbe\xaf\x1b\x14\xe2\xd1\x8c\xff\x03\x9b\xb2\xd2\x07\x2e\x6b\x73\x9a\xe3\x2d\xdb\x46\x35\x74\xdb\xd3\x37\xe5\xd3\xb0\x84\x9f\x4f\xdc\x63\x70\x86\x16\x71\xcc\x75\x99\x9d\x03\x37\x04\x36\x0f\xf5\x72\x9e\x29\x0a\x28\x78\x5f\x93\x88\x3f\xf1\x61\xfb\x57\x96\xd7\x07\x53\x6e\xc8\xe6\x5b\xc6\xd3\x27\x88\xae\xee\x90\x0d\x22\x07\x1c\x8c\xee\xf1\xa7\x1d\x9e\x8b\xbd\x22\x1e\x2c\x93\x78\xf2\x58\xda\xdb\x6b\xa4\x15\x20\xcf\xa9\x26\xd3\x2c\x1f\x71\x51\xf4\x06\xb6\xf2\xb0\x27\x00\xfa\xcb\xbe\xa4\x82\x9f\x3d\xcf\x51\xaf\x18\xe6\x7c\x37\xc2\x71\x4d\xb4\x73\x4f\xe4\x75\x98\xbc\xcc\xb7\xbe\x87\xee\xc6\xd5\x52\xaa\x2e\x1d\x04\xb9\x0d\xbe\x7d\xe0\x05\x84\x5d\xf4\xa2\xc6\xbd\xdd\xd8\x4b\x51\x99\xd5\x5c\x9e\x14\x1f\x22\x93\xc1\xdc\x20\x54\xe9\x5a\x76\x35\xcd\xe8\x45\x32\xcf\x17\x6d\xe4\x15\x35\xd8\x76\x89\x4d\xa4\x41\xe0\x26\xc4\x50\x72\xd0\x4a\x0e\x9a\x69\x90\xc9\x01\xdc\x2b\x00\xaf\xe4\x53\x37\xa2\x10\x2d\xae\x9b\xa5\xe4\x7d\x74\x4d\x84\x74\xb0\x0f\x4d\x11\xf7\xdd\xa5\xbf\x57\x8b\x93\x1b\x93\xe0\xcb\x18\x2a\x6d\x72\x55\xb8\x9b\xaa\xab\x1a\x52\x2b\xb9\x9b\x1a\xda\xaf\x97\x32\x5f\xda\xfd\x1d\xa4\xcc\x57\x96\xd1\x00\xc5\x24\x77\xd1\x73\x7b\xf1\xa2\xce\xe5\xea\x76\x24\x26\xc8\xa2\xfe\x51\xda\x1c\xcf\x66\xb3\xba\x2d\x7a\x5d\xe5\x00\x15\x0c\x9e\x97\x2d\x07\xa8\x4c\xe6\x35\x97\x03\x54\xa6\xfa\x7a\xcb\x01\x6a\x26\xba\x42\x39\x00\xba\xdb\xfb\x96\xa9\x57\x13\x0a\x53\x25\x8d\x1c\xe4\xc3\x1b\xb8\x4d\x56\x01\x4f\x46\xe1\xec\xf5\x1c\x57\x85\x05\xb3\x45\x1d\x68\x3d\x45\x2c\xae\x1a\xa8\x2c\x79\xc5\xaa\x81\x92\x48\xdb\x57\x0d\x84\xaa\x81\x79\xba\xbc\xc6\xaa\x81\xca\x9e\xaf\x56\x35\x50\xb7\xe5\x1b\xc4\x30\x4a\xc3\x7c\x33\x55\x03\x15\x8a\xbe\xe6\xaa\x81\xca\x54\x77\x57\x35\x50\xbf\xb3\xeb\x55\x0d\xd4\x5e\xff\xcd\xfc\xb3\x6d\xce\x1d\x20\xc0\x3d\x73\xd5\x40\x69\x01\xfb\xaa\x81\x2d\x3b\xea\x94\x59\xd0\xcd\x00\xf0\xd1\x5d\xa2\x70\x55\xd6\x2d\xa8\x1b\x00\x95\x76\x07\x1c\xf5\xb4\xb1\x55\xf0\x42\xad\xaa\x75\x77\x4a\x74\xd0\x0e\xb1\xd7\x5e\x7f\x3e\xd7\x36\xea\x3a\xbd\x47\x12\xda\x16\xe3\xa5\x42\xe4\xe0\xbd\x82\x8d\x6b\x62\xb9\x1a\x28\xc7\x2d\x18\xd0\x41\x62\x6c\x0a\x62\xd9\xdc\x88\x16\xe1\x50\x77\x33\xec\xef\xe2\xff\x36\x12\x64\xdb\x3e\x44\xc9\x34\xdf\x24\x3b\x76\xb4\xd9\x63\x13\x36\x91\x6a\x59\xf8\xb1\xc1\x9c\x95\x8a\x8e\x96\x65\xe4\xae\x4a\xbd\x6d\xa9\xe6\x11\x6c\xd7\xf3\x6f\xf8\x52\x98\xc5\x06\x97\x6f\xd4\x14\x7b\xc0\x41\x27\xad\x8d\xb1\x84\x10\xd7\x86\x51\x94\x86\xc2\x83\xf9\x17\x82\x7b\x55\x33\x75\x18\x55\x12\x94\xfd\x9a\xf3\x33\x28\xd1\xdd\x2b\x68\x5b\x90\x3d\x57\x8d\x31\xfe\x15\x64\x6c\x07\x71\xd2\xad\xf6\x17\x03\x72\x54\x39\x6d\x30\xab\xc9\x47\x5b\xcd\xa4\xc6\xf6\xf9\xeb\x38\x86\xf9\x3f\xc2\x46\x0f\x79\xc6\x08\x4d\x12\xa6\x11\x25\xc7\xe5\x80\x20\x20\x6a\xae\xb2\x6d\x76\x95\x8b\x11\xac\xdb\x2a\x93\x51\xc3\x9e\xc0\x3c\x78\x67\x8c\x95\xcc\x47\x63\x6f\x65\xf9\x9e\xae\x75\x7b\xf9\x65\x1e\xff\xfc\x8d\x05\x04\x2a\x5d\xde\xaa\x4c\xb0\x7e\xc4\xd4\x93\xe4\x99\xa3\xa6\x75\xeb\x58\x83\x3b\x4a\xb9\x43\xc5\xf1\xf7\x7e\x6c\xd4\x4a\xa0\x52\xa8\x27\x3a\xa5\x2c\x23\x0f\xb9\x34\x98\x15\xd9\x0a\x78\xb5\xc7\x4c\x06\xd5\x9a\xce\x7a\x81\xae\x61\xf6\x2f\x50\x43\xe0\x21\x17\x4f\xf5\x31\x53\x48\xb4\x60\xe9\x21\x4d\x66\x49\xc6\x93\x48\x25\x1d\x29\x3a\x1d\x2f\xe2\xc4\x7d\xda\xff\x4b\xa5\xfd\xaf\xd8\x0b\x61\x61\xaa\x48\xdc\x4d\xe0\x4d\x97\x23\xcc\xb3\xe3\xbe\x12\x61\x0d\x96\xdc\x6e\x3e\x3b\xe7\xc4\xb7\x54\x18\xd1\xcc\x79\x2f\x9c\x84\x3e\x3f\xb1\x97\x2c\x87\xa8\xb9\x2f\x36\xa3\xee\xcb\x16\x41\xac\xb4\x8c\xc6\x54\xc3\x15\xea\x1f\x4a\xad\xeb\xc2\xbd\xbf\xa4\x1a\xa2\x99\x4a\xaf\x84\x07\x77\x99\x1f\xd5\x24\x6d\x96\xe7\x48\xad\xa3\x2a\xae\x97\x2e\x15\x36\xea\x6d\xa5\x4c\x85\x69\x6f\x98\x36\xd5\x89\x7a\x4c\x8c\x65\x06\x18\x21\x25\x6a\x85\x17\x84\xcc\x8b\x40\x20\xbf\x19\xd0\x2a\x1a\x54\xd7\x02\x6c\x62\x51\x72\x54\xd8\xc4\x6f\x23\x41\x6a\x89\x3d\xb4\x66\x92\x54\x4c\xd4\xed\x12\xa5\xb6\xb4\x6f\xd6\x4b\x96\x5a\xd4\xfa\xbb\xba\xdf\x1b\x84\xf5\xe6\x80\x3d\xf6\x41\xe1\x10\x14\xae\xa7\xcd\x6b\x0c\x0c\xcf\xf7\x92\x5d\x31\x38\xdc\xb4\xfd\xbb\xe0\xa4\x1d\x06\x89\x5f\x38\xf4\xba\x30\xea\x1a\x31\xd8\xcb\xc6\xb2\x17\x85\xb1\x97\xb3\x59\x6d\x5c\xae\x79\x4f\xd7\x0a\x0f\x2f\xa9\x71\xf0\x6f\xd9\x36\x86\x17\xf2\xee\x9f\x34\x8e\x17\xfc\x8c\xd1\x13\x2b\xc6\xf2\x8a\xc2\x80\x7d\x3c\xef\x49\xe3\x79\x35\x84\x5e\x1e\xd3\x2b\x29\x08\xcf\x1a\x88\xa9\xe2\x92\x3d\x65\x30\x66\x99\x52\x95\x0f\xfa\x4f\x7e\x8e\x6a\xd7\xbc\xea\x71\xfa\x12\xf6\xd6\x03\xef\x13\x36\x19\xb0\x34\x05\xa3\xcb\x48\x22\xa1\xf0\xaa\x60\x01\xc1\x90\x59\xad\x79\x46\xb5\xe5\x5c\x0a\x3d\xa8\x78\xca\x22\x9c\xbe\xe2\x0e\xc5\x2c\xbd\x9e\x80\xfd\xcd\x32\xa6\xbc\xce\xae\xc8\x7b\xcd\x45\xc2\x62\x3d\x5e\x91\x54\x32\x2d\xde\x19\xec\x2d\x41\xc5\x8c\xdc\x0b\xf9\x98\xb1\x74\x04\x3b\x54\x9d\xcc\x21\xe1\xac\x45\xb8\x09\x8f\x29\x46\x93\xb1\x15\x97\x3d\x3b\x77\x70\x6b\xe3\x65\xcf\xdc\xb3\xca\x55\x9e\x47\x26\x83\xfe\xd0\x26\xe4\x4c\x90\x21\xb5\x46\xb1\xce\x07\xc5\xf8\xa9\xb4\x0a\x02\xdc\xfe\xf1\xc2\x8b\x41\x9e\x2c\x10\x57\x1b\x78\x6b\xd0\x5e\x2d\x03\x74\x32\x4e\xb7\x72\x8c\x3f\xd0\x6d\x4a\x01\x3f\xe7\xda\x60\x07\x52\xe8\x59\xef\xe6\xeb\x92\x9a\x43\xd9\x33\xa0\x04\x61\x09\xf1\x02\x44\x46\x5a\x59\xca\xba\x73\x29\xa2\x18\x0e\x9c\xc8\x99\x44\x30\x2e\x92\x3b\x95\x8f\x42\x1b\xc5\xe8\xc4\xc1\x2d\x62\xd3\xe5\x21\xc6\x2b\xd0\xd9\xc0\x15\xde\xc0\xeb\x6c\xf1\x39\x17\xf7\x76\x77\x8b\x42\x6f\x09\x55\xb4\xf6\xcd\x35\x9b\xf6\x3d\x17\x54\x6d\xd5\xd8\x10\x3b\x1d\x6c\x64\xca\x0f\x66\x4d\x95\xf0\x86\x2e\x2b\x7b\x5f\xc7\x70\xd7\x7c\x62\xef\x45\xfb\x3a\x02\xa2\x0e\x61\xe5\x28\x31\x74\x64\xe9\x33\x66\xd9\x34\x02\x89\x9a\x52\x65\x02\xe8\xa7\xab\xfe\x4c\xe4\x64\x92\x0b\x28\xd8\x75\xb6\xc0\xa3\x2b\xf3\x73\x7e\xa1\x62\xf0\x76\x4f\x9c\x99\x77\xda\x9e\x2f\x29\x46\xd9\x8c\xd0\xf4\x81\xeb\xa2\xe8\x3e\x91\x42\xe7\x13\xa6\xdc\x2b\xb8\xc6\x96\x1b\xd8\x82\x95\x50\xcf\x2b\x76\x6e\x56\xf1\xf2\x88\x85\xee\x6e\x18\x91\x01\x1b\xda\x4b\x77\x4a\x95\xf6\x3e\x88\x1a\xff\x81\xdb\xdc\xd4\xd2\xea\xc5\xce\xe4\x4f\xf1\xb1\x23\x93\xe2\x84\x52\xa7\xd3\x1e\x55\xcf\x67\x84\x06\xda\x14\x3a\x9f\x5b\x14\x59\x7c\x31\x39\x2a\x9c\xce\xb5\xf3\xa8\x9a\x7a\xbe\xab\x88\x86\x43\x63\xdf\xe3\x15\x1a\x9c\xdc\x5a\xde\xa2\xca\x02\xdd\xac\xd1\x05\x10\x9f\x4d\xd7\x23\x5b\x1b\x6a\x78\xe2\x91\x4d\x03\x6e\x33\x3e\xdd\xbc\xb5\xdb\x02\xea\xea\x84\x66\xf3\x3b\xdc\x4c\xcb\x1b\xfc\xfd\x62\xd9\xe7\x8e\x1b\x8e\xbd\x30\x0d\x22\x91\x59\xb6\x4e\x5d\x7d\x65\xe5\x27\xc5\xe3\x8b\x67\x54\xbc\xc7\x6e\x80\xdf\x0b\x38\x35\x88\x05\x40\x33\xa7\x59\x68\xe3\x76\x29\xfe\x11\xca\xd0\x19\x11\xf9\x64\xc0\x54\x4f\xc8\x21\xc0\x2d\x64\x4d\x66\xe3\x54\xc9\x09\x5f\xa7\x30\xe9\x12\xb6\xf9\xda\x07\x7b\x96\x78\xb3\x7c\x48\xc8\x9e\x22\xc7\x5e\xee\x8d\xd8\x91\x48\xa0\x9e\xb1\xe0\x0c\x4d\xe8\x1c\x7e\xf2\x4a\x04\xff\x4c\xa7\x4b\x28\x3d\x41\xd3\xd5\x51\x0f\xaa\xa1\x19\x80\x18\x00\x91\x1f\xe9\xac\x48\x16\x59\xe7\x38\xdd\xa0\x2e\xc2\x74\xd1\x53\xde\x71\x59\x74\x62\x42\xb0\x0c\xf7\x0b\xa9\xb0\xca\x09\x3a\xa9\x63\xc3\xb5\xcf\x92\x5f\xf3\x53\x2a\xd9\xf1\xb1\x8f\xf5\xeb\x75\x6e\xc3\xf2\x61\x88\x46\x24\x30\x9d\xc5\xa4\xfa\x5c\xe2\x9c\x9d\xd3\xa8\x32\x0e\x41\x5b\xce\xfb\xca\xaf\xea\x47\x7d\x06\x9a\x39\xb6\x5e\x89\x58\x5b\xe6\x9f\xad\xd7\xc5\xc4\xbf\xb1\xa6\x69\x49\x74\xde\xd7\xe9\x8c\xb4\xdc\x86\x18\x5a\xdd\x05\xd5\x4a\x39\x1c\x66\x92\x5a\x4b\xcd\xc5\xae\x87\x3c\x63\xba\x4d\xce\x6a\xec\x09\x13\x35\x16\xc3\xf2\x56\x88\x84\x78\x7d\x27\x57\xdc\x65\x65\x30\xc5\x82\x56\x43\xb8\x03\x1d\x2e\x5c\x0e\x8a\xd9\x39\x03\x03\x83\x26\x3f\xb6\x26\xde\x18\x07\xe0\xe0\xa0\x9a\x50\x63\xec\x94\xc0\xb6\xe3\x06\x7d\x11\x88\xec\x1e\x1e\x90\xd8\xf1\x96\x26\xd8\x8e\xb8\x98\x55\xc3\x96\xee\x02\xf9\x64\xf5\x18\xbd\x7f\x6b\xa5\xed\xf7\xef\xe2\xff\x56\x67\x78\x5b\x1e\x7d\xed\xd9\x05\xbd\x7c\x7d\xe7\xfe\x47\x78\xd4\x3b\x93\x28\x19\x2a\x06\xfe\xc6\x49\xc8\x0b\x14\x29\x53\xda\x48\x09\x37\xd4\xcd\xe9\x8f\x47\x77\x67\x84\x99\x04\x70\x58\x7b\x22\xd1\x0f\x2d\xab\xd0\xfe\x92\x33\x63\x3f\x6e\x02\xe1\x99\x30\xa1\x41\x12\xf0\x55\xf1\xb8\x3d\x61\xec\x7f\x4f\xcb\xcf\x2f\x60\xf9\xa8\x33\x39\x02\x56\x01\xef\x7a\x60\x0c\x60\x53\xa8\xc6\x2e\xb5\x64\x2d\xed\x07\xe2\xed\x77\xeb\xd0\xcf\x36\x88\x06\x8b\xbf\xe7\x62\x4d\x35\xe9\xa4\x78\x28\x9a\x45\x83\x16\x36\x99\x52\xc5\xf5\x7a\xc3\xfb\x67\x6a\x47\x5f\x26\x44\x3c\x5d\x29\x71\x7d\x0b\x48\x01\x14\x47\x8c\x62\x0c\x44\x48\xe0\x27\x77\xd7\xc3\x2d\x1f\x51\x23\x7a\xa8\xdd\x13\x9f\xbd\xff\xb3\xf8\x54\x17\x8d\xc8\x27\x03\x00\x5d\xc9\xc1\x66\x2a\x8f\x02\xc3\xa6\x5c\x87\x0f\xa0\x16\x5f\xe7\x99\x41\x68\xa4\x21\xf4\x22\xf0\x13\xc5\x6f\xea\xa4\x84\xa2\x22\x19\x5f\x94\x5b\x38\xac\x1f\xa1\x1d\xf6\x59\xb6\x8e\xee\x78\x36\xec\x66\xda\xf2\x77\x72\xdf\x70\x3a\xff\xe0\x21\xd5\xd6\xd8\xa0\x62\x31\xa0\xb9\x79\x80\x18\xb4\x4a\xd0\x4f\x97\x21\xd0\x12\x23\xe0\x64\xab\x26\x07\x60\x32\xa5\xdd\x45\xa7\x5b\xfb\xc6\x18\x4a\x66\xc4\xbb\xe5\x06\xf0\x16\x42\x4d\x4f\xa8\x5c\x40\x45\x75\xf0\x9f\x53\xa2\x99\xef\xbe\x91\x48\x81\x3a\x80\x73\x9e\x8c\xac\x98\xb0\x9a\x1f\x36\xe4\x14\x60\x51\xc9\x5c\x5b\x19\x42\x27\xcc\xd8\x0b\xea\x3d\x60\xfe\x61\x04\xa3\x45\xa6\x8a\x4f\x0c\x7f\x60\x01\x06\x21\xde\xb9\x5a\x66\xde\x26\xba\x35\x65\x8a\x9a\x55\x51\x15\xea\xde\x7e\xe9\x47\xa8\x3d\xb0\x19\x1b\x9a\x7e\xad\xdf\x65\x81\x89\x61\x47\x14\x69\x43\x16\x19\x1f\x8d\x77\x30\xe2\xea\xa7\xfe\x4f\xce\x2f\x66\x8f\x7a\x74\xe3\x2b\x29\x0d\xf2\x5b\x21\x93\x88\xa7\x26\xa8\x0b\xee\xa5\x88\xc4\x64\x37\x95\xc3\xae\xda\x33\x7c\x2f\xe4\xa3\x08\xb6\xb5\x55\x1b\xba\x14\xc0\xc1\x82\x60\x71\x71\x0a\x3c\xd5\x4b\xcf\x73\x09\x6d\xe8\x95\xd4\x71\xc4\xbd\xa0\x01\x41\x31\x9b\x91\x02\x51\xaa\xf4\xdc\x2a\xd7\x1b\xda\x9d\xfe\xec\xe2\x82\x1d\x88\x8a\x61\x53\x67\x1b\xbb\x1e\xa7\x21\xc9\x03\xdc\xab\xf6\x55\x6d\xf2\xc5\x6b\x72\x10\x06\x2a\x90\xd0\x5c\x1f\xe7\x8c\xce\x7c\x53\xfd\x3a\xc2\xee\x22\xc1\x7f\xd7\xb1\x99\xc5\x04\x0e\x99\x9b\x35\x54\x2e\x5d\xa8\x42\xa0\x85\xb5\x62\xec\xd8\x5d\xd8\xee\xa1\x1b\xb6\x38\x27\xe1\x23\xa0\xaa\x18\xa6\xec\xb5\x94\x6b\x06\x0d\xb2\xff\x17\x6e\x16\x24\xf6\x87\xce\xce\x0e\xcb\xc3\xf9\x30\xed\xf9\x01\x1f\x9c\x90\xc6\x5e\x8a\x43\x9e\x65\x10\x63\x69\x93\x0e\xe0\x82\x01\xe2\x93\x55\xe4\x7d\xf0\x8e\x8f\x84\x5c\x16\x62\x68\x60\xa6\x24\x62\xa6\x9b\x66\x66\xd2\xc0\x4d\x21\xaa\xb0\x23\x8e\xda\x41\x0a\x9e\x95\x2d\x74\xbe\x8c\x6c\xf5\xc4\xbb\x35\x2e\xe3\x97\x08\xd7\xcd\x4d\x37\x36\x8d\xeb\xa7\xfe\x29\xa7\x8a\x0a\x03\x41\x28\x87\x1e\xab\x5c\xa0\x17\x5a\xb4\xb3\xaf\x10\xad\x15\x68\xd8\xc1\x47\xf1\xe6\x7a\xa7\xfb\x88\x3f\x30\x41\x78\xda\x22\xbc\xcd\xda\x2d\x87\xbe\xab\xf3\x41\xf1\xcb\x31\xd5\x84\xf6\xc4\x5c\x22\x59\x9b\x74\x32\x2d\xdd\x13\x4c\x24\x19\xe0\xf0\x45\xf1\xb2\xc0\xf9\xce\x4d\x04\x0d\xba\xdd\x56\x16\xc3\x4b\xf7\x45\xf4\x60\x4f\x50\x8d\x5e\xe9\x0c\x4e\x7a\xf1\xf9\x92\xfe\xf9\x4f\x5a\x67\x3c\x77\x0d\x3d\xd9\x26\x21\xa0\xdc\xa2\x0d\x82\x5f\xc0\xc6\x14\x09\x7e\x3d\x11\xd8\x99\xbc\xa7\x26\x63\x54\x1b\xf2\xc7\x0f\x6b\x05\x67\xfc\xfa\x0a\xe1\xea\x4e\x6f\x91\x86\xe2\x43\xdf\x4d\x30\xc1\x00\x43\x44\x28\x34\xde\x0e\x89\x29\x2d\xbb\xcd\x46\x92\x07\xae\x73\x40\x36\x8c\xd2\xaa\x10\x9b\x8e\x1b\xed\x61\x56\xd0\x4f\xd9\x20\x46\x3c\x52\xac\xf3\x5f\xba\x69\xd5\x30\x56\x0b\x49\xce\x51\xd9\x85\xcc\xe6\x22\x08\x3d\xb6\x5a\xae\x13\xac\x3e\x6e\x13\x41\x60\x75\xb2\xac\x1c\xf8\xb5\x0a\x4e\xca\x84\x5d\x30\xe0\x32\xb6\x49\xdc\xa4\x56\x17\xb1\xc2\x32\x34\x73\x38\x2b\x56\x71\xee\x89\x90\x9d\x1a\x8f\x5d\xab\xec\xd4\x99\x8b\xcf\xa8\x03\xd7\xbc\xfe\x1c\x01\x32\x57\xd0\x85\x9b\x51\xc6\x17\xb8\x57\xe6\x4c\xf4\x05\xaa\xf1\xae\x5f\xb0\xba\xa6\x5c\x6f\xee\xc2\x2d\xfb\x28\x6b\xac\xe7\x86\xcd\x8d\x54\x8b\x2d\x36\xb5\x08\x5a\x3f\x97\x03\xb7\x34\xf5\xb3\x14\x32\xca\x96\x0b\xc1\x22\x43\xcb\x8b\x0e\x6c\x2f\x98\x46\x39\x26\x51\x00\x1e\x52\x89\xbc\xdc\x73\xbf\x6c\xc2\xc3\x7a\xdb\xcb\x6f\x15\xeb\xf7\x4b\x09\x51\xe8\xf9\x85\x37\xeb\x7a\x9d\xf4\xef\x34\x61\x22\x99\xe1\x9b\x3c\xae\x5f\xa1\xc7\x81\xb2\x17\x55\x70\x52\xb0\xcd\x6b\xb5\x43\x87\x75\xdb\x26\x5d\xb8\x67\x3c\xf4\x2d\x1d\x7a\xff\x42\xf4\xe3\x9e\xb0\x86\x89\xbd\xe2\x35\x4e\xda\x8f\x5f\x66\xf1\xba\x13\x80\xa9\xfb\x5b\xb9\x66\x26\xcb\xc1\x01\x9a\x8c\x09\x5f\x39\x00\x63\x40\xa5\x35\xe9\x8e\x8e\x49\x2a\x93\x7b\xa6\x8e\x14\x4b\xb9\x3e\x06\x57\x79\x43\xbb\xcd\x44\x4e\x26\xd6\xd8\xde\x5a\xd1\xd8\x14\x7d\x1e\xdf\xef\xb2\x8f\xf0\xde\x62\x56\x43\x18\x82\x35\xe1\xb3\x0a\x31\xd5\xd0\x41\x5f\x10\x26\x8c\x9a\x4d\x25\x17\x86\x44\x9d\x51\x63\x42\x78\x43\xc3\xea\x6c\x4d\xb9\x38\x6a\x17\x21\xb5\x0d\x97\x7d\x3b\x66\x9a\xf9\xf8\x01\x2e\xca\x48\x82\xa8\xd0\x28\x2e\xa6\xd4\x8c\x35\xe4\x45\x96\x69\xe0\x6c\x2e\x78\xd4\x52\x88\x4e\x21\xfc\x80\x4e\x8a\xe2\xa1\x90\xf0\xa7\x0d\xcf\xb2\x9e\x10\x8c\xa5\x9a\x00\x4e\xd1\xbb\xda\xfc\x5b\xfb\x68\x8b\xd0\x34\x25\xff\xe7\xfd\xc7\xf3\x9f\x6f\xbb\xfd\xb3\x8b\xab\xbb\xdb\xfe\xc7\xb3\xf3\xee\x87\x56\xf8\xf0\xf2\xee\x36\x7c\x8a\x0e\x96\x07\xa6\xc8\x84\xde\x83\x85\x27\x34\xaa\x7f\x90\x16\x17\xcf\xd4\x97\x3b\xd9\x6f\x34\xf3\xa9\x26\x4e\x4d\x09\x05\x2f\x6e\x0f\x97\x94\x24\xae\x61\xfb\x5e\x87\x47\x16\xf3\xa0\x67\x9e\xf0\x0a\xaf\x06\x4e\x98\x30\x56\xc6\xb8\x9c\xb5\xc2\xf4\x2d\x18\x8e\x89\x11\x17\x4d\x01\x71\x26\x1e\x9e\x52\x87\xff\x91\xcd\x7e\xb2\xd6\xf5\x15\xe5\x6a\x65\xde\xeb\x8a\x07\xae\xa4\x80\xa5\x05\xaf\x56\xd1\xa1\x83\xc1\x82\x2b\x87\x4a\xa3\x2e\x0c\x21\x97\x69\x63\xd2\x85\x18\xf2\xc6\xf4\xaa\x17\x5b\x6e\x07\xdd\xc4\xec\xab\x51\xd4\x35\x04\xd5\x4e\xdc\xd0\x07\xca\x33\x48\x98\xf1\x17\x4d\xc1\x83\xd8\xf8\xe1\x98\xb0\x8c\x0e\xa4\x82\x34\x5a\x8c\xf0\xf9\x21\x1c\xc1\x00\x02\x3d\x0c\xd4\x94\xb8\x21\xd5\xd3\x35\xe4\x29\xdd\x43\x57\x52\xad\x72\x93\xdb\x9f\x01\x15\xe4\xd4\x9a\x64\x15\x21\xea\xae\xd9\x21\xa3\x88\x84\xac\x41\xd2\xe8\x7c\x6a\xd7\xe1\x92\x41\xb2\xac\x04\xba\x65\xcf\x80\x6e\x3b\xe7\x78\xf1\x4b\x29\xc8\x8f\x7f\xd6\x64\x90\x9b\x9e\x28\x8f\x21\x05\xf4\xdf\xf9\x9e\x9a\x64\xfc\xa1\x27\x2e\xad\xc1\xf8\xe3\x9f\x1b\x0a\x72\x52\x6a\x68\xbf\x9e\xbf\x9a\x69\x72\x4a\x0d\x3d\x97\x34\xe5\x62\x74\x82\x8f\xd6\xd3\xe2\xfb\xee\x6d\xe7\x98\x5c\x3a\x6b\x3c\xf4\x8c\x2d\xca\xb8\xa2\x81\x40\xb6\xc2\x42\xbc\x40\x00\xa9\x2c\x82\x14\x77\xce\x2e\x50\x84\xec\xdd\x13\x3a\x4c\x5b\x01\xc9\x0d\x99\x4a\x87\x90\x62\x0d\x2c\x49\x54\x2e\x9c\x53\xda\xf9\x04\x2d\x75\x80\x23\xc3\x66\x38\xd5\x0a\x54\x93\x79\xb9\xdd\x13\x60\x6a\x87\xa4\xf5\x4c\x26\x34\x83\x68\xf9\x61\xe4\x9d\xb3\x06\xb8\xcc\x21\xf5\x18\xc2\x54\x62\x56\x4e\x6a\xf1\xf8\x75\x85\x7e\x15\x6f\x14\x98\xf2\xb0\x8f\x0e\xd6\x65\x22\xad\xf0\x68\xf7\xc4\xd9\x10\x83\xe9\x19\x52\xc7\x3e\xc8\x84\x9d\x7e\x20\x8b\xfd\xd6\x8b\x16\x80\xb8\xc5\x8a\x57\x9a\x80\x23\x5e\xcc\x20\x15\x0a\xa0\x33\x24\x04\x65\x0a\x41\xeb\x98\x72\x6e\x17\xc3\xf5\x16\x3f\xd6\x13\x18\xc4\x2f\x6d\x8c\xa3\x56\xf5\xf5\x52\x40\x8e\x41\x71\xf5\x05\x65\x61\xea\x72\x0e\x9c\xde\x3e\x55\xec\xd0\xb7\x42\xb0\x9f\x46\x44\xb5\xb7\x65\x9b\x5c\xc7\xa6\x72\x2a\x93\x7c\xe2\x6b\x5a\x21\x47\xdb\x05\xa7\xdd\x85\x18\x58\x04\x2f\xe9\x5a\x96\xff\x5d\xfc\xdf\x5a\x3d\xf3\x6a\xcb\x06\x3a\x81\xad\xfa\xd3\xf2\x48\xa5\xd1\xb8\x30\x6c\x54\xad\xcf\x5c\x07\x2a\xe8\x02\x32\xda\xa0\x8f\x37\x74\xd6\x91\xc4\x75\x64\x76\x05\x2c\x53\x99\xbe\xd3\xe4\xec\xca\x2a\x1c\xd6\xc0\x0c\xe7\x24\xd7\x06\x43\xb3\x90\x9e\x8a\x4f\x63\x7a\x5c\x8b\x7c\x47\x7a\xf9\x77\xdf\xfd\x4b\x42\xbe\xfa\x3f\xfe\xfd\xdf\xfe\xed\x5f\xfe\x7d\x93\x46\x51\x30\x6e\x41\x23\x57\x3e\x5e\xd5\x40\xe2\x1d\x98\x97\x26\x5b\xec\x82\x3b\x24\x4d\xe4\xdf\xaa\x25\xff\xc7\x8c\x8e\xdc\x29\xd4\xf1\xe9\x21\xa5\xe3\x83\xa7\x1c\x0e\x0c\x33\xad\xf2\x29\x0e\xba\xa5\x53\xa0\xff\xd7\x82\x22\xb6\xbe\xe5\xe6\xcd\x72\x3b\x78\x16\xb4\x59\x3b\x08\x79\xef\xdc\x6d\x06\xc2\x75\x1f\xfc\x25\x24\xb3\x94\x29\x9c\x53\xf0\x90\x05\xbf\x1d\x9c\x5f\xf6\x75\x9a\xc9\xd4\x37\xd3\xd7\x6c\x4a\xe1\xbe\xb6\xe7\xb5\x4d\x7a\xa2\xfb\x95\x5a\xf1\xda\xf2\x18\xf0\xd8\xb0\x0c\x02\x1d\x43\x9a\x30\x82\xaa\xf1\xfb\xaf\xc7\xf6\xb3\x16\x99\x1d\x43\x0e\x46\x8b\xfc\xe3\xd8\x95\x3e\x51\x65\xfa\xf6\xa3\x0f\x5e\xb7\x75\x43\xc0\xac\xb9\x26\xbd\x83\xa3\x07\xaa\x10\x04\xf4\xc8\xa1\x04\x1d\x38\x01\x18\xc0\xb1\x62\x6d\x38\x93\xf2\xde\x65\xa8\xcc\x3d\xe9\xfe\xd3\x46\x0e\x0f\x81\x0a\xdc\x7d\x97\x6c\x64\x35\xb7\x43\xf8\x01\x23\xed\xe9\x80\xb4\xff\xae\xa5\x20\xed\x19\x9d\x64\xee\x53\xff\xad\x4b\xa0\xa1\xda\xa5\x81\xa7\x56\xa8\x3d\x70\x99\xeb\x6c\x86\xbe\xc9\xef\x33\x39\x80\x75\x7d\xf6\x6b\xc5\x14\x14\x98\x68\x71\x49\x14\xf7\x8a\x5b\x08\xb7\x16\x33\x4d\xb1\x1c\x0c\xfa\x0b\xd8\x9f\x60\x2c\xbd\x6e\x59\x5f\xc3\x9c\xfe\x1b\x23\xb1\x40\x15\x9f\xb8\x8e\xfe\x58\x4b\x2c\x97\x77\x39\x24\x5f\xc9\x7b\x27\x86\x3e\xd8\xbb\xc0\x25\xfc\x20\x1d\xea\x5e\x30\x0b\x2f\xf8\x39\x7a\x01\x17\x04\x4b\x11\x16\x3c\xf9\x8f\xa3\x76\xbb\x1d\x9e\xbe\xb0\x6b\xf9\x7f\x84\x1b\xcd\xb2\x21\x8e\xe4\x6f\x9a\x59\x4f\x7c\xb6\x76\x4b\xec\x2f\x2e\x0a\x78\x01\xf4\x3b\x91\x19\x39\x2c\x7c\xa8\xa9\x4c\x34\xf9\xdf\x56\x93\x8c\x68\x09\x1f\x5a\xd3\xa9\xfe\x5c\xb9\xde\x0f\xcf\x74\xb0\x9c\x0f\xba\x7a\xb4\xe2\xb2\xcc\x60\x4b\x52\xab\x81\xa4\xfc\x81\xa7\xb9\x67\x06\xcb\x3a\x47\xae\x74\x13\xda\x32\x18\xf6\xd5\xc0\x57\xf5\x8b\xab\x4f\x06\xab\x57\xe2\xe6\x44\x6e\x51\xc6\x8a\x7c\xdd\x40\x00\x57\xbf\xe8\xa4\x03\xae\xb3\x15\x07\x2c\xec\x05\x23\x62\xac\x04\x9d\x4f\x26\x54\xcd\x8e\x8a\xe3\x36\xcf\x9c\x05\x64\x0e\xc8\x99\xcc\x13\x00\x82\xa6\x99\x3b\x5b\x2e\x6f\x20\xea\x1e\x37\x0e\xa9\x83\x24\x65\x09\x4f\x5d\xd2\x22\x45\x3c\x3f\x26\x12\x99\x3a\xbe\x2e\x2a\x2e\xca\x8a\x45\xf8\xcd\xbc\x4a\xe1\x4b\xa9\x74\xe1\xff\x12\x06\xcb\xb0\xdc\x2f\xfc\xc3\x0d\x22\x5c\xf6\xb5\xb1\xc2\x72\xb4\x46\x40\xf2\xec\xf2\xc6\x3f\xb3\xfa\xc5\x0b\x74\x28\xab\xd6\xd4\x1b\x66\xde\x09\xa0\xe8\x63\x71\x05\x43\x36\x05\x3a\x44\xf2\x50\x8f\x82\xff\x3e\x91\x57\x3c\xb3\x37\x17\xf0\x78\xbb\x27\x4a\x1f\xb7\x08\xcb\xf8\x84\x8b\x90\x1f\x8a\xf2\x5d\x0e\x51\xcb\xbd\xe7\xc6\x6e\x99\x4e\xef\xad\x08\xf3\xa5\x7d\x91\xe9\xd3\x11\x33\xcf\x3a\x21\x16\xe4\x8c\xfe\x5c\xdb\x79\x15\x66\xb1\xd5\x39\xed\x10\x87\x4e\x6f\xe4\x11\xe3\xc1\xf9\xed\x09\x3b\x9a\x3f\x4b\x23\x26\x98\xf2\xb8\x73\x7e\xbc\x68\xb8\x43\xd0\xd3\xb9\x4f\xbe\x87\x11\xe0\x1d\x34\x37\xd2\x8a\x9b\x84\x66\xd9\x2c\xa8\xa9\x35\x4a\x4a\xb7\xd2\x73\x65\xfd\x5c\x4d\x68\xe1\xd1\x17\x32\x65\x6b\x02\x32\xd4\xf4\xb4\x70\x8e\x5f\x1f\x2f\x54\x0c\xf3\x69\x41\x4e\x34\x15\x10\x30\xad\xd7\x74\x86\xd6\x36\x87\x71\xe3\x00\x2c\xe4\xe3\xa6\x0d\xfa\x0a\x99\x06\xa3\x78\xb3\x20\xaa\x7f\x28\xd1\xbe\xdc\xc0\x66\x2b\x1d\x3d\xdd\xcc\x1d\x8c\x6b\x4f\x80\xec\x45\xab\x4b\x32\x52\x32\x9f\x86\x22\x21\x9f\x2e\x8d\xdb\xe0\x6e\xb4\x33\x31\x94\xc7\x4e\xab\x3e\xe7\xe2\x1e\xef\xc2\xa7\xda\xa3\xd0\x2a\x26\xfa\xdc\x4b\x30\xa4\xf8\xa1\xeb\x17\x66\x67\xad\x0d\x4d\xee\x11\xc0\x63\x51\xab\xa1\x75\x9b\x25\x15\xf7\x65\x9e\x65\xee\xb5\x85\xf8\x2c\xa0\x4c\x1f\x38\x25\x94\xdc\x5d\x9f\xd5\xbf\xfb\x9e\xcf\x7b\xcf\xeb\x65\x67\x99\x41\xe0\x7f\x7e\xe4\x6b\xe5\xb9\x55\x00\x67\x58\x89\xd5\x83\x0b\xa0\x09\x42\xa1\x22\xbb\xb7\x0c\xd7\x59\x19\xd4\x9f\xd4\x70\x6a\xfd\xe2\x8b\x17\x9f\xba\x87\x3f\xdb\x67\xeb\x77\xe4\x33\x24\x83\x86\x8a\xb9\x09\x15\x76\x81\xfe\xad\x0d\x3e\x22\x14\x8b\x1b\x4d\xe9\x6e\xba\xd1\x84\xf0\x8d\x0b\xc1\xcb\xc2\x08\xfe\x55\x7e\x94\x47\x74\x1a\xd1\x0c\x0d\x2e\x33\x06\x45\xbc\x45\x6e\x92\x31\x9b\x50\xc8\x31\x98\x94\x15\x72\xd0\x4b\xde\x67\x54\x8d\x50\x4b\xd0\xcc\xe8\x0f\x35\x3b\x5c\xa0\x2b\x6d\xb1\xc3\x1b\xc0\xff\xc5\xfe\x76\x28\x19\x58\x24\x01\xc2\x2c\xcb\x25\xe1\x41\x38\xf9\xf7\xfb\xbb\xc3\x9a\xab\xf8\x08\xdc\x98\x0a\xfb\xb5\xa5\x56\x15\x6b\xae\x95\xdb\x12\x71\x32\x6e\x72\xed\x61\x27\x11\x7c\xc3\xcd\x6d\xc0\x00\x1e\xa0\x79\x0e\x5b\x63\x4c\xc6\x53\x70\x90\x76\x4d\x33\xe8\x89\x8e\xff\x49\xc8\x4d\x07\xfd\x46\x61\x94\x14\xb2\x92\x30\x07\x0f\x74\x8c\xa8\xdb\x90\x5b\x5c\xc3\x22\x04\x9d\x6c\x23\xeb\xef\xac\x8e\x13\xc0\x41\xd0\xba\xf3\xca\xae\x5f\x47\xc3\x9b\x1d\x5a\xf0\x16\x2f\xbf\xf1\x4b\xac\x00\x0f\xd7\xbd\x78\x99\xf0\xed\x86\xba\x23\x37\x50\x8c\x75\x8c\x99\x4b\xd9\xac\xc8\x93\xb1\x14\x47\xbd\xb4\xf2\xb2\xd2\x61\x1d\x62\x7e\xfd\x76\x0e\x3d\x34\x63\x76\x9e\xa1\x62\xc6\x4c\x80\x26\xb8\xfa\xc8\x50\xa4\xb0\xbe\x37\x8e\x16\x89\xf8\x85\xe1\x12\x82\x0b\xb9\xe0\x0e\x17\xcb\xd9\xaa\x51\xa0\xd8\xfb\x74\x8a\xe7\xb9\x26\x9a\x1a\xae\x87\xbc\x56\x43\x8e\xab\x1a\xb6\xa1\xfa\x5a\xfd\x01\xfd\x36\x2f\x62\xd5\x90\xf0\xd6\x26\x1f\xb9\xd2\x26\x5a\x92\x91\xa1\x28\xa1\xa9\xe3\x90\x35\x6e\x9f\x32\xbe\xe4\x57\x10\xfd\x7e\x61\xd0\x2d\x24\x37\xb6\x49\xa7\x30\xb3\xb1\x2c\x03\x0d\xe8\x25\x2b\x62\x99\x66\x9b\x30\xdf\x4a\x36\x09\xb8\xa3\x81\x81\x08\x88\x4b\x6d\x3f\x2f\xb0\x3d\xc2\x34\x1f\xa1\x7e\x80\xde\xb3\xa6\x3e\x85\xeb\xf6\xb8\x5c\xda\xda\xb2\x13\x4c\x0e\x89\x56\xc7\x26\x13\x5c\xfd\xd8\x15\x95\x30\x7c\x78\x64\x49\xee\x9a\x46\xa3\x6b\x70\x08\x7c\xe8\x6a\x69\x1e\xc7\x52\xc7\xe7\xcc\xef\x1f\x6c\xa6\x51\x39\xf3\xe9\x89\x90\xf5\x19\x08\x8c\x41\x22\x21\xe3\x52\x1b\x98\x75\x38\xa4\x98\xd6\x10\xf6\x9b\xb8\xbb\x01\xc9\x00\xee\x1a\x3f\xd4\xfc\x69\x2e\x05\x84\xb7\x38\xce\xf7\x6c\x59\x5f\x8f\x45\x9b\x16\x4e\x6e\xc3\x35\xb6\x2e\x90\x49\xe3\x59\x5a\x2b\xff\x15\xbc\x0d\x3c\x81\x22\x79\xbc\x76\xa7\x94\xd7\x45\x36\x9c\x57\xed\xb5\xc2\x3d\xec\x1a\xe7\xc1\x2d\x77\x43\x8c\x87\x0c\x9f\xf6\x3e\x40\xf9\xe8\xb1\x1d\x76\x81\x88\x50\xf8\x37\x57\x43\x43\x40\xe6\xd1\xd8\x0d\x0b\xe7\xb5\x1e\x8f\x94\x48\x8c\x6e\x61\x17\xf8\xd5\x10\x24\xc6\x62\x2a\x39\x0c\x00\x16\x18\xdf\x47\xac\x1b\x39\xac\xf9\xc3\x5a\x31\xfa\x43\xdc\xc3\xdb\xbd\xa3\xa8\xa9\x6a\x66\xc1\xdd\xe0\x25\x78\x52\x3c\xe5\x7d\xe8\xcf\x4c\x7c\x1f\xae\x43\xf8\x7a\xa6\x2a\xc2\xef\x98\x52\x4e\x95\xcc\x85\xaf\x37\x97\x82\xc9\x21\x78\x45\x21\xd0\xe0\xed\x7e\x28\x45\x15\xd2\x44\xe9\xe3\x8a\x4d\x31\x79\x11\x34\xd4\x66\x72\x6f\x89\xb9\xb0\x8c\xce\x4f\x81\xb9\xb0\x2d\xdd\xdd\xc1\x79\x21\x82\x6f\x5b\x49\x8f\x47\x69\x0d\x31\x0b\xbf\x5f\x6a\x8c\x07\x39\x00\xd6\x77\x8c\x9a\x8b\xd5\x92\x90\x33\xc1\x0e\x8d\x3c\x84\xb2\x1b\x28\xe6\x40\x14\x94\x26\x6c\x40\x70\x62\xac\x73\x1d\xd8\xdf\xaf\x30\x4f\x4c\x94\xf9\x1a\x4d\xd4\xdd\xbd\x9a\xf8\x8e\x19\xa0\xcc\x08\x68\x7e\x0b\xf6\xd9\xd2\x9b\x63\x4d\x17\x47\xbc\x95\x8b\x7d\x9c\xae\xc2\xbf\x82\x50\x11\xe2\x9b\x34\x12\x02\x6d\x02\xc9\x20\x63\x39\x91\xf6\xda\x96\xb9\x8e\xbe\xc4\x6c\x22\xb8\x6c\x16\xf4\x0b\x99\x62\x99\xed\xcb\xad\xc6\x1e\x2d\xfb\x15\xea\x8e\xf1\x8f\x96\xc3\xf4\x44\x2b\x19\x94\x61\x4e\x96\xcc\x3f\xe0\x53\x2c\xe6\x1b\x70\xa0\x4d\xf8\x68\xec\xd0\x17\x5d\xd5\x39\xff\x87\xb5\x20\x2d\x4b\x85\xc4\x9d\xd0\x1f\x19\x23\xed\xc0\x50\xa2\xae\xed\x54\x63\x00\x63\x1d\x94\x95\x35\xfa\x44\x47\x55\x98\x45\xbc\xdc\x12\x39\xc4\x2c\x7d\x8d\x50\x78\xf0\xa1\x80\xfe\x9c\x4d\x59\x8b\x0c\x72\xf8\xfe\xe2\xf2\x36\xf6\x0d\x71\x01\x5f\x1f\x26\x63\x96\xdc\x43\x8a\x1b\x0a\x45\x24\x97\xc7\x70\x1d\xcc\x7a\xa2\x00\x98\x33\xd2\x3b\x3a\x66\xa1\x82\x3f\xa0\x58\x48\x45\x52\xae\xa7\x19\x9d\x11\xf6\xd5\x30\x81\x91\xb1\x9a\x66\xfd\x96\x59\x36\x33\x5b\x00\x01\xcf\x49\x01\xaf\x87\xc1\xbf\xfc\x22\x02\xd0\x77\x48\xf3\xa8\x53\x3b\xb6\xc6\x54\xd8\x26\x42\xd6\x84\xe5\x18\xc1\xdb\xe3\x8e\xc6\xae\xd2\x50\x4e\x21\x2a\x75\x11\xbd\x03\x9f\x78\x02\x1e\x94\x9e\x47\xc2\xb6\xff\x46\x24\x5d\xa6\x1e\x58\xda\x13\xe5\x82\x15\x77\x95\x15\xbb\x4c\x0a\x8c\xaf\x26\xd1\xb9\x3e\x90\x90\xa5\x73\xc0\xb9\x59\x18\xbc\x83\x24\xdd\xa2\x3a\x37\xe4\x56\x2c\xc0\x1c\xab\xc7\xd2\x7e\x02\x70\xac\x95\x9d\x1f\x05\xa8\x98\x43\x04\x72\x90\x7f\x0c\xc3\xf7\x19\x24\x3d\x06\xc6\x0c\xe9\xf8\x58\xab\x17\x62\xce\x2e\x06\x3d\x97\x10\x59\x37\x46\x4f\xf8\xc4\xb9\x61\x9e\x65\x58\x7f\xdd\xd8\x79\x1f\xcb\x73\x7c\x8c\xf7\xe5\x6a\x20\x82\x5d\x4b\x22\x14\xb6\xa8\x4f\xfd\x34\x85\x54\xa7\x64\x56\x20\xfb\x03\xf3\x32\xa1\x73\xc8\x05\xf2\x08\x4c\x90\xa1\x3a\x62\x86\x58\xbd\x23\xcd\x33\xcc\x04\x83\xd4\x5a\xa8\xf5\xa1\x59\x46\xb8\xd1\x3d\x11\x4a\x93\x10\x19\x15\xae\x02\x9f\x7b\x9b\x3a\x5d\x10\x5e\x01\xc3\x3a\x9c\x5e\xb8\x20\x78\xc2\x4d\x69\x4a\xe0\xa9\x9c\xc5\xb0\x25\xd3\x29\xa3\x98\xb5\xe0\x1b\xc5\xc5\xda\x60\x75\x1b\x5c\x88\x1f\xe0\x53\x9b\x3b\x36\xee\x82\x7b\x11\x3e\x77\xed\x4d\x69\x93\x0e\xae\xce\xaa\x82\x1e\x43\x14\x67\xeb\xb2\x25\x5d\x3c\xc1\xea\x5b\x46\x07\xc0\xfb\xa0\x51\x4f\xa9\x32\x3c\xc9\x33\xaa\xb2\x99\x95\x2e\xc3\x3c\x23\x7c\x18\xc1\xa1\xc2\x26\x60\x65\x0a\xb4\xb5\x90\x70\x47\xf8\xac\x17\x4d\x27\x2c\x4a\xd2\x73\x86\x67\x16\x39\x11\x11\x6d\x03\xbd\x53\x76\xac\x0f\x6d\x72\x5a\x05\xbf\x85\x63\x11\x55\xb4\x72\x8d\x12\x30\xcc\x37\x4a\x2e\x41\x10\x5d\x3e\xb4\xca\xee\xbb\xe8\xe0\x35\xa1\xac\x53\x7d\xbf\xa6\x87\xf2\x96\xea\xfb\xa5\x5e\xca\xb3\xda\xe4\xb2\x5b\x00\xef\x2e\xf9\x2d\xc3\x89\x58\xd2\x51\x6c\xcd\x49\xc6\xd5\xc0\x1b\x4c\xf4\x4b\x84\x8e\x5d\x9d\xec\x64\x01\xfa\x2a\xec\xe3\x9a\x53\x8d\x90\x91\xd6\x9f\x68\xc4\x39\xb1\x3f\xba\x91\xb2\xcb\x8d\xcb\x2f\x25\x8c\x22\x62\xe7\x65\x15\x7b\x86\x11\x8c\x4a\xe3\x05\x98\x83\x03\x33\x02\x3c\x99\x70\xd8\x06\x8c\x64\x5c\xdc\xfb\x7c\x56\xbb\xf3\x2d\x42\x8b\xd1\xe1\xf0\xe1\xec\x91\x99\x1b\x34\x9b\x90\x6f\xb0\x9b\x90\xf0\x6a\x39\x41\xb5\x9b\x1b\xd6\x5d\xf3\xfc\x72\x46\xac\x5b\xc7\xea\xdb\xb2\x30\x6c\x17\x94\x58\x1f\xab\xc3\x0b\xa6\xdc\x4c\x7e\xb6\x8c\xbe\x57\x63\x5a\xdf\xb5\xa4\xa2\x05\x1e\x30\x91\x4f\x0e\x8e\xc9\xff\x14\x94\xb9\xbb\x38\xed\x7e\x3c\xbb\xe8\x9e\x46\x0c\x7c\xf0\x97\xbb\xee\x5d\xf9\x93\xeb\xbb\x8b\x8b\xb3\x8b\x4f\xf1\x47\x37\x77\x27\x27\xdd\xee\x69\xf9\x77\x1f\x3b\x67\xe7\x95\xdf\xd9\x8f\xca\x3f\xea\x7c\x7f\x79\x7d\x5b\xfe\xe8\xe6\xc7\xb3\xab\xab\xf2\x47\xb7\x67\x9f\xbb\xa7\xfd\xcb\xbb\x5b\x4f\xeb\xbf\x46\x14\x86\x42\x06\x88\xee\x86\xf9\xd7\x92\x68\x17\xe0\x86\xeb\xc6\x9f\xa3\x6a\xe5\xa1\xe2\x4c\xa4\xd9\xac\x68\xcd\x69\x0f\x5d\x25\x48\x19\x8b\x74\x3e\x61\x32\xdf\x26\x67\xc0\x9a\xbe\xf2\xc1\x9a\xd4\x19\x71\xa3\xb9\xac\xab\x4a\x6b\xeb\xe8\xad\x8a\x19\x35\xef\x06\x5b\x98\x65\x61\xd4\x2c\xe4\xf1\x2c\xcc\x1f\x08\x65\x18\xee\x25\x64\x6a\x6f\xc2\xe6\xb9\xc0\x85\xab\xf2\xa9\xe1\x83\x79\x47\xd3\x9a\xe5\x09\xeb\x5b\x76\x58\xa3\x57\x9f\x5d\x7d\x51\x2f\xe8\x3c\x58\xd8\x96\x88\x3c\xe0\x99\x5e\x7d\x07\xae\xc2\x23\xf5\xac\x77\xe2\x01\x06\xad\xc9\x6c\xa8\x68\x28\xbe\x5e\x13\x04\xbd\x40\x44\x52\x45\x2b\x02\x77\x53\x79\x2b\xa2\xa8\xe8\xdc\xc4\xb2\x76\xa0\x68\x22\x2d\xfa\x36\x3b\xb0\xb4\x08\x11\xb1\x66\x13\x2a\x30\xd3\x4f\x7e\xcb\x2c\xe4\x79\x97\x75\x0a\xaa\x1f\xa2\xd2\xb8\xb2\x35\xbc\x96\x01\xea\xa9\x31\x54\xb7\x63\x54\xfa\xa0\x7a\x16\x90\xda\x01\xa4\xdd\xcb\xa3\xf5\x15\x8d\x0a\x20\x75\x04\xd6\x8d\xfd\x01\x01\x84\x08\x86\x2d\x7c\x71\x4e\xb3\x40\x39\xf0\xc0\x52\x72\x18\x37\x01\x48\x0f\x21\x7f\xb0\x27\x9a\x2c\xcc\x1a\x00\xfd\x98\x03\xae\x3c\x3e\xe2\x36\x7b\x5f\x43\xfd\xe6\x23\xe8\x89\xbd\x5a\x52\x05\xf1\x3f\x6f\x93\x66\x57\xa6\xdb\x97\x01\x45\x17\x12\x9c\xad\x00\xfc\xd8\x94\xe2\x15\xee\xc2\xf5\x3c\xae\x2b\x79\x5b\x69\xb9\xac\x14\x75\x96\x31\xd5\x98\x83\xe8\x3b\x2a\x15\xa8\xff\x45\xbb\x87\x26\xa3\x25\x80\x84\xed\xb0\xf2\xac\xc9\x82\x6c\x61\x46\x40\xe8\xdc\x14\x23\x2b\x05\x94\xb8\xf5\x18\x3f\xec\x46\xc0\xe3\xa2\x5e\xee\x81\xc0\xca\x68\x6e\x75\xfa\x69\x46\x31\x91\x68\x4c\x35\xb2\xb4\x77\x52\xd2\x01\xcf\xb8\x81\x2c\x4c\x34\xef\x2b\x14\x96\x8a\x4c\xa8\xba\xf7\xd5\x3f\xb4\xa8\x01\x58\xc4\xf4\x5b\x06\xd2\x0a\x70\xd1\xe7\x0c\xa5\x15\x47\x76\x55\xdf\x40\xc1\x96\x2e\x8c\x56\x6c\x07\xb6\xbf\x31\x32\x02\x4a\x5d\x6f\x67\xdd\x88\x57\xd5\xc7\x4b\xf4\xae\xb9\xa8\xd7\xf7\xd9\xba\xd2\xd6\x35\xc4\x7c\xb5\xf0\xb5\xf6\x64\x0d\x33\x49\x1b\xa0\x4e\xfd\xd8\x58\xc7\xda\x34\x76\x2a\xf3\x41\x53\xd5\x14\xce\x6a\xf1\xe8\x8b\x0c\x30\x7f\x6e\x77\xa5\xd0\xc5\x02\x90\x1a\x06\x5d\x73\x37\x22\x68\xd1\x74\xb7\x7e\x70\x57\x2b\xb4\xf2\x9a\xe7\x18\xad\x40\x3c\x08\xb5\x59\xb7\xb3\x29\xab\x81\xd6\xfe\x4b\x0e\xf0\xdd\x97\xc3\x1b\xec\x0d\xba\x0d\x93\x19\x3e\xcf\x61\xf5\x27\xb1\xfa\xd6\xdb\xb2\x75\x1b\xf3\xc0\xca\x5d\x6c\xeb\x56\x03\xbd\xea\x56\x3f\x90\x67\xa1\x7c\x04\xb3\x9f\xb9\x54\x56\x6c\x5a\x53\xa6\xb9\x47\x63\xe3\x7b\xb7\xa0\xe4\x2f\x39\xcb\x99\xe5\xfd\x41\x9e\x8e\xd8\x36\xa6\x59\xb1\xa4\xb1\x7c\x24\x93\x3c\x19\x13\x3f\x38\x49\x59\x46\x67\xa5\xa5\x81\xbe\x64\x64\x06\x05\x5b\x1b\xd6\x0f\x61\x97\x72\x08\x32\x16\xe3\xaa\x5c\x00\xc3\x47\xcd\xcb\x6b\xc8\x58\x4a\xa4\xdf\xd0\xb3\x70\x73\xd5\x3d\x39\xfb\x78\x56\x31\xeb\x3b\x37\x3f\xc6\xff\xfe\x72\x79\xfd\xe3\xc7\xf3\xcb\x2f\xf1\x67\xe7\x9d\xbb\x8b\x93\x1f\xfa\x57\xe7\x9d\x8b\x25\xc6\xff\xfc\x2b\x9a\xa9\x4e\xa3\xa4\x7e\xab\xa8\xb8\x3c\x74\xf0\xbb\x2c\xa0\xc0\x56\x9d\xdf\x5c\x9f\xcc\x27\xf3\xaf\x87\x49\xfa\x3f\xba\xc2\xa8\xd9\x3a\x28\x50\x24\x65\x1a\x94\x22\xe7\x4a\x2f\x23\x10\x31\x0d\x81\x09\x3f\xfa\x05\xdc\xb2\x3e\xd4\xe3\xe2\x85\x8e\x8e\x00\xfe\xc1\x1b\x7b\x82\x66\x56\xfa\xbd\x56\x3a\xc4\x09\xa9\x40\x85\x81\xcc\x45\xea\xa1\xd6\x27\x5c\x1c\x4d\xe8\xd7\x0f\x7e\xa5\x45\xeb\x75\x28\x4a\xc6\xfe\x76\x99\x55\x81\x67\xf6\x74\x2d\x26\x57\x4f\x2c\xa0\xd7\x72\x35\xc5\x1f\x69\xd0\xb7\x0b\xe3\x08\xc3\x17\x0f\x6c\x56\xb7\x7f\x73\xe0\x12\x18\x22\x71\x06\x19\x0c\x32\x55\x0c\x3a\x8b\x84\xe0\x48\x86\x41\xaf\xf0\x6f\x08\xbe\x97\x00\xa7\xea\xa5\x46\xec\x18\xda\xea\xdc\xd4\xba\xa4\x9e\x00\x1e\xc4\xbd\xc9\x6e\x1a\x3a\xa8\x7c\x81\xb6\x4b\x36\x48\xb1\x52\xca\xee\xd6\xdf\xe5\x80\x0c\x21\x37\xc3\xe1\xc9\x2a\x96\x80\xaf\xcd\xee\x85\xaf\x66\x84\x1c\xef\x39\xaf\x97\xe7\x81\x8c\x69\xf0\xfc\x42\x6f\x06\xf6\x4b\xee\x12\x39\xff\xf8\xdd\x7a\x12\xde\xa8\x19\xf1\x75\xd3\x71\x6e\x88\x4b\x8d\x72\xd2\x1e\xe6\x95\x0b\x5e\x87\x01\x7f\x8d\x5d\x09\x9e\xb7\xf9\x4b\xe5\xa5\xee\x9f\x4b\xd3\x67\x6e\x7d\x4d\x16\xfe\xfe\xc9\x8a\x75\x7e\xaa\xd4\xe8\xb8\xd7\x41\x54\xdc\x8d\xae\xa3\x12\x10\x6b\xa6\x3f\x52\x95\xa2\x97\x0a\x1c\x96\x6d\xf2\x83\x7c\x64\x0f\x4c\xb5\x48\xc2\x94\xa1\x2e\x77\xde\x9e\xb5\x2c\x83\x03\xe5\xc6\xe9\x09\x48\x14\xc1\x42\x04\x01\x58\xbc\x86\x8f\xc6\xd6\x92\x71\x1e\x11\xd7\xbf\x43\x33\x03\x79\xaf\xec\xeb\x94\x25\x98\x21\xd4\x94\x16\x31\xcc\xe8\xc3\x7c\x31\xc0\x26\x79\xde\x51\x8b\x12\xdf\x3f\xd9\x15\x50\x2d\xf4\x90\xfa\x4e\x17\x28\x35\xa7\x33\x33\x96\xa2\x45\x46\x32\xa3\x62\xd4\x6e\xb7\x09\x33\x49\xfb\xc3\x5a\x8c\xee\x06\x8c\x5e\x57\x84\x77\x33\xa9\x59\x36\x0b\xb0\x22\x21\x0d\xc7\x52\x19\xd2\x7e\x34\x47\x5b\xbb\x86\xfb\x6f\xaa\xe9\xe2\xcf\xeb\xb3\xad\x37\x91\xd6\xce\x3b\x6b\x18\xa7\xda\xf8\x74\xd9\x48\xf8\xfb\x7a\x95\x7f\x8d\x3c\x4a\x0f\xe1\x55\xe4\x53\x36\x94\xf3\x49\xb1\x6e\x92\xe0\x4f\xb2\x09\xb6\x76\xa3\xfa\x97\xda\x91\x5c\xb5\xc2\x46\x69\x73\xf3\x1c\x5d\xc3\x71\x21\xc3\x74\xab\x5a\xbb\x2c\x9f\xcc\xf7\x5e\xd8\x95\x16\x55\x4c\x12\xff\x3a\x81\xd7\xad\x0e\x74\x18\xd0\x79\xa5\xc2\xd4\x3e\x37\x5f\x74\xc2\x21\x33\x81\xb4\x54\x5c\x43\xd5\xcf\x26\xd9\x77\x61\x18\x1c\x1a\x62\x05\xd6\xa0\x46\xbc\x74\xd7\x99\x16\x12\x0a\x43\x83\x59\x7c\x44\xa3\xaa\x03\x01\x86\x66\xc9\x50\x64\x2c\x6f\x64\xf5\x5c\x5c\x5e\x74\x63\x53\xe6\xec\xe2\xb6\xfb\xa9\x7b\x5d\x0a\x88\x9e\x5f\x76\x6e\x4b\xc1\xcf\xdb\xeb\x4a\xcc\xf4\xfb\xcb\xcb\xf3\x6e\xe7\x22\xfe\xe8\xb4\x73\xdb\xbd\x3d\xfb\x5c\x1a\xfc\xf4\xee\xba\x73\x7b\x76\x59\xfa\xdd\xf7\x67\x17\x9d\xeb\x9f\xe3\x4f\xba\xd7\xd7\x97\xd7\x95\xf7\xdd\x9d\x2c\x0e\xab\x96\x96\x51\xbf\x13\x85\xb2\x1c\x25\x6f\xd7\x29\x85\xb7\x54\xdf\xef\x38\x15\x00\x52\x5f\xd6\x09\xe5\xd7\x46\xee\x4b\x42\x29\x65\xfd\xcd\xb2\x04\x9a\x32\x1d\x6a\xdf\x63\xf5\xc1\x59\x9f\x1a\xc3\x26\xd3\xed\xc0\xef\x56\x3f\x38\xeb\x25\x20\x80\x49\xb3\x42\x02\x42\x69\x57\x5f\x4f\x02\x42\x4d\x6e\xc1\x7c\x02\xc2\xd9\xc5\xd9\xed\x59\xe7\xfc\xec\xff\x55\x46\xfc\xd2\x39\xbb\x3d\xbb\xf8\xd4\xff\x78\x79\xdd\xbf\xee\xde\x5c\xde\x5d\x9f\x74\x6f\x56\x4c\x3f\x98\x77\xf8\x1d\x92\xf8\x3d\xc7\xe4\x56\x06\x50\x14\xa7\x15\xba\xfe\x50\x96\xe2\xd0\x6f\x9b\x1b\xc8\x09\xe7\x62\xd4\x02\x74\xb6\x63\xd2\x55\xea\x6c\x42\x47\xec\x2a\xcf\xb2\x16\x09\x20\x8c\x27\x8a\x51\x03\x3f\xbb\x92\xe9\x59\xf4\x5c\x4f\x90\x43\x52\xbb\x0c\x78\xbf\x03\x3b\xc4\xd7\xb7\xdc\xfb\xa3\x68\x5b\x70\x90\x38\x68\xbe\x00\x2b\x7b\x4c\xbe\xa7\xc9\xbd\x1c\x3a\xd4\x96\x56\x30\x71\xc9\x2f\xb9\x34\x94\xb0\xaf\x09\x63\xa9\xef\xfd\x52\xe5\x93\x73\xb9\x15\x58\xe1\x3a\x4d\x3e\xe3\x33\xbd\x3c\x6f\xa3\xf6\x39\x57\x66\xd3\x5f\x07\x29\xcc\xad\xf2\x33\x3e\xea\xc0\xc1\x6a\x47\x37\x26\xdb\x81\x33\xf9\x5c\x8e\xea\x53\xda\x21\x4b\xcf\xe5\xe1\x17\xa0\x16\x10\x9a\x92\x23\xa2\xb9\xb8\xef\x89\x2f\xd6\xa0\x95\xb9\xc2\x8f\x8c\x54\x50\x1d\x31\xcc\x72\x3d\x66\x00\x4a\xda\x22\x8f\x8c\x4c\xe8\x0c\x43\x54\xe5\x86\x45\xc0\x32\x96\x39\xe1\xe9\x8c\x0b\x2b\x2d\xa6\xdc\x6b\x90\xd5\xad\xdf\x85\x81\x99\x72\x1d\xec\xec\x27\x8c\x1b\x16\x9e\xc2\xc7\x31\x83\x24\xf4\x08\xee\xdc\x77\x4a\x41\xc9\x0d\x05\x8f\x52\xde\xe7\x53\xd7\xe7\x9e\xea\xfb\x77\x3e\xa5\x13\xc8\xfd\x20\x79\x4a\xd2\x7c\x9a\xf1\x24\xc8\xdd\x47\xa9\x1a\x53\x70\xd0\xd2\x59\x23\x05\xa7\x62\xbf\x2f\x5a\x58\x8d\x19\x15\x59\x6d\x0b\x92\x71\x9e\x38\x1d\x29\x82\x58\xca\x35\x53\x87\x46\xf1\xd1\x08\xf4\x46\xef\x94\x79\xfd\xf9\x4a\x9e\x37\x67\xfd\xed\xfd\x0f\xb1\xab\x3a\xc3\x16\x31\x01\x37\xc4\xf2\xd4\x74\x9a\xcd\x7c\x16\x31\x12\xd0\x1f\xfb\x69\xae\x10\xdc\x76\x48\xc2\x84\x1a\xf3\x05\xa6\x8a\xd9\xb7\xa4\x7d\x44\xad\xda\x1e\x4d\xeb\x6c\x88\x18\xae\x88\x92\x13\x05\x6e\x3c\x72\x8e\xbf\xe1\x8a\x77\xfb\x1a\x1f\x2c\xaf\x07\xac\x58\x22\x1f\x05\x36\xf7\x81\xdf\x83\x3e\x2f\x24\xe8\x26\xa1\xee\x07\x3a\xd4\x23\xaa\x60\xea\x4a\xed\x5c\xb9\xb0\xf3\x71\x62\xeb\x82\x97\xcf\x2f\x0b\x82\x1a\xd2\xa6\xcb\x3d\xac\xab\x22\x72\xdb\x22\xa0\x90\x8c\xb3\xa9\x46\xbc\xd8\xa6\x1b\x65\x72\x80\xb0\x7f\x73\xe5\x41\xf1\xad\xb3\x9e\x03\xd3\x77\xda\x2e\xdf\x59\x3e\xcd\x0e\xf2\x36\xe4\x02\xd8\x85\x52\x3f\xc8\x9d\xd6\x4f\x6d\x4f\xb0\xdc\xc8\x08\x68\xd1\x2e\xee\xac\xd2\xaf\xb0\x8d\xc9\xf4\x67\x69\x2d\x6a\x4f\x71\x62\x3c\xe5\x9b\xa4\x73\x8d\x0f\x65\xad\xf2\xaf\xa9\x62\xde\x7b\x36\x63\x26\x38\xcd\x32\x9f\xec\x3f\x9b\x96\x5b\xd4\xc5\x51\x03\xef\x17\x0c\x21\x46\xa8\x46\x89\x9a\xe0\x48\xc1\x84\xd1\x0e\xae\xbe\x27\xdc\xe0\xbe\x98\x34\xe0\x31\xb9\x40\x08\x12\xa6\xe5\x6c\x10\x07\xfd\xab\x65\xf6\x80\xe8\x98\x05\x4d\x8c\x84\x62\x0f\x3b\xc1\x13\x2b\xce\xad\xf2\x42\x45\x5a\x34\x31\x19\xb3\x9e\xa8\x54\x54\x2a\x36\xe2\xda\xc0\xc5\xe2\x39\x36\x7e\x7e\x67\x55\x66\x25\x7d\x67\x11\xe9\x1b\xab\xcc\x96\x09\xae\x21\x4d\xd6\xa9\xf6\x98\x4d\x59\x7a\x16\x9e\x5b\xcc\x0c\x25\xd7\x49\x1a\x85\x96\x4a\x87\x1c\x79\xc0\x83\x7b\x43\xa9\x9e\x0e\xb8\x74\x61\x93\x02\xc2\x57\xe8\xde\x66\xb7\x68\x44\x7d\x07\x3f\x1d\xda\xb7\x61\x24\x3a\x76\x79\x57\xba\x2d\x07\x5d\x2a\x91\xda\x60\x7c\x0d\x1e\x19\x52\x9e\xe5\xaa\x51\x45\x40\xb6\xdc\x79\x0d\xec\x09\x0c\x4b\xea\x76\x2d\xf8\xa5\xa3\x63\x14\x7c\xd2\xa1\x8b\x73\x96\x8f\xb8\xd0\x65\xae\x6f\xee\x66\x32\xd7\xd9\x69\xc9\x86\x17\xcd\xa0\x56\x97\xc5\x1d\x3c\xec\x1a\x16\x0f\x71\x88\x66\x38\x31\xa7\xb4\x45\x73\xef\x89\x5b\xb8\xab\xb1\xc4\x33\x1c\x33\x8a\xf0\xd7\x4a\x1b\xe8\xb7\x5b\xbb\xde\x92\x3c\x2f\x73\xea\x56\xd9\x55\x75\xc5\x98\xcb\xb3\x38\x3f\xd3\xe9\xa2\x3a\xb9\xad\x47\x5c\xb6\x0d\xc1\xbb\x59\x3d\x86\xd5\x7e\x1b\x35\xd4\x0b\x99\xa8\xcf\x12\xc4\x5b\xa7\x6a\x3f\x24\x24\x3b\xbc\x8b\xb9\x92\xeb\x92\x62\x1a\x3f\xba\x7e\x4e\x7a\x11\xbd\x72\x48\xed\x38\xe0\x00\xb3\x88\xe3\xc4\xe7\x2d\x4a\xbe\xc3\xc6\xf8\xb1\x16\x6c\xc7\x96\x49\x99\x45\x1e\xfd\x33\xe6\x64\xfe\x34\x47\xa2\x75\x53\x32\x1f\xe2\x1c\x74\xb8\x1b\x8a\xc6\xe5\x2b\x69\xcc\x21\x15\xf3\xa7\x72\x21\x41\x89\xc4\x92\xaf\x54\x71\x31\x0f\x05\x09\x4a\x4b\xca\x84\x34\x8c\x50\x22\x78\x76\x24\xf2\x2c\x3b\xba\x80\xbe\xb1\x5a\xf3\x11\xb6\xa5\xc2\x46\x0e\x10\x25\x2c\xc0\x89\x4a\xae\xb2\xe8\x08\xc0\x15\x69\xa7\x84\x5e\x3c\x63\x25\xa6\xdd\x82\x6c\xd6\x13\xf6\x09\x54\xb1\x10\xd3\x85\x87\xc8\x2a\xbe\x2d\x34\x8d\xc0\x77\x41\x7e\xdb\x2c\x1e\xbc\x86\xc1\x16\xd5\xa5\x6d\x15\xd2\xdc\x03\x96\xbe\x1a\xc0\x52\xa9\x42\x07\x85\xd5\xa1\x4b\x9b\x0f\xd5\xc6\xd8\xa1\x41\x11\x0b\x21\x81\x15\xf8\xf1\x25\xc3\x01\x4f\x59\xa5\xb8\x75\x49\xa2\xa7\xd4\x2e\xbc\xa2\xbf\x60\xa2\x6b\x5f\x0e\xfb\x7a\x2e\x61\x98\x2c\x16\xf3\x73\xa9\xc6\xab\xb9\xa5\xe2\x24\x8f\x38\x25\x77\x9e\x49\x9a\xf4\x72\x29\xfa\x4e\x73\x5f\x6d\xb2\x55\x82\x5d\x8a\x8f\xf8\xf8\x95\xcc\x78\xb2\xd8\x97\xe7\xaf\x26\xc0\xc0\x98\xf3\xe4\x02\x5a\x8c\x83\xc1\xa6\xde\x9c\x40\x27\x95\x61\x89\x29\x4c\xd3\xf9\xc5\xad\xe3\xea\xf8\x1c\xf5\xcf\x71\x9e\x2b\xc3\x55\x0c\x9c\x52\xd4\x1e\xfa\x98\x5b\x00\xb2\x81\xd3\x99\x4a\x86\xc1\x98\x64\x4c\xc5\x88\xb9\x86\x3e\x56\xcf\xf1\x08\x02\x15\x9b\x69\xc1\x8d\xe1\x67\x73\x8a\xdc\xba\x55\x6a\xeb\x2e\x3d\x69\x0b\xd9\xcf\x47\x28\xbd\x57\x3e\x6e\x89\x5f\x9a\x84\xcb\xbe\x43\x39\x09\x6d\x24\x4d\x79\x07\x11\xe6\xc6\x27\xf8\xb9\x96\x68\x39\x0d\xc5\x37\xe0\xd4\xb0\x1b\xe5\x90\x21\x72\x01\xf9\x7a\xec\x2b\xe2\x6f\x64\xb3\x78\x54\xa8\xd4\x86\x11\xd7\xcc\x62\x00\x3f\x45\x28\xa6\x5f\xca\x20\xcd\xbb\xb9\xad\xe3\x10\x8b\x95\xa6\x19\x15\x7d\x3c\x7c\x2f\xe0\x3a\x8c\x0a\xa6\x9a\xb0\xdc\xf2\x41\x3f\x20\x49\xec\x64\x9e\xe1\x56\xbc\x2e\x95\x31\xc6\x9d\xe4\x5b\x55\xbc\x67\xaf\xc5\x41\x86\x65\xd1\xbb\xd9\xb5\x4f\x61\x5f\xeb\x92\x80\x96\xbb\x3f\x69\xc5\xd9\x11\x7a\x96\x2c\xf1\x7f\x7a\x0e\x78\xad\x3e\xd0\x55\x76\xbe\xc2\xe0\xd5\x6d\x5f\xdf\xfd\x36\x77\xb9\x6e\xe4\x82\x5b\x32\xad\xa7\x75\xc3\x35\x9a\x9b\xf3\xee\xb8\x2f\xe5\x8e\xe4\x56\x83\xc5\x70\x1a\x23\x5a\x5a\x1d\xd8\x5b\xc3\xf5\x05\x71\x95\xdc\x97\x27\x05\x00\x2a\xe3\x1d\xac\x9c\x44\x86\x10\x60\xe4\xac\x68\x94\xd5\x22\xbd\x03\xe4\x2c\xdd\x3b\x40\xd0\x4c\x5f\x57\xe9\xf1\xc5\xca\x3d\x7f\xaa\xce\x6a\x8c\x23\x45\x37\x88\x88\x5c\x2a\x55\xba\x34\x78\x7e\x5e\x12\xd8\x2b\xca\xb0\xc3\x50\xf3\x00\x07\x70\x8a\x3c\xda\x27\x33\x8f\xfa\x05\xb5\xff\x2a\x4f\x4c\xb1\xe0\x00\x92\xf4\xbd\x7f\xd0\x92\x68\x9a\x43\xbf\xc5\xb4\xe8\xba\x26\x55\x4f\xf8\xd1\x0a\xac\xd2\x4e\x96\xcd\x0d\x35\x8f\x0f\x16\xf1\x2a\xa0\x05\xfa\xdc\x77\xa8\xa9\xb0\x3f\x82\xec\xc0\x39\x39\x00\x1d\x4b\x07\xac\xa8\x08\x6f\x93\x02\xa1\x0e\x8a\x8e\x2b\x50\x58\x31\x12\x56\x96\x79\x18\x28\x04\x57\x8a\xb0\x7f\x74\x0e\xad\x74\x86\xb9\x15\x47\xe1\xed\x46\xf6\x04\xa0\xa2\x95\x54\x29\xe8\x46\xa4\x7d\x33\x7f\xcd\xe6\x3a\xb4\x3a\xb2\xbd\x0b\x25\x00\xee\x83\x53\x2b\x44\xec\x53\xb3\x29\x23\x15\x34\x02\x88\x75\x42\x46\x46\x8b\xcc\x64\x1e\x29\x30\x09\x15\x3d\xf1\x77\x4b\x1e\x0f\xf5\xe5\xb6\x55\x0e\xf1\x10\x7b\xf4\x06\xf2\xfe\x6f\x38\xe8\xfb\x7f\xfb\xf0\xb7\x0f\x08\xa4\x98\xeb\xdc\x4a\xd8\x56\xf9\x0a\xf1\x13\xb5\x5b\x0a\xf9\x40\xa1\x8f\x9e\xef\xce\x53\xbc\x62\x21\x28\x88\xd3\x88\x77\x0d\x81\x5f\x78\xe9\x3a\x24\xa1\x26\x19\x1f\x52\xc7\x7b\x31\xfc\x19\xd7\x45\x83\x05\xab\xa1\x43\x8f\xf7\x72\x53\x06\x2c\x42\x21\xa1\x3d\xae\x2e\xd3\xc1\xf2\x0b\xf6\x12\x73\x5a\x61\x05\x48\xc0\xbf\x09\x98\xb3\x28\x65\xff\x52\x48\x06\xff\x73\x5f\x53\x11\x75\xeb\x43\x77\xa2\x35\xf3\x53\xd2\xc3\x1c\xe4\xde\x81\xdf\xfe\x9e\x98\x0e\xda\xd9\x6c\x68\xda\x90\x11\xdd\xb6\x64\x69\x77\x17\xb6\x1c\xc3\x4b\xa8\x9f\xce\x6b\xe5\x4b\xc8\xdd\xa8\xd7\xd7\xeb\x3b\x81\x3a\xe1\x4d\xab\x2b\x2d\xe8\x0e\x08\xf4\xb9\x29\xc7\x0b\x58\xf0\x2f\x30\x8c\x01\xb5\x3c\xbc\x15\x15\x69\xac\x58\x15\xe7\x13\xb0\xd6\xec\x45\x17\xfa\xca\x51\x41\xb3\x19\x54\x36\xb5\x7a\x02\x5b\x5e\xb2\x94\xd0\x64\x96\x64\x3c\x71\x50\x55\x65\x5d\x88\x3d\x30\x61\x4a\x09\x98\x5d\xfb\xc9\x73\xa9\x43\x4d\xa9\x9f\xf5\xd4\xbf\x6b\x50\x85\x02\xac\x60\xd9\xc3\x52\x65\x13\x07\xae\xa1\xd6\x04\x27\x09\xaf\x07\xd1\x9c\x7a\x63\x51\x2a\x3e\xe2\x82\x1a\xa9\xc8\x7b\x70\x15\x67\x19\x53\x1f\x42\x0f\x34\xa0\x62\xfd\x34\xc6\x6b\x75\x1e\xa9\xc1\xa9\xaa\xbf\x6c\x93\x24\x57\x8a\xa5\xfd\xf9\x8c\xbb\x75\x0b\xb9\x17\xe7\x23\x59\xd5\x9a\x4f\x98\x36\x74\x32\x25\xaa\xa8\x95\x0d\x55\x5e\x8e\x32\x19\x12\x81\xf8\x89\xb5\x08\x87\xa4\xba\x10\xda\xef\x09\x17\xd4\xc7\x7d\x93\xaa\x06\xa1\xa4\xba\x4a\x6c\xcc\xb8\x61\x3e\xa3\x43\x6c\x5c\xb3\xcb\x5c\xd5\xb9\x78\x7d\xee\xf3\x2e\x8a\x8b\xa0\x24\x59\x61\xa1\xd0\xb5\xd3\x2a\xa2\xa1\xd1\x71\x48\x1d\xeb\x89\x22\x6d\xeb\x24\x93\x79\x4a\x9c\x6b\xd5\x39\x2a\x55\x9b\x70\xd6\x6e\x11\xfd\x2f\xc7\x47\x47\xed\xf6\x8e\x1a\x97\x94\x7b\x1b\xd6\x73\x38\x76\x1f\xac\x4b\x8b\x5c\x72\xb4\x4a\x40\x85\xfd\xf5\x2c\x0f\x5f\xf6\x02\xdc\x12\x5b\xe6\xe5\xa4\x9f\xea\x2b\xa7\x54\x31\x61\xfa\x90\xc8\xbe\xde\x0b\xe1\x45\x57\xf0\x78\x29\x07\x7b\x25\xb3\xe7\x7f\x6e\x25\x5a\xb3\x3e\x11\xeb\xaf\x11\xf6\xa9\xab\x6b\xa5\xfa\x9e\xbc\xe7\x10\x88\xf8\xe0\xec\x73\xab\x3e\x2f\x01\x7b\x74\x0b\xda\x80\x82\xd1\x82\x4a\xd2\x62\xa5\x05\x15\xb3\x87\xa0\x03\x0d\xc0\x9e\x21\x17\xc5\x9e\x5e\xff\x59\xe1\xc2\xc3\x3c\xa3\xc2\x5f\x49\xa8\x71\xee\xa1\x7f\x30\x25\x8b\x0e\xe4\x0e\xa4\x25\x1a\x78\x41\x52\xe2\xac\x0f\x9d\x2e\x37\x12\xcf\x58\xd4\x09\xcf\x43\x92\x8b\xcf\x14\x8f\x7b\x67\xe2\xdd\x39\x98\xf9\xe4\xc4\x66\x9c\x86\x4d\x1a\xa8\x16\xed\x8b\x8b\x1b\x2a\x12\x69\x5e\xbd\x0f\xf2\xd1\x9f\x9a\x23\xb8\x99\x7d\xff\x7c\x3a\x75\x41\x3f\x87\xcb\x5e\x75\x55\xb4\x61\x11\xff\xf3\xdf\x7f\x6d\x37\xd5\x74\xc1\xd4\x37\x06\xdd\xfb\xe8\x21\xf7\x14\xa3\x69\x01\x86\x15\x63\x5d\x2d\xab\xd7\x5a\xca\x90\x5b\xa8\x17\xdb\xec\xcb\xbc\x02\xe1\x63\x6d\x11\xdb\xf3\x34\x2e\xc8\x0f\x0c\xee\xb6\x27\x60\x21\xc9\x21\x01\xc5\xb4\x41\x85\x69\xbb\x79\xd6\xbc\x61\x0d\xea\xd5\xcb\xa7\x67\x52\xce\x9a\xca\x8e\x56\x99\x7e\xe9\xd9\xad\x55\xca\x6d\xaa\x95\x16\x7a\xc6\x4f\x03\xbc\x3e\x64\x20\x9d\x09\x92\xc8\xc9\xc0\xaa\x75\xf6\xf2\x0b\xae\x4a\x10\x4d\x1d\x9f\xb9\x1e\xd2\x6e\xbd\x88\x41\x80\xaa\x4a\xdd\x4f\x88\x09\xc6\x79\xb5\x31\x9f\xd5\x46\x43\x1a\xee\x83\xdd\x16\x56\xd5\x1f\x8e\x4e\x75\x05\x45\xc3\x87\x7b\x9e\xdc\x33\xcb\xca\xc3\x02\x98\x2e\xd6\x77\x82\xc6\x1b\x12\x8d\x7b\x02\x28\x84\x59\x6d\x9e\xfb\xed\x71\x30\x92\x28\x66\xc5\x58\x94\xb9\x2a\x09\x37\xef\x74\x3d\x71\x9e\xba\x0a\xac\x9e\x16\x30\x7e\xa8\x55\x70\x68\x04\xc1\xd8\x40\xf3\x0c\x74\xb4\x3f\x05\xb9\xa8\x59\x22\x45\xa8\x6f\xd8\x89\xea\x5f\x53\x21\x56\x3f\x5d\xf8\x6e\x0e\xc6\x60\x99\x1d\xb2\xa5\x39\x14\xc9\x36\x25\x13\x07\xcb\x60\x88\x86\xec\x0f\x48\x72\xb4\xef\x6e\x91\x09\xe5\xc2\x1d\x03\xe8\x00\x4d\x52\x36\xc8\x47\xa3\x46\x2d\x3d\x93\xa3\x27\x75\x19\xfa\x7a\xaa\x46\x97\x61\x58\x61\xb6\xa8\x46\x68\x09\x87\x7e\x43\xe6\xd8\xc2\x9c\xda\x5d\x18\x54\x67\xfe\x4d\xe8\x16\x1a\xf2\x8c\x3d\x8f\x0d\xb5\x23\x83\xf0\x6c\x15\x83\xd0\xfb\x15\x21\x0f\x06\xd7\x11\x3c\x3f\xbf\x21\x4b\x11\xf3\x8a\xfb\xf6\xc9\x27\x4d\x2e\x0e\xe5\x10\x70\x58\x31\x6d\xd8\xca\xa6\x54\x03\xec\xc8\xee\xb3\x8d\x41\xb6\x2f\xab\x61\xda\x1a\x76\xe7\x46\x4e\x18\x81\x57\x69\xac\x70\x25\x2e\x91\xa7\x05\x71\x08\xbb\x40\xd7\x75\x3c\x73\xc2\xdf\x39\xda\x31\xf7\xa1\x68\x7e\x44\xde\x0b\xf6\x48\xac\xac\x6d\xc5\x8e\xd9\x68\x7b\x5a\x84\x99\xe4\x83\xd5\x6d\x4a\x71\x5c\xc5\x12\xa9\x52\x28\x31\x1b\x51\x95\x42\x7c\xdf\x31\x7c\x46\x93\x7b\x00\x95\x84\xeb\x08\xdf\xe8\x53\x0a\x5c\x15\x16\x06\x34\x8a\xd1\xb8\x48\x14\x14\x1a\x78\x98\xa0\x30\x3f\x7c\x5c\x13\x9a\x28\xa9\xd1\x38\xf5\x58\x82\x0e\xc4\xce\xaa\x5f\x0f\x3c\xcd\x69\x86\x6f\x5c\x27\x8b\xe0\xca\x31\x84\xcf\x47\x8b\xdc\xe2\x20\x25\x4b\x80\x29\x1f\xa5\x72\x15\x55\x40\xf1\x2b\x87\xcb\xf2\x03\x7f\x60\x2d\x72\x33\xa5\xea\xbe\x45\x4e\x67\x82\x4e\x78\xf2\x5f\x72\x50\xe7\x61\x9d\x4b\xf0\xda\x5a\x25\xde\x3d\x20\x7f\xfd\x41\xff\x32\x97\xbc\x43\x9a\xcc\xce\xb7\xe9\x5f\x6d\xc8\xbd\xfb\xd6\x2f\xf5\x25\x51\xfa\xbd\xab\x74\xa7\x17\x60\xad\xa1\xec\x1d\x9f\x34\x9d\x70\x51\xb2\xd5\x5e\x55\xf8\xa5\xba\xa9\x75\xb9\xae\x25\x61\xbc\x92\x75\xbb\x0b\xcd\xf1\x8a\x5a\x2b\xc7\x1a\x94\x13\x69\x18\xde\xfb\xda\x48\xc5\x1c\x2e\x03\xaa\x93\xd0\x39\x90\x6b\xfc\xa6\x09\x55\x3b\xc9\xa4\x5e\x39\xa7\x72\x7e\xc3\x4e\xdc\xe3\x0b\xb5\x13\x39\x99\x42\x3c\x56\x31\x9d\x67\x46\xd7\xd8\x6b\x73\x81\xac\x9d\xa4\xf6\xcc\x4f\xf7\x33\x33\xf4\x74\xce\x31\x1c\x78\xbb\x94\x51\x07\x6e\xde\xee\x02\x9e\x6e\xba\x62\xbb\x71\x44\xd3\x9e\x6d\xdf\x97\xd1\xf5\x9e\xe2\x62\x94\x35\xb5\x6b\xe9\x09\xd7\xba\x2a\x92\x7d\xb4\xa8\x8a\x0c\x9e\x54\x57\x18\xff\x58\x6a\xdb\x13\xfa\x5e\xb9\xd4\x38\xea\x0c\xf6\xa0\x17\xc1\x5d\xde\x02\x98\x3f\x4c\x15\x14\x80\xf2\xd8\x13\x3a\x1f\x1c\x16\x09\x6c\x52\x81\x74\x05\x98\x9e\x29\x55\x80\x3a\x32\xe6\x59\x7a\x58\x93\xd0\x8a\x5a\x0e\x74\xbc\x0a\x90\x96\x03\x06\xa8\x75\xb0\xe3\xd8\x5d\x16\xf3\x27\xc2\xda\xc3\x38\x83\xdc\x10\x16\x3a\x08\x71\xed\x9c\x47\x15\x4d\xa2\x24\x2f\x4a\xbe\x81\x97\xf6\x08\x2e\x97\x17\x4d\x45\xcf\xdf\xbe\x9c\x28\xd1\x6c\x15\x39\x71\x5b\xf6\xc2\xf9\x53\x43\x45\x90\x1c\x4d\xa4\xd2\x7d\x74\xa1\x3d\x61\x2e\xf1\x97\x00\xec\xe1\x4b\x55\xf5\x94\x3e\x0a\x97\x36\xb6\x16\x62\xfc\x6a\xf2\xa1\x1e\x4d\xc9\xca\x87\xca\x37\xb1\xa4\xb0\xd7\x11\xa4\xfd\xf0\x50\x42\xde\x8a\xb0\x32\xa0\x9b\x60\x51\x17\x58\x98\x3f\x3d\x51\xe4\x33\x16\xed\xcf\x93\xaa\xe0\x76\x69\x82\x29\xa4\x5e\xb0\x96\xcf\x71\x6a\x61\x1d\xb5\x33\x52\x0e\x07\x14\xba\x1b\x34\x61\x44\x97\x4e\x73\x6d\xd8\x73\x17\xd6\xc1\xd9\xd3\x77\xeb\xaa\xbf\x36\x8a\x6e\x67\x45\xf2\x62\x75\xe9\x11\xd0\xe1\xf3\x83\x1b\xad\x57\xaf\x19\xa1\x0f\xae\xce\xe1\x73\x35\xe1\x0e\x79\x0f\xab\x12\xa2\x26\x26\xa5\xd4\x2a\x20\x61\xd1\xe4\x25\xa4\x9d\x45\xa5\x73\x56\x44\xd1\x11\x23\x13\x96\xf2\xbc\x5a\x0e\xbc\x3c\x9e\xfe\xaa\xcc\xce\x55\x38\xcb\x1a\xe0\xc1\x10\xbd\x00\x63\xe1\xd1\xde\xda\x98\x94\x0a\x4e\x8f\x7a\x68\x9e\x28\x31\x9c\x9a\x77\x3a\x04\xe3\xcb\x14\xf3\x2e\xa6\x73\xae\xcd\x4f\x95\x06\x0d\x1b\x54\x9d\x66\xf9\xd3\x65\x03\xfb\xa9\xe2\x34\xa3\x27\x16\x66\xbd\x5e\x97\xba\xdb\x03\x93\xa1\xbb\x02\xb2\xc6\x7c\x3d\xae\x9d\xf7\x3a\x02\xfc\x6f\x81\x5e\x7f\x73\xfd\xf7\x15\x9d\x4e\x99\x22\xae\x07\x7f\xb5\xab\x3e\x16\xb7\xc2\x5b\x7a\x02\x15\xa6\xff\xba\xb9\xbc\x28\x24\x77\x61\x47\x55\x86\x86\x9f\x01\xe9\xda\xf5\x3b\x77\x91\x67\x59\xe3\xce\xad\x80\x39\x79\x77\x7e\xde\xff\xa9\x73\x7e\xd7\x5d\x8c\xe9\x58\xfc\xac\x91\x26\x61\x26\x8e\x26\x78\x8d\x19\xb8\xba\xf2\x09\x73\x0e\x2c\x50\x46\xdc\xaa\x31\xaa\x9e\x67\x59\xb9\x3e\xb1\x27\xfe\xe6\xc6\x81\x94\xd8\x5c\xa0\x9a\xd9\x13\x64\x21\xe1\xca\xef\x87\x9f\xfd\xcd\x0e\xfe\x37\x7c\xf6\x90\x14\x8b\x38\x26\x17\xe1\xad\x0d\x74\x75\x4e\xd7\x2d\x8e\x03\x96\x49\x3e\x57\x05\xf6\x66\xc7\xe3\x4e\x78\xb8\x55\x57\x38\xbd\x93\xd3\x81\xb4\xfb\x5b\xd9\x84\x09\x28\x11\x29\xca\x79\x18\xb7\x85\x75\xb3\xda\xb8\x2c\x15\xa4\x59\x4f\x60\x3a\x11\x74\xe5\x97\xcd\x73\x22\x67\x02\x73\x9d\x33\x2a\x46\x39\x1d\x31\xdd\x22\xfe\xe5\x3d\x11\x7a\xc0\x3b\x98\xa7\xd0\x5b\x8c\x42\x27\x95\x32\x0b\xa1\xab\x93\x7d\xa5\x93\x29\x84\x60\x44\x4f\xb8\x35\x89\x51\x31\x3c\x7a\x41\xff\xeb\x26\x2c\xc7\x72\x5a\x18\xc8\x95\xfe\x8a\x9e\xc0\xcd\xc5\xba\x6f\xaf\xdb\x81\x03\x88\x9a\x2a\xeb\x52\xc5\x3c\xda\x00\xc8\xf4\x11\x68\x99\x88\xf4\xef\x43\x8c\x56\xd2\x47\x50\x55\xe8\x70\xc6\x29\x2d\x97\x27\x7e\x33\xfc\x99\x70\x73\xab\xe7\xfa\xad\xef\x00\x7b\xe0\xea\x5b\xfd\x2c\x66\xdb\x42\x8c\x2d\x91\xe6\x05\x43\x89\xea\x11\x26\xd5\x64\x20\x08\x5e\xef\xa0\xad\xd1\xca\x53\xc2\xdf\x2f\x9c\xd4\x1a\xdd\x90\x56\x7e\xad\x03\xad\x58\xf4\x5a\x6b\xe1\x2c\x7e\xe9\x0e\x4c\xa4\xd2\xa4\xdc\x03\xcb\x88\x91\x27\x0d\x8d\xa7\xb6\x8e\x89\x55\x49\xe4\xa5\xcf\xa2\x09\x65\x5c\x6f\x34\x9d\x42\x7f\x5a\x79\x46\x41\x43\x70\x97\xdd\x5a\x12\xd6\xdd\x73\x25\x01\xdb\x20\x26\x5d\x6a\xa6\x73\xcb\x30\x8e\xe2\x45\x00\x28\x2c\x75\x09\x1e\xad\xc0\x44\xad\x62\xe7\x5a\xd8\xa5\x22\x57\xda\x8a\x4b\x27\xef\x9c\xd4\xb6\x66\x4e\x4f\xf8\x82\x22\x2f\x8e\x3b\xbe\x8b\xa3\x0a\x9f\x62\x9c\x71\x8a\xe9\xf8\xa0\xb1\x9a\xa2\xfd\x27\x35\x3d\x01\x08\x1f\x02\x4c\xc8\x81\x86\x7a\x4a\x87\x63\xe1\xbe\x88\x40\x01\xa9\x08\x9d\x32\x96\xc8\xbc\x8a\x1a\x50\xba\xe7\x7f\x67\xff\xff\xaf\xbf\xfb\xff\x03\x00\x00\xff\xff\x4e\x05\xe2\xb0\xf3\x1f\x03\x00") func adminSwaggerJsonBytes() ([]byte, error) { return bindataRead( @@ -92,7 +92,7 @@ func adminSwaggerJson() (*asset, error) { return nil, err } - info := bindataFileInfo{name: "admin.swagger.json", size: 202889, mode: os.FileMode(420), modTime: time.Unix(1562572800, 0)} + info := bindataFileInfo{name: "admin.swagger.json", size: 204787, mode: os.FileMode(420), modTime: time.Unix(1562572800, 0)} a := &asset{bytes: bytes, info: info} return a, nil } diff --git a/flyteidl/gen/pb-java/flyteidl/admin/NodeExecutionOuterClass.java b/flyteidl/gen/pb-java/flyteidl/admin/NodeExecutionOuterClass.java index d8233be206..7711a7e33f 100644 --- a/flyteidl/gen/pb-java/flyteidl/admin/NodeExecutionOuterClass.java +++ b/flyteidl/gen/pb-java/flyteidl/admin/NodeExecutionOuterClass.java @@ -797,6 +797,26 @@ public interface NodeExecutionListRequestOrBuilder extends * .flyteidl.admin.Sort sort_by = 5; */ flyteidl.admin.Common.SortOrBuilder getSortByOrBuilder(); + + /** + *
+     * Unique identifier of the parent node in the execution
+     * +optional
+     * 
+ * + * string unique_parent_id = 6; + */ + java.lang.String getUniqueParentId(); + /** + *
+     * Unique identifier of the parent node in the execution
+     * +optional
+     * 
+ * + * string unique_parent_id = 6; + */ + com.google.protobuf.ByteString + getUniqueParentIdBytes(); } /** *
@@ -817,6 +837,7 @@ private NodeExecutionListRequest(com.google.protobuf.GeneratedMessageV3.Builder<
     private NodeExecutionListRequest() {
       token_ = "";
       filters_ = "";
+      uniqueParentId_ = "";
     }
 
     @java.lang.Override
@@ -886,6 +907,12 @@ private NodeExecutionListRequest(
 
               break;
             }
+            case 50: {
+              java.lang.String s = input.readStringRequireUtf8();
+
+              uniqueParentId_ = s;
+              break;
+            }
             default: {
               if (!parseUnknownField(
                   input, unknownFields, extensionRegistry, tag)) {
@@ -1092,6 +1119,50 @@ public flyteidl.admin.Common.SortOrBuilder getSortByOrBuilder() {
       return getSortBy();
     }
 
+    public static final int UNIQUE_PARENT_ID_FIELD_NUMBER = 6;
+    private volatile java.lang.Object uniqueParentId_;
+    /**
+     * 
+     * Unique identifier of the parent node in the execution
+     * +optional
+     * 
+ * + * string unique_parent_id = 6; + */ + public java.lang.String getUniqueParentId() { + java.lang.Object ref = uniqueParentId_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + uniqueParentId_ = s; + return s; + } + } + /** + *
+     * Unique identifier of the parent node in the execution
+     * +optional
+     * 
+ * + * string unique_parent_id = 6; + */ + public com.google.protobuf.ByteString + getUniqueParentIdBytes() { + java.lang.Object ref = uniqueParentId_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + uniqueParentId_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { @@ -1121,6 +1192,9 @@ public void writeTo(com.google.protobuf.CodedOutputStream output) if (sortBy_ != null) { output.writeMessage(5, getSortBy()); } + if (!getUniqueParentIdBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 6, uniqueParentId_); + } unknownFields.writeTo(output); } @@ -1148,6 +1222,9 @@ public int getSerializedSize() { size += com.google.protobuf.CodedOutputStream .computeMessageSize(5, getSortBy()); } + if (!getUniqueParentIdBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(6, uniqueParentId_); + } size += unknownFields.getSerializedSize(); memoizedSize = size; return size; @@ -1179,6 +1256,8 @@ public boolean equals(final java.lang.Object obj) { if (!getSortBy() .equals(other.getSortBy())) return false; } + if (!getUniqueParentId() + .equals(other.getUniqueParentId())) return false; if (!unknownFields.equals(other.unknownFields)) return false; return true; } @@ -1204,6 +1283,8 @@ public int hashCode() { hash = (37 * hash) + SORT_BY_FIELD_NUMBER; hash = (53 * hash) + getSortBy().hashCode(); } + hash = (37 * hash) + UNIQUE_PARENT_ID_FIELD_NUMBER; + hash = (53 * hash) + getUniqueParentId().hashCode(); hash = (29 * hash) + unknownFields.hashCode(); memoizedHashCode = hash; return hash; @@ -1359,6 +1440,8 @@ public Builder clear() { sortBy_ = null; sortByBuilder_ = null; } + uniqueParentId_ = ""; + return this; } @@ -1398,6 +1481,7 @@ public flyteidl.admin.NodeExecutionOuterClass.NodeExecutionListRequest buildPart } else { result.sortBy_ = sortByBuilder_.build(); } + result.uniqueParentId_ = uniqueParentId_; onBuilt(); return result; } @@ -1463,6 +1547,10 @@ public Builder mergeFrom(flyteidl.admin.NodeExecutionOuterClass.NodeExecutionLis if (other.hasSortBy()) { mergeSortBy(other.getSortBy()); } + if (!other.getUniqueParentId().isEmpty()) { + uniqueParentId_ = other.uniqueParentId_; + onChanged(); + } this.mergeUnknownFields(other.unknownFields); onChanged(); return this; @@ -2042,6 +2130,100 @@ public flyteidl.admin.Common.SortOrBuilder getSortByOrBuilder() { } return sortByBuilder_; } + + private java.lang.Object uniqueParentId_ = ""; + /** + *
+       * Unique identifier of the parent node in the execution
+       * +optional
+       * 
+ * + * string unique_parent_id = 6; + */ + public java.lang.String getUniqueParentId() { + java.lang.Object ref = uniqueParentId_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + uniqueParentId_ = s; + return s; + } else { + return (java.lang.String) ref; + } + } + /** + *
+       * Unique identifier of the parent node in the execution
+       * +optional
+       * 
+ * + * string unique_parent_id = 6; + */ + public com.google.protobuf.ByteString + getUniqueParentIdBytes() { + java.lang.Object ref = uniqueParentId_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + uniqueParentId_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + /** + *
+       * Unique identifier of the parent node in the execution
+       * +optional
+       * 
+ * + * string unique_parent_id = 6; + */ + public Builder setUniqueParentId( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + uniqueParentId_ = value; + onChanged(); + return this; + } + /** + *
+       * Unique identifier of the parent node in the execution
+       * +optional
+       * 
+ * + * string unique_parent_id = 6; + */ + public Builder clearUniqueParentId() { + + uniqueParentId_ = getDefaultInstance().getUniqueParentId(); + onChanged(); + return this; + } + /** + *
+       * Unique identifier of the parent node in the execution
+       * +optional
+       * 
+ * + * string unique_parent_id = 6; + */ + public Builder setUniqueParentIdBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + + uniqueParentId_ = value; + onChanged(); + return this; + } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { @@ -4866,6 +5048,55 @@ public flyteidl.admin.NodeExecutionOuterClass.NodeExecution getDefaultInstanceFo public interface NodeExecutionMetaDataOrBuilder extends // @@protoc_insertion_point(interface_extends:flyteidl.admin.NodeExecutionMetaData) com.google.protobuf.MessageOrBuilder { + + /** + *
+     * Node executions are grouped depending on retries of the parent
+     * Retry group is unique within the context of a parent node.
+     * 
+ * + * string retry_group = 1; + */ + java.lang.String getRetryGroup(); + /** + *
+     * Node executions are grouped depending on retries of the parent
+     * Retry group is unique within the context of a parent node.
+     * 
+ * + * string retry_group = 1; + */ + com.google.protobuf.ByteString + getRetryGroupBytes(); + + /** + *
+     * Boolean flag indicating if the node has child nodes under it
+     * 
+ * + * bool is_parent_node = 2; + */ + boolean getIsParentNode(); + + /** + *
+     * Node id of the node in the original workflow
+     * This maps to value of WorkflowTemplate.nodes[X].id
+     * 
+ * + * string spec_node_id = 3; + */ + java.lang.String getSpecNodeId(); + /** + *
+     * Node id of the node in the original workflow
+     * This maps to value of WorkflowTemplate.nodes[X].id
+     * 
+ * + * string spec_node_id = 3; + */ + com.google.protobuf.ByteString + getSpecNodeIdBytes(); } /** *
@@ -4884,6 +5115,8 @@ private NodeExecutionMetaData(com.google.protobuf.GeneratedMessageV3.Builder
       super(builder);
     }
     private NodeExecutionMetaData() {
+      retryGroup_ = "";
+      specNodeId_ = "";
     }
 
     @java.lang.Override
@@ -4899,6 +5132,7 @@ private NodeExecutionMetaData(
       if (extensionRegistry == null) {
         throw new java.lang.NullPointerException();
       }
+      int mutable_bitField0_ = 0;
       com.google.protobuf.UnknownFieldSet.Builder unknownFields =
           com.google.protobuf.UnknownFieldSet.newBuilder();
       try {
@@ -4909,6 +5143,23 @@ private NodeExecutionMetaData(
             case 0:
               done = true;
               break;
+            case 10: {
+              java.lang.String s = input.readStringRequireUtf8();
+
+              retryGroup_ = s;
+              break;
+            }
+            case 16: {
+
+              isParentNode_ = input.readBool();
+              break;
+            }
+            case 26: {
+              java.lang.String s = input.readStringRequireUtf8();
+
+              specNodeId_ = s;
+              break;
+            }
             default: {
               if (!parseUnknownField(
                   input, unknownFields, extensionRegistry, tag)) {
@@ -4941,6 +5192,107 @@ private NodeExecutionMetaData(
               flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData.class, flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData.Builder.class);
     }
 
+    public static final int RETRY_GROUP_FIELD_NUMBER = 1;
+    private volatile java.lang.Object retryGroup_;
+    /**
+     * 
+     * Node executions are grouped depending on retries of the parent
+     * Retry group is unique within the context of a parent node.
+     * 
+ * + * string retry_group = 1; + */ + public java.lang.String getRetryGroup() { + java.lang.Object ref = retryGroup_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + retryGroup_ = s; + return s; + } + } + /** + *
+     * Node executions are grouped depending on retries of the parent
+     * Retry group is unique within the context of a parent node.
+     * 
+ * + * string retry_group = 1; + */ + public com.google.protobuf.ByteString + getRetryGroupBytes() { + java.lang.Object ref = retryGroup_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + retryGroup_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + + public static final int IS_PARENT_NODE_FIELD_NUMBER = 2; + private boolean isParentNode_; + /** + *
+     * Boolean flag indicating if the node has child nodes under it
+     * 
+ * + * bool is_parent_node = 2; + */ + public boolean getIsParentNode() { + return isParentNode_; + } + + public static final int SPEC_NODE_ID_FIELD_NUMBER = 3; + private volatile java.lang.Object specNodeId_; + /** + *
+     * Node id of the node in the original workflow
+     * This maps to value of WorkflowTemplate.nodes[X].id
+     * 
+ * + * string spec_node_id = 3; + */ + public java.lang.String getSpecNodeId() { + java.lang.Object ref = specNodeId_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + specNodeId_ = s; + return s; + } + } + /** + *
+     * Node id of the node in the original workflow
+     * This maps to value of WorkflowTemplate.nodes[X].id
+     * 
+ * + * string spec_node_id = 3; + */ + public com.google.protobuf.ByteString + getSpecNodeIdBytes() { + java.lang.Object ref = specNodeId_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + specNodeId_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { @@ -4955,6 +5307,15 @@ public final boolean isInitialized() { @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { + if (!getRetryGroupBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 1, retryGroup_); + } + if (isParentNode_ != false) { + output.writeBool(2, isParentNode_); + } + if (!getSpecNodeIdBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 3, specNodeId_); + } unknownFields.writeTo(output); } @@ -4964,6 +5325,16 @@ public int getSerializedSize() { if (size != -1) return size; size = 0; + if (!getRetryGroupBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, retryGroup_); + } + if (isParentNode_ != false) { + size += com.google.protobuf.CodedOutputStream + .computeBoolSize(2, isParentNode_); + } + if (!getSpecNodeIdBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(3, specNodeId_); + } size += unknownFields.getSerializedSize(); memoizedSize = size; return size; @@ -4979,6 +5350,12 @@ public boolean equals(final java.lang.Object obj) { } flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData other = (flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData) obj; + if (!getRetryGroup() + .equals(other.getRetryGroup())) return false; + if (getIsParentNode() + != other.getIsParentNode()) return false; + if (!getSpecNodeId() + .equals(other.getSpecNodeId())) return false; if (!unknownFields.equals(other.unknownFields)) return false; return true; } @@ -4990,6 +5367,13 @@ public int hashCode() { } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); + hash = (37 * hash) + RETRY_GROUP_FIELD_NUMBER; + hash = (53 * hash) + getRetryGroup().hashCode(); + hash = (37 * hash) + IS_PARENT_NODE_FIELD_NUMBER; + hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean( + getIsParentNode()); + hash = (37 * hash) + SPEC_NODE_ID_FIELD_NUMBER; + hash = (53 * hash) + getSpecNodeId().hashCode(); hash = (29 * hash) + unknownFields.hashCode(); memoizedHashCode = hash; return hash; @@ -5127,6 +5511,12 @@ private void maybeForceBuilderInitialization() { @java.lang.Override public Builder clear() { super.clear(); + retryGroup_ = ""; + + isParentNode_ = false; + + specNodeId_ = ""; + return this; } @@ -5153,6 +5543,9 @@ public flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData build() { @java.lang.Override public flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData buildPartial() { flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData result = new flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData(this); + result.retryGroup_ = retryGroup_; + result.isParentNode_ = isParentNode_; + result.specNodeId_ = specNodeId_; onBuilt(); return result; } @@ -5201,6 +5594,17 @@ public Builder mergeFrom(com.google.protobuf.Message other) { public Builder mergeFrom(flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData other) { if (other == flyteidl.admin.NodeExecutionOuterClass.NodeExecutionMetaData.getDefaultInstance()) return this; + if (!other.getRetryGroup().isEmpty()) { + retryGroup_ = other.retryGroup_; + onChanged(); + } + if (other.getIsParentNode() != false) { + setIsParentNode(other.getIsParentNode()); + } + if (!other.getSpecNodeId().isEmpty()) { + specNodeId_ = other.specNodeId_; + onChanged(); + } this.mergeUnknownFields(other.unknownFields); onChanged(); return this; @@ -5229,6 +5633,232 @@ public Builder mergeFrom( } return this; } + + private java.lang.Object retryGroup_ = ""; + /** + *
+       * Node executions are grouped depending on retries of the parent
+       * Retry group is unique within the context of a parent node.
+       * 
+ * + * string retry_group = 1; + */ + public java.lang.String getRetryGroup() { + java.lang.Object ref = retryGroup_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + retryGroup_ = s; + return s; + } else { + return (java.lang.String) ref; + } + } + /** + *
+       * Node executions are grouped depending on retries of the parent
+       * Retry group is unique within the context of a parent node.
+       * 
+ * + * string retry_group = 1; + */ + public com.google.protobuf.ByteString + getRetryGroupBytes() { + java.lang.Object ref = retryGroup_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + retryGroup_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + /** + *
+       * Node executions are grouped depending on retries of the parent
+       * Retry group is unique within the context of a parent node.
+       * 
+ * + * string retry_group = 1; + */ + public Builder setRetryGroup( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + retryGroup_ = value; + onChanged(); + return this; + } + /** + *
+       * Node executions are grouped depending on retries of the parent
+       * Retry group is unique within the context of a parent node.
+       * 
+ * + * string retry_group = 1; + */ + public Builder clearRetryGroup() { + + retryGroup_ = getDefaultInstance().getRetryGroup(); + onChanged(); + return this; + } + /** + *
+       * Node executions are grouped depending on retries of the parent
+       * Retry group is unique within the context of a parent node.
+       * 
+ * + * string retry_group = 1; + */ + public Builder setRetryGroupBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + + retryGroup_ = value; + onChanged(); + return this; + } + + private boolean isParentNode_ ; + /** + *
+       * Boolean flag indicating if the node has child nodes under it
+       * 
+ * + * bool is_parent_node = 2; + */ + public boolean getIsParentNode() { + return isParentNode_; + } + /** + *
+       * Boolean flag indicating if the node has child nodes under it
+       * 
+ * + * bool is_parent_node = 2; + */ + public Builder setIsParentNode(boolean value) { + + isParentNode_ = value; + onChanged(); + return this; + } + /** + *
+       * Boolean flag indicating if the node has child nodes under it
+       * 
+ * + * bool is_parent_node = 2; + */ + public Builder clearIsParentNode() { + + isParentNode_ = false; + onChanged(); + return this; + } + + private java.lang.Object specNodeId_ = ""; + /** + *
+       * Node id of the node in the original workflow
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 3; + */ + public java.lang.String getSpecNodeId() { + java.lang.Object ref = specNodeId_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + specNodeId_ = s; + return s; + } else { + return (java.lang.String) ref; + } + } + /** + *
+       * Node id of the node in the original workflow
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 3; + */ + public com.google.protobuf.ByteString + getSpecNodeIdBytes() { + java.lang.Object ref = specNodeId_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + specNodeId_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + /** + *
+       * Node id of the node in the original workflow
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 3; + */ + public Builder setSpecNodeId( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + specNodeId_ = value; + onChanged(); + return this; + } + /** + *
+       * Node id of the node in the original workflow
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 3; + */ + public Builder clearSpecNodeId() { + + specNodeId_ = getDefaultInstance().getSpecNodeId(); + onChanged(); + return this; + } + /** + *
+       * Node id of the node in the original workflow
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 3; + */ + public Builder setSpecNodeIdBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + + specNodeId_ = value; + onChanged(); + return this; + } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { @@ -10898,44 +11528,46 @@ public flyteidl.admin.NodeExecutionOuterClass.NodeExecutionGetDataResponse getDe "uf/timestamp.proto\032\036google/protobuf/dura" + "tion.proto\"M\n\027NodeExecutionGetRequest\0222\n" + "\002id\030\001 \001(\0132&.flyteidl.core.NodeExecutionI" + - "dentifier\"\273\001\n\030NodeExecutionListRequest\022I" + + "dentifier\"\325\001\n\030NodeExecutionListRequest\022I" + "\n\025workflow_execution_id\030\001 \001(\0132*.flyteidl" + ".core.WorkflowExecutionIdentifier\022\r\n\005lim" + "it\030\002 \001(\r\022\r\n\005token\030\003 \001(\t\022\017\n\007filters\030\004 \001(\t" + - "\022%\n\007sort_by\030\005 \001(\0132\024.flyteidl.admin.Sort\"" + - "\272\001\n\037NodeExecutionForTaskListRequest\022A\n\021t" + - "ask_execution_id\030\001 \001(\0132&.flyteidl.core.T" + - "askExecutionIdentifier\022\r\n\005limit\030\002 \001(\r\022\r\n" + - "\005token\030\003 \001(\t\022\017\n\007filters\030\004 \001(\t\022%\n\007sort_by" + - "\030\005 \001(\0132\024.flyteidl.admin.Sort\"\306\001\n\rNodeExe" + - "cution\0222\n\002id\030\001 \001(\0132&.flyteidl.core.NodeE" + - "xecutionIdentifier\022\021\n\tinput_uri\030\002 \001(\t\0225\n" + - "\007closure\030\003 \001(\0132$.flyteidl.admin.NodeExec" + - "utionClosure\0227\n\010metadata\030\004 \001(\0132%.flyteid" + - "l.admin.NodeExecutionMetaData\"\027\n\025NodeExe" + - "cutionMetaData\"Z\n\021NodeExecutionList\0226\n\017n" + - "ode_executions\030\001 \003(\0132\035.flyteidl.admin.No" + - "deExecution\022\r\n\005token\030\002 \001(\t\"\270\003\n\024NodeExecu" + - "tionClosure\022\024\n\noutput_uri\030\001 \001(\tH\000\022.\n\005err" + - "or\030\002 \001(\0132\035.flyteidl.core.ExecutionErrorH" + - "\000\0221\n\005phase\030\003 \001(\0162\".flyteidl.core.NodeExe" + - "cution.Phase\022.\n\nstarted_at\030\004 \001(\0132\032.googl" + - "e.protobuf.Timestamp\022+\n\010duration\030\005 \001(\0132\031" + - ".google.protobuf.Duration\022.\n\ncreated_at\030" + - "\006 \001(\0132\032.google.protobuf.Timestamp\022.\n\nupd" + - "ated_at\030\007 \001(\0132\032.google.protobuf.Timestam" + - "p\022F\n\026workflow_node_metadata\030\010 \001(\0132$.flyt" + - "eidl.admin.WorkflowNodeMetadataH\001B\017\n\rout" + - "put_resultB\021\n\017target_metadata\"W\n\024Workflo" + - "wNodeMetadata\022?\n\013executionId\030\001 \001(\0132*.fly" + - "teidl.core.WorkflowExecutionIdentifier\"Q" + - "\n\033NodeExecutionGetDataRequest\0222\n\002id\030\001 \001(" + - "\0132&.flyteidl.core.NodeExecutionIdentifie" + - "r\"q\n\034NodeExecutionGetDataResponse\022\'\n\006inp" + - "uts\030\001 \001(\0132\027.flyteidl.admin.UrlBlob\022(\n\007ou" + - "tputs\030\002 \001(\0132\027.flyteidl.admin.UrlBlobB3Z1" + - "github.com/lyft/flyteidl/gen/pb-go/flyte" + - "idl/adminb\006proto3" + "\022%\n\007sort_by\030\005 \001(\0132\024.flyteidl.admin.Sort\022" + + "\030\n\020unique_parent_id\030\006 \001(\t\"\272\001\n\037NodeExecut" + + "ionForTaskListRequest\022A\n\021task_execution_" + + "id\030\001 \001(\0132&.flyteidl.core.TaskExecutionId" + + "entifier\022\r\n\005limit\030\002 \001(\r\022\r\n\005token\030\003 \001(\t\022\017" + + "\n\007filters\030\004 \001(\t\022%\n\007sort_by\030\005 \001(\0132\024.flyte" + + "idl.admin.Sort\"\306\001\n\rNodeExecution\0222\n\002id\030\001" + + " \001(\0132&.flyteidl.core.NodeExecutionIdenti" + + "fier\022\021\n\tinput_uri\030\002 \001(\t\0225\n\007closure\030\003 \001(\013" + + "2$.flyteidl.admin.NodeExecutionClosure\0227" + + "\n\010metadata\030\004 \001(\0132%.flyteidl.admin.NodeEx" + + "ecutionMetaData\"Z\n\025NodeExecutionMetaData" + + "\022\023\n\013retry_group\030\001 \001(\t\022\026\n\016is_parent_node\030" + + "\002 \001(\010\022\024\n\014spec_node_id\030\003 \001(\t\"Z\n\021NodeExecu" + + "tionList\0226\n\017node_executions\030\001 \003(\0132\035.flyt" + + "eidl.admin.NodeExecution\022\r\n\005token\030\002 \001(\t\"" + + "\270\003\n\024NodeExecutionClosure\022\024\n\noutput_uri\030\001" + + " \001(\tH\000\022.\n\005error\030\002 \001(\0132\035.flyteidl.core.Ex" + + "ecutionErrorH\000\0221\n\005phase\030\003 \001(\0162\".flyteidl" + + ".core.NodeExecution.Phase\022.\n\nstarted_at\030" + + "\004 \001(\0132\032.google.protobuf.Timestamp\022+\n\010dur" + + "ation\030\005 \001(\0132\031.google.protobuf.Duration\022." + + "\n\ncreated_at\030\006 \001(\0132\032.google.protobuf.Tim" + + "estamp\022.\n\nupdated_at\030\007 \001(\0132\032.google.prot" + + "obuf.Timestamp\022F\n\026workflow_node_metadata" + + "\030\010 \001(\0132$.flyteidl.admin.WorkflowNodeMeta" + + "dataH\001B\017\n\routput_resultB\021\n\017target_metada" + + "ta\"W\n\024WorkflowNodeMetadata\022?\n\013executionI" + + "d\030\001 \001(\0132*.flyteidl.core.WorkflowExecutio" + + "nIdentifier\"Q\n\033NodeExecutionGetDataReque" + + "st\0222\n\002id\030\001 \001(\0132&.flyteidl.core.NodeExecu" + + "tionIdentifier\"q\n\034NodeExecutionGetDataRe" + + "sponse\022\'\n\006inputs\030\001 \001(\0132\027.flyteidl.admin." + + "UrlBlob\022(\n\007outputs\030\002 \001(\0132\027.flyteidl.admi" + + "n.UrlBlobB3Z1github.com/lyft/flyteidl/ge" + + "n/pb-go/flyteidl/adminb\006proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -10965,7 +11597,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_admin_NodeExecutionListRequest_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_NodeExecutionListRequest_descriptor, - new java.lang.String[] { "WorkflowExecutionId", "Limit", "Token", "Filters", "SortBy", }); + new java.lang.String[] { "WorkflowExecutionId", "Limit", "Token", "Filters", "SortBy", "UniqueParentId", }); internal_static_flyteidl_admin_NodeExecutionForTaskListRequest_descriptor = getDescriptor().getMessageTypes().get(2); internal_static_flyteidl_admin_NodeExecutionForTaskListRequest_fieldAccessorTable = new @@ -10983,7 +11615,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_admin_NodeExecutionMetaData_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_NodeExecutionMetaData_descriptor, - new java.lang.String[] { }); + new java.lang.String[] { "RetryGroup", "IsParentNode", "SpecNodeId", }); internal_static_flyteidl_admin_NodeExecutionList_descriptor = getDescriptor().getMessageTypes().get(5); internal_static_flyteidl_admin_NodeExecutionList_fieldAccessorTable = new diff --git a/flyteidl/gen/pb-java/flyteidl/event/Event.java b/flyteidl/gen/pb-java/flyteidl/event/Event.java index 36ca67248f..9be166c1d5 100644 --- a/flyteidl/gen/pb-java/flyteidl/event/Event.java +++ b/flyteidl/gen/pb-java/flyteidl/event/Event.java @@ -1924,7 +1924,7 @@ public interface NodeExecutionEventOrBuilder extends /** *
-     * Specifies which task (if any) launched this node.
+     * [To be deprecated] Specifies which task (if any) launched this node.
      * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -1932,7 +1932,7 @@ public interface NodeExecutionEventOrBuilder extends boolean hasParentTaskMetadata(); /** *
-     * Specifies which task (if any) launched this node.
+     * [To be deprecated] Specifies which task (if any) launched this node.
      * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -1940,13 +1940,94 @@ public interface NodeExecutionEventOrBuilder extends flyteidl.event.Event.ParentTaskExecutionMetadata getParentTaskMetadata(); /** *
-     * Specifies which task (if any) launched this node.
+     * [To be deprecated] Specifies which task (if any) launched this node.
      * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; */ flyteidl.event.Event.ParentTaskExecutionMetadataOrBuilder getParentTaskMetadataOrBuilder(); + /** + *
+     * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+     * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + boolean hasParentNodeMetadata(); + /** + *
+     * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+     * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + flyteidl.event.Event.ParentNodeExecutionMetadata getParentNodeMetadata(); + /** + *
+     * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+     * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + flyteidl.event.Event.ParentNodeExecutionMetadataOrBuilder getParentNodeMetadataOrBuilder(); + + /** + *
+     * Retry group to indicate grouping of nodes by retries
+     * 
+ * + * string retry_group = 11; + */ + java.lang.String getRetryGroup(); + /** + *
+     * Retry group to indicate grouping of nodes by retries
+     * 
+ * + * string retry_group = 11; + */ + com.google.protobuf.ByteString + getRetryGroupBytes(); + + /** + *
+     * Identifier of the node in the original workflow/graph
+     * This maps to value of WorkflowTemplate.nodes[X].id
+     * 
+ * + * string spec_node_id = 12; + */ + java.lang.String getSpecNodeId(); + /** + *
+     * Identifier of the node in the original workflow/graph
+     * This maps to value of WorkflowTemplate.nodes[X].id
+     * 
+ * + * string spec_node_id = 12; + */ + com.google.protobuf.ByteString + getSpecNodeIdBytes(); + + /** + *
+     * Friendly readable name for the node
+     * 
+ * + * string node_name = 13; + */ + java.lang.String getNodeName(); + /** + *
+     * Friendly readable name for the node
+     * 
+ * + * string node_name = 13; + */ + com.google.protobuf.ByteString + getNodeNameBytes(); + public flyteidl.event.Event.NodeExecutionEvent.OutputResultCase getOutputResultCase(); public flyteidl.event.Event.NodeExecutionEvent.TargetMetadataCase getTargetMetadataCase(); @@ -1967,6 +2048,9 @@ private NodeExecutionEvent() { producerId_ = ""; phase_ = 0; inputUri_ = ""; + retryGroup_ = ""; + specNodeId_ = ""; + nodeName_ = ""; } @java.lang.Override @@ -2084,6 +2168,37 @@ private NodeExecutionEvent( break; } + case 82: { + flyteidl.event.Event.ParentNodeExecutionMetadata.Builder subBuilder = null; + if (parentNodeMetadata_ != null) { + subBuilder = parentNodeMetadata_.toBuilder(); + } + parentNodeMetadata_ = input.readMessage(flyteidl.event.Event.ParentNodeExecutionMetadata.parser(), extensionRegistry); + if (subBuilder != null) { + subBuilder.mergeFrom(parentNodeMetadata_); + parentNodeMetadata_ = subBuilder.buildPartial(); + } + + break; + } + case 90: { + java.lang.String s = input.readStringRequireUtf8(); + + retryGroup_ = s; + break; + } + case 98: { + java.lang.String s = input.readStringRequireUtf8(); + + specNodeId_ = s; + break; + } + case 106: { + java.lang.String s = input.readStringRequireUtf8(); + + nodeName_ = s; + break; + } default: { if (!parseUnknownField( input, unknownFields, extensionRegistry, tag)) { @@ -2473,7 +2588,7 @@ public flyteidl.event.Event.WorkflowNodeMetadataOrBuilder getWorkflowNodeMetadat private flyteidl.event.Event.ParentTaskExecutionMetadata parentTaskMetadata_; /** *
-     * Specifies which task (if any) launched this node.
+     * [To be deprecated] Specifies which task (if any) launched this node.
      * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -2483,7 +2598,7 @@ public boolean hasParentTaskMetadata() { } /** *
-     * Specifies which task (if any) launched this node.
+     * [To be deprecated] Specifies which task (if any) launched this node.
      * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -2493,7 +2608,7 @@ public flyteidl.event.Event.ParentTaskExecutionMetadata getParentTaskMetadata() } /** *
-     * Specifies which task (if any) launched this node.
+     * [To be deprecated] Specifies which task (if any) launched this node.
      * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -2502,6 +2617,167 @@ public flyteidl.event.Event.ParentTaskExecutionMetadataOrBuilder getParentTaskMe return getParentTaskMetadata(); } + public static final int PARENT_NODE_METADATA_FIELD_NUMBER = 10; + private flyteidl.event.Event.ParentNodeExecutionMetadata parentNodeMetadata_; + /** + *
+     * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+     * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public boolean hasParentNodeMetadata() { + return parentNodeMetadata_ != null; + } + /** + *
+     * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+     * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public flyteidl.event.Event.ParentNodeExecutionMetadata getParentNodeMetadata() { + return parentNodeMetadata_ == null ? flyteidl.event.Event.ParentNodeExecutionMetadata.getDefaultInstance() : parentNodeMetadata_; + } + /** + *
+     * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+     * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public flyteidl.event.Event.ParentNodeExecutionMetadataOrBuilder getParentNodeMetadataOrBuilder() { + return getParentNodeMetadata(); + } + + public static final int RETRY_GROUP_FIELD_NUMBER = 11; + private volatile java.lang.Object retryGroup_; + /** + *
+     * Retry group to indicate grouping of nodes by retries
+     * 
+ * + * string retry_group = 11; + */ + public java.lang.String getRetryGroup() { + java.lang.Object ref = retryGroup_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + retryGroup_ = s; + return s; + } + } + /** + *
+     * Retry group to indicate grouping of nodes by retries
+     * 
+ * + * string retry_group = 11; + */ + public com.google.protobuf.ByteString + getRetryGroupBytes() { + java.lang.Object ref = retryGroup_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + retryGroup_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + + public static final int SPEC_NODE_ID_FIELD_NUMBER = 12; + private volatile java.lang.Object specNodeId_; + /** + *
+     * Identifier of the node in the original workflow/graph
+     * This maps to value of WorkflowTemplate.nodes[X].id
+     * 
+ * + * string spec_node_id = 12; + */ + public java.lang.String getSpecNodeId() { + java.lang.Object ref = specNodeId_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + specNodeId_ = s; + return s; + } + } + /** + *
+     * Identifier of the node in the original workflow/graph
+     * This maps to value of WorkflowTemplate.nodes[X].id
+     * 
+ * + * string spec_node_id = 12; + */ + public com.google.protobuf.ByteString + getSpecNodeIdBytes() { + java.lang.Object ref = specNodeId_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + specNodeId_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + + public static final int NODE_NAME_FIELD_NUMBER = 13; + private volatile java.lang.Object nodeName_; + /** + *
+     * Friendly readable name for the node
+     * 
+ * + * string node_name = 13; + */ + public java.lang.String getNodeName() { + java.lang.Object ref = nodeName_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + nodeName_ = s; + return s; + } + } + /** + *
+     * Friendly readable name for the node
+     * 
+ * + * string node_name = 13; + */ + public com.google.protobuf.ByteString + getNodeNameBytes() { + java.lang.Object ref = nodeName_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + nodeName_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { @@ -2543,6 +2819,18 @@ public void writeTo(com.google.protobuf.CodedOutputStream output) if (parentTaskMetadata_ != null) { output.writeMessage(9, getParentTaskMetadata()); } + if (parentNodeMetadata_ != null) { + output.writeMessage(10, getParentNodeMetadata()); + } + if (!getRetryGroupBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 11, retryGroup_); + } + if (!getSpecNodeIdBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 12, specNodeId_); + } + if (!getNodeNameBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 13, nodeName_); + } unknownFields.writeTo(output); } @@ -2585,6 +2873,19 @@ public int getSerializedSize() { size += com.google.protobuf.CodedOutputStream .computeMessageSize(9, getParentTaskMetadata()); } + if (parentNodeMetadata_ != null) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(10, getParentNodeMetadata()); + } + if (!getRetryGroupBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(11, retryGroup_); + } + if (!getSpecNodeIdBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(12, specNodeId_); + } + if (!getNodeNameBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(13, nodeName_); + } size += unknownFields.getSerializedSize(); memoizedSize = size; return size; @@ -2620,6 +2921,17 @@ public boolean equals(final java.lang.Object obj) { if (!getParentTaskMetadata() .equals(other.getParentTaskMetadata())) return false; } + if (hasParentNodeMetadata() != other.hasParentNodeMetadata()) return false; + if (hasParentNodeMetadata()) { + if (!getParentNodeMetadata() + .equals(other.getParentNodeMetadata())) return false; + } + if (!getRetryGroup() + .equals(other.getRetryGroup())) return false; + if (!getSpecNodeId() + .equals(other.getSpecNodeId())) return false; + if (!getNodeName() + .equals(other.getNodeName())) return false; if (!getOutputResultCase().equals(other.getOutputResultCase())) return false; switch (outputResultCase_) { case 6: @@ -2671,6 +2983,16 @@ public int hashCode() { hash = (37 * hash) + PARENT_TASK_METADATA_FIELD_NUMBER; hash = (53 * hash) + getParentTaskMetadata().hashCode(); } + if (hasParentNodeMetadata()) { + hash = (37 * hash) + PARENT_NODE_METADATA_FIELD_NUMBER; + hash = (53 * hash) + getParentNodeMetadata().hashCode(); + } + hash = (37 * hash) + RETRY_GROUP_FIELD_NUMBER; + hash = (53 * hash) + getRetryGroup().hashCode(); + hash = (37 * hash) + SPEC_NODE_ID_FIELD_NUMBER; + hash = (53 * hash) + getSpecNodeId().hashCode(); + hash = (37 * hash) + NODE_NAME_FIELD_NUMBER; + hash = (53 * hash) + getNodeName().hashCode(); switch (outputResultCase_) { case 6: hash = (37 * hash) + OUTPUT_URI_FIELD_NUMBER; @@ -2848,6 +3170,18 @@ public Builder clear() { parentTaskMetadata_ = null; parentTaskMetadataBuilder_ = null; } + if (parentNodeMetadataBuilder_ == null) { + parentNodeMetadata_ = null; + } else { + parentNodeMetadata_ = null; + parentNodeMetadataBuilder_ = null; + } + retryGroup_ = ""; + + specNodeId_ = ""; + + nodeName_ = ""; + outputResultCase_ = 0; outputResult_ = null; targetMetadataCase_ = 0; @@ -2913,6 +3247,14 @@ public flyteidl.event.Event.NodeExecutionEvent buildPartial() { } else { result.parentTaskMetadata_ = parentTaskMetadataBuilder_.build(); } + if (parentNodeMetadataBuilder_ == null) { + result.parentNodeMetadata_ = parentNodeMetadata_; + } else { + result.parentNodeMetadata_ = parentNodeMetadataBuilder_.build(); + } + result.retryGroup_ = retryGroup_; + result.specNodeId_ = specNodeId_; + result.nodeName_ = nodeName_; result.outputResultCase_ = outputResultCase_; result.targetMetadataCase_ = targetMetadataCase_; onBuilt(); @@ -2983,6 +3325,21 @@ public Builder mergeFrom(flyteidl.event.Event.NodeExecutionEvent other) { if (other.hasParentTaskMetadata()) { mergeParentTaskMetadata(other.getParentTaskMetadata()); } + if (other.hasParentNodeMetadata()) { + mergeParentNodeMetadata(other.getParentNodeMetadata()); + } + if (!other.getRetryGroup().isEmpty()) { + retryGroup_ = other.retryGroup_; + onChanged(); + } + if (!other.getSpecNodeId().isEmpty()) { + specNodeId_ = other.specNodeId_; + onChanged(); + } + if (!other.getNodeName().isEmpty()) { + nodeName_ = other.nodeName_; + onChanged(); + } switch (other.getOutputResultCase()) { case OUTPUT_URI: { outputResultCase_ = 6; @@ -4002,7 +4359,7 @@ public flyteidl.event.Event.WorkflowNodeMetadataOrBuilder getWorkflowNodeMetadat flyteidl.event.Event.ParentTaskExecutionMetadata, flyteidl.event.Event.ParentTaskExecutionMetadata.Builder, flyteidl.event.Event.ParentTaskExecutionMetadataOrBuilder> parentTaskMetadataBuilder_; /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4012,7 +4369,7 @@ public boolean hasParentTaskMetadata() { } /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4026,7 +4383,7 @@ public flyteidl.event.Event.ParentTaskExecutionMetadata getParentTaskMetadata() } /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4046,7 +4403,7 @@ public Builder setParentTaskMetadata(flyteidl.event.Event.ParentTaskExecutionMet } /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4064,7 +4421,7 @@ public Builder setParentTaskMetadata( } /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4086,7 +4443,7 @@ public Builder mergeParentTaskMetadata(flyteidl.event.Event.ParentTaskExecutionM } /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4104,7 +4461,7 @@ public Builder clearParentTaskMetadata() { } /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4116,7 +4473,7 @@ public flyteidl.event.Event.ParentTaskExecutionMetadata.Builder getParentTaskMet } /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4131,7 +4488,7 @@ public flyteidl.event.Event.ParentTaskExecutionMetadataOrBuilder getParentTaskMe } /** *
-       * Specifies which task (if any) launched this node.
+       * [To be deprecated] Specifies which task (if any) launched this node.
        * 
* * .flyteidl.event.ParentTaskExecutionMetadata parent_task_metadata = 9; @@ -4149,93 +4506,1128 @@ public flyteidl.event.Event.ParentTaskExecutionMetadataOrBuilder getParentTaskMe } return parentTaskMetadataBuilder_; } - @java.lang.Override - public final Builder setUnknownFields( - final com.google.protobuf.UnknownFieldSet unknownFields) { - return super.setUnknownFields(unknownFields); - } - @java.lang.Override - public final Builder mergeUnknownFields( - final com.google.protobuf.UnknownFieldSet unknownFields) { - return super.mergeUnknownFields(unknownFields); + private flyteidl.event.Event.ParentNodeExecutionMetadata parentNodeMetadata_; + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.event.Event.ParentNodeExecutionMetadata, flyteidl.event.Event.ParentNodeExecutionMetadata.Builder, flyteidl.event.Event.ParentNodeExecutionMetadataOrBuilder> parentNodeMetadataBuilder_; + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public boolean hasParentNodeMetadata() { + return parentNodeMetadataBuilder_ != null || parentNodeMetadata_ != null; } + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public flyteidl.event.Event.ParentNodeExecutionMetadata getParentNodeMetadata() { + if (parentNodeMetadataBuilder_ == null) { + return parentNodeMetadata_ == null ? flyteidl.event.Event.ParentNodeExecutionMetadata.getDefaultInstance() : parentNodeMetadata_; + } else { + return parentNodeMetadataBuilder_.getMessage(); + } + } + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public Builder setParentNodeMetadata(flyteidl.event.Event.ParentNodeExecutionMetadata value) { + if (parentNodeMetadataBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + parentNodeMetadata_ = value; + onChanged(); + } else { + parentNodeMetadataBuilder_.setMessage(value); + } + return this; + } + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public Builder setParentNodeMetadata( + flyteidl.event.Event.ParentNodeExecutionMetadata.Builder builderForValue) { + if (parentNodeMetadataBuilder_ == null) { + parentNodeMetadata_ = builderForValue.build(); + onChanged(); + } else { + parentNodeMetadataBuilder_.setMessage(builderForValue.build()); + } - // @@protoc_insertion_point(builder_scope:flyteidl.event.NodeExecutionEvent) - } - - // @@protoc_insertion_point(class_scope:flyteidl.event.NodeExecutionEvent) - private static final flyteidl.event.Event.NodeExecutionEvent DEFAULT_INSTANCE; - static { - DEFAULT_INSTANCE = new flyteidl.event.Event.NodeExecutionEvent(); + return this; + } + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public Builder mergeParentNodeMetadata(flyteidl.event.Event.ParentNodeExecutionMetadata value) { + if (parentNodeMetadataBuilder_ == null) { + if (parentNodeMetadata_ != null) { + parentNodeMetadata_ = + flyteidl.event.Event.ParentNodeExecutionMetadata.newBuilder(parentNodeMetadata_).mergeFrom(value).buildPartial(); + } else { + parentNodeMetadata_ = value; + } + onChanged(); + } else { + parentNodeMetadataBuilder_.mergeFrom(value); + } + + return this; + } + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public Builder clearParentNodeMetadata() { + if (parentNodeMetadataBuilder_ == null) { + parentNodeMetadata_ = null; + onChanged(); + } else { + parentNodeMetadata_ = null; + parentNodeMetadataBuilder_ = null; + } + + return this; + } + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public flyteidl.event.Event.ParentNodeExecutionMetadata.Builder getParentNodeMetadataBuilder() { + + onChanged(); + return getParentNodeMetadataFieldBuilder().getBuilder(); + } + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + public flyteidl.event.Event.ParentNodeExecutionMetadataOrBuilder getParentNodeMetadataOrBuilder() { + if (parentNodeMetadataBuilder_ != null) { + return parentNodeMetadataBuilder_.getMessageOrBuilder(); + } else { + return parentNodeMetadata_ == null ? + flyteidl.event.Event.ParentNodeExecutionMetadata.getDefaultInstance() : parentNodeMetadata_; + } + } + /** + *
+       * Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node.
+       * 
+ * + * .flyteidl.event.ParentNodeExecutionMetadata parent_node_metadata = 10; + */ + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.event.Event.ParentNodeExecutionMetadata, flyteidl.event.Event.ParentNodeExecutionMetadata.Builder, flyteidl.event.Event.ParentNodeExecutionMetadataOrBuilder> + getParentNodeMetadataFieldBuilder() { + if (parentNodeMetadataBuilder_ == null) { + parentNodeMetadataBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.event.Event.ParentNodeExecutionMetadata, flyteidl.event.Event.ParentNodeExecutionMetadata.Builder, flyteidl.event.Event.ParentNodeExecutionMetadataOrBuilder>( + getParentNodeMetadata(), + getParentForChildren(), + isClean()); + parentNodeMetadata_ = null; + } + return parentNodeMetadataBuilder_; + } + + private java.lang.Object retryGroup_ = ""; + /** + *
+       * Retry group to indicate grouping of nodes by retries
+       * 
+ * + * string retry_group = 11; + */ + public java.lang.String getRetryGroup() { + java.lang.Object ref = retryGroup_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + retryGroup_ = s; + return s; + } else { + return (java.lang.String) ref; + } + } + /** + *
+       * Retry group to indicate grouping of nodes by retries
+       * 
+ * + * string retry_group = 11; + */ + public com.google.protobuf.ByteString + getRetryGroupBytes() { + java.lang.Object ref = retryGroup_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + retryGroup_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + /** + *
+       * Retry group to indicate grouping of nodes by retries
+       * 
+ * + * string retry_group = 11; + */ + public Builder setRetryGroup( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + retryGroup_ = value; + onChanged(); + return this; + } + /** + *
+       * Retry group to indicate grouping of nodes by retries
+       * 
+ * + * string retry_group = 11; + */ + public Builder clearRetryGroup() { + + retryGroup_ = getDefaultInstance().getRetryGroup(); + onChanged(); + return this; + } + /** + *
+       * Retry group to indicate grouping of nodes by retries
+       * 
+ * + * string retry_group = 11; + */ + public Builder setRetryGroupBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + + retryGroup_ = value; + onChanged(); + return this; + } + + private java.lang.Object specNodeId_ = ""; + /** + *
+       * Identifier of the node in the original workflow/graph
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 12; + */ + public java.lang.String getSpecNodeId() { + java.lang.Object ref = specNodeId_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + specNodeId_ = s; + return s; + } else { + return (java.lang.String) ref; + } + } + /** + *
+       * Identifier of the node in the original workflow/graph
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 12; + */ + public com.google.protobuf.ByteString + getSpecNodeIdBytes() { + java.lang.Object ref = specNodeId_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + specNodeId_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + /** + *
+       * Identifier of the node in the original workflow/graph
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 12; + */ + public Builder setSpecNodeId( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + specNodeId_ = value; + onChanged(); + return this; + } + /** + *
+       * Identifier of the node in the original workflow/graph
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 12; + */ + public Builder clearSpecNodeId() { + + specNodeId_ = getDefaultInstance().getSpecNodeId(); + onChanged(); + return this; + } + /** + *
+       * Identifier of the node in the original workflow/graph
+       * This maps to value of WorkflowTemplate.nodes[X].id
+       * 
+ * + * string spec_node_id = 12; + */ + public Builder setSpecNodeIdBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + + specNodeId_ = value; + onChanged(); + return this; + } + + private java.lang.Object nodeName_ = ""; + /** + *
+       * Friendly readable name for the node
+       * 
+ * + * string node_name = 13; + */ + public java.lang.String getNodeName() { + java.lang.Object ref = nodeName_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + nodeName_ = s; + return s; + } else { + return (java.lang.String) ref; + } + } + /** + *
+       * Friendly readable name for the node
+       * 
+ * + * string node_name = 13; + */ + public com.google.protobuf.ByteString + getNodeNameBytes() { + java.lang.Object ref = nodeName_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + nodeName_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + /** + *
+       * Friendly readable name for the node
+       * 
+ * + * string node_name = 13; + */ + public Builder setNodeName( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + nodeName_ = value; + onChanged(); + return this; + } + /** + *
+       * Friendly readable name for the node
+       * 
+ * + * string node_name = 13; + */ + public Builder clearNodeName() { + + nodeName_ = getDefaultInstance().getNodeName(); + onChanged(); + return this; + } + /** + *
+       * Friendly readable name for the node
+       * 
+ * + * string node_name = 13; + */ + public Builder setNodeNameBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + + nodeName_ = value; + onChanged(); + return this; + } + @java.lang.Override + public final Builder setUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.setUnknownFields(unknownFields); + } + + @java.lang.Override + public final Builder mergeUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.mergeUnknownFields(unknownFields); + } + + + // @@protoc_insertion_point(builder_scope:flyteidl.event.NodeExecutionEvent) + } + + // @@protoc_insertion_point(class_scope:flyteidl.event.NodeExecutionEvent) + private static final flyteidl.event.Event.NodeExecutionEvent DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.event.Event.NodeExecutionEvent(); + } + + public static flyteidl.event.Event.NodeExecutionEvent getDefaultInstance() { + return DEFAULT_INSTANCE; + } + + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { + @java.lang.Override + public NodeExecutionEvent parsePartialFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return new NodeExecutionEvent(input, extensionRegistry); + } + }; + + public static com.google.protobuf.Parser parser() { + return PARSER; + } + + @java.lang.Override + public com.google.protobuf.Parser getParserForType() { + return PARSER; + } + + @java.lang.Override + public flyteidl.event.Event.NodeExecutionEvent getDefaultInstanceForType() { + return DEFAULT_INSTANCE; + } + + } + + public interface WorkflowNodeMetadataOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.event.WorkflowNodeMetadata) + com.google.protobuf.MessageOrBuilder { + + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + boolean hasExecutionId(); + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier getExecutionId(); + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder getExecutionIdOrBuilder(); + } + /** + *
+   * For Workflow Nodes we need to send information about the workflow that's launched
+   * 
+ * + * Protobuf type {@code flyteidl.event.WorkflowNodeMetadata} + */ + public static final class WorkflowNodeMetadata extends + com.google.protobuf.GeneratedMessageV3 implements + // @@protoc_insertion_point(message_implements:flyteidl.event.WorkflowNodeMetadata) + WorkflowNodeMetadataOrBuilder { + private static final long serialVersionUID = 0L; + // Use WorkflowNodeMetadata.newBuilder() to construct. + private WorkflowNodeMetadata(com.google.protobuf.GeneratedMessageV3.Builder builder) { + super(builder); + } + private WorkflowNodeMetadata() { + } + + @java.lang.Override + public final com.google.protobuf.UnknownFieldSet + getUnknownFields() { + return this.unknownFields; + } + private WorkflowNodeMetadata( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + this(); + if (extensionRegistry == null) { + throw new java.lang.NullPointerException(); + } + int mutable_bitField0_ = 0; + com.google.protobuf.UnknownFieldSet.Builder unknownFields = + com.google.protobuf.UnknownFieldSet.newBuilder(); + try { + boolean done = false; + while (!done) { + int tag = input.readTag(); + switch (tag) { + case 0: + done = true; + break; + case 10: { + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder subBuilder = null; + if (executionId_ != null) { + subBuilder = executionId_.toBuilder(); + } + executionId_ = input.readMessage(flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.parser(), extensionRegistry); + if (subBuilder != null) { + subBuilder.mergeFrom(executionId_); + executionId_ = subBuilder.buildPartial(); + } + + break; + } + default: { + if (!parseUnknownField( + input, unknownFields, extensionRegistry, tag)) { + done = true; + } + break; + } + } + } + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + throw e.setUnfinishedMessage(this); + } catch (java.io.IOException e) { + throw new com.google.protobuf.InvalidProtocolBufferException( + e).setUnfinishedMessage(this); + } finally { + this.unknownFields = unknownFields.build(); + makeExtensionsImmutable(); + } + } + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.event.Event.WorkflowNodeMetadata.class, flyteidl.event.Event.WorkflowNodeMetadata.Builder.class); + } + + public static final int EXECUTION_ID_FIELD_NUMBER = 1; + private flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier executionId_; + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public boolean hasExecutionId() { + return executionId_ != null; + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier getExecutionId() { + return executionId_ == null ? flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.getDefaultInstance() : executionId_; + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder getExecutionIdOrBuilder() { + return getExecutionId(); + } + + private byte memoizedIsInitialized = -1; + @java.lang.Override + public final boolean isInitialized() { + byte isInitialized = memoizedIsInitialized; + if (isInitialized == 1) return true; + if (isInitialized == 0) return false; + + memoizedIsInitialized = 1; + return true; + } + + @java.lang.Override + public void writeTo(com.google.protobuf.CodedOutputStream output) + throws java.io.IOException { + if (executionId_ != null) { + output.writeMessage(1, getExecutionId()); + } + unknownFields.writeTo(output); + } + + @java.lang.Override + public int getSerializedSize() { + int size = memoizedSize; + if (size != -1) return size; + + size = 0; + if (executionId_ != null) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(1, getExecutionId()); + } + size += unknownFields.getSerializedSize(); + memoizedSize = size; + return size; + } + + @java.lang.Override + public boolean equals(final java.lang.Object obj) { + if (obj == this) { + return true; + } + if (!(obj instanceof flyteidl.event.Event.WorkflowNodeMetadata)) { + return super.equals(obj); + } + flyteidl.event.Event.WorkflowNodeMetadata other = (flyteidl.event.Event.WorkflowNodeMetadata) obj; + + if (hasExecutionId() != other.hasExecutionId()) return false; + if (hasExecutionId()) { + if (!getExecutionId() + .equals(other.getExecutionId())) return false; + } + if (!unknownFields.equals(other.unknownFields)) return false; + return true; + } + + @java.lang.Override + public int hashCode() { + if (memoizedHashCode != 0) { + return memoizedHashCode; + } + int hash = 41; + hash = (19 * hash) + getDescriptor().hashCode(); + if (hasExecutionId()) { + hash = (37 * hash) + EXECUTION_ID_FIELD_NUMBER; + hash = (53 * hash) + getExecutionId().hashCode(); + } + hash = (29 * hash) + unknownFields.hashCode(); + memoizedHashCode = hash; + return hash; + } + + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + java.nio.ByteBuffer data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + java.nio.ByteBuffer data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + com.google.protobuf.ByteString data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + com.google.protobuf.ByteString data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom(byte[] data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + byte[] data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + java.io.InputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input, extensionRegistry); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseDelimitedFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseDelimitedFrom( + java.io.InputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input, extensionRegistry); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + com.google.protobuf.CodedInputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input, extensionRegistry); + } + + @java.lang.Override + public Builder newBuilderForType() { return newBuilder(); } + public static Builder newBuilder() { + return DEFAULT_INSTANCE.toBuilder(); + } + public static Builder newBuilder(flyteidl.event.Event.WorkflowNodeMetadata prototype) { + return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); + } + @java.lang.Override + public Builder toBuilder() { + return this == DEFAULT_INSTANCE + ? new Builder() : new Builder().mergeFrom(this); + } + + @java.lang.Override + protected Builder newBuilderForType( + com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { + Builder builder = new Builder(parent); + return builder; + } + /** + *
+     * For Workflow Nodes we need to send information about the workflow that's launched
+     * 
+ * + * Protobuf type {@code flyteidl.event.WorkflowNodeMetadata} + */ + public static final class Builder extends + com.google.protobuf.GeneratedMessageV3.Builder implements + // @@protoc_insertion_point(builder_implements:flyteidl.event.WorkflowNodeMetadata) + flyteidl.event.Event.WorkflowNodeMetadataOrBuilder { + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.event.Event.WorkflowNodeMetadata.class, flyteidl.event.Event.WorkflowNodeMetadata.Builder.class); + } + + // Construct using flyteidl.event.Event.WorkflowNodeMetadata.newBuilder() + private Builder() { + maybeForceBuilderInitialization(); + } + + private Builder( + com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { + super(parent); + maybeForceBuilderInitialization(); + } + private void maybeForceBuilderInitialization() { + if (com.google.protobuf.GeneratedMessageV3 + .alwaysUseFieldBuilders) { + } + } + @java.lang.Override + public Builder clear() { + super.clear(); + if (executionIdBuilder_ == null) { + executionId_ = null; + } else { + executionId_ = null; + executionIdBuilder_ = null; + } + return this; + } + + @java.lang.Override + public com.google.protobuf.Descriptors.Descriptor + getDescriptorForType() { + return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_descriptor; + } + + @java.lang.Override + public flyteidl.event.Event.WorkflowNodeMetadata getDefaultInstanceForType() { + return flyteidl.event.Event.WorkflowNodeMetadata.getDefaultInstance(); + } + + @java.lang.Override + public flyteidl.event.Event.WorkflowNodeMetadata build() { + flyteidl.event.Event.WorkflowNodeMetadata result = buildPartial(); + if (!result.isInitialized()) { + throw newUninitializedMessageException(result); + } + return result; + } + + @java.lang.Override + public flyteidl.event.Event.WorkflowNodeMetadata buildPartial() { + flyteidl.event.Event.WorkflowNodeMetadata result = new flyteidl.event.Event.WorkflowNodeMetadata(this); + if (executionIdBuilder_ == null) { + result.executionId_ = executionId_; + } else { + result.executionId_ = executionIdBuilder_.build(); + } + onBuilt(); + return result; + } + + @java.lang.Override + public Builder clone() { + return super.clone(); + } + @java.lang.Override + public Builder setField( + com.google.protobuf.Descriptors.FieldDescriptor field, + java.lang.Object value) { + return super.setField(field, value); + } + @java.lang.Override + public Builder clearField( + com.google.protobuf.Descriptors.FieldDescriptor field) { + return super.clearField(field); + } + @java.lang.Override + public Builder clearOneof( + com.google.protobuf.Descriptors.OneofDescriptor oneof) { + return super.clearOneof(oneof); + } + @java.lang.Override + public Builder setRepeatedField( + com.google.protobuf.Descriptors.FieldDescriptor field, + int index, java.lang.Object value) { + return super.setRepeatedField(field, index, value); + } + @java.lang.Override + public Builder addRepeatedField( + com.google.protobuf.Descriptors.FieldDescriptor field, + java.lang.Object value) { + return super.addRepeatedField(field, value); + } + @java.lang.Override + public Builder mergeFrom(com.google.protobuf.Message other) { + if (other instanceof flyteidl.event.Event.WorkflowNodeMetadata) { + return mergeFrom((flyteidl.event.Event.WorkflowNodeMetadata)other); + } else { + super.mergeFrom(other); + return this; + } + } + + public Builder mergeFrom(flyteidl.event.Event.WorkflowNodeMetadata other) { + if (other == flyteidl.event.Event.WorkflowNodeMetadata.getDefaultInstance()) return this; + if (other.hasExecutionId()) { + mergeExecutionId(other.getExecutionId()); + } + this.mergeUnknownFields(other.unknownFields); + onChanged(); + return this; + } + + @java.lang.Override + public final boolean isInitialized() { + return true; + } + + @java.lang.Override + public Builder mergeFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws java.io.IOException { + flyteidl.event.Event.WorkflowNodeMetadata parsedMessage = null; + try { + parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + parsedMessage = (flyteidl.event.Event.WorkflowNodeMetadata) e.getUnfinishedMessage(); + throw e.unwrapIOException(); + } finally { + if (parsedMessage != null) { + mergeFrom(parsedMessage); + } + } + return this; + } + + private flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier executionId_; + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder> executionIdBuilder_; + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public boolean hasExecutionId() { + return executionIdBuilder_ != null || executionId_ != null; + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier getExecutionId() { + if (executionIdBuilder_ == null) { + return executionId_ == null ? flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.getDefaultInstance() : executionId_; + } else { + return executionIdBuilder_.getMessage(); + } + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public Builder setExecutionId(flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier value) { + if (executionIdBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + executionId_ = value; + onChanged(); + } else { + executionIdBuilder_.setMessage(value); + } + + return this; + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public Builder setExecutionId( + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder builderForValue) { + if (executionIdBuilder_ == null) { + executionId_ = builderForValue.build(); + onChanged(); + } else { + executionIdBuilder_.setMessage(builderForValue.build()); + } + + return this; + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public Builder mergeExecutionId(flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier value) { + if (executionIdBuilder_ == null) { + if (executionId_ != null) { + executionId_ = + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.newBuilder(executionId_).mergeFrom(value).buildPartial(); + } else { + executionId_ = value; + } + onChanged(); + } else { + executionIdBuilder_.mergeFrom(value); + } + + return this; + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public Builder clearExecutionId() { + if (executionIdBuilder_ == null) { + executionId_ = null; + onChanged(); + } else { + executionId_ = null; + executionIdBuilder_ = null; + } + + return this; + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder getExecutionIdBuilder() { + + onChanged(); + return getExecutionIdFieldBuilder().getBuilder(); + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder getExecutionIdOrBuilder() { + if (executionIdBuilder_ != null) { + return executionIdBuilder_.getMessageOrBuilder(); + } else { + return executionId_ == null ? + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.getDefaultInstance() : executionId_; + } + } + /** + * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + */ + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder> + getExecutionIdFieldBuilder() { + if (executionIdBuilder_ == null) { + executionIdBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder>( + getExecutionId(), + getParentForChildren(), + isClean()); + executionId_ = null; + } + return executionIdBuilder_; + } + @java.lang.Override + public final Builder setUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.setUnknownFields(unknownFields); + } + + @java.lang.Override + public final Builder mergeUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.mergeUnknownFields(unknownFields); + } + + + // @@protoc_insertion_point(builder_scope:flyteidl.event.WorkflowNodeMetadata) } - public static flyteidl.event.Event.NodeExecutionEvent getDefaultInstance() { + // @@protoc_insertion_point(class_scope:flyteidl.event.WorkflowNodeMetadata) + private static final flyteidl.event.Event.WorkflowNodeMetadata DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.event.Event.WorkflowNodeMetadata(); + } + + public static flyteidl.event.Event.WorkflowNodeMetadata getDefaultInstance() { return DEFAULT_INSTANCE; } - private static final com.google.protobuf.Parser - PARSER = new com.google.protobuf.AbstractParser() { + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override - public NodeExecutionEvent parsePartialFrom( + public WorkflowNodeMetadata parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { - return new NodeExecutionEvent(input, extensionRegistry); + return new WorkflowNodeMetadata(input, extensionRegistry); } }; - public static com.google.protobuf.Parser parser() { + public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override - public com.google.protobuf.Parser getParserForType() { + public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override - public flyteidl.event.Event.NodeExecutionEvent getDefaultInstanceForType() { + public flyteidl.event.Event.WorkflowNodeMetadata getDefaultInstanceForType() { return DEFAULT_INSTANCE; } } - public interface WorkflowNodeMetadataOrBuilder extends - // @@protoc_insertion_point(interface_extends:flyteidl.event.WorkflowNodeMetadata) + public interface ParentTaskExecutionMetadataOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.event.ParentTaskExecutionMetadata) com.google.protobuf.MessageOrBuilder { /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - boolean hasExecutionId(); + boolean hasId(); /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier getExecutionId(); + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier getId(); /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder getExecutionIdOrBuilder(); + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder getIdOrBuilder(); } /** - *
-   * For Workflow Nodes we need to send information about the workflow that's launched
-   * 
- * - * Protobuf type {@code flyteidl.event.WorkflowNodeMetadata} + * Protobuf type {@code flyteidl.event.ParentTaskExecutionMetadata} */ - public static final class WorkflowNodeMetadata extends + public static final class ParentTaskExecutionMetadata extends com.google.protobuf.GeneratedMessageV3 implements - // @@protoc_insertion_point(message_implements:flyteidl.event.WorkflowNodeMetadata) - WorkflowNodeMetadataOrBuilder { + // @@protoc_insertion_point(message_implements:flyteidl.event.ParentTaskExecutionMetadata) + ParentTaskExecutionMetadataOrBuilder { private static final long serialVersionUID = 0L; - // Use WorkflowNodeMetadata.newBuilder() to construct. - private WorkflowNodeMetadata(com.google.protobuf.GeneratedMessageV3.Builder builder) { + // Use ParentTaskExecutionMetadata.newBuilder() to construct. + private ParentTaskExecutionMetadata(com.google.protobuf.GeneratedMessageV3.Builder builder) { super(builder); } - private WorkflowNodeMetadata() { + private ParentTaskExecutionMetadata() { } @java.lang.Override @@ -4243,7 +5635,7 @@ private WorkflowNodeMetadata() { getUnknownFields() { return this.unknownFields; } - private WorkflowNodeMetadata( + private ParentTaskExecutionMetadata( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { @@ -4263,14 +5655,14 @@ private WorkflowNodeMetadata( done = true; break; case 10: { - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder subBuilder = null; - if (executionId_ != null) { - subBuilder = executionId_.toBuilder(); + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder subBuilder = null; + if (id_ != null) { + subBuilder = id_.toBuilder(); } - executionId_ = input.readMessage(flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.parser(), extensionRegistry); + id_ = input.readMessage(flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.parser(), extensionRegistry); if (subBuilder != null) { - subBuilder.mergeFrom(executionId_); - executionId_ = subBuilder.buildPartial(); + subBuilder.mergeFrom(id_); + id_ = subBuilder.buildPartial(); } break; @@ -4296,36 +5688,36 @@ private WorkflowNodeMetadata( } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { - return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_descriptor; + return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { - return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_fieldAccessorTable + return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_fieldAccessorTable .ensureFieldAccessorsInitialized( - flyteidl.event.Event.WorkflowNodeMetadata.class, flyteidl.event.Event.WorkflowNodeMetadata.Builder.class); + flyteidl.event.Event.ParentTaskExecutionMetadata.class, flyteidl.event.Event.ParentTaskExecutionMetadata.Builder.class); } - public static final int EXECUTION_ID_FIELD_NUMBER = 1; - private flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier executionId_; + public static final int ID_FIELD_NUMBER = 1; + private flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier id_; /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public boolean hasExecutionId() { - return executionId_ != null; + public boolean hasId() { + return id_ != null; } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier getExecutionId() { - return executionId_ == null ? flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.getDefaultInstance() : executionId_; + public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier getId() { + return id_ == null ? flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.getDefaultInstance() : id_; } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder getExecutionIdOrBuilder() { - return getExecutionId(); + public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder getIdOrBuilder() { + return getId(); } private byte memoizedIsInitialized = -1; @@ -4342,8 +5734,8 @@ public final boolean isInitialized() { @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { - if (executionId_ != null) { - output.writeMessage(1, getExecutionId()); + if (id_ != null) { + output.writeMessage(1, getId()); } unknownFields.writeTo(output); } @@ -4354,9 +5746,9 @@ public int getSerializedSize() { if (size != -1) return size; size = 0; - if (executionId_ != null) { + if (id_ != null) { size += com.google.protobuf.CodedOutputStream - .computeMessageSize(1, getExecutionId()); + .computeMessageSize(1, getId()); } size += unknownFields.getSerializedSize(); memoizedSize = size; @@ -4368,15 +5760,15 @@ public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } - if (!(obj instanceof flyteidl.event.Event.WorkflowNodeMetadata)) { + if (!(obj instanceof flyteidl.event.Event.ParentTaskExecutionMetadata)) { return super.equals(obj); } - flyteidl.event.Event.WorkflowNodeMetadata other = (flyteidl.event.Event.WorkflowNodeMetadata) obj; + flyteidl.event.Event.ParentTaskExecutionMetadata other = (flyteidl.event.Event.ParentTaskExecutionMetadata) obj; - if (hasExecutionId() != other.hasExecutionId()) return false; - if (hasExecutionId()) { - if (!getExecutionId() - .equals(other.getExecutionId())) return false; + if (hasId() != other.hasId()) return false; + if (hasId()) { + if (!getId() + .equals(other.getId())) return false; } if (!unknownFields.equals(other.unknownFields)) return false; return true; @@ -4389,78 +5781,78 @@ public int hashCode() { } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); - if (hasExecutionId()) { - hash = (37 * hash) + EXECUTION_ID_FIELD_NUMBER; - hash = (53 * hash) + getExecutionId().hashCode(); + if (hasId()) { + hash = (37 * hash) + ID_FIELD_NUMBER; + hash = (53 * hash) + getId().hashCode(); } hash = (29 * hash) + unknownFields.hashCode(); memoizedHashCode = hash; return hash; } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom(byte[] data) + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom(java.io.InputStream input) + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseDelimitedFrom(java.io.InputStream input) + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseDelimitedFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseDelimitedFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input, extensionRegistry); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } - public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( + public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { @@ -4473,7 +5865,7 @@ public static flyteidl.event.Event.WorkflowNodeMetadata parseFrom( public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } - public static Builder newBuilder(flyteidl.event.Event.WorkflowNodeMetadata prototype) { + public static Builder newBuilder(flyteidl.event.Event.ParentTaskExecutionMetadata prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override @@ -4489,30 +5881,26 @@ protected Builder newBuilderForType( return builder; } /** - *
-     * For Workflow Nodes we need to send information about the workflow that's launched
-     * 
- * - * Protobuf type {@code flyteidl.event.WorkflowNodeMetadata} + * Protobuf type {@code flyteidl.event.ParentTaskExecutionMetadata} */ public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements - // @@protoc_insertion_point(builder_implements:flyteidl.event.WorkflowNodeMetadata) - flyteidl.event.Event.WorkflowNodeMetadataOrBuilder { + // @@protoc_insertion_point(builder_implements:flyteidl.event.ParentTaskExecutionMetadata) + flyteidl.event.Event.ParentTaskExecutionMetadataOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { - return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_descriptor; + return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { - return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_fieldAccessorTable + return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_fieldAccessorTable .ensureFieldAccessorsInitialized( - flyteidl.event.Event.WorkflowNodeMetadata.class, flyteidl.event.Event.WorkflowNodeMetadata.Builder.class); + flyteidl.event.Event.ParentTaskExecutionMetadata.class, flyteidl.event.Event.ParentTaskExecutionMetadata.Builder.class); } - // Construct using flyteidl.event.Event.WorkflowNodeMetadata.newBuilder() + // Construct using flyteidl.event.Event.ParentTaskExecutionMetadata.newBuilder() private Builder() { maybeForceBuilderInitialization(); } @@ -4530,11 +5918,11 @@ private void maybeForceBuilderInitialization() { @java.lang.Override public Builder clear() { super.clear(); - if (executionIdBuilder_ == null) { - executionId_ = null; + if (idBuilder_ == null) { + id_ = null; } else { - executionId_ = null; - executionIdBuilder_ = null; + id_ = null; + idBuilder_ = null; } return this; } @@ -4542,17 +5930,17 @@ public Builder clear() { @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { - return flyteidl.event.Event.internal_static_flyteidl_event_WorkflowNodeMetadata_descriptor; + return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_descriptor; } @java.lang.Override - public flyteidl.event.Event.WorkflowNodeMetadata getDefaultInstanceForType() { - return flyteidl.event.Event.WorkflowNodeMetadata.getDefaultInstance(); + public flyteidl.event.Event.ParentTaskExecutionMetadata getDefaultInstanceForType() { + return flyteidl.event.Event.ParentTaskExecutionMetadata.getDefaultInstance(); } @java.lang.Override - public flyteidl.event.Event.WorkflowNodeMetadata build() { - flyteidl.event.Event.WorkflowNodeMetadata result = buildPartial(); + public flyteidl.event.Event.ParentTaskExecutionMetadata build() { + flyteidl.event.Event.ParentTaskExecutionMetadata result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } @@ -4560,12 +5948,12 @@ public flyteidl.event.Event.WorkflowNodeMetadata build() { } @java.lang.Override - public flyteidl.event.Event.WorkflowNodeMetadata buildPartial() { - flyteidl.event.Event.WorkflowNodeMetadata result = new flyteidl.event.Event.WorkflowNodeMetadata(this); - if (executionIdBuilder_ == null) { - result.executionId_ = executionId_; + public flyteidl.event.Event.ParentTaskExecutionMetadata buildPartial() { + flyteidl.event.Event.ParentTaskExecutionMetadata result = new flyteidl.event.Event.ParentTaskExecutionMetadata(this); + if (idBuilder_ == null) { + result.id_ = id_; } else { - result.executionId_ = executionIdBuilder_.build(); + result.id_ = idBuilder_.build(); } onBuilt(); return result; @@ -4605,18 +5993,18 @@ public Builder addRepeatedField( } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { - if (other instanceof flyteidl.event.Event.WorkflowNodeMetadata) { - return mergeFrom((flyteidl.event.Event.WorkflowNodeMetadata)other); + if (other instanceof flyteidl.event.Event.ParentTaskExecutionMetadata) { + return mergeFrom((flyteidl.event.Event.ParentTaskExecutionMetadata)other); } else { super.mergeFrom(other); return this; } } - public Builder mergeFrom(flyteidl.event.Event.WorkflowNodeMetadata other) { - if (other == flyteidl.event.Event.WorkflowNodeMetadata.getDefaultInstance()) return this; - if (other.hasExecutionId()) { - mergeExecutionId(other.getExecutionId()); + public Builder mergeFrom(flyteidl.event.Event.ParentTaskExecutionMetadata other) { + if (other == flyteidl.event.Event.ParentTaskExecutionMetadata.getDefaultInstance()) return this; + if (other.hasId()) { + mergeId(other.getId()); } this.mergeUnknownFields(other.unknownFields); onChanged(); @@ -4633,11 +6021,11 @@ public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { - flyteidl.event.Event.WorkflowNodeMetadata parsedMessage = null; + flyteidl.event.Event.ParentTaskExecutionMetadata parsedMessage = null; try { parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { - parsedMessage = (flyteidl.event.Event.WorkflowNodeMetadata) e.getUnfinishedMessage(); + parsedMessage = (flyteidl.event.Event.ParentTaskExecutionMetadata) e.getUnfinishedMessage(); throw e.unwrapIOException(); } finally { if (parsedMessage != null) { @@ -4647,121 +6035,121 @@ public Builder mergeFrom( return this; } - private flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier executionId_; + private flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier id_; private com.google.protobuf.SingleFieldBuilderV3< - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder> executionIdBuilder_; + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder> idBuilder_; /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public boolean hasExecutionId() { - return executionIdBuilder_ != null || executionId_ != null; + public boolean hasId() { + return idBuilder_ != null || id_ != null; } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier getExecutionId() { - if (executionIdBuilder_ == null) { - return executionId_ == null ? flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.getDefaultInstance() : executionId_; + public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier getId() { + if (idBuilder_ == null) { + return id_ == null ? flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.getDefaultInstance() : id_; } else { - return executionIdBuilder_.getMessage(); + return idBuilder_.getMessage(); } } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public Builder setExecutionId(flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier value) { - if (executionIdBuilder_ == null) { + public Builder setId(flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier value) { + if (idBuilder_ == null) { if (value == null) { throw new NullPointerException(); } - executionId_ = value; + id_ = value; onChanged(); } else { - executionIdBuilder_.setMessage(value); + idBuilder_.setMessage(value); } return this; } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public Builder setExecutionId( - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder builderForValue) { - if (executionIdBuilder_ == null) { - executionId_ = builderForValue.build(); + public Builder setId( + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder builderForValue) { + if (idBuilder_ == null) { + id_ = builderForValue.build(); onChanged(); } else { - executionIdBuilder_.setMessage(builderForValue.build()); + idBuilder_.setMessage(builderForValue.build()); } return this; } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public Builder mergeExecutionId(flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier value) { - if (executionIdBuilder_ == null) { - if (executionId_ != null) { - executionId_ = - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.newBuilder(executionId_).mergeFrom(value).buildPartial(); + public Builder mergeId(flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier value) { + if (idBuilder_ == null) { + if (id_ != null) { + id_ = + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.newBuilder(id_).mergeFrom(value).buildPartial(); } else { - executionId_ = value; + id_ = value; } onChanged(); } else { - executionIdBuilder_.mergeFrom(value); + idBuilder_.mergeFrom(value); } return this; } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public Builder clearExecutionId() { - if (executionIdBuilder_ == null) { - executionId_ = null; + public Builder clearId() { + if (idBuilder_ == null) { + id_ = null; onChanged(); } else { - executionId_ = null; - executionIdBuilder_ = null; + id_ = null; + idBuilder_ = null; } return this; } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder getExecutionIdBuilder() { + public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder getIdBuilder() { onChanged(); - return getExecutionIdFieldBuilder().getBuilder(); + return getIdFieldBuilder().getBuilder(); } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ - public flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder getExecutionIdOrBuilder() { - if (executionIdBuilder_ != null) { - return executionIdBuilder_.getMessageOrBuilder(); + public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder getIdOrBuilder() { + if (idBuilder_ != null) { + return idBuilder_.getMessageOrBuilder(); } else { - return executionId_ == null ? - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.getDefaultInstance() : executionId_; + return id_ == null ? + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.getDefaultInstance() : id_; } } /** - * .flyteidl.core.WorkflowExecutionIdentifier execution_id = 1; + * .flyteidl.core.TaskExecutionIdentifier id = 1; */ private com.google.protobuf.SingleFieldBuilderV3< - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder> - getExecutionIdFieldBuilder() { - if (executionIdBuilder_ == null) { - executionIdBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< - flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.WorkflowExecutionIdentifierOrBuilder>( - getExecutionId(), + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder> + getIdFieldBuilder() { + if (idBuilder_ == null) { + idBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder>( + getId(), getParentForChildren(), isClean()); - executionId_ = null; + id_ = null; } - return executionIdBuilder_; + return idBuilder_; } @java.lang.Override public final Builder setUnknownFields( @@ -4776,76 +6164,84 @@ public final Builder mergeUnknownFields( } - // @@protoc_insertion_point(builder_scope:flyteidl.event.WorkflowNodeMetadata) + // @@protoc_insertion_point(builder_scope:flyteidl.event.ParentTaskExecutionMetadata) } - // @@protoc_insertion_point(class_scope:flyteidl.event.WorkflowNodeMetadata) - private static final flyteidl.event.Event.WorkflowNodeMetadata DEFAULT_INSTANCE; + // @@protoc_insertion_point(class_scope:flyteidl.event.ParentTaskExecutionMetadata) + private static final flyteidl.event.Event.ParentTaskExecutionMetadata DEFAULT_INSTANCE; static { - DEFAULT_INSTANCE = new flyteidl.event.Event.WorkflowNodeMetadata(); + DEFAULT_INSTANCE = new flyteidl.event.Event.ParentTaskExecutionMetadata(); } - public static flyteidl.event.Event.WorkflowNodeMetadata getDefaultInstance() { + public static flyteidl.event.Event.ParentTaskExecutionMetadata getDefaultInstance() { return DEFAULT_INSTANCE; } - private static final com.google.protobuf.Parser - PARSER = new com.google.protobuf.AbstractParser() { + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override - public WorkflowNodeMetadata parsePartialFrom( + public ParentTaskExecutionMetadata parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { - return new WorkflowNodeMetadata(input, extensionRegistry); + return new ParentTaskExecutionMetadata(input, extensionRegistry); } }; - public static com.google.protobuf.Parser parser() { + public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override - public com.google.protobuf.Parser getParserForType() { + public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override - public flyteidl.event.Event.WorkflowNodeMetadata getDefaultInstanceForType() { + public flyteidl.event.Event.ParentTaskExecutionMetadata getDefaultInstanceForType() { return DEFAULT_INSTANCE; } } - public interface ParentTaskExecutionMetadataOrBuilder extends - // @@protoc_insertion_point(interface_extends:flyteidl.event.ParentTaskExecutionMetadata) + public interface ParentNodeExecutionMetadataOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.event.ParentNodeExecutionMetadata) com.google.protobuf.MessageOrBuilder { /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; - */ - boolean hasId(); - /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+     * Unique identifier of the parent node id within the execution
+     * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+     * 
+ * + * string node_id = 1; */ - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier getId(); + java.lang.String getNodeId(); /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+     * Unique identifier of the parent node id within the execution
+     * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+     * 
+ * + * string node_id = 1; */ - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder getIdOrBuilder(); + com.google.protobuf.ByteString + getNodeIdBytes(); } /** - * Protobuf type {@code flyteidl.event.ParentTaskExecutionMetadata} + * Protobuf type {@code flyteidl.event.ParentNodeExecutionMetadata} */ - public static final class ParentTaskExecutionMetadata extends + public static final class ParentNodeExecutionMetadata extends com.google.protobuf.GeneratedMessageV3 implements - // @@protoc_insertion_point(message_implements:flyteidl.event.ParentTaskExecutionMetadata) - ParentTaskExecutionMetadataOrBuilder { + // @@protoc_insertion_point(message_implements:flyteidl.event.ParentNodeExecutionMetadata) + ParentNodeExecutionMetadataOrBuilder { private static final long serialVersionUID = 0L; - // Use ParentTaskExecutionMetadata.newBuilder() to construct. - private ParentTaskExecutionMetadata(com.google.protobuf.GeneratedMessageV3.Builder builder) { + // Use ParentNodeExecutionMetadata.newBuilder() to construct. + private ParentNodeExecutionMetadata(com.google.protobuf.GeneratedMessageV3.Builder builder) { super(builder); } - private ParentTaskExecutionMetadata() { + private ParentNodeExecutionMetadata() { + nodeId_ = ""; } @java.lang.Override @@ -4853,7 +6249,7 @@ private ParentTaskExecutionMetadata() { getUnknownFields() { return this.unknownFields; } - private ParentTaskExecutionMetadata( + private ParentNodeExecutionMetadata( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { @@ -4873,16 +6269,9 @@ private ParentTaskExecutionMetadata( done = true; break; case 10: { - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder subBuilder = null; - if (id_ != null) { - subBuilder = id_.toBuilder(); - } - id_ = input.readMessage(flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.parser(), extensionRegistry); - if (subBuilder != null) { - subBuilder.mergeFrom(id_); - id_ = subBuilder.buildPartial(); - } + java.lang.String s = input.readStringRequireUtf8(); + nodeId_ = s; break; } default: { @@ -4906,36 +6295,59 @@ private ParentTaskExecutionMetadata( } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { - return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_descriptor; + return flyteidl.event.Event.internal_static_flyteidl_event_ParentNodeExecutionMetadata_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { - return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_fieldAccessorTable + return flyteidl.event.Event.internal_static_flyteidl_event_ParentNodeExecutionMetadata_fieldAccessorTable .ensureFieldAccessorsInitialized( - flyteidl.event.Event.ParentTaskExecutionMetadata.class, flyteidl.event.Event.ParentTaskExecutionMetadata.Builder.class); + flyteidl.event.Event.ParentNodeExecutionMetadata.class, flyteidl.event.Event.ParentNodeExecutionMetadata.Builder.class); } - public static final int ID_FIELD_NUMBER = 1; - private flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier id_; - /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; - */ - public boolean hasId() { - return id_ != null; - } + public static final int NODE_ID_FIELD_NUMBER = 1; + private volatile java.lang.Object nodeId_; /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+     * Unique identifier of the parent node id within the execution
+     * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+     * 
+ * + * string node_id = 1; */ - public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier getId() { - return id_ == null ? flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.getDefaultInstance() : id_; + public java.lang.String getNodeId() { + java.lang.Object ref = nodeId_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + nodeId_ = s; + return s; + } } /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+     * Unique identifier of the parent node id within the execution
+     * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+     * 
+ * + * string node_id = 1; */ - public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder getIdOrBuilder() { - return getId(); + public com.google.protobuf.ByteString + getNodeIdBytes() { + java.lang.Object ref = nodeId_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + nodeId_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } } private byte memoizedIsInitialized = -1; @@ -4952,8 +6364,8 @@ public final boolean isInitialized() { @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { - if (id_ != null) { - output.writeMessage(1, getId()); + if (!getNodeIdBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 1, nodeId_); } unknownFields.writeTo(output); } @@ -4964,9 +6376,8 @@ public int getSerializedSize() { if (size != -1) return size; size = 0; - if (id_ != null) { - size += com.google.protobuf.CodedOutputStream - .computeMessageSize(1, getId()); + if (!getNodeIdBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, nodeId_); } size += unknownFields.getSerializedSize(); memoizedSize = size; @@ -4978,16 +6389,13 @@ public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } - if (!(obj instanceof flyteidl.event.Event.ParentTaskExecutionMetadata)) { + if (!(obj instanceof flyteidl.event.Event.ParentNodeExecutionMetadata)) { return super.equals(obj); } - flyteidl.event.Event.ParentTaskExecutionMetadata other = (flyteidl.event.Event.ParentTaskExecutionMetadata) obj; + flyteidl.event.Event.ParentNodeExecutionMetadata other = (flyteidl.event.Event.ParentNodeExecutionMetadata) obj; - if (hasId() != other.hasId()) return false; - if (hasId()) { - if (!getId() - .equals(other.getId())) return false; - } + if (!getNodeId() + .equals(other.getNodeId())) return false; if (!unknownFields.equals(other.unknownFields)) return false; return true; } @@ -4999,78 +6407,76 @@ public int hashCode() { } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); - if (hasId()) { - hash = (37 * hash) + ID_FIELD_NUMBER; - hash = (53 * hash) + getId().hashCode(); - } + hash = (37 * hash) + NODE_ID_FIELD_NUMBER; + hash = (53 * hash) + getNodeId().hashCode(); hash = (29 * hash) + unknownFields.hashCode(); memoizedHashCode = hash; return hash; } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom( java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom(byte[] data) + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom(java.io.InputStream input) + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseDelimitedFrom(java.io.InputStream input) + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseDelimitedFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseDelimitedFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input, extensionRegistry); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( + public static flyteidl.event.Event.ParentNodeExecutionMetadata parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { @@ -5083,7 +6489,7 @@ public static flyteidl.event.Event.ParentTaskExecutionMetadata parseFrom( public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } - public static Builder newBuilder(flyteidl.event.Event.ParentTaskExecutionMetadata prototype) { + public static Builder newBuilder(flyteidl.event.Event.ParentNodeExecutionMetadata prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override @@ -5099,26 +6505,26 @@ protected Builder newBuilderForType( return builder; } /** - * Protobuf type {@code flyteidl.event.ParentTaskExecutionMetadata} + * Protobuf type {@code flyteidl.event.ParentNodeExecutionMetadata} */ public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements - // @@protoc_insertion_point(builder_implements:flyteidl.event.ParentTaskExecutionMetadata) - flyteidl.event.Event.ParentTaskExecutionMetadataOrBuilder { + // @@protoc_insertion_point(builder_implements:flyteidl.event.ParentNodeExecutionMetadata) + flyteidl.event.Event.ParentNodeExecutionMetadataOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { - return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_descriptor; + return flyteidl.event.Event.internal_static_flyteidl_event_ParentNodeExecutionMetadata_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { - return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_fieldAccessorTable + return flyteidl.event.Event.internal_static_flyteidl_event_ParentNodeExecutionMetadata_fieldAccessorTable .ensureFieldAccessorsInitialized( - flyteidl.event.Event.ParentTaskExecutionMetadata.class, flyteidl.event.Event.ParentTaskExecutionMetadata.Builder.class); + flyteidl.event.Event.ParentNodeExecutionMetadata.class, flyteidl.event.Event.ParentNodeExecutionMetadata.Builder.class); } - // Construct using flyteidl.event.Event.ParentTaskExecutionMetadata.newBuilder() + // Construct using flyteidl.event.Event.ParentNodeExecutionMetadata.newBuilder() private Builder() { maybeForceBuilderInitialization(); } @@ -5136,29 +6542,25 @@ private void maybeForceBuilderInitialization() { @java.lang.Override public Builder clear() { super.clear(); - if (idBuilder_ == null) { - id_ = null; - } else { - id_ = null; - idBuilder_ = null; - } + nodeId_ = ""; + return this; } @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { - return flyteidl.event.Event.internal_static_flyteidl_event_ParentTaskExecutionMetadata_descriptor; + return flyteidl.event.Event.internal_static_flyteidl_event_ParentNodeExecutionMetadata_descriptor; } @java.lang.Override - public flyteidl.event.Event.ParentTaskExecutionMetadata getDefaultInstanceForType() { - return flyteidl.event.Event.ParentTaskExecutionMetadata.getDefaultInstance(); + public flyteidl.event.Event.ParentNodeExecutionMetadata getDefaultInstanceForType() { + return flyteidl.event.Event.ParentNodeExecutionMetadata.getDefaultInstance(); } @java.lang.Override - public flyteidl.event.Event.ParentTaskExecutionMetadata build() { - flyteidl.event.Event.ParentTaskExecutionMetadata result = buildPartial(); + public flyteidl.event.Event.ParentNodeExecutionMetadata build() { + flyteidl.event.Event.ParentNodeExecutionMetadata result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } @@ -5166,13 +6568,9 @@ public flyteidl.event.Event.ParentTaskExecutionMetadata build() { } @java.lang.Override - public flyteidl.event.Event.ParentTaskExecutionMetadata buildPartial() { - flyteidl.event.Event.ParentTaskExecutionMetadata result = new flyteidl.event.Event.ParentTaskExecutionMetadata(this); - if (idBuilder_ == null) { - result.id_ = id_; - } else { - result.id_ = idBuilder_.build(); - } + public flyteidl.event.Event.ParentNodeExecutionMetadata buildPartial() { + flyteidl.event.Event.ParentNodeExecutionMetadata result = new flyteidl.event.Event.ParentNodeExecutionMetadata(this); + result.nodeId_ = nodeId_; onBuilt(); return result; } @@ -5211,18 +6609,19 @@ public Builder addRepeatedField( } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { - if (other instanceof flyteidl.event.Event.ParentTaskExecutionMetadata) { - return mergeFrom((flyteidl.event.Event.ParentTaskExecutionMetadata)other); + if (other instanceof flyteidl.event.Event.ParentNodeExecutionMetadata) { + return mergeFrom((flyteidl.event.Event.ParentNodeExecutionMetadata)other); } else { super.mergeFrom(other); return this; } } - public Builder mergeFrom(flyteidl.event.Event.ParentTaskExecutionMetadata other) { - if (other == flyteidl.event.Event.ParentTaskExecutionMetadata.getDefaultInstance()) return this; - if (other.hasId()) { - mergeId(other.getId()); + public Builder mergeFrom(flyteidl.event.Event.ParentNodeExecutionMetadata other) { + if (other == flyteidl.event.Event.ParentNodeExecutionMetadata.getDefaultInstance()) return this; + if (!other.getNodeId().isEmpty()) { + nodeId_ = other.nodeId_; + onChanged(); } this.mergeUnknownFields(other.unknownFields); onChanged(); @@ -5239,11 +6638,11 @@ public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { - flyteidl.event.Event.ParentTaskExecutionMetadata parsedMessage = null; + flyteidl.event.Event.ParentNodeExecutionMetadata parsedMessage = null; try { parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { - parsedMessage = (flyteidl.event.Event.ParentTaskExecutionMetadata) e.getUnfinishedMessage(); + parsedMessage = (flyteidl.event.Event.ParentNodeExecutionMetadata) e.getUnfinishedMessage(); throw e.unwrapIOException(); } finally { if (parsedMessage != null) { @@ -5253,121 +6652,98 @@ public Builder mergeFrom( return this; } - private flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier id_; - private com.google.protobuf.SingleFieldBuilderV3< - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder> idBuilder_; - /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; - */ - public boolean hasId() { - return idBuilder_ != null || id_ != null; - } + private java.lang.Object nodeId_ = ""; /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; - */ - public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier getId() { - if (idBuilder_ == null) { - return id_ == null ? flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.getDefaultInstance() : id_; - } else { - return idBuilder_.getMessage(); - } - } - /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+       * Unique identifier of the parent node id within the execution
+       * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+       * 
+ * + * string node_id = 1; */ - public Builder setId(flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier value) { - if (idBuilder_ == null) { - if (value == null) { - throw new NullPointerException(); - } - id_ = value; - onChanged(); + public java.lang.String getNodeId() { + java.lang.Object ref = nodeId_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + nodeId_ = s; + return s; } else { - idBuilder_.setMessage(value); + return (java.lang.String) ref; } - - return this; } /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+       * Unique identifier of the parent node id within the execution
+       * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+       * 
+ * + * string node_id = 1; */ - public Builder setId( - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder builderForValue) { - if (idBuilder_ == null) { - id_ = builderForValue.build(); - onChanged(); + public com.google.protobuf.ByteString + getNodeIdBytes() { + java.lang.Object ref = nodeId_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + nodeId_ = b; + return b; } else { - idBuilder_.setMessage(builderForValue.build()); + return (com.google.protobuf.ByteString) ref; } - - return this; } /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+       * Unique identifier of the parent node id within the execution
+       * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+       * 
+ * + * string node_id = 1; */ - public Builder mergeId(flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier value) { - if (idBuilder_ == null) { - if (id_ != null) { - id_ = - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.newBuilder(id_).mergeFrom(value).buildPartial(); - } else { - id_ = value; - } - onChanged(); - } else { - idBuilder_.mergeFrom(value); - } - + public Builder setNodeId( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + nodeId_ = value; + onChanged(); return this; } /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+       * Unique identifier of the parent node id within the execution
+       * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+       * 
+ * + * string node_id = 1; */ - public Builder clearId() { - if (idBuilder_ == null) { - id_ = null; - onChanged(); - } else { - id_ = null; - idBuilder_ = null; - } - + public Builder clearNodeId() { + + nodeId_ = getDefaultInstance().getNodeId(); + onChanged(); return this; } /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; + *
+       * Unique identifier of the parent node id within the execution
+       * This is value of core.NodeExecutionIdentifier.node_id of the parent node 
+       * 
+ * + * string node_id = 1; */ - public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder getIdBuilder() { + public Builder setNodeIdBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + nodeId_ = value; onChanged(); - return getIdFieldBuilder().getBuilder(); - } - /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; - */ - public flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder getIdOrBuilder() { - if (idBuilder_ != null) { - return idBuilder_.getMessageOrBuilder(); - } else { - return id_ == null ? - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.getDefaultInstance() : id_; - } - } - /** - * .flyteidl.core.TaskExecutionIdentifier id = 1; - */ - private com.google.protobuf.SingleFieldBuilderV3< - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder> - getIdFieldBuilder() { - if (idBuilder_ == null) { - idBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< - flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifier.Builder, flyteidl.core.IdentifierOuterClass.TaskExecutionIdentifierOrBuilder>( - getId(), - getParentForChildren(), - isClean()); - id_ = null; - } - return idBuilder_; + return this; } @java.lang.Override public final Builder setUnknownFields( @@ -5382,41 +6758,41 @@ public final Builder mergeUnknownFields( } - // @@protoc_insertion_point(builder_scope:flyteidl.event.ParentTaskExecutionMetadata) + // @@protoc_insertion_point(builder_scope:flyteidl.event.ParentNodeExecutionMetadata) } - // @@protoc_insertion_point(class_scope:flyteidl.event.ParentTaskExecutionMetadata) - private static final flyteidl.event.Event.ParentTaskExecutionMetadata DEFAULT_INSTANCE; + // @@protoc_insertion_point(class_scope:flyteidl.event.ParentNodeExecutionMetadata) + private static final flyteidl.event.Event.ParentNodeExecutionMetadata DEFAULT_INSTANCE; static { - DEFAULT_INSTANCE = new flyteidl.event.Event.ParentTaskExecutionMetadata(); + DEFAULT_INSTANCE = new flyteidl.event.Event.ParentNodeExecutionMetadata(); } - public static flyteidl.event.Event.ParentTaskExecutionMetadata getDefaultInstance() { + public static flyteidl.event.Event.ParentNodeExecutionMetadata getDefaultInstance() { return DEFAULT_INSTANCE; } - private static final com.google.protobuf.Parser - PARSER = new com.google.protobuf.AbstractParser() { + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override - public ParentTaskExecutionMetadata parsePartialFrom( + public ParentNodeExecutionMetadata parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { - return new ParentTaskExecutionMetadata(input, extensionRegistry); + return new ParentNodeExecutionMetadata(input, extensionRegistry); } }; - public static com.google.protobuf.Parser parser() { + public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override - public com.google.protobuf.Parser getParserForType() { + public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override - public flyteidl.event.Event.ParentTaskExecutionMetadata getDefaultInstanceForType() { + public flyteidl.event.Event.ParentNodeExecutionMetadata getDefaultInstanceForType() { return DEFAULT_INSTANCE; } @@ -8620,6 +9996,11 @@ public flyteidl.event.Event.TaskExecutionEvent getDefaultInstanceForType() { private static final com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internal_static_flyteidl_event_ParentTaskExecutionMetadata_fieldAccessorTable; + private static final com.google.protobuf.Descriptors.Descriptor + internal_static_flyteidl_event_ParentNodeExecutionMetadata_descriptor; + private static final + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internal_static_flyteidl_event_ParentNodeExecutionMetadata_fieldAccessorTable; private static final com.google.protobuf.Descriptors.Descriptor internal_static_flyteidl_event_TaskExecutionEvent_descriptor; private static final @@ -8645,7 +10026,7 @@ public flyteidl.event.Event.TaskExecutionEvent getDefaultInstanceForType() { "flowExecution.Phase\022/\n\013occurred_at\030\004 \001(\013" + "2\032.google.protobuf.Timestamp\022\024\n\noutput_u" + "ri\030\005 \001(\tH\000\022.\n\005error\030\006 \001(\0132\035.flyteidl.cor" + - "e.ExecutionErrorH\000B\017\n\routput_result\"\321\003\n\022" + + "e.ExecutionErrorH\000B\017\n\routput_result\"\332\004\n\022" + "NodeExecutionEvent\0222\n\002id\030\001 \001(\0132&.flyteid" + "l.core.NodeExecutionIdentifier\022\023\n\013produc" + "er_id\030\002 \001(\t\0221\n\005phase\030\003 \001(\0162\".flyteidl.co" + @@ -8656,26 +10037,31 @@ public flyteidl.event.Event.TaskExecutionEvent getDefaultInstanceForType() { "\022F\n\026workflow_node_metadata\030\010 \001(\0132$.flyte" + "idl.event.WorkflowNodeMetadataH\001\022I\n\024pare" + "nt_task_metadata\030\t \001(\0132+.flyteidl.event." + - "ParentTaskExecutionMetadataB\017\n\routput_re" + - "sultB\021\n\017target_metadata\"X\n\024WorkflowNodeM" + - "etadata\022@\n\014execution_id\030\001 \001(\0132*.flyteidl" + - ".core.WorkflowExecutionIdentifier\"Q\n\033Par" + - "entTaskExecutionMetadata\0222\n\002id\030\001 \001(\0132&.f" + - "lyteidl.core.TaskExecutionIdentifier\"\357\003\n" + - "\022TaskExecutionEvent\022*\n\007task_id\030\001 \001(\0132\031.f" + - "lyteidl.core.Identifier\022H\n\030parent_node_e" + - "xecution_id\030\002 \001(\0132&.flyteidl.core.NodeEx" + - "ecutionIdentifier\022\025\n\rretry_attempt\030\003 \001(\r" + - "\0221\n\005phase\030\004 \001(\0162\".flyteidl.core.TaskExec" + - "ution.Phase\022\023\n\013producer_id\030\005 \001(\t\022$\n\004logs" + - "\030\006 \003(\0132\026.flyteidl.core.TaskLog\022/\n\013occurr" + - "ed_at\030\007 \001(\0132\032.google.protobuf.Timestamp\022" + - "\021\n\tinput_uri\030\010 \001(\t\022\024\n\noutput_uri\030\t \001(\tH\000" + - "\022.\n\005error\030\n \001(\0132\035.flyteidl.core.Executio" + - "nErrorH\000\022,\n\013custom_info\030\013 \001(\0132\027.google.p" + - "rotobuf.Struct\022\025\n\rphase_version\030\014 \001(\rB\017\n" + - "\routput_resultB3Z1github.com/lyft/flytei" + - "dl/gen/pb-go/flyteidl/eventb\006proto3" + "ParentTaskExecutionMetadata\022I\n\024parent_no" + + "de_metadata\030\n \001(\0132+.flyteidl.event.Paren" + + "tNodeExecutionMetadata\022\023\n\013retry_group\030\013 " + + "\001(\t\022\024\n\014spec_node_id\030\014 \001(\t\022\021\n\tnode_name\030\r" + + " \001(\tB\017\n\routput_resultB\021\n\017target_metadata" + + "\"X\n\024WorkflowNodeMetadata\022@\n\014execution_id" + + "\030\001 \001(\0132*.flyteidl.core.WorkflowExecution" + + "Identifier\"Q\n\033ParentTaskExecutionMetadat" + + "a\0222\n\002id\030\001 \001(\0132&.flyteidl.core.TaskExecut" + + "ionIdentifier\".\n\033ParentNodeExecutionMeta" + + "data\022\017\n\007node_id\030\001 \001(\t\"\357\003\n\022TaskExecutionE" + + "vent\022*\n\007task_id\030\001 \001(\0132\031.flyteidl.core.Id" + + "entifier\022H\n\030parent_node_execution_id\030\002 \001" + + "(\0132&.flyteidl.core.NodeExecutionIdentifi" + + "er\022\025\n\rretry_attempt\030\003 \001(\r\0221\n\005phase\030\004 \001(\016" + + "2\".flyteidl.core.TaskExecution.Phase\022\023\n\013" + + "producer_id\030\005 \001(\t\022$\n\004logs\030\006 \003(\0132\026.flytei" + + "dl.core.TaskLog\022/\n\013occurred_at\030\007 \001(\0132\032.g" + + "oogle.protobuf.Timestamp\022\021\n\tinput_uri\030\010 " + + "\001(\t\022\024\n\noutput_uri\030\t \001(\tH\000\022.\n\005error\030\n \001(\013" + + "2\035.flyteidl.core.ExecutionErrorH\000\022,\n\013cus" + + "tom_info\030\013 \001(\0132\027.google.protobuf.Struct\022" + + "\025\n\rphase_version\030\014 \001(\rB\017\n\routput_resultB" + + "3Z1github.com/lyft/flyteidl/gen/pb-go/fl" + + "yteidl/eventb\006proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -8704,7 +10090,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_event_NodeExecutionEvent_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_event_NodeExecutionEvent_descriptor, - new java.lang.String[] { "Id", "ProducerId", "Phase", "OccurredAt", "InputUri", "OutputUri", "Error", "WorkflowNodeMetadata", "ParentTaskMetadata", "OutputResult", "TargetMetadata", }); + new java.lang.String[] { "Id", "ProducerId", "Phase", "OccurredAt", "InputUri", "OutputUri", "Error", "WorkflowNodeMetadata", "ParentTaskMetadata", "ParentNodeMetadata", "RetryGroup", "SpecNodeId", "NodeName", "OutputResult", "TargetMetadata", }); internal_static_flyteidl_event_WorkflowNodeMetadata_descriptor = getDescriptor().getMessageTypes().get(2); internal_static_flyteidl_event_WorkflowNodeMetadata_fieldAccessorTable = new @@ -8717,8 +10103,14 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_event_ParentTaskExecutionMetadata_descriptor, new java.lang.String[] { "Id", }); - internal_static_flyteidl_event_TaskExecutionEvent_descriptor = + internal_static_flyteidl_event_ParentNodeExecutionMetadata_descriptor = getDescriptor().getMessageTypes().get(4); + internal_static_flyteidl_event_ParentNodeExecutionMetadata_fieldAccessorTable = new + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( + internal_static_flyteidl_event_ParentNodeExecutionMetadata_descriptor, + new java.lang.String[] { "NodeId", }); + internal_static_flyteidl_event_TaskExecutionEvent_descriptor = + getDescriptor().getMessageTypes().get(5); internal_static_flyteidl_event_TaskExecutionEvent_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_event_TaskExecutionEvent_descriptor, diff --git a/flyteidl/gen/pb-js/flyteidl.d.ts b/flyteidl/gen/pb-js/flyteidl.d.ts index 0965b43e52..98e1668222 100644 --- a/flyteidl/gen/pb-js/flyteidl.d.ts +++ b/flyteidl/gen/pb-js/flyteidl.d.ts @@ -4763,6 +4763,18 @@ export namespace flyteidl { /** NodeExecutionEvent parentTaskMetadata */ parentTaskMetadata?: (flyteidl.event.IParentTaskExecutionMetadata|null); + + /** NodeExecutionEvent parentNodeMetadata */ + parentNodeMetadata?: (flyteidl.event.IParentNodeExecutionMetadata|null); + + /** NodeExecutionEvent retryGroup */ + retryGroup?: (string|null); + + /** NodeExecutionEvent specNodeId */ + specNodeId?: (string|null); + + /** NodeExecutionEvent nodeName */ + nodeName?: (string|null); } /** Represents a NodeExecutionEvent. */ @@ -4801,6 +4813,18 @@ export namespace flyteidl { /** NodeExecutionEvent parentTaskMetadata. */ public parentTaskMetadata?: (flyteidl.event.IParentTaskExecutionMetadata|null); + /** NodeExecutionEvent parentNodeMetadata. */ + public parentNodeMetadata?: (flyteidl.event.IParentNodeExecutionMetadata|null); + + /** NodeExecutionEvent retryGroup. */ + public retryGroup: string; + + /** NodeExecutionEvent specNodeId. */ + public specNodeId: string; + + /** NodeExecutionEvent nodeName. */ + public nodeName: string; + /** NodeExecutionEvent outputResult. */ public outputResult?: ("outputUri"|"error"); @@ -4944,6 +4968,58 @@ export namespace flyteidl { public static verify(message: { [k: string]: any }): (string|null); } + /** Properties of a ParentNodeExecutionMetadata. */ + interface IParentNodeExecutionMetadata { + + /** ParentNodeExecutionMetadata nodeId */ + nodeId?: (string|null); + } + + /** Represents a ParentNodeExecutionMetadata. */ + class ParentNodeExecutionMetadata implements IParentNodeExecutionMetadata { + + /** + * Constructs a new ParentNodeExecutionMetadata. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.event.IParentNodeExecutionMetadata); + + /** ParentNodeExecutionMetadata nodeId. */ + public nodeId: string; + + /** + * Creates a new ParentNodeExecutionMetadata instance using the specified properties. + * @param [properties] Properties to set + * @returns ParentNodeExecutionMetadata instance + */ + public static create(properties?: flyteidl.event.IParentNodeExecutionMetadata): flyteidl.event.ParentNodeExecutionMetadata; + + /** + * Encodes the specified ParentNodeExecutionMetadata message. Does not implicitly {@link flyteidl.event.ParentNodeExecutionMetadata.verify|verify} messages. + * @param message ParentNodeExecutionMetadata message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.event.IParentNodeExecutionMetadata, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ParentNodeExecutionMetadata message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ParentNodeExecutionMetadata + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.event.ParentNodeExecutionMetadata; + + /** + * Verifies a ParentNodeExecutionMetadata message. + * @param message Plain object to verify + * @returns `null` if valid, otherwise the reason why it is not + */ + public static verify(message: { [k: string]: any }): (string|null); + } + /** Properties of a TaskExecutionEvent. */ interface ITaskExecutionEvent { @@ -9421,6 +9497,9 @@ export namespace flyteidl { /** NodeExecutionListRequest sortBy */ sortBy?: (flyteidl.admin.ISort|null); + + /** NodeExecutionListRequest uniqueParentId */ + uniqueParentId?: (string|null); } /** Represents a NodeExecutionListRequest. */ @@ -9447,6 +9526,9 @@ export namespace flyteidl { /** NodeExecutionListRequest sortBy. */ public sortBy?: (flyteidl.admin.ISort|null); + /** NodeExecutionListRequest uniqueParentId. */ + public uniqueParentId: string; + /** * Creates a new NodeExecutionListRequest instance using the specified properties. * @param [properties] Properties to set @@ -9628,6 +9710,15 @@ export namespace flyteidl { /** Properties of a NodeExecutionMetaData. */ interface INodeExecutionMetaData { + + /** NodeExecutionMetaData retryGroup */ + retryGroup?: (string|null); + + /** NodeExecutionMetaData isParentNode */ + isParentNode?: (boolean|null); + + /** NodeExecutionMetaData specNodeId */ + specNodeId?: (string|null); } /** Represents a NodeExecutionMetaData. */ @@ -9639,6 +9730,15 @@ export namespace flyteidl { */ constructor(properties?: flyteidl.admin.INodeExecutionMetaData); + /** NodeExecutionMetaData retryGroup. */ + public retryGroup: string; + + /** NodeExecutionMetaData isParentNode. */ + public isParentNode: boolean; + + /** NodeExecutionMetaData specNodeId. */ + public specNodeId: string; + /** * Creates a new NodeExecutionMetaData instance using the specified properties. * @param [properties] Properties to set diff --git a/flyteidl/gen/pb-js/flyteidl.js b/flyteidl/gen/pb-js/flyteidl.js index 8647ede705..dc4983f69b 100644 --- a/flyteidl/gen/pb-js/flyteidl.js +++ b/flyteidl/gen/pb-js/flyteidl.js @@ -11419,6 +11419,10 @@ export const flyteidl = $root.flyteidl = (() => { * @property {flyteidl.core.IExecutionError|null} [error] NodeExecutionEvent error * @property {flyteidl.event.IWorkflowNodeMetadata|null} [workflowNodeMetadata] NodeExecutionEvent workflowNodeMetadata * @property {flyteidl.event.IParentTaskExecutionMetadata|null} [parentTaskMetadata] NodeExecutionEvent parentTaskMetadata + * @property {flyteidl.event.IParentNodeExecutionMetadata|null} [parentNodeMetadata] NodeExecutionEvent parentNodeMetadata + * @property {string|null} [retryGroup] NodeExecutionEvent retryGroup + * @property {string|null} [specNodeId] NodeExecutionEvent specNodeId + * @property {string|null} [nodeName] NodeExecutionEvent nodeName */ /** @@ -11508,6 +11512,38 @@ export const flyteidl = $root.flyteidl = (() => { */ NodeExecutionEvent.prototype.parentTaskMetadata = null; + /** + * NodeExecutionEvent parentNodeMetadata. + * @member {flyteidl.event.IParentNodeExecutionMetadata|null|undefined} parentNodeMetadata + * @memberof flyteidl.event.NodeExecutionEvent + * @instance + */ + NodeExecutionEvent.prototype.parentNodeMetadata = null; + + /** + * NodeExecutionEvent retryGroup. + * @member {string} retryGroup + * @memberof flyteidl.event.NodeExecutionEvent + * @instance + */ + NodeExecutionEvent.prototype.retryGroup = ""; + + /** + * NodeExecutionEvent specNodeId. + * @member {string} specNodeId + * @memberof flyteidl.event.NodeExecutionEvent + * @instance + */ + NodeExecutionEvent.prototype.specNodeId = ""; + + /** + * NodeExecutionEvent nodeName. + * @member {string} nodeName + * @memberof flyteidl.event.NodeExecutionEvent + * @instance + */ + NodeExecutionEvent.prototype.nodeName = ""; + // OneOf field names bound to virtual getters and setters let $oneOfFields; @@ -11575,6 +11611,14 @@ export const flyteidl = $root.flyteidl = (() => { $root.flyteidl.event.WorkflowNodeMetadata.encode(message.workflowNodeMetadata, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); if (message.parentTaskMetadata != null && message.hasOwnProperty("parentTaskMetadata")) $root.flyteidl.event.ParentTaskExecutionMetadata.encode(message.parentTaskMetadata, writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim(); + if (message.parentNodeMetadata != null && message.hasOwnProperty("parentNodeMetadata")) + $root.flyteidl.event.ParentNodeExecutionMetadata.encode(message.parentNodeMetadata, writer.uint32(/* id 10, wireType 2 =*/82).fork()).ldelim(); + if (message.retryGroup != null && message.hasOwnProperty("retryGroup")) + writer.uint32(/* id 11, wireType 2 =*/90).string(message.retryGroup); + if (message.specNodeId != null && message.hasOwnProperty("specNodeId")) + writer.uint32(/* id 12, wireType 2 =*/98).string(message.specNodeId); + if (message.nodeName != null && message.hasOwnProperty("nodeName")) + writer.uint32(/* id 13, wireType 2 =*/106).string(message.nodeName); return writer; }; @@ -11623,6 +11667,18 @@ export const flyteidl = $root.flyteidl = (() => { case 9: message.parentTaskMetadata = $root.flyteidl.event.ParentTaskExecutionMetadata.decode(reader, reader.uint32()); break; + case 10: + message.parentNodeMetadata = $root.flyteidl.event.ParentNodeExecutionMetadata.decode(reader, reader.uint32()); + break; + case 11: + message.retryGroup = reader.string(); + break; + case 12: + message.specNodeId = reader.string(); + break; + case 13: + message.nodeName = reader.string(); + break; default: reader.skipType(tag & 7); break; @@ -11702,6 +11758,20 @@ export const flyteidl = $root.flyteidl = (() => { if (error) return "parentTaskMetadata." + error; } + if (message.parentNodeMetadata != null && message.hasOwnProperty("parentNodeMetadata")) { + let error = $root.flyteidl.event.ParentNodeExecutionMetadata.verify(message.parentNodeMetadata); + if (error) + return "parentNodeMetadata." + error; + } + if (message.retryGroup != null && message.hasOwnProperty("retryGroup")) + if (!$util.isString(message.retryGroup)) + return "retryGroup: string expected"; + if (message.specNodeId != null && message.hasOwnProperty("specNodeId")) + if (!$util.isString(message.specNodeId)) + return "specNodeId: string expected"; + if (message.nodeName != null && message.hasOwnProperty("nodeName")) + if (!$util.isString(message.nodeName)) + return "nodeName: string expected"; return null; }; @@ -11932,6 +12002,116 @@ export const flyteidl = $root.flyteidl = (() => { return ParentTaskExecutionMetadata; })(); + event.ParentNodeExecutionMetadata = (function() { + + /** + * Properties of a ParentNodeExecutionMetadata. + * @memberof flyteidl.event + * @interface IParentNodeExecutionMetadata + * @property {string|null} [nodeId] ParentNodeExecutionMetadata nodeId + */ + + /** + * Constructs a new ParentNodeExecutionMetadata. + * @memberof flyteidl.event + * @classdesc Represents a ParentNodeExecutionMetadata. + * @implements IParentNodeExecutionMetadata + * @constructor + * @param {flyteidl.event.IParentNodeExecutionMetadata=} [properties] Properties to set + */ + function ParentNodeExecutionMetadata(properties) { + if (properties) + for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ParentNodeExecutionMetadata nodeId. + * @member {string} nodeId + * @memberof flyteidl.event.ParentNodeExecutionMetadata + * @instance + */ + ParentNodeExecutionMetadata.prototype.nodeId = ""; + + /** + * Creates a new ParentNodeExecutionMetadata instance using the specified properties. + * @function create + * @memberof flyteidl.event.ParentNodeExecutionMetadata + * @static + * @param {flyteidl.event.IParentNodeExecutionMetadata=} [properties] Properties to set + * @returns {flyteidl.event.ParentNodeExecutionMetadata} ParentNodeExecutionMetadata instance + */ + ParentNodeExecutionMetadata.create = function create(properties) { + return new ParentNodeExecutionMetadata(properties); + }; + + /** + * Encodes the specified ParentNodeExecutionMetadata message. Does not implicitly {@link flyteidl.event.ParentNodeExecutionMetadata.verify|verify} messages. + * @function encode + * @memberof flyteidl.event.ParentNodeExecutionMetadata + * @static + * @param {flyteidl.event.IParentNodeExecutionMetadata} message ParentNodeExecutionMetadata message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ParentNodeExecutionMetadata.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.nodeId != null && message.hasOwnProperty("nodeId")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.nodeId); + return writer; + }; + + /** + * Decodes a ParentNodeExecutionMetadata message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.event.ParentNodeExecutionMetadata + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.event.ParentNodeExecutionMetadata} ParentNodeExecutionMetadata + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ParentNodeExecutionMetadata.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.event.ParentNodeExecutionMetadata(); + while (reader.pos < end) { + let tag = reader.uint32(); + switch (tag >>> 3) { + case 1: + message.nodeId = reader.string(); + break; + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Verifies a ParentNodeExecutionMetadata message. + * @function verify + * @memberof flyteidl.event.ParentNodeExecutionMetadata + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ParentNodeExecutionMetadata.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.nodeId != null && message.hasOwnProperty("nodeId")) + if (!$util.isString(message.nodeId)) + return "nodeId: string expected"; + return null; + }; + + return ParentNodeExecutionMetadata; + })(); + event.TaskExecutionEvent = (function() { /** @@ -22505,6 +22685,7 @@ export const flyteidl = $root.flyteidl = (() => { * @property {string|null} [token] NodeExecutionListRequest token * @property {string|null} [filters] NodeExecutionListRequest filters * @property {flyteidl.admin.ISort|null} [sortBy] NodeExecutionListRequest sortBy + * @property {string|null} [uniqueParentId] NodeExecutionListRequest uniqueParentId */ /** @@ -22562,6 +22743,14 @@ export const flyteidl = $root.flyteidl = (() => { */ NodeExecutionListRequest.prototype.sortBy = null; + /** + * NodeExecutionListRequest uniqueParentId. + * @member {string} uniqueParentId + * @memberof flyteidl.admin.NodeExecutionListRequest + * @instance + */ + NodeExecutionListRequest.prototype.uniqueParentId = ""; + /** * Creates a new NodeExecutionListRequest instance using the specified properties. * @function create @@ -22596,6 +22785,8 @@ export const flyteidl = $root.flyteidl = (() => { writer.uint32(/* id 4, wireType 2 =*/34).string(message.filters); if (message.sortBy != null && message.hasOwnProperty("sortBy")) $root.flyteidl.admin.Sort.encode(message.sortBy, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + if (message.uniqueParentId != null && message.hasOwnProperty("uniqueParentId")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.uniqueParentId); return writer; }; @@ -22632,6 +22823,9 @@ export const flyteidl = $root.flyteidl = (() => { case 5: message.sortBy = $root.flyteidl.admin.Sort.decode(reader, reader.uint32()); break; + case 6: + message.uniqueParentId = reader.string(); + break; default: reader.skipType(tag & 7); break; @@ -22670,6 +22864,9 @@ export const flyteidl = $root.flyteidl = (() => { if (error) return "sortBy." + error; } + if (message.uniqueParentId != null && message.hasOwnProperty("uniqueParentId")) + if (!$util.isString(message.uniqueParentId)) + return "uniqueParentId: string expected"; return null; }; @@ -23031,6 +23228,9 @@ export const flyteidl = $root.flyteidl = (() => { * Properties of a NodeExecutionMetaData. * @memberof flyteidl.admin * @interface INodeExecutionMetaData + * @property {string|null} [retryGroup] NodeExecutionMetaData retryGroup + * @property {boolean|null} [isParentNode] NodeExecutionMetaData isParentNode + * @property {string|null} [specNodeId] NodeExecutionMetaData specNodeId */ /** @@ -23048,6 +23248,30 @@ export const flyteidl = $root.flyteidl = (() => { this[keys[i]] = properties[keys[i]]; } + /** + * NodeExecutionMetaData retryGroup. + * @member {string} retryGroup + * @memberof flyteidl.admin.NodeExecutionMetaData + * @instance + */ + NodeExecutionMetaData.prototype.retryGroup = ""; + + /** + * NodeExecutionMetaData isParentNode. + * @member {boolean} isParentNode + * @memberof flyteidl.admin.NodeExecutionMetaData + * @instance + */ + NodeExecutionMetaData.prototype.isParentNode = false; + + /** + * NodeExecutionMetaData specNodeId. + * @member {string} specNodeId + * @memberof flyteidl.admin.NodeExecutionMetaData + * @instance + */ + NodeExecutionMetaData.prototype.specNodeId = ""; + /** * Creates a new NodeExecutionMetaData instance using the specified properties. * @function create @@ -23072,6 +23296,12 @@ export const flyteidl = $root.flyteidl = (() => { NodeExecutionMetaData.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); + if (message.retryGroup != null && message.hasOwnProperty("retryGroup")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.retryGroup); + if (message.isParentNode != null && message.hasOwnProperty("isParentNode")) + writer.uint32(/* id 2, wireType 0 =*/16).bool(message.isParentNode); + if (message.specNodeId != null && message.hasOwnProperty("specNodeId")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.specNodeId); return writer; }; @@ -23093,6 +23323,15 @@ export const flyteidl = $root.flyteidl = (() => { while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { + case 1: + message.retryGroup = reader.string(); + break; + case 2: + message.isParentNode = reader.bool(); + break; + case 3: + message.specNodeId = reader.string(); + break; default: reader.skipType(tag & 7); break; @@ -23112,6 +23351,15 @@ export const flyteidl = $root.flyteidl = (() => { NodeExecutionMetaData.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; + if (message.retryGroup != null && message.hasOwnProperty("retryGroup")) + if (!$util.isString(message.retryGroup)) + return "retryGroup: string expected"; + if (message.isParentNode != null && message.hasOwnProperty("isParentNode")) + if (typeof message.isParentNode !== "boolean") + return "isParentNode: boolean expected"; + if (message.specNodeId != null && message.hasOwnProperty("specNodeId")) + if (!$util.isString(message.specNodeId)) + return "specNodeId: string expected"; return null; }; diff --git a/flyteidl/gen/pb-protodoc/flyteidl/admin/node_execution.proto.rst b/flyteidl/gen/pb-protodoc/flyteidl/admin/node_execution.proto.rst index 79216b80df..b5d5d75d8a 100644 --- a/flyteidl/gen/pb-protodoc/flyteidl/admin/node_execution.proto.rst +++ b/flyteidl/gen/pb-protodoc/flyteidl/admin/node_execution.proto.rst @@ -42,7 +42,8 @@ Represents a request structure to retrieve a list of node execution entities. "limit": "...", "token": "...", "filters": "...", - "sort_by": "{...}" + "sort_by": "{...}", + "unique_parent_id": "..." } .. _api_field_flyteidl.admin.NodeExecutionListRequest.workflow_execution_id: @@ -80,6 +81,13 @@ sort_by +optional +.. _api_field_flyteidl.admin.NodeExecutionListRequest.unique_parent_id: + +unique_parent_id + (`string `_) Unique identifier of the parent node in the execution + +optional + + .. _api_msg_flyteidl.admin.NodeExecutionForTaskListRequest: @@ -87,7 +95,7 @@ sort_by flyteidl.admin.NodeExecutionForTaskListRequest ---------------------------------------------- -`[flyteidl.admin.NodeExecutionForTaskListRequest proto] `_ +`[flyteidl.admin.NodeExecutionForTaskListRequest proto] `_ Represents a request structure to retrieve a list of node execution entities launched by a specific task. @@ -143,7 +151,7 @@ sort_by flyteidl.admin.NodeExecution ---------------------------- -`[flyteidl.admin.NodeExecution proto] `_ +`[flyteidl.admin.NodeExecution proto] `_ Encapsulates all details for a single node execution entity. A node represents a component in the overall workflow graph. A node launch a task, multiple tasks, an entire nested @@ -190,15 +198,38 @@ metadata flyteidl.admin.NodeExecutionMetaData ------------------------------------ -`[flyteidl.admin.NodeExecutionMetaData proto] `_ +`[flyteidl.admin.NodeExecutionMetaData proto] `_ Represents additional attributes related to a Node Execution .. code-block:: json - {} + { + "retry_group": "...", + "is_parent_node": "...", + "spec_node_id": "..." + } +.. _api_field_flyteidl.admin.NodeExecutionMetaData.retry_group: +retry_group + (`string `_) Node executions are grouped depending on retries of the parent + Retry group is unique within the context of a parent node. + + +.. _api_field_flyteidl.admin.NodeExecutionMetaData.is_parent_node: + +is_parent_node + (`bool `_) Boolean flag indicating if the node has child nodes under it + + +.. _api_field_flyteidl.admin.NodeExecutionMetaData.spec_node_id: + +spec_node_id + (`string `_) Node id of the node in the original workflow + This maps to value of WorkflowTemplate.nodes[X].id + + .. _api_msg_flyteidl.admin.NodeExecutionList: @@ -206,7 +237,7 @@ Represents additional attributes related to a Node Execution flyteidl.admin.NodeExecutionList -------------------------------- -`[flyteidl.admin.NodeExecutionList proto] `_ +`[flyteidl.admin.NodeExecutionList proto] `_ Request structure to retrieve a list of node execution entities. @@ -236,7 +267,7 @@ token flyteidl.admin.NodeExecutionClosure ----------------------------------- -`[flyteidl.admin.NodeExecutionClosure proto] `_ +`[flyteidl.admin.NodeExecutionClosure proto] `_ Container for node execution details and results. @@ -317,7 +348,7 @@ workflow_node_metadata flyteidl.admin.WorkflowNodeMetadata ----------------------------------- -`[flyteidl.admin.WorkflowNodeMetadata proto] `_ +`[flyteidl.admin.WorkflowNodeMetadata proto] `_ Metadata for a WorkflowNode @@ -339,7 +370,7 @@ executionId flyteidl.admin.NodeExecutionGetDataRequest ------------------------------------------ -`[flyteidl.admin.NodeExecutionGetDataRequest proto] `_ +`[flyteidl.admin.NodeExecutionGetDataRequest proto] `_ Request structure to fetch inputs and output urls for a node execution. @@ -362,7 +393,7 @@ id flyteidl.admin.NodeExecutionGetDataResponse ------------------------------------------- -`[flyteidl.admin.NodeExecutionGetDataResponse proto] `_ +`[flyteidl.admin.NodeExecutionGetDataResponse proto] `_ Response structure for NodeExecutionGetDataRequest which contains inputs and outputs for a node execution. diff --git a/flyteidl/gen/pb-protodoc/flyteidl/event/event.proto.rst b/flyteidl/gen/pb-protodoc/flyteidl/event/event.proto.rst index 6252fd40f2..7032c6c987 100644 --- a/flyteidl/gen/pb-protodoc/flyteidl/event/event.proto.rst +++ b/flyteidl/gen/pb-protodoc/flyteidl/event/event.proto.rst @@ -86,7 +86,11 @@ flyteidl.event.NodeExecutionEvent "output_uri": "...", "error": "{...}", "workflow_node_metadata": "{...}", - "parent_task_metadata": "{...}" + "parent_task_metadata": "{...}", + "parent_node_metadata": "{...}", + "retry_group": "...", + "spec_node_id": "...", + "node_name": "..." } .. _api_field_flyteidl.event.NodeExecutionEvent.id: @@ -148,7 +152,32 @@ workflow_node_metadata .. _api_field_flyteidl.event.NodeExecutionEvent.parent_task_metadata: parent_task_metadata - (:ref:`flyteidl.event.ParentTaskExecutionMetadata `) Specifies which task (if any) launched this node. + (:ref:`flyteidl.event.ParentTaskExecutionMetadata `) [To be deprecated] Specifies which task (if any) launched this node. + + +.. _api_field_flyteidl.event.NodeExecutionEvent.parent_node_metadata: + +parent_node_metadata + (:ref:`flyteidl.event.ParentNodeExecutionMetadata `) Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node. + + +.. _api_field_flyteidl.event.NodeExecutionEvent.retry_group: + +retry_group + (`string `_) Retry group to indicate grouping of nodes by retries + + +.. _api_field_flyteidl.event.NodeExecutionEvent.spec_node_id: + +spec_node_id + (`string `_) Identifier of the node in the original workflow/graph + This maps to value of WorkflowTemplate.nodes[X].id + + +.. _api_field_flyteidl.event.NodeExecutionEvent.node_name: + +node_name + (`string `_) Friendly readable name for the node @@ -158,7 +187,7 @@ parent_task_metadata flyteidl.event.WorkflowNodeMetadata ----------------------------------- -`[flyteidl.event.WorkflowNodeMetadata proto] `_ +`[flyteidl.event.WorkflowNodeMetadata proto] `_ For Workflow Nodes we need to send information about the workflow that's launched @@ -180,7 +209,7 @@ execution_id flyteidl.event.ParentTaskExecutionMetadata ------------------------------------------ -`[flyteidl.event.ParentTaskExecutionMetadata proto] `_ +`[flyteidl.event.ParentTaskExecutionMetadata proto] `_ .. code-block:: json @@ -196,12 +225,35 @@ id +.. _api_msg_flyteidl.event.ParentNodeExecutionMetadata: + +flyteidl.event.ParentNodeExecutionMetadata +------------------------------------------ + +`[flyteidl.event.ParentNodeExecutionMetadata proto] `_ + + +.. code-block:: json + + { + "node_id": "..." + } + +.. _api_field_flyteidl.event.ParentNodeExecutionMetadata.node_id: + +node_id + (`string `_) Unique identifier of the parent node id within the execution + This is value of core.NodeExecutionIdentifier.node_id of the parent node + + + + .. _api_msg_flyteidl.event.TaskExecutionEvent: flyteidl.event.TaskExecutionEvent --------------------------------- -`[flyteidl.event.TaskExecutionEvent proto] `_ +`[flyteidl.event.TaskExecutionEvent proto] `_ Plugin specific execution event information. For tasks like Python, Hive, Spark, DynamicJob. diff --git a/flyteidl/gen/pb_python/flyteidl/admin/node_execution_pb2.py b/flyteidl/gen/pb_python/flyteidl/admin/node_execution_pb2.py index 5784de50e2..94d3081c75 100644 --- a/flyteidl/gen/pb_python/flyteidl/admin/node_execution_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/admin/node_execution_pb2.py @@ -25,7 +25,7 @@ package='flyteidl.admin', syntax='proto3', serialized_options=_b('Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/admin'), - serialized_pb=_b('\n#flyteidl/admin/node_execution.proto\x12\x0e\x66lyteidl.admin\x1a\x1b\x66lyteidl/admin/common.proto\x1a\x1d\x66lyteidl/core/execution.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1fgoogle/protobuf/timestamp.proto\x1a\x1egoogle/protobuf/duration.proto\"M\n\x17NodeExecutionGetRequest\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\"\xbb\x01\n\x18NodeExecutionListRequest\x12I\n\x15workflow_execution_id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\r\n\x05limit\x18\x02 \x01(\r\x12\r\n\x05token\x18\x03 \x01(\t\x12\x0f\n\x07\x66ilters\x18\x04 \x01(\t\x12%\n\x07sort_by\x18\x05 \x01(\x0b\x32\x14.flyteidl.admin.Sort\"\xba\x01\n\x1fNodeExecutionForTaskListRequest\x12\x41\n\x11task_execution_id\x18\x01 \x01(\x0b\x32&.flyteidl.core.TaskExecutionIdentifier\x12\r\n\x05limit\x18\x02 \x01(\r\x12\r\n\x05token\x18\x03 \x01(\t\x12\x0f\n\x07\x66ilters\x18\x04 \x01(\t\x12%\n\x07sort_by\x18\x05 \x01(\x0b\x32\x14.flyteidl.admin.Sort\"\xc6\x01\n\rNodeExecution\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\x12\x11\n\tinput_uri\x18\x02 \x01(\t\x12\x35\n\x07\x63losure\x18\x03 \x01(\x0b\x32$.flyteidl.admin.NodeExecutionClosure\x12\x37\n\x08metadata\x18\x04 \x01(\x0b\x32%.flyteidl.admin.NodeExecutionMetaData\"\x17\n\x15NodeExecutionMetaData\"Z\n\x11NodeExecutionList\x12\x36\n\x0fnode_executions\x18\x01 \x03(\x0b\x32\x1d.flyteidl.admin.NodeExecution\x12\r\n\x05token\x18\x02 \x01(\t\"\xb8\x03\n\x14NodeExecutionClosure\x12\x14\n\noutput_uri\x18\x01 \x01(\tH\x00\x12.\n\x05\x65rror\x18\x02 \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x12\x31\n\x05phase\x18\x03 \x01(\x0e\x32\".flyteidl.core.NodeExecution.Phase\x12.\n\nstarted_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12+\n\x08\x64uration\x18\x05 \x01(\x0b\x32\x19.google.protobuf.Duration\x12.\n\ncreated_at\x18\x06 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x07 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x46\n\x16workflow_node_metadata\x18\x08 \x01(\x0b\x32$.flyteidl.admin.WorkflowNodeMetadataH\x01\x42\x0f\n\routput_resultB\x11\n\x0ftarget_metadata\"W\n\x14WorkflowNodeMetadata\x12?\n\x0b\x65xecutionId\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"Q\n\x1bNodeExecutionGetDataRequest\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\"q\n\x1cNodeExecutionGetDataResponse\x12\'\n\x06inputs\x18\x01 \x01(\x0b\x32\x17.flyteidl.admin.UrlBlob\x12(\n\x07outputs\x18\x02 \x01(\x0b\x32\x17.flyteidl.admin.UrlBlobB3Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/adminb\x06proto3') + serialized_pb=_b('\n#flyteidl/admin/node_execution.proto\x12\x0e\x66lyteidl.admin\x1a\x1b\x66lyteidl/admin/common.proto\x1a\x1d\x66lyteidl/core/execution.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1fgoogle/protobuf/timestamp.proto\x1a\x1egoogle/protobuf/duration.proto\"M\n\x17NodeExecutionGetRequest\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\"\xd5\x01\n\x18NodeExecutionListRequest\x12I\n\x15workflow_execution_id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\r\n\x05limit\x18\x02 \x01(\r\x12\r\n\x05token\x18\x03 \x01(\t\x12\x0f\n\x07\x66ilters\x18\x04 \x01(\t\x12%\n\x07sort_by\x18\x05 \x01(\x0b\x32\x14.flyteidl.admin.Sort\x12\x18\n\x10unique_parent_id\x18\x06 \x01(\t\"\xba\x01\n\x1fNodeExecutionForTaskListRequest\x12\x41\n\x11task_execution_id\x18\x01 \x01(\x0b\x32&.flyteidl.core.TaskExecutionIdentifier\x12\r\n\x05limit\x18\x02 \x01(\r\x12\r\n\x05token\x18\x03 \x01(\t\x12\x0f\n\x07\x66ilters\x18\x04 \x01(\t\x12%\n\x07sort_by\x18\x05 \x01(\x0b\x32\x14.flyteidl.admin.Sort\"\xc6\x01\n\rNodeExecution\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\x12\x11\n\tinput_uri\x18\x02 \x01(\t\x12\x35\n\x07\x63losure\x18\x03 \x01(\x0b\x32$.flyteidl.admin.NodeExecutionClosure\x12\x37\n\x08metadata\x18\x04 \x01(\x0b\x32%.flyteidl.admin.NodeExecutionMetaData\"Z\n\x15NodeExecutionMetaData\x12\x13\n\x0bretry_group\x18\x01 \x01(\t\x12\x16\n\x0eis_parent_node\x18\x02 \x01(\x08\x12\x14\n\x0cspec_node_id\x18\x03 \x01(\t\"Z\n\x11NodeExecutionList\x12\x36\n\x0fnode_executions\x18\x01 \x03(\x0b\x32\x1d.flyteidl.admin.NodeExecution\x12\r\n\x05token\x18\x02 \x01(\t\"\xb8\x03\n\x14NodeExecutionClosure\x12\x14\n\noutput_uri\x18\x01 \x01(\tH\x00\x12.\n\x05\x65rror\x18\x02 \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x12\x31\n\x05phase\x18\x03 \x01(\x0e\x32\".flyteidl.core.NodeExecution.Phase\x12.\n\nstarted_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12+\n\x08\x64uration\x18\x05 \x01(\x0b\x32\x19.google.protobuf.Duration\x12.\n\ncreated_at\x18\x06 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x07 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x46\n\x16workflow_node_metadata\x18\x08 \x01(\x0b\x32$.flyteidl.admin.WorkflowNodeMetadataH\x01\x42\x0f\n\routput_resultB\x11\n\x0ftarget_metadata\"W\n\x14WorkflowNodeMetadata\x12?\n\x0b\x65xecutionId\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"Q\n\x1bNodeExecutionGetDataRequest\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\"q\n\x1cNodeExecutionGetDataResponse\x12\'\n\x06inputs\x18\x01 \x01(\x0b\x32\x17.flyteidl.admin.UrlBlob\x12(\n\x07outputs\x18\x02 \x01(\x0b\x32\x17.flyteidl.admin.UrlBlobB3Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/adminb\x06proto3') , dependencies=[flyteidl_dot_admin_dot_common__pb2.DESCRIPTOR,flyteidl_dot_core_dot_execution__pb2.DESCRIPTOR,flyteidl_dot_core_dot_identifier__pb2.DESCRIPTOR,google_dot_protobuf_dot_timestamp__pb2.DESCRIPTOR,google_dot_protobuf_dot_duration__pb2.DESCRIPTOR,]) @@ -105,6 +105,13 @@ message_type=None, enum_type=None, containing_type=None, is_extension=False, extension_scope=None, serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='unique_parent_id', full_name='flyteidl.admin.NodeExecutionListRequest.unique_parent_id', index=5, + number=6, type=9, cpp_type=9, label=1, + has_default_value=False, default_value=_b("").decode('utf-8'), + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), ], extensions=[ ], @@ -118,7 +125,7 @@ oneofs=[ ], serialized_start=292, - serialized_end=479, + serialized_end=505, ) @@ -176,8 +183,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=482, - serialized_end=668, + serialized_start=508, + serialized_end=694, ) @@ -228,8 +235,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=671, - serialized_end=869, + serialized_start=697, + serialized_end=895, ) @@ -240,6 +247,27 @@ file=DESCRIPTOR, containing_type=None, fields=[ + _descriptor.FieldDescriptor( + name='retry_group', full_name='flyteidl.admin.NodeExecutionMetaData.retry_group', index=0, + number=1, type=9, cpp_type=9, label=1, + has_default_value=False, default_value=_b("").decode('utf-8'), + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='is_parent_node', full_name='flyteidl.admin.NodeExecutionMetaData.is_parent_node', index=1, + number=2, type=8, cpp_type=7, label=1, + has_default_value=False, default_value=False, + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='spec_node_id', full_name='flyteidl.admin.NodeExecutionMetaData.spec_node_id', index=2, + number=3, type=9, cpp_type=9, label=1, + has_default_value=False, default_value=_b("").decode('utf-8'), + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), ], extensions=[ ], @@ -252,8 +280,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=871, - serialized_end=894, + serialized_start=897, + serialized_end=987, ) @@ -290,8 +318,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=896, - serialized_end=986, + serialized_start=989, + serialized_end=1079, ) @@ -376,8 +404,8 @@ name='target_metadata', full_name='flyteidl.admin.NodeExecutionClosure.target_metadata', index=1, containing_type=None, fields=[]), ], - serialized_start=989, - serialized_end=1429, + serialized_start=1082, + serialized_end=1522, ) @@ -407,8 +435,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1431, - serialized_end=1518, + serialized_start=1524, + serialized_end=1611, ) @@ -438,8 +466,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1520, - serialized_end=1601, + serialized_start=1613, + serialized_end=1694, ) @@ -476,8 +504,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1603, - serialized_end=1716, + serialized_start=1696, + serialized_end=1809, ) _NODEEXECUTIONGETREQUEST.fields_by_name['id'].message_type = flyteidl_dot_core_dot_identifier__pb2._NODEEXECUTIONIDENTIFIER diff --git a/flyteidl/gen/pb_python/flyteidl/event/event_pb2.py b/flyteidl/gen/pb_python/flyteidl/event/event_pb2.py index f9a4e7db8b..9ad5cf42d7 100644 --- a/flyteidl/gen/pb_python/flyteidl/event/event_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/event/event_pb2.py @@ -24,7 +24,7 @@ package='flyteidl.event', syntax='proto3', serialized_options=_b('Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/event'), - serialized_pb=_b('\n\x1a\x66lyteidl/event/event.proto\x12\x0e\x66lyteidl.event\x1a\x1d\x66lyteidl/core/execution.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1fgoogle/protobuf/timestamp.proto\x1a\x1cgoogle/protobuf/struct.proto\"\xae\x02\n\x16WorkflowExecutionEvent\x12@\n\x0c\x65xecution_id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\x13\n\x0bproducer_id\x18\x02 \x01(\t\x12\x35\n\x05phase\x18\x03 \x01(\x0e\x32&.flyteidl.core.WorkflowExecution.Phase\x12/\n\x0boccurred_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x14\n\noutput_uri\x18\x05 \x01(\tH\x00\x12.\n\x05\x65rror\x18\x06 \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x42\x0f\n\routput_result\"\xd1\x03\n\x12NodeExecutionEvent\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\x12\x13\n\x0bproducer_id\x18\x02 \x01(\t\x12\x31\n\x05phase\x18\x03 \x01(\x0e\x32\".flyteidl.core.NodeExecution.Phase\x12/\n\x0boccurred_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x11\n\tinput_uri\x18\x05 \x01(\t\x12\x14\n\noutput_uri\x18\x06 \x01(\tH\x00\x12.\n\x05\x65rror\x18\x07 \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x12\x46\n\x16workflow_node_metadata\x18\x08 \x01(\x0b\x32$.flyteidl.event.WorkflowNodeMetadataH\x01\x12I\n\x14parent_task_metadata\x18\t \x01(\x0b\x32+.flyteidl.event.ParentTaskExecutionMetadataB\x0f\n\routput_resultB\x11\n\x0ftarget_metadata\"X\n\x14WorkflowNodeMetadata\x12@\n\x0c\x65xecution_id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"Q\n\x1bParentTaskExecutionMetadata\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.TaskExecutionIdentifier\"\xef\x03\n\x12TaskExecutionEvent\x12*\n\x07task_id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12H\n\x18parent_node_execution_id\x18\x02 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\x12\x15\n\rretry_attempt\x18\x03 \x01(\r\x12\x31\n\x05phase\x18\x04 \x01(\x0e\x32\".flyteidl.core.TaskExecution.Phase\x12\x13\n\x0bproducer_id\x18\x05 \x01(\t\x12$\n\x04logs\x18\x06 \x03(\x0b\x32\x16.flyteidl.core.TaskLog\x12/\n\x0boccurred_at\x18\x07 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x11\n\tinput_uri\x18\x08 \x01(\t\x12\x14\n\noutput_uri\x18\t \x01(\tH\x00\x12.\n\x05\x65rror\x18\n \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x12,\n\x0b\x63ustom_info\x18\x0b \x01(\x0b\x32\x17.google.protobuf.Struct\x12\x15\n\rphase_version\x18\x0c \x01(\rB\x0f\n\routput_resultB3Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/eventb\x06proto3') + serialized_pb=_b('\n\x1a\x66lyteidl/event/event.proto\x12\x0e\x66lyteidl.event\x1a\x1d\x66lyteidl/core/execution.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1fgoogle/protobuf/timestamp.proto\x1a\x1cgoogle/protobuf/struct.proto\"\xae\x02\n\x16WorkflowExecutionEvent\x12@\n\x0c\x65xecution_id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\x13\n\x0bproducer_id\x18\x02 \x01(\t\x12\x35\n\x05phase\x18\x03 \x01(\x0e\x32&.flyteidl.core.WorkflowExecution.Phase\x12/\n\x0boccurred_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x14\n\noutput_uri\x18\x05 \x01(\tH\x00\x12.\n\x05\x65rror\x18\x06 \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x42\x0f\n\routput_result\"\xda\x04\n\x12NodeExecutionEvent\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\x12\x13\n\x0bproducer_id\x18\x02 \x01(\t\x12\x31\n\x05phase\x18\x03 \x01(\x0e\x32\".flyteidl.core.NodeExecution.Phase\x12/\n\x0boccurred_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x11\n\tinput_uri\x18\x05 \x01(\t\x12\x14\n\noutput_uri\x18\x06 \x01(\tH\x00\x12.\n\x05\x65rror\x18\x07 \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x12\x46\n\x16workflow_node_metadata\x18\x08 \x01(\x0b\x32$.flyteidl.event.WorkflowNodeMetadataH\x01\x12I\n\x14parent_task_metadata\x18\t \x01(\x0b\x32+.flyteidl.event.ParentTaskExecutionMetadata\x12I\n\x14parent_node_metadata\x18\n \x01(\x0b\x32+.flyteidl.event.ParentNodeExecutionMetadata\x12\x13\n\x0bretry_group\x18\x0b \x01(\t\x12\x14\n\x0cspec_node_id\x18\x0c \x01(\t\x12\x11\n\tnode_name\x18\r \x01(\tB\x0f\n\routput_resultB\x11\n\x0ftarget_metadata\"X\n\x14WorkflowNodeMetadata\x12@\n\x0c\x65xecution_id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"Q\n\x1bParentTaskExecutionMetadata\x12\x32\n\x02id\x18\x01 \x01(\x0b\x32&.flyteidl.core.TaskExecutionIdentifier\".\n\x1bParentNodeExecutionMetadata\x12\x0f\n\x07node_id\x18\x01 \x01(\t\"\xef\x03\n\x12TaskExecutionEvent\x12*\n\x07task_id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12H\n\x18parent_node_execution_id\x18\x02 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\x12\x15\n\rretry_attempt\x18\x03 \x01(\r\x12\x31\n\x05phase\x18\x04 \x01(\x0e\x32\".flyteidl.core.TaskExecution.Phase\x12\x13\n\x0bproducer_id\x18\x05 \x01(\t\x12$\n\x04logs\x18\x06 \x03(\x0b\x32\x16.flyteidl.core.TaskLog\x12/\n\x0boccurred_at\x18\x07 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x11\n\tinput_uri\x18\x08 \x01(\t\x12\x14\n\noutput_uri\x18\t \x01(\tH\x00\x12.\n\x05\x65rror\x18\n \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x12,\n\x0b\x63ustom_info\x18\x0b \x01(\x0b\x32\x17.google.protobuf.Struct\x12\x15\n\rphase_version\x18\x0c \x01(\rB\x0f\n\routput_resultB3Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/eventb\x06proto3') , dependencies=[flyteidl_dot_core_dot_execution__pb2.DESCRIPTOR,flyteidl_dot_core_dot_identifier__pb2.DESCRIPTOR,google_dot_protobuf_dot_timestamp__pb2.DESCRIPTOR,google_dot_protobuf_dot_struct__pb2.DESCRIPTOR,]) @@ -170,6 +170,34 @@ message_type=None, enum_type=None, containing_type=None, is_extension=False, extension_scope=None, serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='parent_node_metadata', full_name='flyteidl.event.NodeExecutionEvent.parent_node_metadata', index=9, + number=10, type=11, cpp_type=10, label=1, + has_default_value=False, default_value=None, + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='retry_group', full_name='flyteidl.event.NodeExecutionEvent.retry_group', index=10, + number=11, type=9, cpp_type=9, label=1, + has_default_value=False, default_value=_b("").decode('utf-8'), + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='spec_node_id', full_name='flyteidl.event.NodeExecutionEvent.spec_node_id', index=11, + number=12, type=9, cpp_type=9, label=1, + has_default_value=False, default_value=_b("").decode('utf-8'), + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='node_name', full_name='flyteidl.event.NodeExecutionEvent.node_name', index=12, + number=13, type=9, cpp_type=9, label=1, + has_default_value=False, default_value=_b("").decode('utf-8'), + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), ], extensions=[ ], @@ -189,7 +217,7 @@ index=1, containing_type=None, fields=[]), ], serialized_start=478, - serialized_end=943, + serialized_end=1080, ) @@ -219,8 +247,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=945, - serialized_end=1033, + serialized_start=1082, + serialized_end=1170, ) @@ -250,8 +278,39 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1035, - serialized_end=1116, + serialized_start=1172, + serialized_end=1253, +) + + +_PARENTNODEEXECUTIONMETADATA = _descriptor.Descriptor( + name='ParentNodeExecutionMetadata', + full_name='flyteidl.event.ParentNodeExecutionMetadata', + filename=None, + file=DESCRIPTOR, + containing_type=None, + fields=[ + _descriptor.FieldDescriptor( + name='node_id', full_name='flyteidl.event.ParentNodeExecutionMetadata.node_id', index=0, + number=1, type=9, cpp_type=9, label=1, + has_default_value=False, default_value=_b("").decode('utf-8'), + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), + ], + extensions=[ + ], + nested_types=[], + enum_types=[ + ], + serialized_options=None, + is_extendable=False, + syntax='proto3', + extension_ranges=[], + oneofs=[ + ], + serialized_start=1255, + serialized_end=1301, ) @@ -361,8 +420,8 @@ name='output_result', full_name='flyteidl.event.TaskExecutionEvent.output_result', index=0, containing_type=None, fields=[]), ], - serialized_start=1119, - serialized_end=1614, + serialized_start=1304, + serialized_end=1799, ) _WORKFLOWEXECUTIONEVENT.fields_by_name['execution_id'].message_type = flyteidl_dot_core_dot_identifier__pb2._WORKFLOWEXECUTIONIDENTIFIER @@ -381,6 +440,7 @@ _NODEEXECUTIONEVENT.fields_by_name['error'].message_type = flyteidl_dot_core_dot_execution__pb2._EXECUTIONERROR _NODEEXECUTIONEVENT.fields_by_name['workflow_node_metadata'].message_type = _WORKFLOWNODEMETADATA _NODEEXECUTIONEVENT.fields_by_name['parent_task_metadata'].message_type = _PARENTTASKEXECUTIONMETADATA +_NODEEXECUTIONEVENT.fields_by_name['parent_node_metadata'].message_type = _PARENTNODEEXECUTIONMETADATA _NODEEXECUTIONEVENT.oneofs_by_name['output_result'].fields.append( _NODEEXECUTIONEVENT.fields_by_name['output_uri']) _NODEEXECUTIONEVENT.fields_by_name['output_uri'].containing_oneof = _NODEEXECUTIONEVENT.oneofs_by_name['output_result'] @@ -409,6 +469,7 @@ DESCRIPTOR.message_types_by_name['NodeExecutionEvent'] = _NODEEXECUTIONEVENT DESCRIPTOR.message_types_by_name['WorkflowNodeMetadata'] = _WORKFLOWNODEMETADATA DESCRIPTOR.message_types_by_name['ParentTaskExecutionMetadata'] = _PARENTTASKEXECUTIONMETADATA +DESCRIPTOR.message_types_by_name['ParentNodeExecutionMetadata'] = _PARENTNODEEXECUTIONMETADATA DESCRIPTOR.message_types_by_name['TaskExecutionEvent'] = _TASKEXECUTIONEVENT _sym_db.RegisterFileDescriptor(DESCRIPTOR) @@ -440,6 +501,13 @@ )) _sym_db.RegisterMessage(ParentTaskExecutionMetadata) +ParentNodeExecutionMetadata = _reflection.GeneratedProtocolMessageType('ParentNodeExecutionMetadata', (_message.Message,), dict( + DESCRIPTOR = _PARENTNODEEXECUTIONMETADATA, + __module__ = 'flyteidl.event.event_pb2' + # @@protoc_insertion_point(class_scope:flyteidl.event.ParentNodeExecutionMetadata) + )) +_sym_db.RegisterMessage(ParentNodeExecutionMetadata) + TaskExecutionEvent = _reflection.GeneratedProtocolMessageType('TaskExecutionEvent', (_message.Message,), dict( DESCRIPTOR = _TASKEXECUTIONEVENT, __module__ = 'flyteidl.event.event_pb2' diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/README.md b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/README.md index e56d307391..f51279751f 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/README.md +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/README.md @@ -287,6 +287,7 @@ Class | Method | HTTP request | Description - [CoreWorkflowTemplate](docs/CoreWorkflowTemplate.md) - [DataLoadingConfigLiteralMapFormat](docs/DataLoadingConfigLiteralMapFormat.md) - [EventNodeExecutionEvent](docs/EventNodeExecutionEvent.md) + - [EventParentNodeExecutionMetadata](docs/EventParentNodeExecutionMetadata.md) - [EventParentTaskExecutionMetadata](docs/EventParentTaskExecutionMetadata.md) - [EventTaskExecutionEvent](docs/EventTaskExecutionEvent.md) - [EventWorkflowExecutionEvent](docs/EventWorkflowExecutionEvent.md) diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/__init__.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/__init__.py index 139afebf05..c8cb8226fd 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/__init__.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/__init__.py @@ -190,6 +190,7 @@ from flyteadmin.models.core_workflow_template import CoreWorkflowTemplate from flyteadmin.models.data_loading_config_literal_map_format import DataLoadingConfigLiteralMapFormat from flyteadmin.models.event_node_execution_event import EventNodeExecutionEvent +from flyteadmin.models.event_parent_node_execution_metadata import EventParentNodeExecutionMetadata from flyteadmin.models.event_parent_task_execution_metadata import EventParentTaskExecutionMetadata from flyteadmin.models.event_task_execution_event import EventTaskExecutionEvent from flyteadmin.models.event_workflow_execution_event import EventWorkflowExecutionEvent diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/api/admin_service_api.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/api/admin_service_api.py index 457b86c48d..631841693b 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/api/admin_service_api.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/api/admin_service_api.py @@ -3518,6 +3518,7 @@ def list_node_executions(self, workflow_execution_id_project, workflow_execution :param str filters: Indicates a list of filters passed as string. More info on constructing filters : +optional. :param str sort_by_key: Indicates an attribute to sort the response values. TODO(katrogan): Add string validation here. This should never be empty. :param str sort_by_direction: Indicates the direction to apply sort key for response values. +optional. + :param str unique_parent_id: Unique identifier of the parent node in the execution +optional. :return: AdminNodeExecutionList If the method is called asynchronously, returns the request thread. @@ -3547,12 +3548,13 @@ def list_node_executions_with_http_info(self, workflow_execution_id_project, wor :param str filters: Indicates a list of filters passed as string. More info on constructing filters : +optional. :param str sort_by_key: Indicates an attribute to sort the response values. TODO(katrogan): Add string validation here. This should never be empty. :param str sort_by_direction: Indicates the direction to apply sort key for response values. +optional. + :param str unique_parent_id: Unique identifier of the parent node in the execution +optional. :return: AdminNodeExecutionList If the method is called asynchronously, returns the request thread. """ - all_params = ['workflow_execution_id_project', 'workflow_execution_id_domain', 'workflow_execution_id_name', 'limit', 'token', 'filters', 'sort_by_key', 'sort_by_direction'] # noqa: E501 + all_params = ['workflow_execution_id_project', 'workflow_execution_id_domain', 'workflow_execution_id_name', 'limit', 'token', 'filters', 'sort_by_key', 'sort_by_direction', 'unique_parent_id'] # noqa: E501 all_params.append('async_req') all_params.append('_return_http_data_only') all_params.append('_preload_content') @@ -3601,6 +3603,8 @@ def list_node_executions_with_http_info(self, workflow_execution_id_project, wor query_params.append(('sort_by.key', params['sort_by_key'])) # noqa: E501 if 'sort_by_direction' in params: query_params.append(('sort_by.direction', params['sort_by_direction'])) # noqa: E501 + if 'unique_parent_id' in params: + query_params.append(('unique_parent_id', params['unique_parent_id'])) # noqa: E501 header_params = {} diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/__init__.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/__init__.py index 218445dad0..43495c450f 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/__init__.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/__init__.py @@ -183,6 +183,7 @@ from flyteadmin.models.core_workflow_template import CoreWorkflowTemplate from flyteadmin.models.data_loading_config_literal_map_format import DataLoadingConfigLiteralMapFormat from flyteadmin.models.event_node_execution_event import EventNodeExecutionEvent +from flyteadmin.models.event_parent_node_execution_metadata import EventParentNodeExecutionMetadata from flyteadmin.models.event_parent_task_execution_metadata import EventParentTaskExecutionMetadata from flyteadmin.models.event_task_execution_event import EventTaskExecutionEvent from flyteadmin.models.event_workflow_execution_event import EventWorkflowExecutionEvent diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_node_execution_meta_data.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_node_execution_meta_data.py index cfd8c4f738..29e520b28f 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_node_execution_meta_data.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_node_execution_meta_data.py @@ -31,15 +31,97 @@ class AdminNodeExecutionMetaData(object): and the value is json key in definition. """ swagger_types = { + 'retry_group': 'str', + 'is_parent_node': 'bool', + 'spec_node_id': 'str' } attribute_map = { + 'retry_group': 'retry_group', + 'is_parent_node': 'is_parent_node', + 'spec_node_id': 'spec_node_id' } - def __init__(self): # noqa: E501 + def __init__(self, retry_group=None, is_parent_node=None, spec_node_id=None): # noqa: E501 """AdminNodeExecutionMetaData - a model defined in Swagger""" # noqa: E501 + + self._retry_group = None + self._is_parent_node = None + self._spec_node_id = None self.discriminator = None + if retry_group is not None: + self.retry_group = retry_group + if is_parent_node is not None: + self.is_parent_node = is_parent_node + if spec_node_id is not None: + self.spec_node_id = spec_node_id + + @property + def retry_group(self): + """Gets the retry_group of this AdminNodeExecutionMetaData. # noqa: E501 + + Node executions are grouped depending on retries of the parent Retry group is unique within the context of a parent node. # noqa: E501 + + :return: The retry_group of this AdminNodeExecutionMetaData. # noqa: E501 + :rtype: str + """ + return self._retry_group + + @retry_group.setter + def retry_group(self, retry_group): + """Sets the retry_group of this AdminNodeExecutionMetaData. + + Node executions are grouped depending on retries of the parent Retry group is unique within the context of a parent node. # noqa: E501 + + :param retry_group: The retry_group of this AdminNodeExecutionMetaData. # noqa: E501 + :type: str + """ + + self._retry_group = retry_group + + @property + def is_parent_node(self): + """Gets the is_parent_node of this AdminNodeExecutionMetaData. # noqa: E501 + + + :return: The is_parent_node of this AdminNodeExecutionMetaData. # noqa: E501 + :rtype: bool + """ + return self._is_parent_node + + @is_parent_node.setter + def is_parent_node(self, is_parent_node): + """Sets the is_parent_node of this AdminNodeExecutionMetaData. + + + :param is_parent_node: The is_parent_node of this AdminNodeExecutionMetaData. # noqa: E501 + :type: bool + """ + + self._is_parent_node = is_parent_node + + @property + def spec_node_id(self): + """Gets the spec_node_id of this AdminNodeExecutionMetaData. # noqa: E501 + + + :return: The spec_node_id of this AdminNodeExecutionMetaData. # noqa: E501 + :rtype: str + """ + return self._spec_node_id + + @spec_node_id.setter + def spec_node_id(self, spec_node_id): + """Sets the spec_node_id of this AdminNodeExecutionMetaData. + + + :param spec_node_id: The spec_node_id of this AdminNodeExecutionMetaData. # noqa: E501 + :type: str + """ + + self._spec_node_id = spec_node_id + def to_dict(self): """Returns the model properties as a dict""" result = {} diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/event_node_execution_event.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/event_node_execution_event.py index ff758e5d0b..a3692c3f73 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/event_node_execution_event.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/event_node_execution_event.py @@ -19,6 +19,7 @@ from flyteadmin.models.core_execution_error import CoreExecutionError # noqa: F401,E501 from flyteadmin.models.core_node_execution_identifier import CoreNodeExecutionIdentifier # noqa: F401,E501 from flyteadmin.models.core_node_execution_phase import CoreNodeExecutionPhase # noqa: F401,E501 +from flyteadmin.models.event_parent_node_execution_metadata import EventParentNodeExecutionMetadata # noqa: F401,E501 from flyteadmin.models.event_parent_task_execution_metadata import EventParentTaskExecutionMetadata # noqa: F401,E501 from flyteadmin.models.flyteidlevent_workflow_node_metadata import FlyteidleventWorkflowNodeMetadata # noqa: F401,E501 @@ -45,7 +46,11 @@ class EventNodeExecutionEvent(object): 'output_uri': 'str', 'error': 'CoreExecutionError', 'workflow_node_metadata': 'FlyteidleventWorkflowNodeMetadata', - 'parent_task_metadata': 'EventParentTaskExecutionMetadata' + 'parent_task_metadata': 'EventParentTaskExecutionMetadata', + 'parent_node_metadata': 'EventParentNodeExecutionMetadata', + 'retry_group': 'str', + 'spec_node_id': 'str', + 'node_name': 'str' } attribute_map = { @@ -57,10 +62,14 @@ class EventNodeExecutionEvent(object): 'output_uri': 'output_uri', 'error': 'error', 'workflow_node_metadata': 'workflow_node_metadata', - 'parent_task_metadata': 'parent_task_metadata' + 'parent_task_metadata': 'parent_task_metadata', + 'parent_node_metadata': 'parent_node_metadata', + 'retry_group': 'retry_group', + 'spec_node_id': 'spec_node_id', + 'node_name': 'node_name' } - def __init__(self, id=None, producer_id=None, phase=None, occurred_at=None, input_uri=None, output_uri=None, error=None, workflow_node_metadata=None, parent_task_metadata=None): # noqa: E501 + def __init__(self, id=None, producer_id=None, phase=None, occurred_at=None, input_uri=None, output_uri=None, error=None, workflow_node_metadata=None, parent_task_metadata=None, parent_node_metadata=None, retry_group=None, spec_node_id=None, node_name=None): # noqa: E501 """EventNodeExecutionEvent - a model defined in Swagger""" # noqa: E501 self._id = None @@ -72,6 +81,10 @@ def __init__(self, id=None, producer_id=None, phase=None, occurred_at=None, inpu self._error = None self._workflow_node_metadata = None self._parent_task_metadata = None + self._parent_node_metadata = None + self._retry_group = None + self._spec_node_id = None + self._node_name = None self.discriminator = None if id is not None: @@ -92,6 +105,14 @@ def __init__(self, id=None, producer_id=None, phase=None, occurred_at=None, inpu self.workflow_node_metadata = workflow_node_metadata if parent_task_metadata is not None: self.parent_task_metadata = parent_task_metadata + if parent_node_metadata is not None: + self.parent_node_metadata = parent_node_metadata + if retry_group is not None: + self.retry_group = retry_group + if spec_node_id is not None: + self.spec_node_id = spec_node_id + if node_name is not None: + self.node_name = node_name @property def id(self): @@ -269,7 +290,7 @@ def workflow_node_metadata(self, workflow_node_metadata): def parent_task_metadata(self): """Gets the parent_task_metadata of this EventNodeExecutionEvent. # noqa: E501 - Specifies which task (if any) launched this node. # noqa: E501 + [To be deprecated] Specifies which task (if any) launched this node. # noqa: E501 :return: The parent_task_metadata of this EventNodeExecutionEvent. # noqa: E501 :rtype: EventParentTaskExecutionMetadata @@ -280,7 +301,7 @@ def parent_task_metadata(self): def parent_task_metadata(self, parent_task_metadata): """Sets the parent_task_metadata of this EventNodeExecutionEvent. - Specifies which task (if any) launched this node. # noqa: E501 + [To be deprecated] Specifies which task (if any) launched this node. # noqa: E501 :param parent_task_metadata: The parent_task_metadata of this EventNodeExecutionEvent. # noqa: E501 :type: EventParentTaskExecutionMetadata @@ -288,6 +309,92 @@ def parent_task_metadata(self, parent_task_metadata): self._parent_task_metadata = parent_task_metadata + @property + def parent_node_metadata(self): + """Gets the parent_node_metadata of this EventNodeExecutionEvent. # noqa: E501 + + Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node. # noqa: E501 + + :return: The parent_node_metadata of this EventNodeExecutionEvent. # noqa: E501 + :rtype: EventParentNodeExecutionMetadata + """ + return self._parent_node_metadata + + @parent_node_metadata.setter + def parent_node_metadata(self, parent_node_metadata): + """Sets the parent_node_metadata of this EventNodeExecutionEvent. + + Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node. # noqa: E501 + + :param parent_node_metadata: The parent_node_metadata of this EventNodeExecutionEvent. # noqa: E501 + :type: EventParentNodeExecutionMetadata + """ + + self._parent_node_metadata = parent_node_metadata + + @property + def retry_group(self): + """Gets the retry_group of this EventNodeExecutionEvent. # noqa: E501 + + + :return: The retry_group of this EventNodeExecutionEvent. # noqa: E501 + :rtype: str + """ + return self._retry_group + + @retry_group.setter + def retry_group(self, retry_group): + """Sets the retry_group of this EventNodeExecutionEvent. + + + :param retry_group: The retry_group of this EventNodeExecutionEvent. # noqa: E501 + :type: str + """ + + self._retry_group = retry_group + + @property + def spec_node_id(self): + """Gets the spec_node_id of this EventNodeExecutionEvent. # noqa: E501 + + + :return: The spec_node_id of this EventNodeExecutionEvent. # noqa: E501 + :rtype: str + """ + return self._spec_node_id + + @spec_node_id.setter + def spec_node_id(self, spec_node_id): + """Sets the spec_node_id of this EventNodeExecutionEvent. + + + :param spec_node_id: The spec_node_id of this EventNodeExecutionEvent. # noqa: E501 + :type: str + """ + + self._spec_node_id = spec_node_id + + @property + def node_name(self): + """Gets the node_name of this EventNodeExecutionEvent. # noqa: E501 + + + :return: The node_name of this EventNodeExecutionEvent. # noqa: E501 + :rtype: str + """ + return self._node_name + + @node_name.setter + def node_name(self, node_name): + """Sets the node_name of this EventNodeExecutionEvent. + + + :param node_name: The node_name of this EventNodeExecutionEvent. # noqa: E501 + :type: str + """ + + self._node_name = node_name + def to_dict(self): """Returns the model properties as a dict""" result = {} diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/event_parent_node_execution_metadata.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/event_parent_node_execution_metadata.py new file mode 100644 index 0000000000..8ca2ec7492 --- /dev/null +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/event_parent_node_execution_metadata.py @@ -0,0 +1,115 @@ +# coding: utf-8 + +""" + flyteidl/service/admin.proto + + No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen) # noqa: E501 + + OpenAPI spec version: version not set + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + + +import pprint +import re # noqa: F401 + +import six + + +class EventParentNodeExecutionMetadata(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'node_id': 'str' + } + + attribute_map = { + 'node_id': 'node_id' + } + + def __init__(self, node_id=None): # noqa: E501 + """EventParentNodeExecutionMetadata - a model defined in Swagger""" # noqa: E501 + + self._node_id = None + self.discriminator = None + + if node_id is not None: + self.node_id = node_id + + @property + def node_id(self): + """Gets the node_id of this EventParentNodeExecutionMetadata. # noqa: E501 + + + :return: The node_id of this EventParentNodeExecutionMetadata. # noqa: E501 + :rtype: str + """ + return self._node_id + + @node_id.setter + def node_id(self, node_id): + """Sets the node_id of this EventParentNodeExecutionMetadata. + + + :param node_id: The node_id of this EventParentNodeExecutionMetadata. # noqa: E501 + :type: str + """ + + self._node_id = node_id + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(EventParentNodeExecutionMetadata, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, EventParentNodeExecutionMetadata): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_event_parent_node_execution_metadata.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_event_parent_node_execution_metadata.py new file mode 100644 index 0000000000..3e91fb9a11 --- /dev/null +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_event_parent_node_execution_metadata.py @@ -0,0 +1,40 @@ +# coding: utf-8 + +""" + flyteidl/service/admin.proto + + No description provided (generated by Swagger Codegen https://github.com/swagger-api/swagger-codegen) # noqa: E501 + + OpenAPI spec version: version not set + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + + +from __future__ import absolute_import + +import unittest + +import flyteadmin +from flyteadmin.models.event_parent_node_execution_metadata import EventParentNodeExecutionMetadata # noqa: E501 +from flyteadmin.rest import ApiException + + +class TestEventParentNodeExecutionMetadata(unittest.TestCase): + """EventParentNodeExecutionMetadata unit test stubs""" + + def setUp(self): + pass + + def tearDown(self): + pass + + def testEventParentNodeExecutionMetadata(self): + """Test EventParentNodeExecutionMetadata""" + # FIXME: construct object with mandatory attributes with example values + # model = flyteadmin.models.event_parent_node_execution_metadata.EventParentNodeExecutionMetadata() # noqa: E501 + pass + + +if __name__ == '__main__': + unittest.main() diff --git a/flyteidl/protos/flyteidl/admin/node_execution.proto b/flyteidl/protos/flyteidl/admin/node_execution.proto index a2e4fe5b1a..e794dfc4b0 100644 --- a/flyteidl/protos/flyteidl/admin/node_execution.proto +++ b/flyteidl/protos/flyteidl/admin/node_execution.proto @@ -35,6 +35,10 @@ message NodeExecutionListRequest { // Sort ordering. // +optional Sort sort_by = 5; + + // Unique identifier of the parent node in the execution + // +optional + string unique_parent_id = 6; } // Represents a request structure to retrieve a list of node execution entities launched by a specific task. @@ -79,6 +83,16 @@ message NodeExecution { // Represents additional attributes related to a Node Execution message NodeExecutionMetaData { + // Node executions are grouped depending on retries of the parent + // Retry group is unique within the context of a parent node. + string retry_group = 1; + + // Boolean flag indicating if the node has child nodes under it + bool is_parent_node = 2; + + // Node id of the node in the original workflow + // This maps to value of WorkflowTemplate.nodes[X].id + string spec_node_id = 3; } // Request structure to retrieve a list of node execution entities. diff --git a/flyteidl/protos/flyteidl/event/event.proto b/flyteidl/protos/flyteidl/event/event.proto index f3eb03a34d..c6e5ddafdd 100644 --- a/flyteidl/protos/flyteidl/event/event.proto +++ b/flyteidl/protos/flyteidl/event/event.proto @@ -62,8 +62,21 @@ message NodeExecutionEvent { WorkflowNodeMetadata workflow_node_metadata = 8; } - // Specifies which task (if any) launched this node. + // [To be deprecated] Specifies which task (if any) launched this node. ParentTaskExecutionMetadata parent_task_metadata = 9; + + // Specifies the parent node of the current node execution. Node executions at level zero will not have a parent node. + ParentNodeExecutionMetadata parent_node_metadata = 10; + + // Retry group to indicate grouping of nodes by retries + string retry_group = 11; + + // Identifier of the node in the original workflow/graph + // This maps to value of WorkflowTemplate.nodes[X].id + string spec_node_id = 12; + + // Friendly readable name for the node + string node_name = 13; } // For Workflow Nodes we need to send information about the workflow that's launched @@ -75,6 +88,12 @@ message ParentTaskExecutionMetadata { core.TaskExecutionIdentifier id = 1; } +message ParentNodeExecutionMetadata { + // Unique identifier of the parent node id within the execution + // This is value of core.NodeExecutionIdentifier.node_id of the parent node + string node_id = 1; +} + // Plugin specific execution event information. For tasks like Python, Hive, Spark, DynamicJob. message TaskExecutionEvent { // ID of the task. In combination with the retryAttempt this will indicate