diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.cc index 9387fe1efb3..577b434fa6b 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.cc @@ -27,9 +27,10 @@ extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fexecution_2eproto ::google::p extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_NotificationList_flyteidl_2fadmin_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<3> scc_info_Execution_flyteidl_2fadmin_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<4> scc_info_ExecutionMetadata_flyteidl_2fadmin_2fexecution_2eproto; -extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<7> scc_info_ExecutionSpec_flyteidl_2fadmin_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<8> scc_info_ExecutionClosure_flyteidl_2fadmin_2fexecution_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<8> scc_info_ExecutionSpec_flyteidl_2fadmin_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_ExecutionError_flyteidl_2fcore_2fexecution_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fidentifier_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_Identifier_flyteidl_2fcore_2fidentifier_2eproto; 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; @@ -318,15 +319,16 @@ static void InitDefaultsExecutionSpec_flyteidl_2fadmin_2fexecution_2eproto() { ::flyteidl::admin::ExecutionSpec::InitAsDefaultInstance(); } -::google::protobuf::internal::SCCInfo<7> scc_info_ExecutionSpec_flyteidl_2fadmin_2fexecution_2eproto = - {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 7, InitDefaultsExecutionSpec_flyteidl_2fadmin_2fexecution_2eproto}, { +::google::protobuf::internal::SCCInfo<8> scc_info_ExecutionSpec_flyteidl_2fadmin_2fexecution_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 8, InitDefaultsExecutionSpec_flyteidl_2fadmin_2fexecution_2eproto}, { &scc_info_Identifier_flyteidl_2fcore_2fidentifier_2eproto.base, &scc_info_Literal_flyteidl_2fcore_2fliterals_2eproto.base, &scc_info_ExecutionMetadata_flyteidl_2fadmin_2fexecution_2eproto.base, &scc_info_NotificationList_flyteidl_2fadmin_2fexecution_2eproto.base, &scc_info_Labels_flyteidl_2fadmin_2fcommon_2eproto.base, &scc_info_Annotations_flyteidl_2fadmin_2fcommon_2eproto.base, - &scc_info_AuthRole_flyteidl_2fadmin_2fcommon_2eproto.base,}}; + &scc_info_AuthRole_flyteidl_2fadmin_2fcommon_2eproto.base, + &scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto.base,}}; static void InitDefaultsExecutionTerminateRequest_flyteidl_2fadmin_2fexecution_2eproto() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -526,6 +528,7 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2fexecution_2eprot PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ExecutionSpec, labels_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ExecutionSpec, annotations_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ExecutionSpec, auth_role_), + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ExecutionSpec, quality_of_service_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ExecutionSpec, notification_overrides_), ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ExecutionTerminateRequest, _internal_metadata_), @@ -567,10 +570,10 @@ static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SE { 83, -1, sizeof(::flyteidl::admin::ExecutionMetadata)}, { 95, -1, sizeof(::flyteidl::admin::NotificationList)}, { 101, -1, sizeof(::flyteidl::admin::ExecutionSpec)}, - { 115, -1, sizeof(::flyteidl::admin::ExecutionTerminateRequest)}, - { 122, -1, sizeof(::flyteidl::admin::ExecutionTerminateResponse)}, - { 127, -1, sizeof(::flyteidl::admin::WorkflowExecutionGetDataRequest)}, - { 133, -1, sizeof(::flyteidl::admin::WorkflowExecutionGetDataResponse)}, + { 116, -1, sizeof(::flyteidl::admin::ExecutionTerminateRequest)}, + { 123, -1, sizeof(::flyteidl::admin::ExecutionTerminateResponse)}, + { 128, -1, sizeof(::flyteidl::admin::WorkflowExecutionGetDataRequest)}, + { 134, -1, sizeof(::flyteidl::admin::WorkflowExecutionGetDataResponse)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -656,7 +659,7 @@ const char descriptor_table_protodef_flyteidl_2fadmin_2fexecution_2eproto[] = "CHEDULED\020\001\022\n\n\006SYSTEM\020\002\022\014\n\010RELAUNCH\020\003\022\022\n\016" "CHILD_WORKFLOW\020\004\"G\n\020NotificationList\0223\n\r" "notifications\030\001 \003(\0132\034.flyteidl.admin.Not" - "ification\"\234\003\n\rExecutionSpec\022.\n\013launch_pl" + "ification\"\331\003\n\rExecutionSpec\022.\n\013launch_pl" "an\030\001 \001(\0132\031.flyteidl.core.Identifier\022-\n\006i" "nputs\030\002 \001(\0132\031.flyteidl.core.LiteralMapB\002" "\030\001\0223\n\010metadata\030\003 \001(\0132!.flyteidl.admin.Ex" @@ -665,23 +668,25 @@ const char descriptor_table_protodef_flyteidl_2fadmin_2fexecution_2eproto[] = "sable_all\030\006 \001(\010H\000\022&\n\006labels\030\007 \001(\0132\026.flyt" "eidl.admin.Labels\0220\n\013annotations\030\010 \001(\0132\033" ".flyteidl.admin.Annotations\022+\n\tauth_role" - "\030\020 \001(\0132\030.flyteidl.admin.AuthRoleB\030\n\026noti" - "fication_overridesJ\004\010\004\020\005\"b\n\031ExecutionTer" - "minateRequest\0226\n\002id\030\001 \001(\0132*.flyteidl.cor" - "e.WorkflowExecutionIdentifier\022\r\n\005cause\030\002" - " \001(\t\"\034\n\032ExecutionTerminateResponse\"Y\n\037Wo" - "rkflowExecutionGetDataRequest\0226\n\002id\030\001 \001(" - "\0132*.flyteidl.core.WorkflowExecutionIdent" - "ifier\"u\n WorkflowExecutionGetDataRespons" - "e\022(\n\007outputs\030\001 \001(\0132\027.flyteidl.admin.UrlB" - "lob\022\'\n\006inputs\030\002 \001(\0132\027.flyteidl.admin.Url" - "BlobB3Z1github.com/lyft/flyteidl/gen/pb-" - "go/flyteidl/adminb\006proto3" + "\030\020 \001(\0132\030.flyteidl.admin.AuthRole\022;\n\022qual" + "ity_of_service\030\021 \001(\0132\037.flyteidl.core.Qua" + "lityOfServiceB\030\n\026notification_overridesJ" + "\004\010\004\020\005\"b\n\031ExecutionTerminateRequest\0226\n\002id" + "\030\001 \001(\0132*.flyteidl.core.WorkflowExecution" + "Identifier\022\r\n\005cause\030\002 \001(\t\"\034\n\032ExecutionTe" + "rminateResponse\"Y\n\037WorkflowExecutionGetD" + "ataRequest\0226\n\002id\030\001 \001(\0132*.flyteidl.core.W" + "orkflowExecutionIdentifier\"u\n WorkflowEx" + "ecutionGetDataResponse\022(\n\007outputs\030\001 \001(\0132" + "\027.flyteidl.admin.UrlBlob\022\'\n\006inputs\030\002 \001(\013" + "2\027.flyteidl.admin.UrlBlobB3Z1github.com/" + "lyft/flyteidl/gen/pb-go/flyteidl/adminb\006" + "proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fadmin_2fexecution_2eproto = { false, InitDefaults_flyteidl_2fadmin_2fexecution_2eproto, descriptor_table_protodef_flyteidl_2fadmin_2fexecution_2eproto, - "flyteidl/admin/execution.proto", &assign_descriptors_table_flyteidl_2fadmin_2fexecution_2eproto, 3065, + "flyteidl/admin/execution.proto", &assign_descriptors_table_flyteidl_2fadmin_2fexecution_2eproto, 3126, }; void AddDescriptors_flyteidl_2fadmin_2fexecution_2eproto() { @@ -6229,6 +6234,8 @@ void ExecutionSpec::InitAsDefaultInstance() { ::flyteidl::admin::Annotations::internal_default_instance()); ::flyteidl::admin::_ExecutionSpec_default_instance_._instance.get_mutable()->auth_role_ = const_cast< ::flyteidl::admin::AuthRole*>( ::flyteidl::admin::AuthRole::internal_default_instance()); + ::flyteidl::admin::_ExecutionSpec_default_instance_._instance.get_mutable()->quality_of_service_ = const_cast< ::flyteidl::core::QualityOfService*>( + ::flyteidl::core::QualityOfService::internal_default_instance()); } class ExecutionSpec::HasBitSetters { public: @@ -6239,6 +6246,7 @@ class ExecutionSpec::HasBitSetters { static const ::flyteidl::admin::Labels& labels(const ExecutionSpec* msg); static const ::flyteidl::admin::Annotations& annotations(const ExecutionSpec* msg); static const ::flyteidl::admin::AuthRole& auth_role(const ExecutionSpec* msg); + static const ::flyteidl::core::QualityOfService& quality_of_service(const ExecutionSpec* msg); }; const ::flyteidl::core::Identifier& @@ -6269,6 +6277,10 @@ const ::flyteidl::admin::AuthRole& ExecutionSpec::HasBitSetters::auth_role(const ExecutionSpec* msg) { return *msg->auth_role_; } +const ::flyteidl::core::QualityOfService& +ExecutionSpec::HasBitSetters::quality_of_service(const ExecutionSpec* msg) { + return *msg->quality_of_service_; +} void ExecutionSpec::clear_launch_plan() { if (GetArenaNoVirtual() == nullptr && launch_plan_ != nullptr) { delete launch_plan_; @@ -6313,6 +6325,12 @@ void ExecutionSpec::clear_auth_role() { } auth_role_ = nullptr; } +void ExecutionSpec::clear_quality_of_service() { + if (GetArenaNoVirtual() == nullptr && quality_of_service_ != nullptr) { + delete quality_of_service_; + } + quality_of_service_ = nullptr; +} #if !defined(_MSC_VER) || _MSC_VER >= 1900 const int ExecutionSpec::kLaunchPlanFieldNumber; const int ExecutionSpec::kInputsFieldNumber; @@ -6322,6 +6340,7 @@ const int ExecutionSpec::kDisableAllFieldNumber; const int ExecutionSpec::kLabelsFieldNumber; const int ExecutionSpec::kAnnotationsFieldNumber; const int ExecutionSpec::kAuthRoleFieldNumber; +const int ExecutionSpec::kQualityOfServiceFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 ExecutionSpec::ExecutionSpec() @@ -6363,6 +6382,11 @@ ExecutionSpec::ExecutionSpec(const ExecutionSpec& from) } else { auth_role_ = nullptr; } + if (from.has_quality_of_service()) { + quality_of_service_ = new ::flyteidl::core::QualityOfService(*from.quality_of_service_); + } else { + quality_of_service_ = nullptr; + } clear_has_notification_overrides(); switch (from.notification_overrides_case()) { case kNotifications: { @@ -6384,8 +6408,8 @@ void ExecutionSpec::SharedCtor() { ::google::protobuf::internal::InitSCC( &scc_info_ExecutionSpec_flyteidl_2fadmin_2fexecution_2eproto.base); ::memset(&launch_plan_, 0, static_cast( - reinterpret_cast(&auth_role_) - - reinterpret_cast(&launch_plan_)) + sizeof(auth_role_)); + reinterpret_cast(&quality_of_service_) - + reinterpret_cast(&launch_plan_)) + sizeof(quality_of_service_)); clear_has_notification_overrides(); } @@ -6401,6 +6425,7 @@ void ExecutionSpec::SharedDtor() { if (this != internal_default_instance()) delete labels_; if (this != internal_default_instance()) delete annotations_; if (this != internal_default_instance()) delete auth_role_; + if (this != internal_default_instance()) delete quality_of_service_; if (has_notification_overrides()) { clear_notification_overrides(); } @@ -6464,6 +6489,10 @@ void ExecutionSpec::Clear() { delete auth_role_; } auth_role_ = nullptr; + if (GetArenaNoVirtual() == nullptr && quality_of_service_ != nullptr) { + delete quality_of_service_; + } + quality_of_service_ = nullptr; clear_notification_overrides(); _internal_metadata_.Clear(); } @@ -6579,6 +6608,19 @@ const char* ExecutionSpec::_InternalParse(const char* begin, const char* end, vo {parser_till_end, object}, ptr - size, ptr)); break; } + // .flyteidl.core.QualityOfService quality_of_service = 17; + case 17: { + if (static_cast<::google::protobuf::uint8>(tag) != 138) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + parser_till_end = ::flyteidl::core::QualityOfService::_InternalParse; + object = msg->mutable_quality_of_service(); + 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; + } default: { handle_unusual: if ((tag & 7) == 4 || tag == 0) { @@ -6700,6 +6742,17 @@ bool ExecutionSpec::MergePartialFromCodedStream( break; } + // .flyteidl.core.QualityOfService quality_of_service = 17; + case 17: { + if (static_cast< ::google::protobuf::uint8>(tag) == (138 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_quality_of_service())); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -6774,6 +6827,12 @@ void ExecutionSpec::SerializeWithCachedSizes( 16, HasBitSetters::auth_role(this), output); } + // .flyteidl.core.QualityOfService quality_of_service = 17; + if (this->has_quality_of_service()) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 17, HasBitSetters::quality_of_service(this), output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -6841,6 +6900,13 @@ ::google::protobuf::uint8* ExecutionSpec::InternalSerializeWithCachedSizesToArra 16, HasBitSetters::auth_role(this), target); } + // .flyteidl.core.QualityOfService quality_of_service = 17; + if (this->has_quality_of_service()) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 17, HasBitSetters::quality_of_service(this), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -6904,6 +6970,13 @@ size_t ExecutionSpec::ByteSizeLong() const { *auth_role_); } + // .flyteidl.core.QualityOfService quality_of_service = 17; + if (this->has_quality_of_service()) { + total_size += 2 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *quality_of_service_); + } + switch (notification_overrides_case()) { // .flyteidl.admin.NotificationList notifications = 5; case kNotifications: { @@ -6966,6 +7039,9 @@ void ExecutionSpec::MergeFrom(const ExecutionSpec& from) { if (from.has_auth_role()) { mutable_auth_role()->::flyteidl::admin::AuthRole::MergeFrom(from.auth_role()); } + if (from.has_quality_of_service()) { + mutable_quality_of_service()->::flyteidl::core::QualityOfService::MergeFrom(from.quality_of_service()); + } switch (from.notification_overrides_case()) { case kNotifications: { mutable_notifications()->::flyteidl::admin::NotificationList::MergeFrom(from.notifications()); @@ -7012,6 +7088,7 @@ void ExecutionSpec::InternalSwap(ExecutionSpec* other) { swap(labels_, other->labels_); swap(annotations_, other->annotations_); swap(auth_role_, other->auth_role_); + swap(quality_of_service_, other->quality_of_service_); swap(notification_overrides_, other->notification_overrides_); swap(_oneof_case_[0], other->_oneof_case_[0]); } diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.h b/flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.h index 3de047b3817..6e2b5a01d17 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/execution.pb.h @@ -2098,6 +2098,15 @@ class ExecutionSpec final : ::flyteidl::admin::AuthRole* mutable_auth_role(); void set_allocated_auth_role(::flyteidl::admin::AuthRole* auth_role); + // .flyteidl.core.QualityOfService quality_of_service = 17; + bool has_quality_of_service() const; + void clear_quality_of_service(); + static const int kQualityOfServiceFieldNumber = 17; + const ::flyteidl::core::QualityOfService& quality_of_service() const; + ::flyteidl::core::QualityOfService* release_quality_of_service(); + ::flyteidl::core::QualityOfService* mutable_quality_of_service(); + void set_allocated_quality_of_service(::flyteidl::core::QualityOfService* quality_of_service); + // .flyteidl.admin.NotificationList notifications = 5; bool has_notifications() const; void clear_notifications(); @@ -2134,6 +2143,7 @@ class ExecutionSpec final : ::flyteidl::admin::Labels* labels_; ::flyteidl::admin::Annotations* annotations_; ::flyteidl::admin::AuthRole* auth_role_; + ::flyteidl::core::QualityOfService* quality_of_service_; union NotificationOverridesUnion { NotificationOverridesUnion() {} ::flyteidl::admin::NotificationList* notifications_; @@ -4820,6 +4830,51 @@ inline void ExecutionSpec::set_allocated_auth_role(::flyteidl::admin::AuthRole* // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.ExecutionSpec.auth_role) } +// .flyteidl.core.QualityOfService quality_of_service = 17; +inline bool ExecutionSpec::has_quality_of_service() const { + return this != internal_default_instance() && quality_of_service_ != nullptr; +} +inline const ::flyteidl::core::QualityOfService& ExecutionSpec::quality_of_service() const { + const ::flyteidl::core::QualityOfService* p = quality_of_service_; + // @@protoc_insertion_point(field_get:flyteidl.admin.ExecutionSpec.quality_of_service) + return p != nullptr ? *p : *reinterpret_cast( + &::flyteidl::core::_QualityOfService_default_instance_); +} +inline ::flyteidl::core::QualityOfService* ExecutionSpec::release_quality_of_service() { + // @@protoc_insertion_point(field_release:flyteidl.admin.ExecutionSpec.quality_of_service) + + ::flyteidl::core::QualityOfService* temp = quality_of_service_; + quality_of_service_ = nullptr; + return temp; +} +inline ::flyteidl::core::QualityOfService* ExecutionSpec::mutable_quality_of_service() { + + if (quality_of_service_ == nullptr) { + auto* p = CreateMaybeMessage<::flyteidl::core::QualityOfService>(GetArenaNoVirtual()); + quality_of_service_ = p; + } + // @@protoc_insertion_point(field_mutable:flyteidl.admin.ExecutionSpec.quality_of_service) + return quality_of_service_; +} +inline void ExecutionSpec::set_allocated_quality_of_service(::flyteidl::core::QualityOfService* quality_of_service) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + if (message_arena == nullptr) { + delete reinterpret_cast< ::google::protobuf::MessageLite*>(quality_of_service_); + } + if (quality_of_service) { + ::google::protobuf::Arena* submessage_arena = nullptr; + if (message_arena != submessage_arena) { + quality_of_service = ::google::protobuf::internal::GetOwnedMessage( + message_arena, quality_of_service, submessage_arena); + } + + } else { + + } + quality_of_service_ = quality_of_service; + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.ExecutionSpec.quality_of_service) +} + inline bool ExecutionSpec::has_notification_overrides() const { return notification_overrides_case() != NOTIFICATION_OVERRIDES_NOT_SET; } diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/launch_plan.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/launch_plan.pb.cc index 2b6867c5438..4ecacbea86e 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/launch_plan.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/launch_plan.pb.cc @@ -26,8 +26,9 @@ extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2flaunch_5fplan_2eproto ::googl extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2flaunch_5fplan_2eproto ::google::protobuf::internal::SCCInfo<2> scc_info_LaunchPlanMetadata_flyteidl_2fadmin_2flaunch_5fplan_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2flaunch_5fplan_2eproto ::google::protobuf::internal::SCCInfo<3> scc_info_LaunchPlanClosure_flyteidl_2fadmin_2flaunch_5fplan_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2flaunch_5fplan_2eproto ::google::protobuf::internal::SCCInfo<3> scc_info_LaunchPlan_flyteidl_2fadmin_2flaunch_5fplan_2eproto; -extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2flaunch_5fplan_2eproto ::google::protobuf::internal::SCCInfo<8> scc_info_LaunchPlanSpec_flyteidl_2fadmin_2flaunch_5fplan_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2flaunch_5fplan_2eproto ::google::protobuf::internal::SCCInfo<9> scc_info_LaunchPlanSpec_flyteidl_2fadmin_2flaunch_5fplan_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fschedule_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_Schedule_flyteidl_2fadmin_2fschedule_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fidentifier_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_Identifier_flyteidl_2fcore_2fidentifier_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2finterface_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_ParameterMap_flyteidl_2fcore_2finterface_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2finterface_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_VariableMap_flyteidl_2fcore_2finterface_2eproto; @@ -174,8 +175,8 @@ static void InitDefaultsLaunchPlanSpec_flyteidl_2fadmin_2flaunch_5fplan_2eproto( ::flyteidl::admin::LaunchPlanSpec::InitAsDefaultInstance(); } -::google::protobuf::internal::SCCInfo<8> scc_info_LaunchPlanSpec_flyteidl_2fadmin_2flaunch_5fplan_2eproto = - {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 8, InitDefaultsLaunchPlanSpec_flyteidl_2fadmin_2flaunch_5fplan_2eproto}, { +::google::protobuf::internal::SCCInfo<9> scc_info_LaunchPlanSpec_flyteidl_2fadmin_2flaunch_5fplan_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 9, InitDefaultsLaunchPlanSpec_flyteidl_2fadmin_2flaunch_5fplan_2eproto}, { &scc_info_Identifier_flyteidl_2fcore_2fidentifier_2eproto.base, &scc_info_LaunchPlanMetadata_flyteidl_2fadmin_2flaunch_5fplan_2eproto.base, &scc_info_ParameterMap_flyteidl_2fcore_2finterface_2eproto.base, @@ -183,7 +184,8 @@ ::google::protobuf::internal::SCCInfo<8> scc_info_LaunchPlanSpec_flyteidl_2fadmi &scc_info_Labels_flyteidl_2fadmin_2fcommon_2eproto.base, &scc_info_Annotations_flyteidl_2fadmin_2fcommon_2eproto.base, &scc_info_Auth_flyteidl_2fadmin_2flaunch_5fplan_2eproto.base, - &scc_info_AuthRole_flyteidl_2fadmin_2fcommon_2eproto.base,}}; + &scc_info_AuthRole_flyteidl_2fadmin_2fcommon_2eproto.base, + &scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto.base,}}; static void InitDefaultsLaunchPlanClosure_flyteidl_2fadmin_2flaunch_5fplan_2eproto() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -346,6 +348,7 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2flaunch_5fplan_2e PROTOBUF_FIELD_OFFSET(::flyteidl::admin::LaunchPlanSpec, annotations_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::LaunchPlanSpec, auth_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::LaunchPlanSpec, auth_role_), + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::LaunchPlanSpec, quality_of_service_), ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::admin::LaunchPlanClosure, _internal_metadata_), ~0u, // no _extensions_ @@ -399,12 +402,12 @@ static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SE { 20, -1, sizeof(::flyteidl::admin::LaunchPlanList)}, { 27, -1, sizeof(::flyteidl::admin::Auth)}, { 35, -1, sizeof(::flyteidl::admin::LaunchPlanSpec)}, - { 49, -1, sizeof(::flyteidl::admin::LaunchPlanClosure)}, - { 59, -1, sizeof(::flyteidl::admin::LaunchPlanMetadata)}, - { 66, -1, sizeof(::flyteidl::admin::LaunchPlanUpdateRequest)}, - { 73, -1, sizeof(::flyteidl::admin::LaunchPlanUpdateResponse)}, - { 78, -1, sizeof(::flyteidl::admin::ActiveLaunchPlanRequest)}, - { 84, -1, sizeof(::flyteidl::admin::ActiveLaunchPlanListRequest)}, + { 50, -1, sizeof(::flyteidl::admin::LaunchPlanClosure)}, + { 60, -1, sizeof(::flyteidl::admin::LaunchPlanMetadata)}, + { 67, -1, sizeof(::flyteidl::admin::LaunchPlanUpdateRequest)}, + { 74, -1, sizeof(::flyteidl::admin::LaunchPlanUpdateResponse)}, + { 79, -1, sizeof(::flyteidl::admin::ActiveLaunchPlanRequest)}, + { 85, -1, sizeof(::flyteidl::admin::ActiveLaunchPlanListRequest)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -430,65 +433,68 @@ ::google::protobuf::internal::AssignDescriptorsTable assign_descriptors_table_fl const char descriptor_table_protodef_flyteidl_2fadmin_2flaunch_5fplan_2eproto[] = "\n flyteidl/admin/launch_plan.proto\022\016flyt" - "eidl.admin\032\034flyteidl/core/literals.proto" - "\032\036flyteidl/core/identifier.proto\032\035flytei" - "dl/core/interface.proto\032\035flyteidl/admin/" - "schedule.proto\032\033flyteidl/admin/common.pr" - "oto\032\037google/protobuf/timestamp.proto\"n\n\027" - "LaunchPlanCreateRequest\022%\n\002id\030\001 \001(\0132\031.fl" - "yteidl.core.Identifier\022,\n\004spec\030\002 \001(\0132\036.f" - "lyteidl.admin.LaunchPlanSpec\"\032\n\030LaunchPl" - "anCreateResponse\"\225\001\n\nLaunchPlan\022%\n\002id\030\001 " - "\001(\0132\031.flyteidl.core.Identifier\022,\n\004spec\030\002" - " \001(\0132\036.flyteidl.admin.LaunchPlanSpec\0222\n\007" - "closure\030\003 \001(\0132!.flyteidl.admin.LaunchPla" - "nClosure\"Q\n\016LaunchPlanList\0220\n\014launch_pla" - "ns\030\001 \003(\0132\032.flyteidl.admin.LaunchPlan\022\r\n\005" - "token\030\002 \001(\t\"T\n\004Auth\022\034\n\022assumable_iam_rol" - "e\030\001 \001(\tH\000\022$\n\032kubernetes_service_account\030" - "\002 \001(\tH\000B\010\n\006method\"\244\003\n\016LaunchPlanSpec\022.\n\013" - "workflow_id\030\001 \001(\0132\031.flyteidl.core.Identi" - "fier\022;\n\017entity_metadata\030\002 \001(\0132\".flyteidl" - ".admin.LaunchPlanMetadata\0223\n\016default_inp" - "uts\030\003 \001(\0132\033.flyteidl.core.ParameterMap\022/" - "\n\014fixed_inputs\030\004 \001(\0132\031.flyteidl.core.Lit" - "eralMap\022\020\n\004role\030\005 \001(\tB\002\030\001\022&\n\006labels\030\006 \001(" - "\0132\026.flyteidl.admin.Labels\0220\n\013annotations" - "\030\007 \001(\0132\033.flyteidl.admin.Annotations\022&\n\004a" - "uth\030\010 \001(\0132\024.flyteidl.admin.AuthB\002\030\001\022+\n\ta" - "uth_role\030\t \001(\0132\030.flyteidl.admin.AuthRole" - "\"\217\002\n\021LaunchPlanClosure\022.\n\005state\030\001 \001(\0162\037." - "flyteidl.admin.LaunchPlanState\0224\n\017expect" - "ed_inputs\030\002 \001(\0132\033.flyteidl.core.Paramete" - "rMap\0224\n\020expected_outputs\030\003 \001(\0132\032.flyteid" - "l.core.VariableMap\022.\n\ncreated_at\030\004 \001(\0132\032" - ".google.protobuf.Timestamp\022.\n\nupdated_at" - "\030\005 \001(\0132\032.google.protobuf.Timestamp\"u\n\022La" - "unchPlanMetadata\022*\n\010schedule\030\001 \001(\0132\030.fly" - "teidl.admin.Schedule\0223\n\rnotifications\030\002 " - "\003(\0132\034.flyteidl.admin.Notification\"p\n\027Lau" - "nchPlanUpdateRequest\022%\n\002id\030\001 \001(\0132\031.flyte" - "idl.core.Identifier\022.\n\005state\030\002 \001(\0162\037.fly" - "teidl.admin.LaunchPlanState\"\032\n\030LaunchPla" - "nUpdateResponse\"L\n\027ActiveLaunchPlanReque" - "st\0221\n\002id\030\001 \001(\0132%.flyteidl.admin.NamedEnt" - "ityIdentifier\"\203\001\n\033ActiveLaunchPlanListRe" - "quest\022\017\n\007project\030\001 \001(\t\022\016\n\006domain\030\002 \001(\t\022\r" - "\n\005limit\030\003 \001(\r\022\r\n\005token\030\004 \001(\t\022%\n\007sort_by\030" - "\005 \001(\0132\024.flyteidl.admin.Sort*+\n\017LaunchPla" - "nState\022\014\n\010INACTIVE\020\000\022\n\n\006ACTIVE\020\001B3Z1gith" - "ub.com/lyft/flyteidl/gen/pb-go/flyteidl/" - "adminb\006proto3" + "eidl.admin\032\035flyteidl/core/execution.prot" + "o\032\034flyteidl/core/literals.proto\032\036flyteid" + "l/core/identifier.proto\032\035flyteidl/core/i" + "nterface.proto\032\035flyteidl/admin/schedule." + "proto\032\033flyteidl/admin/common.proto\032\037goog" + "le/protobuf/timestamp.proto\"n\n\027LaunchPla" + "nCreateRequest\022%\n\002id\030\001 \001(\0132\031.flyteidl.co" + "re.Identifier\022,\n\004spec\030\002 \001(\0132\036.flyteidl.a" + "dmin.LaunchPlanSpec\"\032\n\030LaunchPlanCreateR" + "esponse\"\225\001\n\nLaunchPlan\022%\n\002id\030\001 \001(\0132\031.fly" + "teidl.core.Identifier\022,\n\004spec\030\002 \001(\0132\036.fl" + "yteidl.admin.LaunchPlanSpec\0222\n\007closure\030\003" + " \001(\0132!.flyteidl.admin.LaunchPlanClosure\"" + "Q\n\016LaunchPlanList\0220\n\014launch_plans\030\001 \003(\0132" + "\032.flyteidl.admin.LaunchPlan\022\r\n\005token\030\002 \001" + "(\t\"T\n\004Auth\022\034\n\022assumable_iam_role\030\001 \001(\tH\000" + "\022$\n\032kubernetes_service_account\030\002 \001(\tH\000B\010" + "\n\006method\"\341\003\n\016LaunchPlanSpec\022.\n\013workflow_" + "id\030\001 \001(\0132\031.flyteidl.core.Identifier\022;\n\017e" + "ntity_metadata\030\002 \001(\0132\".flyteidl.admin.La" + "unchPlanMetadata\0223\n\016default_inputs\030\003 \001(\013" + "2\033.flyteidl.core.ParameterMap\022/\n\014fixed_i" + "nputs\030\004 \001(\0132\031.flyteidl.core.LiteralMap\022\020" + "\n\004role\030\005 \001(\tB\002\030\001\022&\n\006labels\030\006 \001(\0132\026.flyte" + "idl.admin.Labels\0220\n\013annotations\030\007 \001(\0132\033." + "flyteidl.admin.Annotations\022&\n\004auth\030\010 \001(\013" + "2\024.flyteidl.admin.AuthB\002\030\001\022+\n\tauth_role\030" + "\t \001(\0132\030.flyteidl.admin.AuthRole\022;\n\022quali" + "ty_of_service\030\020 \001(\0132\037.flyteidl.core.Qual" + "ityOfService\"\217\002\n\021LaunchPlanClosure\022.\n\005st" + "ate\030\001 \001(\0162\037.flyteidl.admin.LaunchPlanSta" + "te\0224\n\017expected_inputs\030\002 \001(\0132\033.flyteidl.c" + "ore.ParameterMap\0224\n\020expected_outputs\030\003 \001" + "(\0132\032.flyteidl.core.VariableMap\022.\n\ncreate" + "d_at\030\004 \001(\0132\032.google.protobuf.Timestamp\022." + "\n\nupdated_at\030\005 \001(\0132\032.google.protobuf.Tim" + "estamp\"u\n\022LaunchPlanMetadata\022*\n\010schedule" + "\030\001 \001(\0132\030.flyteidl.admin.Schedule\0223\n\rnoti" + "fications\030\002 \003(\0132\034.flyteidl.admin.Notific" + "ation\"p\n\027LaunchPlanUpdateRequest\022%\n\002id\030\001" + " \001(\0132\031.flyteidl.core.Identifier\022.\n\005state" + "\030\002 \001(\0162\037.flyteidl.admin.LaunchPlanState\"" + "\032\n\030LaunchPlanUpdateResponse\"L\n\027ActiveLau" + "nchPlanRequest\0221\n\002id\030\001 \001(\0132%.flyteidl.ad" + "min.NamedEntityIdentifier\"\203\001\n\033ActiveLaun" + "chPlanListRequest\022\017\n\007project\030\001 \001(\t\022\016\n\006do" + "main\030\002 \001(\t\022\r\n\005limit\030\003 \001(\r\022\r\n\005token\030\004 \001(\t" + "\022%\n\007sort_by\030\005 \001(\0132\024.flyteidl.admin.Sort*" + "+\n\017LaunchPlanState\022\014\n\010INACTIVE\020\000\022\n\n\006ACTI" + "VE\020\001B3Z1github.com/lyft/flyteidl/gen/pb-" + "go/flyteidl/adminb\006proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fadmin_2flaunch_5fplan_2eproto = { false, InitDefaults_flyteidl_2fadmin_2flaunch_5fplan_2eproto, descriptor_table_protodef_flyteidl_2fadmin_2flaunch_5fplan_2eproto, - "flyteidl/admin/launch_plan.proto", &assign_descriptors_table_flyteidl_2fadmin_2flaunch_5fplan_2eproto, 1973, + "flyteidl/admin/launch_plan.proto", &assign_descriptors_table_flyteidl_2fadmin_2flaunch_5fplan_2eproto, 2065, }; void AddDescriptors_flyteidl_2fadmin_2flaunch_5fplan_2eproto() { - static constexpr ::google::protobuf::internal::InitFunc deps[6] = + static constexpr ::google::protobuf::internal::InitFunc deps[7] = { + ::AddDescriptors_flyteidl_2fcore_2fexecution_2eproto, ::AddDescriptors_flyteidl_2fcore_2fliterals_2eproto, ::AddDescriptors_flyteidl_2fcore_2fidentifier_2eproto, ::AddDescriptors_flyteidl_2fcore_2finterface_2eproto, @@ -496,7 +502,7 @@ void AddDescriptors_flyteidl_2fadmin_2flaunch_5fplan_2eproto() { ::AddDescriptors_flyteidl_2fadmin_2fcommon_2eproto, ::AddDescriptors_google_2fprotobuf_2ftimestamp_2eproto, }; - ::google::protobuf::internal::AddDescriptors(&descriptor_table_flyteidl_2fadmin_2flaunch_5fplan_2eproto, deps, 6); + ::google::protobuf::internal::AddDescriptors(&descriptor_table_flyteidl_2fadmin_2flaunch_5fplan_2eproto, deps, 7); } // Force running AddDescriptors() at dynamic initialization time. @@ -2297,6 +2303,8 @@ void LaunchPlanSpec::InitAsDefaultInstance() { ::flyteidl::admin::Auth::internal_default_instance()); ::flyteidl::admin::_LaunchPlanSpec_default_instance_._instance.get_mutable()->auth_role_ = const_cast< ::flyteidl::admin::AuthRole*>( ::flyteidl::admin::AuthRole::internal_default_instance()); + ::flyteidl::admin::_LaunchPlanSpec_default_instance_._instance.get_mutable()->quality_of_service_ = const_cast< ::flyteidl::core::QualityOfService*>( + ::flyteidl::core::QualityOfService::internal_default_instance()); } class LaunchPlanSpec::HasBitSetters { public: @@ -2308,6 +2316,7 @@ class LaunchPlanSpec::HasBitSetters { static const ::flyteidl::admin::Annotations& annotations(const LaunchPlanSpec* msg); static const ::flyteidl::admin::Auth& auth(const LaunchPlanSpec* msg); static const ::flyteidl::admin::AuthRole& auth_role(const LaunchPlanSpec* msg); + static const ::flyteidl::core::QualityOfService& quality_of_service(const LaunchPlanSpec* msg); }; const ::flyteidl::core::Identifier& @@ -2342,6 +2351,10 @@ const ::flyteidl::admin::AuthRole& LaunchPlanSpec::HasBitSetters::auth_role(const LaunchPlanSpec* msg) { return *msg->auth_role_; } +const ::flyteidl::core::QualityOfService& +LaunchPlanSpec::HasBitSetters::quality_of_service(const LaunchPlanSpec* msg) { + return *msg->quality_of_service_; +} void LaunchPlanSpec::clear_workflow_id() { if (GetArenaNoVirtual() == nullptr && workflow_id_ != nullptr) { delete workflow_id_; @@ -2378,6 +2391,12 @@ void LaunchPlanSpec::clear_auth_role() { } auth_role_ = nullptr; } +void LaunchPlanSpec::clear_quality_of_service() { + if (GetArenaNoVirtual() == nullptr && quality_of_service_ != nullptr) { + delete quality_of_service_; + } + quality_of_service_ = nullptr; +} #if !defined(_MSC_VER) || _MSC_VER >= 1900 const int LaunchPlanSpec::kWorkflowIdFieldNumber; const int LaunchPlanSpec::kEntityMetadataFieldNumber; @@ -2388,6 +2407,7 @@ const int LaunchPlanSpec::kLabelsFieldNumber; const int LaunchPlanSpec::kAnnotationsFieldNumber; const int LaunchPlanSpec::kAuthFieldNumber; const int LaunchPlanSpec::kAuthRoleFieldNumber; +const int LaunchPlanSpec::kQualityOfServiceFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 LaunchPlanSpec::LaunchPlanSpec() @@ -2443,6 +2463,11 @@ LaunchPlanSpec::LaunchPlanSpec(const LaunchPlanSpec& from) } else { auth_role_ = nullptr; } + if (from.has_quality_of_service()) { + quality_of_service_ = new ::flyteidl::core::QualityOfService(*from.quality_of_service_); + } else { + quality_of_service_ = nullptr; + } // @@protoc_insertion_point(copy_constructor:flyteidl.admin.LaunchPlanSpec) } @@ -2451,8 +2476,8 @@ void LaunchPlanSpec::SharedCtor() { &scc_info_LaunchPlanSpec_flyteidl_2fadmin_2flaunch_5fplan_2eproto.base); role_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); ::memset(&workflow_id_, 0, static_cast( - reinterpret_cast(&auth_role_) - - reinterpret_cast(&workflow_id_)) + sizeof(auth_role_)); + reinterpret_cast(&quality_of_service_) - + reinterpret_cast(&workflow_id_)) + sizeof(quality_of_service_)); } LaunchPlanSpec::~LaunchPlanSpec() { @@ -2470,6 +2495,7 @@ void LaunchPlanSpec::SharedDtor() { if (this != internal_default_instance()) delete annotations_; if (this != internal_default_instance()) delete auth_; if (this != internal_default_instance()) delete auth_role_; + if (this != internal_default_instance()) delete quality_of_service_; } void LaunchPlanSpec::SetCachedSize(int size) const { @@ -2520,6 +2546,10 @@ void LaunchPlanSpec::Clear() { delete auth_role_; } auth_role_ = nullptr; + if (GetArenaNoVirtual() == nullptr && quality_of_service_ != nullptr) { + delete quality_of_service_; + } + quality_of_service_ = nullptr; _internal_metadata_.Clear(); } @@ -2656,6 +2686,19 @@ const char* LaunchPlanSpec::_InternalParse(const char* begin, const char* end, v {parser_till_end, object}, ptr - size, ptr)); break; } + // .flyteidl.core.QualityOfService quality_of_service = 16; + case 16: { + if (static_cast<::google::protobuf::uint8>(tag) != 130) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + parser_till_end = ::flyteidl::core::QualityOfService::_InternalParse; + object = msg->mutable_quality_of_service(); + 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; + } default: { handle_unusual: if ((tag & 7) == 4 || tag == 0) { @@ -2686,7 +2729,7 @@ bool LaunchPlanSpec::MergePartialFromCodedStream( ::google::protobuf::uint32 tag; // @@protoc_insertion_point(parse_start:flyteidl.admin.LaunchPlanSpec) for (;;) { - ::std::pair<::google::protobuf::uint32, bool> p = input->ReadTagWithCutoffNoLastTag(127u); + ::std::pair<::google::protobuf::uint32, bool> p = input->ReadTagWithCutoffNoLastTag(16383u); tag = p.first; if (!p.second) goto handle_unusual; switch (::google::protobuf::internal::WireFormatLite::GetTagFieldNumber(tag)) { @@ -2793,6 +2836,17 @@ bool LaunchPlanSpec::MergePartialFromCodedStream( break; } + // .flyteidl.core.QualityOfService quality_of_service = 16; + case 16: { + if (static_cast< ::google::protobuf::uint8>(tag) == (130 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_quality_of_service())); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -2878,6 +2932,12 @@ void LaunchPlanSpec::SerializeWithCachedSizes( 9, HasBitSetters::auth_role(this), output); } + // .flyteidl.core.QualityOfService quality_of_service = 16; + if (this->has_quality_of_service()) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 16, HasBitSetters::quality_of_service(this), output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -2958,6 +3018,13 @@ ::google::protobuf::uint8* LaunchPlanSpec::InternalSerializeWithCachedSizesToArr 9, HasBitSetters::auth_role(this), target); } + // .flyteidl.core.QualityOfService quality_of_service = 16; + if (this->has_quality_of_service()) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 16, HasBitSetters::quality_of_service(this), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -3042,6 +3109,13 @@ size_t LaunchPlanSpec::ByteSizeLong() const { *auth_role_); } + // .flyteidl.core.QualityOfService quality_of_service = 16; + if (this->has_quality_of_service()) { + total_size += 2 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *quality_of_service_); + } + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); SetCachedSize(cached_size); return total_size; @@ -3097,6 +3171,9 @@ void LaunchPlanSpec::MergeFrom(const LaunchPlanSpec& from) { if (from.has_auth_role()) { mutable_auth_role()->::flyteidl::admin::AuthRole::MergeFrom(from.auth_role()); } + if (from.has_quality_of_service()) { + mutable_quality_of_service()->::flyteidl::core::QualityOfService::MergeFrom(from.quality_of_service()); + } } void LaunchPlanSpec::CopyFrom(const ::google::protobuf::Message& from) { @@ -3134,6 +3211,7 @@ void LaunchPlanSpec::InternalSwap(LaunchPlanSpec* other) { swap(annotations_, other->annotations_); swap(auth_, other->auth_); swap(auth_role_, other->auth_role_); + swap(quality_of_service_, other->quality_of_service_); } ::google::protobuf::Metadata LaunchPlanSpec::GetMetadata() const { diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/launch_plan.pb.h b/flyteidl/gen/pb-cpp/flyteidl/admin/launch_plan.pb.h index f63ae365160..599fa3f820b 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/launch_plan.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/launch_plan.pb.h @@ -32,6 +32,7 @@ #include // IWYU pragma: export #include #include +#include "flyteidl/core/execution.pb.h" #include "flyteidl/core/literals.pb.h" #include "flyteidl/core/identifier.pb.h" #include "flyteidl/core/interface.pb.h" @@ -975,6 +976,15 @@ class LaunchPlanSpec final : ::flyteidl::admin::AuthRole* mutable_auth_role(); void set_allocated_auth_role(::flyteidl::admin::AuthRole* auth_role); + // .flyteidl.core.QualityOfService quality_of_service = 16; + bool has_quality_of_service() const; + void clear_quality_of_service(); + static const int kQualityOfServiceFieldNumber = 16; + const ::flyteidl::core::QualityOfService& quality_of_service() const; + ::flyteidl::core::QualityOfService* release_quality_of_service(); + ::flyteidl::core::QualityOfService* mutable_quality_of_service(); + void set_allocated_quality_of_service(::flyteidl::core::QualityOfService* quality_of_service); + // @@protoc_insertion_point(class_scope:flyteidl.admin.LaunchPlanSpec) private: class HasBitSetters; @@ -989,6 +999,7 @@ class LaunchPlanSpec final : ::flyteidl::admin::Annotations* annotations_; ::flyteidl::admin::Auth* auth_; ::flyteidl::admin::AuthRole* auth_role_; + ::flyteidl::core::QualityOfService* quality_of_service_; mutable ::google::protobuf::internal::CachedSize _cached_size_; friend struct ::TableStruct_flyteidl_2fadmin_2flaunch_5fplan_2eproto; }; @@ -2756,6 +2767,51 @@ inline void LaunchPlanSpec::set_allocated_auth_role(::flyteidl::admin::AuthRole* // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.LaunchPlanSpec.auth_role) } +// .flyteidl.core.QualityOfService quality_of_service = 16; +inline bool LaunchPlanSpec::has_quality_of_service() const { + return this != internal_default_instance() && quality_of_service_ != nullptr; +} +inline const ::flyteidl::core::QualityOfService& LaunchPlanSpec::quality_of_service() const { + const ::flyteidl::core::QualityOfService* p = quality_of_service_; + // @@protoc_insertion_point(field_get:flyteidl.admin.LaunchPlanSpec.quality_of_service) + return p != nullptr ? *p : *reinterpret_cast( + &::flyteidl::core::_QualityOfService_default_instance_); +} +inline ::flyteidl::core::QualityOfService* LaunchPlanSpec::release_quality_of_service() { + // @@protoc_insertion_point(field_release:flyteidl.admin.LaunchPlanSpec.quality_of_service) + + ::flyteidl::core::QualityOfService* temp = quality_of_service_; + quality_of_service_ = nullptr; + return temp; +} +inline ::flyteidl::core::QualityOfService* LaunchPlanSpec::mutable_quality_of_service() { + + if (quality_of_service_ == nullptr) { + auto* p = CreateMaybeMessage<::flyteidl::core::QualityOfService>(GetArenaNoVirtual()); + quality_of_service_ = p; + } + // @@protoc_insertion_point(field_mutable:flyteidl.admin.LaunchPlanSpec.quality_of_service) + return quality_of_service_; +} +inline void LaunchPlanSpec::set_allocated_quality_of_service(::flyteidl::core::QualityOfService* quality_of_service) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + if (message_arena == nullptr) { + delete reinterpret_cast< ::google::protobuf::MessageLite*>(quality_of_service_); + } + if (quality_of_service) { + ::google::protobuf::Arena* submessage_arena = nullptr; + if (message_arena != submessage_arena) { + quality_of_service = ::google::protobuf::internal::GetOwnedMessage( + message_arena, quality_of_service, submessage_arena); + } + + } else { + + } + quality_of_service_ = quality_of_service; + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.LaunchPlanSpec.quality_of_service) +} + // ------------------------------------------------------------------- // LaunchPlanClosure diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/matchable_resource.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/matchable_resource.pb.cc index cd5d7c32676..c6436c2e260 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/matchable_resource.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/matchable_resource.pb.cc @@ -23,7 +23,8 @@ extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_ClusterResourceAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_MatchableAttributesConfiguration_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_TaskResourceAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; -extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<4> scc_info_MatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<5> scc_info_MatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto; namespace flyteidl { namespace admin { class TaskResourceSpecDefaultTypeInternal { @@ -57,6 +58,7 @@ class MatchingAttributesDefaultTypeInternal { const ::flyteidl::admin::ClusterResourceAttributes* cluster_resource_attributes_; const ::flyteidl::admin::ExecutionQueueAttributes* execution_queue_attributes_; const ::flyteidl::admin::ExecutionClusterLabel* execution_cluster_label_; + const ::flyteidl::core::QualityOfService* quality_of_service_; } _MatchingAttributes_default_instance_; class MatchableAttributesConfigurationDefaultTypeInternal { public: @@ -168,12 +170,13 @@ static void InitDefaultsMatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresour ::flyteidl::admin::MatchingAttributes::InitAsDefaultInstance(); } -::google::protobuf::internal::SCCInfo<4> scc_info_MatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto = - {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 4, InitDefaultsMatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto}, { +::google::protobuf::internal::SCCInfo<5> scc_info_MatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 5, InitDefaultsMatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto}, { &scc_info_TaskResourceAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto.base, &scc_info_ClusterResourceAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto.base, &scc_info_ExecutionQueueAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto.base, - &scc_info_ExecutionClusterLabel_flyteidl_2fadmin_2fmatchable_5fresource_2eproto.base,}}; + &scc_info_ExecutionClusterLabel_flyteidl_2fadmin_2fmatchable_5fresource_2eproto.base, + &scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto.base,}}; static void InitDefaultsMatchableAttributesConfiguration_flyteidl_2fadmin_2fmatchable_5fresource_2eproto() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -289,6 +292,7 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2fmatchable_5freso offsetof(::flyteidl::admin::MatchingAttributesDefaultTypeInternal, cluster_resource_attributes_), offsetof(::flyteidl::admin::MatchingAttributesDefaultTypeInternal, execution_queue_attributes_), offsetof(::flyteidl::admin::MatchingAttributesDefaultTypeInternal, execution_cluster_label_), + offsetof(::flyteidl::admin::MatchingAttributesDefaultTypeInternal, quality_of_service_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::MatchingAttributes, target_), ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::admin::MatchableAttributesConfiguration, _internal_metadata_), @@ -321,9 +325,9 @@ static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SE { 31, -1, sizeof(::flyteidl::admin::ExecutionQueueAttributes)}, { 37, -1, sizeof(::flyteidl::admin::ExecutionClusterLabel)}, { 43, -1, sizeof(::flyteidl::admin::MatchingAttributes)}, - { 53, -1, sizeof(::flyteidl::admin::MatchableAttributesConfiguration)}, - { 63, -1, sizeof(::flyteidl::admin::ListMatchableAttributesRequest)}, - { 69, -1, sizeof(::flyteidl::admin::ListMatchableAttributesResponse)}, + { 54, -1, sizeof(::flyteidl::admin::MatchableAttributesConfiguration)}, + { 64, -1, sizeof(::flyteidl::admin::ListMatchableAttributesRequest)}, + { 70, -1, sizeof(::flyteidl::admin::ListMatchableAttributesResponse)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -347,52 +351,58 @@ ::google::protobuf::internal::AssignDescriptorsTable assign_descriptors_table_fl const char descriptor_table_protodef_flyteidl_2fadmin_2fmatchable_5fresource_2eproto[] = "\n\'flyteidl/admin/matchable_resource.prot" - "o\022\016flyteidl.admin\"M\n\020TaskResourceSpec\022\013\n" - "\003cpu\030\001 \001(\t\022\013\n\003gpu\030\002 \001(\t\022\016\n\006memory\030\003 \001(\t\022" - "\017\n\007storage\030\004 \001(\t\"~\n\026TaskResourceAttribut" - "es\0222\n\010defaults\030\001 \001(\0132 .flyteidl.admin.Ta" - "skResourceSpec\0220\n\006limits\030\002 \001(\0132 .flyteid" - "l.admin.TaskResourceSpec\"\235\001\n\031ClusterReso" - "urceAttributes\022M\n\nattributes\030\001 \003(\01329.fly" - "teidl.admin.ClusterResourceAttributes.At" - "tributesEntry\0321\n\017AttributesEntry\022\013\n\003key\030" - "\001 \001(\t\022\r\n\005value\030\002 \001(\t:\0028\001\"(\n\030ExecutionQue" - "ueAttributes\022\014\n\004tags\030\001 \003(\t\"&\n\025ExecutionC" - "lusterLabel\022\r\n\005value\030\001 \001(\t\"\326\002\n\022MatchingA" - "ttributes\022J\n\030task_resource_attributes\030\001 " - "\001(\0132&.flyteidl.admin.TaskResourceAttribu" - "tesH\000\022P\n\033cluster_resource_attributes\030\002 \001" - "(\0132).flyteidl.admin.ClusterResourceAttri" - "butesH\000\022N\n\032execution_queue_attributes\030\003 " - "\001(\0132(.flyteidl.admin.ExecutionQueueAttri" - "butesH\000\022H\n\027execution_cluster_label\030\004 \001(\013" - "2%.flyteidl.admin.ExecutionClusterLabelH" - "\000B\010\n\006target\"\242\001\n MatchableAttributesConfi" - "guration\0226\n\nattributes\030\001 \001(\0132\".flyteidl." - "admin.MatchingAttributes\022\016\n\006domain\030\002 \001(\t" - "\022\017\n\007project\030\003 \001(\t\022\020\n\010workflow\030\004 \001(\t\022\023\n\013l" - "aunch_plan\030\005 \001(\t\"Z\n\036ListMatchableAttribu" - "tesRequest\0228\n\rresource_type\030\001 \001(\0162!.flyt" - "eidl.admin.MatchableResource\"k\n\037ListMatc" - "hableAttributesResponse\022H\n\016configuration" - "s\030\001 \003(\01320.flyteidl.admin.MatchableAttrib" - "utesConfiguration*n\n\021MatchableResource\022\021" - "\n\rTASK_RESOURCE\020\000\022\024\n\020CLUSTER_RESOURCE\020\001\022" - "\023\n\017EXECUTION_QUEUE\020\002\022\033\n\027EXECUTION_CLUSTE" - "R_LABEL\020\003B3Z1github.com/lyft/flyteidl/ge" - "n/pb-go/flyteidl/adminb\006proto3" + "o\022\016flyteidl.admin\032\033flyteidl/admin/common" + ".proto\032\035flyteidl/core/execution.proto\"M\n" + "\020TaskResourceSpec\022\013\n\003cpu\030\001 \001(\t\022\013\n\003gpu\030\002 " + "\001(\t\022\016\n\006memory\030\003 \001(\t\022\017\n\007storage\030\004 \001(\t\"~\n\026" + "TaskResourceAttributes\0222\n\010defaults\030\001 \001(\013" + "2 .flyteidl.admin.TaskResourceSpec\0220\n\006li" + "mits\030\002 \001(\0132 .flyteidl.admin.TaskResource" + "Spec\"\235\001\n\031ClusterResourceAttributes\022M\n\nat" + "tributes\030\001 \003(\01329.flyteidl.admin.ClusterR" + "esourceAttributes.AttributesEntry\0321\n\017Att" + "ributesEntry\022\013\n\003key\030\001 \001(\t\022\r\n\005value\030\002 \001(\t" + ":\0028\001\"(\n\030ExecutionQueueAttributes\022\014\n\004tags" + "\030\001 \003(\t\"&\n\025ExecutionClusterLabel\022\r\n\005value" + "\030\001 \001(\t\"\225\003\n\022MatchingAttributes\022J\n\030task_re" + "source_attributes\030\001 \001(\0132&.flyteidl.admin" + ".TaskResourceAttributesH\000\022P\n\033cluster_res" + "ource_attributes\030\002 \001(\0132).flyteidl.admin." + "ClusterResourceAttributesH\000\022N\n\032execution" + "_queue_attributes\030\003 \001(\0132(.flyteidl.admin" + ".ExecutionQueueAttributesH\000\022H\n\027execution" + "_cluster_label\030\004 \001(\0132%.flyteidl.admin.Ex" + "ecutionClusterLabelH\000\022=\n\022quality_of_serv" + "ice\030\005 \001(\0132\037.flyteidl.core.QualityOfServi" + "ceH\000B\010\n\006target\"\242\001\n MatchableAttributesCo" + "nfiguration\0226\n\nattributes\030\001 \001(\0132\".flytei" + "dl.admin.MatchingAttributes\022\016\n\006domain\030\002 " + "\001(\t\022\017\n\007project\030\003 \001(\t\022\020\n\010workflow\030\004 \001(\t\022\023" + "\n\013launch_plan\030\005 \001(\t\"Z\n\036ListMatchableAttr" + "ibutesRequest\0228\n\rresource_type\030\001 \001(\0162!.f" + "lyteidl.admin.MatchableResource\"k\n\037ListM" + "atchableAttributesResponse\022H\n\016configurat" + "ions\030\001 \003(\01320.flyteidl.admin.MatchableAtt" + "ributesConfiguration*\224\001\n\021MatchableResour" + "ce\022\021\n\rTASK_RESOURCE\020\000\022\024\n\020CLUSTER_RESOURC" + "E\020\001\022\023\n\017EXECUTION_QUEUE\020\002\022\033\n\027EXECUTION_CL" + "USTER_LABEL\020\003\022$\n QUALITY_OF_SERVICE_SPEC" + "IFICATION\020\004B3Z1github.com/lyft/flyteidl/" + "gen/pb-go/flyteidl/adminb\006proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fadmin_2fmatchable_5fresource_2eproto = { false, InitDefaults_flyteidl_2fadmin_2fmatchable_5fresource_2eproto, descriptor_table_protodef_flyteidl_2fadmin_2fmatchable_5fresource_2eproto, - "flyteidl/admin/matchable_resource.proto", &assign_descriptors_table_flyteidl_2fadmin_2fmatchable_5fresource_2eproto, 1390, + "flyteidl/admin/matchable_resource.proto", &assign_descriptors_table_flyteidl_2fadmin_2fmatchable_5fresource_2eproto, 1552, }; void AddDescriptors_flyteidl_2fadmin_2fmatchable_5fresource_2eproto() { - static constexpr ::google::protobuf::internal::InitFunc deps[1] = + static constexpr ::google::protobuf::internal::InitFunc deps[2] = { + ::AddDescriptors_flyteidl_2fadmin_2fcommon_2eproto, + ::AddDescriptors_flyteidl_2fcore_2fexecution_2eproto, }; - ::google::protobuf::internal::AddDescriptors(&descriptor_table_flyteidl_2fadmin_2fmatchable_5fresource_2eproto, deps, 0); + ::google::protobuf::internal::AddDescriptors(&descriptor_table_flyteidl_2fadmin_2fmatchable_5fresource_2eproto, deps, 2); } // Force running AddDescriptors() at dynamic initialization time. @@ -409,6 +419,7 @@ bool MatchableResource_IsValid(int value) { case 1: case 2: case 3: + case 4: return true; default: return false; @@ -2310,6 +2321,8 @@ void MatchingAttributes::InitAsDefaultInstance() { ::flyteidl::admin::ExecutionQueueAttributes::internal_default_instance()); ::flyteidl::admin::_MatchingAttributes_default_instance_.execution_cluster_label_ = const_cast< ::flyteidl::admin::ExecutionClusterLabel*>( ::flyteidl::admin::ExecutionClusterLabel::internal_default_instance()); + ::flyteidl::admin::_MatchingAttributes_default_instance_.quality_of_service_ = const_cast< ::flyteidl::core::QualityOfService*>( + ::flyteidl::core::QualityOfService::internal_default_instance()); } class MatchingAttributes::HasBitSetters { public: @@ -2317,6 +2330,7 @@ class MatchingAttributes::HasBitSetters { static const ::flyteidl::admin::ClusterResourceAttributes& cluster_resource_attributes(const MatchingAttributes* msg); static const ::flyteidl::admin::ExecutionQueueAttributes& execution_queue_attributes(const MatchingAttributes* msg); static const ::flyteidl::admin::ExecutionClusterLabel& execution_cluster_label(const MatchingAttributes* msg); + static const ::flyteidl::core::QualityOfService& quality_of_service(const MatchingAttributes* msg); }; const ::flyteidl::admin::TaskResourceAttributes& @@ -2335,6 +2349,10 @@ const ::flyteidl::admin::ExecutionClusterLabel& MatchingAttributes::HasBitSetters::execution_cluster_label(const MatchingAttributes* msg) { return *msg->target_.execution_cluster_label_; } +const ::flyteidl::core::QualityOfService& +MatchingAttributes::HasBitSetters::quality_of_service(const MatchingAttributes* msg) { + return *msg->target_.quality_of_service_; +} void MatchingAttributes::set_allocated_task_resource_attributes(::flyteidl::admin::TaskResourceAttributes* task_resource_attributes) { ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); clear_target(); @@ -2391,11 +2409,32 @@ void MatchingAttributes::set_allocated_execution_cluster_label(::flyteidl::admin } // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.MatchingAttributes.execution_cluster_label) } +void MatchingAttributes::set_allocated_quality_of_service(::flyteidl::core::QualityOfService* quality_of_service) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + clear_target(); + if (quality_of_service) { + ::google::protobuf::Arena* submessage_arena = nullptr; + if (message_arena != submessage_arena) { + quality_of_service = ::google::protobuf::internal::GetOwnedMessage( + message_arena, quality_of_service, submessage_arena); + } + set_has_quality_of_service(); + target_.quality_of_service_ = quality_of_service; + } + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.MatchingAttributes.quality_of_service) +} +void MatchingAttributes::clear_quality_of_service() { + if (has_quality_of_service()) { + delete target_.quality_of_service_; + clear_has_target(); + } +} #if !defined(_MSC_VER) || _MSC_VER >= 1900 const int MatchingAttributes::kTaskResourceAttributesFieldNumber; const int MatchingAttributes::kClusterResourceAttributesFieldNumber; const int MatchingAttributes::kExecutionQueueAttributesFieldNumber; const int MatchingAttributes::kExecutionClusterLabelFieldNumber; +const int MatchingAttributes::kQualityOfServiceFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 MatchingAttributes::MatchingAttributes() @@ -2425,6 +2464,10 @@ MatchingAttributes::MatchingAttributes(const MatchingAttributes& from) mutable_execution_cluster_label()->::flyteidl::admin::ExecutionClusterLabel::MergeFrom(from.execution_cluster_label()); break; } + case kQualityOfService: { + mutable_quality_of_service()->::flyteidl::core::QualityOfService::MergeFrom(from.quality_of_service()); + break; + } case TARGET_NOT_SET: { break; } @@ -2477,6 +2520,10 @@ void MatchingAttributes::clear_target() { delete target_.execution_cluster_label_; break; } + case kQualityOfService: { + delete target_.quality_of_service_; + break; + } case TARGET_NOT_SET: { break; } @@ -2560,6 +2607,19 @@ const char* MatchingAttributes::_InternalParse(const char* begin, const char* en {parser_till_end, object}, ptr - size, ptr)); break; } + // .flyteidl.core.QualityOfService quality_of_service = 5; + case 5: { + if (static_cast<::google::protobuf::uint8>(tag) != 42) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + parser_till_end = ::flyteidl::core::QualityOfService::_InternalParse; + object = msg->mutable_quality_of_service(); + 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; + } default: { handle_unusual: if ((tag & 7) == 4 || tag == 0) { @@ -2634,6 +2694,17 @@ bool MatchingAttributes::MergePartialFromCodedStream( break; } + // .flyteidl.core.QualityOfService quality_of_service = 5; + case 5: { + if (static_cast< ::google::protobuf::uint8>(tag) == (42 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_quality_of_service())); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -2685,6 +2756,12 @@ void MatchingAttributes::SerializeWithCachedSizes( 4, HasBitSetters::execution_cluster_label(this), output); } + // .flyteidl.core.QualityOfService quality_of_service = 5; + if (has_quality_of_service()) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 5, HasBitSetters::quality_of_service(this), output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -2726,6 +2803,13 @@ ::google::protobuf::uint8* MatchingAttributes::InternalSerializeWithCachedSizesT 4, HasBitSetters::execution_cluster_label(this), target); } + // .flyteidl.core.QualityOfService quality_of_service = 5; + if (has_quality_of_service()) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 5, HasBitSetters::quality_of_service(this), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -2776,6 +2860,13 @@ size_t MatchingAttributes::ByteSizeLong() const { *target_.execution_cluster_label_); break; } + // .flyteidl.core.QualityOfService quality_of_service = 5; + case kQualityOfService: { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *target_.quality_of_service_); + break; + } case TARGET_NOT_SET: { break; } @@ -2824,6 +2915,10 @@ void MatchingAttributes::MergeFrom(const MatchingAttributes& from) { mutable_execution_cluster_label()->::flyteidl::admin::ExecutionClusterLabel::MergeFrom(from.execution_cluster_label()); break; } + case kQualityOfService: { + mutable_quality_of_service()->::flyteidl::core::QualityOfService::MergeFrom(from.quality_of_service()); + break; + } case TARGET_NOT_SET: { break; } diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/matchable_resource.pb.h b/flyteidl/gen/pb-cpp/flyteidl/admin/matchable_resource.pb.h index 0dfdec8be13..8f25f98fba9 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/matchable_resource.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/matchable_resource.pb.h @@ -35,6 +35,8 @@ #include #include #include +#include "flyteidl/admin/common.pb.h" +#include "flyteidl/core/execution.pb.h" // @@protoc_insertion_point(includes) #include #define PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto @@ -108,12 +110,13 @@ enum MatchableResource { CLUSTER_RESOURCE = 1, EXECUTION_QUEUE = 2, EXECUTION_CLUSTER_LABEL = 3, + QUALITY_OF_SERVICE_SPECIFICATION = 4, MatchableResource_INT_MIN_SENTINEL_DO_NOT_USE_ = std::numeric_limits<::google::protobuf::int32>::min(), MatchableResource_INT_MAX_SENTINEL_DO_NOT_USE_ = std::numeric_limits<::google::protobuf::int32>::max() }; bool MatchableResource_IsValid(int value); const MatchableResource MatchableResource_MIN = TASK_RESOURCE; -const MatchableResource MatchableResource_MAX = EXECUTION_CLUSTER_LABEL; +const MatchableResource MatchableResource_MAX = QUALITY_OF_SERVICE_SPECIFICATION; const int MatchableResource_ARRAYSIZE = MatchableResource_MAX + 1; const ::google::protobuf::EnumDescriptor* MatchableResource_descriptor(); @@ -848,6 +851,7 @@ class MatchingAttributes final : kClusterResourceAttributes = 2, kExecutionQueueAttributes = 3, kExecutionClusterLabel = 4, + kQualityOfService = 5, TARGET_NOT_SET = 0, }; @@ -950,6 +954,15 @@ class MatchingAttributes final : ::flyteidl::admin::ExecutionClusterLabel* mutable_execution_cluster_label(); void set_allocated_execution_cluster_label(::flyteidl::admin::ExecutionClusterLabel* execution_cluster_label); + // .flyteidl.core.QualityOfService quality_of_service = 5; + bool has_quality_of_service() const; + void clear_quality_of_service(); + static const int kQualityOfServiceFieldNumber = 5; + const ::flyteidl::core::QualityOfService& quality_of_service() const; + ::flyteidl::core::QualityOfService* release_quality_of_service(); + ::flyteidl::core::QualityOfService* mutable_quality_of_service(); + void set_allocated_quality_of_service(::flyteidl::core::QualityOfService* quality_of_service); + void clear_target(); TargetCase target_case() const; // @@protoc_insertion_point(class_scope:flyteidl.admin.MatchingAttributes) @@ -959,6 +972,7 @@ class MatchingAttributes final : void set_has_cluster_resource_attributes(); void set_has_execution_queue_attributes(); void set_has_execution_cluster_label(); + void set_has_quality_of_service(); inline bool has_target() const; inline void clear_has_target(); @@ -970,6 +984,7 @@ class MatchingAttributes final : ::flyteidl::admin::ClusterResourceAttributes* cluster_resource_attributes_; ::flyteidl::admin::ExecutionQueueAttributes* execution_queue_attributes_; ::flyteidl::admin::ExecutionClusterLabel* execution_cluster_label_; + ::flyteidl::core::QualityOfService* quality_of_service_; } target_; mutable ::google::protobuf::internal::CachedSize _cached_size_; ::google::protobuf::uint32 _oneof_case_[1]; @@ -2032,6 +2047,41 @@ inline ::flyteidl::admin::ExecutionClusterLabel* MatchingAttributes::mutable_exe return target_.execution_cluster_label_; } +// .flyteidl.core.QualityOfService quality_of_service = 5; +inline bool MatchingAttributes::has_quality_of_service() const { + return target_case() == kQualityOfService; +} +inline void MatchingAttributes::set_has_quality_of_service() { + _oneof_case_[0] = kQualityOfService; +} +inline ::flyteidl::core::QualityOfService* MatchingAttributes::release_quality_of_service() { + // @@protoc_insertion_point(field_release:flyteidl.admin.MatchingAttributes.quality_of_service) + if (has_quality_of_service()) { + clear_has_target(); + ::flyteidl::core::QualityOfService* temp = target_.quality_of_service_; + target_.quality_of_service_ = nullptr; + return temp; + } else { + return nullptr; + } +} +inline const ::flyteidl::core::QualityOfService& MatchingAttributes::quality_of_service() const { + // @@protoc_insertion_point(field_get:flyteidl.admin.MatchingAttributes.quality_of_service) + return has_quality_of_service() + ? *target_.quality_of_service_ + : *reinterpret_cast< ::flyteidl::core::QualityOfService*>(&::flyteidl::core::_QualityOfService_default_instance_); +} +inline ::flyteidl::core::QualityOfService* MatchingAttributes::mutable_quality_of_service() { + if (!has_quality_of_service()) { + clear_target(); + set_has_quality_of_service(); + target_.quality_of_service_ = CreateMaybeMessage< ::flyteidl::core::QualityOfService >( + GetArenaNoVirtual()); + } + // @@protoc_insertion_point(field_mutable:flyteidl.admin.MatchingAttributes.quality_of_service) + return target_.quality_of_service_; +} + inline bool MatchingAttributes::has_target() const { return target_case() != TARGET_NOT_SET; } diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/project_domain_attributes.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/project_domain_attributes.pb.cc index 722b44484b7..aa63905041f 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/project_domain_attributes.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/project_domain_attributes.pb.cc @@ -16,7 +16,7 @@ // @@protoc_insertion_point(includes) #include -extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<4> scc_info_MatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<5> scc_info_MatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fproject_5fdomain_5fattributes_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_ProjectDomainAttributes_flyteidl_2fadmin_2fproject_5fdomain_5fattributes_2eproto; namespace flyteidl { namespace admin { diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/workflow_attributes.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/workflow_attributes.pb.cc index 7a401751405..71898d24b64 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/workflow_attributes.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/workflow_attributes.pb.cc @@ -16,7 +16,7 @@ // @@protoc_insertion_point(includes) #include -extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<4> scc_info_MatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fmatchable_5fresource_2eproto ::google::protobuf::internal::SCCInfo<5> scc_info_MatchingAttributes_flyteidl_2fadmin_2fmatchable_5fresource_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fworkflow_5fattributes_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_WorkflowAttributes_flyteidl_2fadmin_2fworkflow_5fattributes_2eproto; namespace flyteidl { namespace admin { diff --git a/flyteidl/gen/pb-cpp/flyteidl/core/execution.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/core/execution.pb.cc index d8ba7bbaec0..0c94cf9e049 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/core/execution.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/core/execution.pb.cc @@ -16,6 +16,7 @@ // @@protoc_insertion_point(includes) #include +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_QualityOfServiceSpec_flyteidl_2fcore_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_google_2fprotobuf_2fduration_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_Duration_google_2fprotobuf_2fduration_2eproto; namespace flyteidl { namespace core { @@ -39,6 +40,16 @@ class TaskLogDefaultTypeInternal { public: ::google::protobuf::internal::ExplicitlyConstructed _instance; } _TaskLog_default_instance_; +class QualityOfServiceSpecDefaultTypeInternal { + public: + ::google::protobuf::internal::ExplicitlyConstructed _instance; +} _QualityOfServiceSpec_default_instance_; +class QualityOfServiceDefaultTypeInternal { + public: + ::google::protobuf::internal::ExplicitlyConstructed _instance; + int tier_; + const ::flyteidl::core::QualityOfServiceSpec* spec_; +} _QualityOfService_default_instance_; } // namespace core } // namespace flyteidl static void InitDefaultsWorkflowExecution_flyteidl_2fcore_2fexecution_2eproto() { @@ -112,16 +123,48 @@ ::google::protobuf::internal::SCCInfo<1> scc_info_TaskLog_flyteidl_2fcore_2fexec {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsTaskLog_flyteidl_2fcore_2fexecution_2eproto}, { &scc_info_Duration_google_2fprotobuf_2fduration_2eproto.base,}}; +static void InitDefaultsQualityOfServiceSpec_flyteidl_2fcore_2fexecution_2eproto() { + GOOGLE_PROTOBUF_VERIFY_VERSION; + + { + void* ptr = &::flyteidl::core::_QualityOfServiceSpec_default_instance_; + new (ptr) ::flyteidl::core::QualityOfServiceSpec(); + ::google::protobuf::internal::OnShutdownDestroyMessage(ptr); + } + ::flyteidl::core::QualityOfServiceSpec::InitAsDefaultInstance(); +} + +::google::protobuf::internal::SCCInfo<1> scc_info_QualityOfServiceSpec_flyteidl_2fcore_2fexecution_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsQualityOfServiceSpec_flyteidl_2fcore_2fexecution_2eproto}, { + &scc_info_Duration_google_2fprotobuf_2fduration_2eproto.base,}}; + +static void InitDefaultsQualityOfService_flyteidl_2fcore_2fexecution_2eproto() { + GOOGLE_PROTOBUF_VERIFY_VERSION; + + { + void* ptr = &::flyteidl::core::_QualityOfService_default_instance_; + new (ptr) ::flyteidl::core::QualityOfService(); + ::google::protobuf::internal::OnShutdownDestroyMessage(ptr); + } + ::flyteidl::core::QualityOfService::InitAsDefaultInstance(); +} + +::google::protobuf::internal::SCCInfo<1> scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsQualityOfService_flyteidl_2fcore_2fexecution_2eproto}, { + &scc_info_QualityOfServiceSpec_flyteidl_2fcore_2fexecution_2eproto.base,}}; + void InitDefaults_flyteidl_2fcore_2fexecution_2eproto() { ::google::protobuf::internal::InitSCC(&scc_info_WorkflowExecution_flyteidl_2fcore_2fexecution_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_NodeExecution_flyteidl_2fcore_2fexecution_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_TaskExecution_flyteidl_2fcore_2fexecution_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_ExecutionError_flyteidl_2fcore_2fexecution_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_TaskLog_flyteidl_2fcore_2fexecution_2eproto.base); + ::google::protobuf::internal::InitSCC(&scc_info_QualityOfServiceSpec_flyteidl_2fcore_2fexecution_2eproto.base); + ::google::protobuf::internal::InitSCC(&scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto.base); } -::google::protobuf::Metadata file_level_metadata_flyteidl_2fcore_2fexecution_2eproto[5]; -const ::google::protobuf::EnumDescriptor* file_level_enum_descriptors_flyteidl_2fcore_2fexecution_2eproto[5]; +::google::protobuf::Metadata file_level_metadata_flyteidl_2fcore_2fexecution_2eproto[7]; +const ::google::protobuf::EnumDescriptor* file_level_enum_descriptors_flyteidl_2fcore_2fexecution_2eproto[6]; constexpr ::google::protobuf::ServiceDescriptor const** file_level_service_descriptors_flyteidl_2fcore_2fexecution_2eproto = nullptr; const ::google::protobuf::uint32 TableStruct_flyteidl_2fcore_2fexecution_2eproto::offsets[] PROTOBUF_SECTION_VARIABLE(protodesc_cold) = { @@ -158,6 +201,20 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fcore_2fexecution_2eproto PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskLog, name_), PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskLog, message_format_), PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskLog, ttl_), + ~0u, // no _has_bits_ + PROTOBUF_FIELD_OFFSET(::flyteidl::core::QualityOfServiceSpec, _internal_metadata_), + ~0u, // no _extensions_ + ~0u, // no _oneof_case_ + ~0u, // no _weak_field_map_ + PROTOBUF_FIELD_OFFSET(::flyteidl::core::QualityOfServiceSpec, queueing_budget_), + ~0u, // no _has_bits_ + PROTOBUF_FIELD_OFFSET(::flyteidl::core::QualityOfService, _internal_metadata_), + ~0u, // no _extensions_ + PROTOBUF_FIELD_OFFSET(::flyteidl::core::QualityOfService, _oneof_case_[0]), + ~0u, // no _weak_field_map_ + offsetof(::flyteidl::core::QualityOfServiceDefaultTypeInternal, tier_), + offsetof(::flyteidl::core::QualityOfServiceDefaultTypeInternal, spec_), + PROTOBUF_FIELD_OFFSET(::flyteidl::core::QualityOfService, designation_), }; static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SECTION_VARIABLE(protodesc_cold) = { { 0, -1, sizeof(::flyteidl::core::WorkflowExecution)}, @@ -165,6 +222,8 @@ static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SE { 10, -1, sizeof(::flyteidl::core::TaskExecution)}, { 15, -1, sizeof(::flyteidl::core::ExecutionError)}, { 24, -1, sizeof(::flyteidl::core::TaskLog)}, + { 33, -1, sizeof(::flyteidl::core::QualityOfServiceSpec)}, + { 39, -1, sizeof(::flyteidl::core::QualityOfService)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -173,12 +232,14 @@ static ::google::protobuf::Message const * const file_default_instances[] = { reinterpret_cast(&::flyteidl::core::_TaskExecution_default_instance_), reinterpret_cast(&::flyteidl::core::_ExecutionError_default_instance_), reinterpret_cast(&::flyteidl::core::_TaskLog_default_instance_), + reinterpret_cast(&::flyteidl::core::_QualityOfServiceSpec_default_instance_), + reinterpret_cast(&::flyteidl::core::_QualityOfService_default_instance_), }; ::google::protobuf::internal::AssignDescriptorsTable assign_descriptors_table_flyteidl_2fcore_2fexecution_2eproto = { {}, AddDescriptors_flyteidl_2fcore_2fexecution_2eproto, "flyteidl/core/execution.proto", schemas, file_default_instances, TableStruct_flyteidl_2fcore_2fexecution_2eproto::offsets, - file_level_metadata_flyteidl_2fcore_2fexecution_2eproto, 5, file_level_enum_descriptors_flyteidl_2fcore_2fexecution_2eproto, file_level_service_descriptors_flyteidl_2fcore_2fexecution_2eproto, + file_level_metadata_flyteidl_2fcore_2fexecution_2eproto, 7, file_level_enum_descriptors_flyteidl_2fcore_2fexecution_2eproto, file_level_service_descriptors_flyteidl_2fcore_2fexecution_2eproto, }; const char descriptor_table_protodef_flyteidl_2fcore_2fexecution_2eproto[] = @@ -204,13 +265,20 @@ const char descriptor_table_protodef_flyteidl_2fcore_2fexecution_2eproto[] = "ormat\030\003 \001(\0162$.flyteidl.core.TaskLog.Mess" "ageFormat\022&\n\003ttl\030\004 \001(\0132\031.google.protobuf" ".Duration\"/\n\rMessageFormat\022\013\n\007UNKNOWN\020\000\022" - "\007\n\003CSV\020\001\022\010\n\004JSON\020\002B2Z0github.com/lyft/fl" - "yteidl/gen/pb-go/flyteidl/coreb\006proto3" + "\007\n\003CSV\020\001\022\010\n\004JSON\020\002\"J\n\024QualityOfServiceSp" + "ec\0222\n\017queueing_budget\030\001 \001(\0132\031.google.pro" + "tobuf.Duration\"\302\001\n\020QualityOfService\0224\n\004t" + "ier\030\001 \001(\0162$.flyteidl.core.QualityOfServi" + "ce.TierH\000\0223\n\004spec\030\002 \001(\0132#.flyteidl.core." + "QualityOfServiceSpecH\000\"4\n\004Tier\022\r\n\tUNDEFI" + "NED\020\000\022\010\n\004HIGH\020\001\022\n\n\006MEDIUM\020\002\022\007\n\003LOW\020\003B\r\n\013" + "designationB2Z0github.com/lyft/flyteidl/" + "gen/pb-go/flyteidl/coreb\006proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fcore_2fexecution_2eproto = { false, InitDefaults_flyteidl_2fcore_2fexecution_2eproto, descriptor_table_protodef_flyteidl_2fcore_2fexecution_2eproto, - "flyteidl/core/execution.proto", &assign_descriptors_table_flyteidl_2fcore_2fexecution_2eproto, 958, + "flyteidl/core/execution.proto", &assign_descriptors_table_flyteidl_2fcore_2fexecution_2eproto, 1231, }; void AddDescriptors_flyteidl_2fcore_2fexecution_2eproto() { @@ -374,6 +442,31 @@ const TaskLog_MessageFormat TaskLog::MessageFormat_MIN; const TaskLog_MessageFormat TaskLog::MessageFormat_MAX; const int TaskLog::MessageFormat_ARRAYSIZE; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 +const ::google::protobuf::EnumDescriptor* QualityOfService_Tier_descriptor() { + ::google::protobuf::internal::AssignDescriptors(&assign_descriptors_table_flyteidl_2fcore_2fexecution_2eproto); + return file_level_enum_descriptors_flyteidl_2fcore_2fexecution_2eproto[5]; +} +bool QualityOfService_Tier_IsValid(int value) { + switch (value) { + case 0: + case 1: + case 2: + case 3: + return true; + default: + return false; + } +} + +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +const QualityOfService_Tier QualityOfService::UNDEFINED; +const QualityOfService_Tier QualityOfService::HIGH; +const QualityOfService_Tier QualityOfService::MEDIUM; +const QualityOfService_Tier QualityOfService::LOW; +const QualityOfService_Tier QualityOfService::Tier_MIN; +const QualityOfService_Tier QualityOfService::Tier_MAX; +const int QualityOfService::Tier_ARRAYSIZE; +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 // =================================================================== @@ -1985,6 +2078,685 @@ ::google::protobuf::Metadata TaskLog::GetMetadata() const { } +// =================================================================== + +void QualityOfServiceSpec::InitAsDefaultInstance() { + ::flyteidl::core::_QualityOfServiceSpec_default_instance_._instance.get_mutable()->queueing_budget_ = const_cast< ::google::protobuf::Duration*>( + ::google::protobuf::Duration::internal_default_instance()); +} +class QualityOfServiceSpec::HasBitSetters { + public: + static const ::google::protobuf::Duration& queueing_budget(const QualityOfServiceSpec* msg); +}; + +const ::google::protobuf::Duration& +QualityOfServiceSpec::HasBitSetters::queueing_budget(const QualityOfServiceSpec* msg) { + return *msg->queueing_budget_; +} +void QualityOfServiceSpec::clear_queueing_budget() { + if (GetArenaNoVirtual() == nullptr && queueing_budget_ != nullptr) { + delete queueing_budget_; + } + queueing_budget_ = nullptr; +} +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +const int QualityOfServiceSpec::kQueueingBudgetFieldNumber; +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 + +QualityOfServiceSpec::QualityOfServiceSpec() + : ::google::protobuf::Message(), _internal_metadata_(nullptr) { + SharedCtor(); + // @@protoc_insertion_point(constructor:flyteidl.core.QualityOfServiceSpec) +} +QualityOfServiceSpec::QualityOfServiceSpec(const QualityOfServiceSpec& from) + : ::google::protobuf::Message(), + _internal_metadata_(nullptr) { + _internal_metadata_.MergeFrom(from._internal_metadata_); + if (from.has_queueing_budget()) { + queueing_budget_ = new ::google::protobuf::Duration(*from.queueing_budget_); + } else { + queueing_budget_ = nullptr; + } + // @@protoc_insertion_point(copy_constructor:flyteidl.core.QualityOfServiceSpec) +} + +void QualityOfServiceSpec::SharedCtor() { + ::google::protobuf::internal::InitSCC( + &scc_info_QualityOfServiceSpec_flyteidl_2fcore_2fexecution_2eproto.base); + queueing_budget_ = nullptr; +} + +QualityOfServiceSpec::~QualityOfServiceSpec() { + // @@protoc_insertion_point(destructor:flyteidl.core.QualityOfServiceSpec) + SharedDtor(); +} + +void QualityOfServiceSpec::SharedDtor() { + if (this != internal_default_instance()) delete queueing_budget_; +} + +void QualityOfServiceSpec::SetCachedSize(int size) const { + _cached_size_.Set(size); +} +const QualityOfServiceSpec& QualityOfServiceSpec::default_instance() { + ::google::protobuf::internal::InitSCC(&::scc_info_QualityOfServiceSpec_flyteidl_2fcore_2fexecution_2eproto.base); + return *internal_default_instance(); +} + + +void QualityOfServiceSpec::Clear() { +// @@protoc_insertion_point(message_clear_start:flyteidl.core.QualityOfServiceSpec) + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + if (GetArenaNoVirtual() == nullptr && queueing_budget_ != nullptr) { + delete queueing_budget_; + } + queueing_budget_ = nullptr; + _internal_metadata_.Clear(); +} + +#if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +const char* QualityOfServiceSpec::_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) { + // .google.protobuf.Duration queueing_budget = 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); + parser_till_end = ::google::protobuf::Duration::_InternalParse; + object = msg->mutable_queueing_budget(); + 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; + } + 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; +len_delim_till_end: + return ctx->StoreAndTailCall(ptr, end, {_InternalParse, msg}, + {parser_till_end, object}, size); +} +#else // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +bool QualityOfServiceSpec::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.core.QualityOfServiceSpec) + 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)) { + // .google.protobuf.Duration queueing_budget = 1; + case 1: { + if (static_cast< ::google::protobuf::uint8>(tag) == (10 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_queueing_budget())); + } 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.core.QualityOfServiceSpec) + return true; +failure: + // @@protoc_insertion_point(parse_failure:flyteidl.core.QualityOfServiceSpec) + return false; +#undef DO_ +} +#endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + +void QualityOfServiceSpec::SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const { + // @@protoc_insertion_point(serialize_start:flyteidl.core.QualityOfServiceSpec) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // .google.protobuf.Duration queueing_budget = 1; + if (this->has_queueing_budget()) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 1, HasBitSetters::queueing_budget(this), output); + } + + if (_internal_metadata_.have_unknown_fields()) { + ::google::protobuf::internal::WireFormat::SerializeUnknownFields( + _internal_metadata_.unknown_fields(), output); + } + // @@protoc_insertion_point(serialize_end:flyteidl.core.QualityOfServiceSpec) +} + +::google::protobuf::uint8* QualityOfServiceSpec::InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const { + // @@protoc_insertion_point(serialize_to_array_start:flyteidl.core.QualityOfServiceSpec) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // .google.protobuf.Duration queueing_budget = 1; + if (this->has_queueing_budget()) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 1, HasBitSetters::queueing_budget(this), 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.core.QualityOfServiceSpec) + return target; +} + +size_t QualityOfServiceSpec::ByteSizeLong() const { +// @@protoc_insertion_point(message_byte_size_start:flyteidl.core.QualityOfServiceSpec) + 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; + + // .google.protobuf.Duration queueing_budget = 1; + if (this->has_queueing_budget()) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *queueing_budget_); + } + + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); + SetCachedSize(cached_size); + return total_size; +} + +void QualityOfServiceSpec::MergeFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_merge_from_start:flyteidl.core.QualityOfServiceSpec) + GOOGLE_DCHECK_NE(&from, this); + const QualityOfServiceSpec* source = + ::google::protobuf::DynamicCastToGenerated( + &from); + if (source == nullptr) { + // @@protoc_insertion_point(generalized_merge_from_cast_fail:flyteidl.core.QualityOfServiceSpec) + ::google::protobuf::internal::ReflectionOps::Merge(from, this); + } else { + // @@protoc_insertion_point(generalized_merge_from_cast_success:flyteidl.core.QualityOfServiceSpec) + MergeFrom(*source); + } +} + +void QualityOfServiceSpec::MergeFrom(const QualityOfServiceSpec& from) { +// @@protoc_insertion_point(class_specific_merge_from_start:flyteidl.core.QualityOfServiceSpec) + GOOGLE_DCHECK_NE(&from, this); + _internal_metadata_.MergeFrom(from._internal_metadata_); + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + if (from.has_queueing_budget()) { + mutable_queueing_budget()->::google::protobuf::Duration::MergeFrom(from.queueing_budget()); + } +} + +void QualityOfServiceSpec::CopyFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_copy_from_start:flyteidl.core.QualityOfServiceSpec) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +void QualityOfServiceSpec::CopyFrom(const QualityOfServiceSpec& from) { +// @@protoc_insertion_point(class_specific_copy_from_start:flyteidl.core.QualityOfServiceSpec) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +bool QualityOfServiceSpec::IsInitialized() const { + return true; +} + +void QualityOfServiceSpec::Swap(QualityOfServiceSpec* other) { + if (other == this) return; + InternalSwap(other); +} +void QualityOfServiceSpec::InternalSwap(QualityOfServiceSpec* other) { + using std::swap; + _internal_metadata_.Swap(&other->_internal_metadata_); + swap(queueing_budget_, other->queueing_budget_); +} + +::google::protobuf::Metadata QualityOfServiceSpec::GetMetadata() const { + ::google::protobuf::internal::AssignDescriptors(&::assign_descriptors_table_flyteidl_2fcore_2fexecution_2eproto); + return ::file_level_metadata_flyteidl_2fcore_2fexecution_2eproto[kIndexInFileMessages]; +} + + +// =================================================================== + +void QualityOfService::InitAsDefaultInstance() { + ::flyteidl::core::_QualityOfService_default_instance_.tier_ = 0; + ::flyteidl::core::_QualityOfService_default_instance_.spec_ = const_cast< ::flyteidl::core::QualityOfServiceSpec*>( + ::flyteidl::core::QualityOfServiceSpec::internal_default_instance()); +} +class QualityOfService::HasBitSetters { + public: + static const ::flyteidl::core::QualityOfServiceSpec& spec(const QualityOfService* msg); +}; + +const ::flyteidl::core::QualityOfServiceSpec& +QualityOfService::HasBitSetters::spec(const QualityOfService* msg) { + return *msg->designation_.spec_; +} +void QualityOfService::set_allocated_spec(::flyteidl::core::QualityOfServiceSpec* spec) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + clear_designation(); + if (spec) { + ::google::protobuf::Arena* submessage_arena = nullptr; + if (message_arena != submessage_arena) { + spec = ::google::protobuf::internal::GetOwnedMessage( + message_arena, spec, submessage_arena); + } + set_has_spec(); + designation_.spec_ = spec; + } + // @@protoc_insertion_point(field_set_allocated:flyteidl.core.QualityOfService.spec) +} +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +const int QualityOfService::kTierFieldNumber; +const int QualityOfService::kSpecFieldNumber; +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 + +QualityOfService::QualityOfService() + : ::google::protobuf::Message(), _internal_metadata_(nullptr) { + SharedCtor(); + // @@protoc_insertion_point(constructor:flyteidl.core.QualityOfService) +} +QualityOfService::QualityOfService(const QualityOfService& from) + : ::google::protobuf::Message(), + _internal_metadata_(nullptr) { + _internal_metadata_.MergeFrom(from._internal_metadata_); + clear_has_designation(); + switch (from.designation_case()) { + case kTier: { + set_tier(from.tier()); + break; + } + case kSpec: { + mutable_spec()->::flyteidl::core::QualityOfServiceSpec::MergeFrom(from.spec()); + break; + } + case DESIGNATION_NOT_SET: { + break; + } + } + // @@protoc_insertion_point(copy_constructor:flyteidl.core.QualityOfService) +} + +void QualityOfService::SharedCtor() { + ::google::protobuf::internal::InitSCC( + &scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto.base); + clear_has_designation(); +} + +QualityOfService::~QualityOfService() { + // @@protoc_insertion_point(destructor:flyteidl.core.QualityOfService) + SharedDtor(); +} + +void QualityOfService::SharedDtor() { + if (has_designation()) { + clear_designation(); + } +} + +void QualityOfService::SetCachedSize(int size) const { + _cached_size_.Set(size); +} +const QualityOfService& QualityOfService::default_instance() { + ::google::protobuf::internal::InitSCC(&::scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto.base); + return *internal_default_instance(); +} + + +void QualityOfService::clear_designation() { +// @@protoc_insertion_point(one_of_clear_start:flyteidl.core.QualityOfService) + switch (designation_case()) { + case kTier: { + // No need to clear + break; + } + case kSpec: { + delete designation_.spec_; + break; + } + case DESIGNATION_NOT_SET: { + break; + } + } + _oneof_case_[0] = DESIGNATION_NOT_SET; +} + + +void QualityOfService::Clear() { +// @@protoc_insertion_point(message_clear_start:flyteidl.core.QualityOfService) + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + clear_designation(); + _internal_metadata_.Clear(); +} + +#if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +const char* QualityOfService::_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) { + // .flyteidl.core.QualityOfService.Tier tier = 1; + case 1: { + if (static_cast<::google::protobuf::uint8>(tag) != 8) goto handle_unusual; + ::google::protobuf::uint64 val = ::google::protobuf::internal::ReadVarint(&ptr); + msg->set_tier(static_cast<::flyteidl::core::QualityOfService_Tier>(val)); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + break; + } + // .flyteidl.core.QualityOfServiceSpec spec = 2; + case 2: { + if (static_cast<::google::protobuf::uint8>(tag) != 18) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + parser_till_end = ::flyteidl::core::QualityOfServiceSpec::_InternalParse; + object = msg->mutable_spec(); + 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; + } + 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; +len_delim_till_end: + return ctx->StoreAndTailCall(ptr, end, {_InternalParse, msg}, + {parser_till_end, object}, size); +} +#else // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +bool QualityOfService::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.core.QualityOfService) + 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)) { + // .flyteidl.core.QualityOfService.Tier tier = 1; + case 1: { + if (static_cast< ::google::protobuf::uint8>(tag) == (8 & 0xFF)) { + int value = 0; + DO_((::google::protobuf::internal::WireFormatLite::ReadPrimitive< + int, ::google::protobuf::internal::WireFormatLite::TYPE_ENUM>( + input, &value))); + set_tier(static_cast< ::flyteidl::core::QualityOfService_Tier >(value)); + } else { + goto handle_unusual; + } + break; + } + + // .flyteidl.core.QualityOfServiceSpec spec = 2; + case 2: { + if (static_cast< ::google::protobuf::uint8>(tag) == (18 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_spec())); + } 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.core.QualityOfService) + return true; +failure: + // @@protoc_insertion_point(parse_failure:flyteidl.core.QualityOfService) + return false; +#undef DO_ +} +#endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + +void QualityOfService::SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const { + // @@protoc_insertion_point(serialize_start:flyteidl.core.QualityOfService) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // .flyteidl.core.QualityOfService.Tier tier = 1; + if (has_tier()) { + ::google::protobuf::internal::WireFormatLite::WriteEnum( + 1, this->tier(), output); + } + + // .flyteidl.core.QualityOfServiceSpec spec = 2; + if (has_spec()) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 2, HasBitSetters::spec(this), output); + } + + if (_internal_metadata_.have_unknown_fields()) { + ::google::protobuf::internal::WireFormat::SerializeUnknownFields( + _internal_metadata_.unknown_fields(), output); + } + // @@protoc_insertion_point(serialize_end:flyteidl.core.QualityOfService) +} + +::google::protobuf::uint8* QualityOfService::InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const { + // @@protoc_insertion_point(serialize_to_array_start:flyteidl.core.QualityOfService) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // .flyteidl.core.QualityOfService.Tier tier = 1; + if (has_tier()) { + target = ::google::protobuf::internal::WireFormatLite::WriteEnumToArray( + 1, this->tier(), target); + } + + // .flyteidl.core.QualityOfServiceSpec spec = 2; + if (has_spec()) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 2, HasBitSetters::spec(this), 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.core.QualityOfService) + return target; +} + +size_t QualityOfService::ByteSizeLong() const { +// @@protoc_insertion_point(message_byte_size_start:flyteidl.core.QualityOfService) + 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; + + switch (designation_case()) { + // .flyteidl.core.QualityOfService.Tier tier = 1; + case kTier: { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::EnumSize(this->tier()); + break; + } + // .flyteidl.core.QualityOfServiceSpec spec = 2; + case kSpec: { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *designation_.spec_); + break; + } + case DESIGNATION_NOT_SET: { + break; + } + } + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); + SetCachedSize(cached_size); + return total_size; +} + +void QualityOfService::MergeFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_merge_from_start:flyteidl.core.QualityOfService) + GOOGLE_DCHECK_NE(&from, this); + const QualityOfService* source = + ::google::protobuf::DynamicCastToGenerated( + &from); + if (source == nullptr) { + // @@protoc_insertion_point(generalized_merge_from_cast_fail:flyteidl.core.QualityOfService) + ::google::protobuf::internal::ReflectionOps::Merge(from, this); + } else { + // @@protoc_insertion_point(generalized_merge_from_cast_success:flyteidl.core.QualityOfService) + MergeFrom(*source); + } +} + +void QualityOfService::MergeFrom(const QualityOfService& from) { +// @@protoc_insertion_point(class_specific_merge_from_start:flyteidl.core.QualityOfService) + GOOGLE_DCHECK_NE(&from, this); + _internal_metadata_.MergeFrom(from._internal_metadata_); + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + switch (from.designation_case()) { + case kTier: { + set_tier(from.tier()); + break; + } + case kSpec: { + mutable_spec()->::flyteidl::core::QualityOfServiceSpec::MergeFrom(from.spec()); + break; + } + case DESIGNATION_NOT_SET: { + break; + } + } +} + +void QualityOfService::CopyFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_copy_from_start:flyteidl.core.QualityOfService) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +void QualityOfService::CopyFrom(const QualityOfService& from) { +// @@protoc_insertion_point(class_specific_copy_from_start:flyteidl.core.QualityOfService) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +bool QualityOfService::IsInitialized() const { + return true; +} + +void QualityOfService::Swap(QualityOfService* other) { + if (other == this) return; + InternalSwap(other); +} +void QualityOfService::InternalSwap(QualityOfService* other) { + using std::swap; + _internal_metadata_.Swap(&other->_internal_metadata_); + swap(designation_, other->designation_); + swap(_oneof_case_[0], other->_oneof_case_[0]); +} + +::google::protobuf::Metadata QualityOfService::GetMetadata() const { + ::google::protobuf::internal::AssignDescriptors(&::assign_descriptors_table_flyteidl_2fcore_2fexecution_2eproto); + return ::file_level_metadata_flyteidl_2fcore_2fexecution_2eproto[kIndexInFileMessages]; +} + + // @@protoc_insertion_point(namespace_scope) } // namespace core } // namespace flyteidl @@ -2005,6 +2777,12 @@ template<> PROTOBUF_NOINLINE ::flyteidl::core::ExecutionError* Arena::CreateMayb template<> PROTOBUF_NOINLINE ::flyteidl::core::TaskLog* Arena::CreateMaybeMessage< ::flyteidl::core::TaskLog >(Arena* arena) { return Arena::CreateInternal< ::flyteidl::core::TaskLog >(arena); } +template<> PROTOBUF_NOINLINE ::flyteidl::core::QualityOfServiceSpec* Arena::CreateMaybeMessage< ::flyteidl::core::QualityOfServiceSpec >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::core::QualityOfServiceSpec >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::core::QualityOfService* Arena::CreateMaybeMessage< ::flyteidl::core::QualityOfService >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::core::QualityOfService >(arena); +} } // namespace protobuf } // namespace google diff --git a/flyteidl/gen/pb-cpp/flyteidl/core/execution.pb.h b/flyteidl/gen/pb-cpp/flyteidl/core/execution.pb.h index 9aaeb67124c..54f3a8eebcc 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/core/execution.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/core/execution.pb.h @@ -43,7 +43,7 @@ struct TableStruct_flyteidl_2fcore_2fexecution_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[7] PROTOBUF_SECTION_VARIABLE(protodesc_cold); static const ::google::protobuf::internal::FieldMetadata field_metadata[]; static const ::google::protobuf::internal::SerializationTable serialization_table[]; @@ -58,6 +58,12 @@ extern ExecutionErrorDefaultTypeInternal _ExecutionError_default_instance_; class NodeExecution; class NodeExecutionDefaultTypeInternal; extern NodeExecutionDefaultTypeInternal _NodeExecution_default_instance_; +class QualityOfService; +class QualityOfServiceDefaultTypeInternal; +extern QualityOfServiceDefaultTypeInternal _QualityOfService_default_instance_; +class QualityOfServiceSpec; +class QualityOfServiceSpecDefaultTypeInternal; +extern QualityOfServiceSpecDefaultTypeInternal _QualityOfServiceSpec_default_instance_; class TaskExecution; class TaskExecutionDefaultTypeInternal; extern TaskExecutionDefaultTypeInternal _TaskExecution_default_instance_; @@ -73,6 +79,8 @@ namespace google { namespace protobuf { template<> ::flyteidl::core::ExecutionError* Arena::CreateMaybeMessage<::flyteidl::core::ExecutionError>(Arena*); template<> ::flyteidl::core::NodeExecution* Arena::CreateMaybeMessage<::flyteidl::core::NodeExecution>(Arena*); +template<> ::flyteidl::core::QualityOfService* Arena::CreateMaybeMessage<::flyteidl::core::QualityOfService>(Arena*); +template<> ::flyteidl::core::QualityOfServiceSpec* Arena::CreateMaybeMessage<::flyteidl::core::QualityOfServiceSpec>(Arena*); template<> ::flyteidl::core::TaskExecution* Arena::CreateMaybeMessage<::flyteidl::core::TaskExecution>(Arena*); template<> ::flyteidl::core::TaskLog* Arena::CreateMaybeMessage<::flyteidl::core::TaskLog>(Arena*); template<> ::flyteidl::core::WorkflowExecution* Arena::CreateMaybeMessage<::flyteidl::core::WorkflowExecution>(Arena*); @@ -208,6 +216,29 @@ inline bool TaskLog_MessageFormat_Parse( return ::google::protobuf::internal::ParseNamedEnum( TaskLog_MessageFormat_descriptor(), name, value); } +enum QualityOfService_Tier { + QualityOfService_Tier_UNDEFINED = 0, + QualityOfService_Tier_HIGH = 1, + QualityOfService_Tier_MEDIUM = 2, + QualityOfService_Tier_LOW = 3, + QualityOfService_Tier_QualityOfService_Tier_INT_MIN_SENTINEL_DO_NOT_USE_ = std::numeric_limits<::google::protobuf::int32>::min(), + QualityOfService_Tier_QualityOfService_Tier_INT_MAX_SENTINEL_DO_NOT_USE_ = std::numeric_limits<::google::protobuf::int32>::max() +}; +bool QualityOfService_Tier_IsValid(int value); +const QualityOfService_Tier QualityOfService_Tier_Tier_MIN = QualityOfService_Tier_UNDEFINED; +const QualityOfService_Tier QualityOfService_Tier_Tier_MAX = QualityOfService_Tier_LOW; +const int QualityOfService_Tier_Tier_ARRAYSIZE = QualityOfService_Tier_Tier_MAX + 1; + +const ::google::protobuf::EnumDescriptor* QualityOfService_Tier_descriptor(); +inline const ::std::string& QualityOfService_Tier_Name(QualityOfService_Tier value) { + return ::google::protobuf::internal::NameOfEnum( + QualityOfService_Tier_descriptor(), value); +} +inline bool QualityOfService_Tier_Parse( + const ::std::string& name, QualityOfService_Tier* value) { + return ::google::protobuf::internal::ParseNamedEnum( + QualityOfService_Tier_descriptor(), name, value); +} // =================================================================== class WorkflowExecution final : @@ -1006,6 +1037,294 @@ class TaskLog final : mutable ::google::protobuf::internal::CachedSize _cached_size_; friend struct ::TableStruct_flyteidl_2fcore_2fexecution_2eproto; }; +// ------------------------------------------------------------------- + +class QualityOfServiceSpec final : + public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.core.QualityOfServiceSpec) */ { + public: + QualityOfServiceSpec(); + virtual ~QualityOfServiceSpec(); + + QualityOfServiceSpec(const QualityOfServiceSpec& from); + + inline QualityOfServiceSpec& operator=(const QualityOfServiceSpec& from) { + CopyFrom(from); + return *this; + } + #if LANG_CXX11 + QualityOfServiceSpec(QualityOfServiceSpec&& from) noexcept + : QualityOfServiceSpec() { + *this = ::std::move(from); + } + + inline QualityOfServiceSpec& operator=(QualityOfServiceSpec&& 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 QualityOfServiceSpec& default_instance(); + + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY + static inline const QualityOfServiceSpec* internal_default_instance() { + return reinterpret_cast( + &_QualityOfServiceSpec_default_instance_); + } + static constexpr int kIndexInFileMessages = + 5; + + void Swap(QualityOfServiceSpec* other); + friend void swap(QualityOfServiceSpec& a, QualityOfServiceSpec& b) { + a.Swap(&b); + } + + // implements Message ---------------------------------------------- + + inline QualityOfServiceSpec* New() const final { + return CreateMaybeMessage(nullptr); + } + + QualityOfServiceSpec* 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 QualityOfServiceSpec& from); + void MergeFrom(const QualityOfServiceSpec& 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(QualityOfServiceSpec* 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 ------------------------------------------------------- + + // .google.protobuf.Duration queueing_budget = 1; + bool has_queueing_budget() const; + void clear_queueing_budget(); + static const int kQueueingBudgetFieldNumber = 1; + const ::google::protobuf::Duration& queueing_budget() const; + ::google::protobuf::Duration* release_queueing_budget(); + ::google::protobuf::Duration* mutable_queueing_budget(); + void set_allocated_queueing_budget(::google::protobuf::Duration* queueing_budget); + + // @@protoc_insertion_point(class_scope:flyteidl.core.QualityOfServiceSpec) + private: + class HasBitSetters; + + ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + ::google::protobuf::Duration* queueing_budget_; + mutable ::google::protobuf::internal::CachedSize _cached_size_; + friend struct ::TableStruct_flyteidl_2fcore_2fexecution_2eproto; +}; +// ------------------------------------------------------------------- + +class QualityOfService final : + public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.core.QualityOfService) */ { + public: + QualityOfService(); + virtual ~QualityOfService(); + + QualityOfService(const QualityOfService& from); + + inline QualityOfService& operator=(const QualityOfService& from) { + CopyFrom(from); + return *this; + } + #if LANG_CXX11 + QualityOfService(QualityOfService&& from) noexcept + : QualityOfService() { + *this = ::std::move(from); + } + + inline QualityOfService& operator=(QualityOfService&& 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 QualityOfService& default_instance(); + + enum DesignationCase { + kTier = 1, + kSpec = 2, + DESIGNATION_NOT_SET = 0, + }; + + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY + static inline const QualityOfService* internal_default_instance() { + return reinterpret_cast( + &_QualityOfService_default_instance_); + } + static constexpr int kIndexInFileMessages = + 6; + + void Swap(QualityOfService* other); + friend void swap(QualityOfService& a, QualityOfService& b) { + a.Swap(&b); + } + + // implements Message ---------------------------------------------- + + inline QualityOfService* New() const final { + return CreateMaybeMessage(nullptr); + } + + QualityOfService* 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 QualityOfService& from); + void MergeFrom(const QualityOfService& 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(QualityOfService* 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 ---------------------------------------------------- + + typedef QualityOfService_Tier Tier; + static const Tier UNDEFINED = + QualityOfService_Tier_UNDEFINED; + static const Tier HIGH = + QualityOfService_Tier_HIGH; + static const Tier MEDIUM = + QualityOfService_Tier_MEDIUM; + static const Tier LOW = + QualityOfService_Tier_LOW; + static inline bool Tier_IsValid(int value) { + return QualityOfService_Tier_IsValid(value); + } + static const Tier Tier_MIN = + QualityOfService_Tier_Tier_MIN; + static const Tier Tier_MAX = + QualityOfService_Tier_Tier_MAX; + static const int Tier_ARRAYSIZE = + QualityOfService_Tier_Tier_ARRAYSIZE; + static inline const ::google::protobuf::EnumDescriptor* + Tier_descriptor() { + return QualityOfService_Tier_descriptor(); + } + static inline const ::std::string& Tier_Name(Tier value) { + return QualityOfService_Tier_Name(value); + } + static inline bool Tier_Parse(const ::std::string& name, + Tier* value) { + return QualityOfService_Tier_Parse(name, value); + } + + // accessors ------------------------------------------------------- + + // .flyteidl.core.QualityOfService.Tier tier = 1; + private: + bool has_tier() const; + public: + void clear_tier(); + static const int kTierFieldNumber = 1; + ::flyteidl::core::QualityOfService_Tier tier() const; + void set_tier(::flyteidl::core::QualityOfService_Tier value); + + // .flyteidl.core.QualityOfServiceSpec spec = 2; + bool has_spec() const; + void clear_spec(); + static const int kSpecFieldNumber = 2; + const ::flyteidl::core::QualityOfServiceSpec& spec() const; + ::flyteidl::core::QualityOfServiceSpec* release_spec(); + ::flyteidl::core::QualityOfServiceSpec* mutable_spec(); + void set_allocated_spec(::flyteidl::core::QualityOfServiceSpec* spec); + + void clear_designation(); + DesignationCase designation_case() const; + // @@protoc_insertion_point(class_scope:flyteidl.core.QualityOfService) + private: + class HasBitSetters; + void set_has_tier(); + void set_has_spec(); + + inline bool has_designation() const; + inline void clear_has_designation(); + + ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + union DesignationUnion { + DesignationUnion() {} + int tier_; + ::flyteidl::core::QualityOfServiceSpec* spec_; + } designation_; + mutable ::google::protobuf::internal::CachedSize _cached_size_; + ::google::protobuf::uint32 _oneof_case_[1]; + + friend struct ::TableStruct_flyteidl_2fcore_2fexecution_2eproto; +}; // =================================================================== @@ -1372,6 +1691,139 @@ inline void TaskLog::set_allocated_ttl(::google::protobuf::Duration* ttl) { // @@protoc_insertion_point(field_set_allocated:flyteidl.core.TaskLog.ttl) } +// ------------------------------------------------------------------- + +// QualityOfServiceSpec + +// .google.protobuf.Duration queueing_budget = 1; +inline bool QualityOfServiceSpec::has_queueing_budget() const { + return this != internal_default_instance() && queueing_budget_ != nullptr; +} +inline const ::google::protobuf::Duration& QualityOfServiceSpec::queueing_budget() const { + const ::google::protobuf::Duration* p = queueing_budget_; + // @@protoc_insertion_point(field_get:flyteidl.core.QualityOfServiceSpec.queueing_budget) + return p != nullptr ? *p : *reinterpret_cast( + &::google::protobuf::_Duration_default_instance_); +} +inline ::google::protobuf::Duration* QualityOfServiceSpec::release_queueing_budget() { + // @@protoc_insertion_point(field_release:flyteidl.core.QualityOfServiceSpec.queueing_budget) + + ::google::protobuf::Duration* temp = queueing_budget_; + queueing_budget_ = nullptr; + return temp; +} +inline ::google::protobuf::Duration* QualityOfServiceSpec::mutable_queueing_budget() { + + if (queueing_budget_ == nullptr) { + auto* p = CreateMaybeMessage<::google::protobuf::Duration>(GetArenaNoVirtual()); + queueing_budget_ = p; + } + // @@protoc_insertion_point(field_mutable:flyteidl.core.QualityOfServiceSpec.queueing_budget) + return queueing_budget_; +} +inline void QualityOfServiceSpec::set_allocated_queueing_budget(::google::protobuf::Duration* queueing_budget) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + if (message_arena == nullptr) { + delete reinterpret_cast< ::google::protobuf::MessageLite*>(queueing_budget_); + } + if (queueing_budget) { + ::google::protobuf::Arena* submessage_arena = + reinterpret_cast<::google::protobuf::MessageLite*>(queueing_budget)->GetArena(); + if (message_arena != submessage_arena) { + queueing_budget = ::google::protobuf::internal::GetOwnedMessage( + message_arena, queueing_budget, submessage_arena); + } + + } else { + + } + queueing_budget_ = queueing_budget; + // @@protoc_insertion_point(field_set_allocated:flyteidl.core.QualityOfServiceSpec.queueing_budget) +} + +// ------------------------------------------------------------------- + +// QualityOfService + +// .flyteidl.core.QualityOfService.Tier tier = 1; +inline bool QualityOfService::has_tier() const { + return designation_case() == kTier; +} +inline void QualityOfService::set_has_tier() { + _oneof_case_[0] = kTier; +} +inline void QualityOfService::clear_tier() { + if (has_tier()) { + designation_.tier_ = 0; + clear_has_designation(); + } +} +inline ::flyteidl::core::QualityOfService_Tier QualityOfService::tier() const { + // @@protoc_insertion_point(field_get:flyteidl.core.QualityOfService.tier) + if (has_tier()) { + return static_cast< ::flyteidl::core::QualityOfService_Tier >(designation_.tier_); + } + return static_cast< ::flyteidl::core::QualityOfService_Tier >(0); +} +inline void QualityOfService::set_tier(::flyteidl::core::QualityOfService_Tier value) { + if (!has_tier()) { + clear_designation(); + set_has_tier(); + } + designation_.tier_ = value; + // @@protoc_insertion_point(field_set:flyteidl.core.QualityOfService.tier) +} + +// .flyteidl.core.QualityOfServiceSpec spec = 2; +inline bool QualityOfService::has_spec() const { + return designation_case() == kSpec; +} +inline void QualityOfService::set_has_spec() { + _oneof_case_[0] = kSpec; +} +inline void QualityOfService::clear_spec() { + if (has_spec()) { + delete designation_.spec_; + clear_has_designation(); + } +} +inline ::flyteidl::core::QualityOfServiceSpec* QualityOfService::release_spec() { + // @@protoc_insertion_point(field_release:flyteidl.core.QualityOfService.spec) + if (has_spec()) { + clear_has_designation(); + ::flyteidl::core::QualityOfServiceSpec* temp = designation_.spec_; + designation_.spec_ = nullptr; + return temp; + } else { + return nullptr; + } +} +inline const ::flyteidl::core::QualityOfServiceSpec& QualityOfService::spec() const { + // @@protoc_insertion_point(field_get:flyteidl.core.QualityOfService.spec) + return has_spec() + ? *designation_.spec_ + : *reinterpret_cast< ::flyteidl::core::QualityOfServiceSpec*>(&::flyteidl::core::_QualityOfServiceSpec_default_instance_); +} +inline ::flyteidl::core::QualityOfServiceSpec* QualityOfService::mutable_spec() { + if (!has_spec()) { + clear_designation(); + set_has_spec(); + designation_.spec_ = CreateMaybeMessage< ::flyteidl::core::QualityOfServiceSpec >( + GetArenaNoVirtual()); + } + // @@protoc_insertion_point(field_mutable:flyteidl.core.QualityOfService.spec) + return designation_.spec_; +} + +inline bool QualityOfService::has_designation() const { + return designation_case() != DESIGNATION_NOT_SET; +} +inline void QualityOfService::clear_has_designation() { + _oneof_case_[0] = DESIGNATION_NOT_SET; +} +inline QualityOfService::DesignationCase QualityOfService::designation_case() const { + return QualityOfService::DesignationCase(_oneof_case_[0]); +} #ifdef __GNUC__ #pragma GCC diagnostic pop #endif // __GNUC__ @@ -1383,6 +1835,10 @@ inline void TaskLog::set_allocated_ttl(::google::protobuf::Duration* ttl) { // ------------------------------------------------------------------- +// ------------------------------------------------------------------- + +// ------------------------------------------------------------------- + // @@protoc_insertion_point(namespace_scope) @@ -1417,6 +1873,11 @@ template <> inline const EnumDescriptor* GetEnumDescriptor< ::flyteidl::core::TaskLog_MessageFormat>() { return ::flyteidl::core::TaskLog_MessageFormat_descriptor(); } +template <> struct is_proto_enum< ::flyteidl::core::QualityOfService_Tier> : ::std::true_type {}; +template <> +inline const EnumDescriptor* GetEnumDescriptor< ::flyteidl::core::QualityOfService_Tier>() { + return ::flyteidl::core::QualityOfService_Tier_descriptor(); +} } // namespace protobuf } // namespace google diff --git a/flyteidl/gen/pb-cpp/flyteidl/core/workflow.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/core/workflow.pb.cc index 8a8ac03a895..66dd29313bb 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/core/workflow.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/core/workflow.pb.cc @@ -17,6 +17,7 @@ #include extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fcondition_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_BooleanExpression_flyteidl_2fcore_2fcondition_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fidentifier_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_Identifier_flyteidl_2fcore_2fidentifier_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2finterface_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_TypedInterface_flyteidl_2fcore_2finterface_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fliterals_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_RetryStrategy_flyteidl_2fcore_2fliterals_2eproto; @@ -199,7 +200,7 @@ static void InitDefaultsWorkflowMetadata_flyteidl_2fcore_2fworkflow_2eproto() { ::google::protobuf::internal::SCCInfo<1> scc_info_WorkflowMetadata_flyteidl_2fcore_2fworkflow_2eproto = {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsWorkflowMetadata_flyteidl_2fcore_2fworkflow_2eproto}, { - &scc_info_Duration_google_2fprotobuf_2fduration_2eproto.base,}}; + &scc_info_QualityOfService_flyteidl_2fcore_2fexecution_2eproto.base,}}; static void InitDefaultsWorkflowMetadataDefaults_flyteidl_2fcore_2fworkflow_2eproto() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -325,7 +326,7 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fcore_2fworkflow_2eproto: ~0u, // no _extensions_ ~0u, // no _oneof_case_ ~0u, // no _weak_field_map_ - PROTOBUF_FIELD_OFFSET(::flyteidl::core::WorkflowMetadata, queuing_budget_), + PROTOBUF_FIELD_OFFSET(::flyteidl::core::WorkflowMetadata, quality_of_service_), PROTOBUF_FIELD_OFFSET(::flyteidl::core::WorkflowMetadata, on_failure_), ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::core::WorkflowMetadataDefaults, _internal_metadata_), @@ -382,74 +383,76 @@ ::google::protobuf::internal::AssignDescriptorsTable assign_descriptors_table_fl const char descriptor_table_protodef_flyteidl_2fcore_2fworkflow_2eproto[] = "\n\034flyteidl/core/workflow.proto\022\rflyteidl" - ".core\032\035flyteidl/core/condition.proto\032\036fl" - "yteidl/core/identifier.proto\032\035flyteidl/c" - "ore/interface.proto\032\034flyteidl/core/liter" - "als.proto\032\031flyteidl/core/types.proto\032\036go" - "ogle/protobuf/duration.proto\"f\n\007IfBlock\022" - "3\n\tcondition\030\001 \001(\0132 .flyteidl.core.Boole" - "anExpression\022&\n\tthen_node\030\002 \001(\0132\023.flytei" - "dl.core.Node\"\266\001\n\013IfElseBlock\022$\n\004case\030\001 \001" - "(\0132\026.flyteidl.core.IfBlock\022%\n\005other\030\002 \003(" - "\0132\026.flyteidl.core.IfBlock\022(\n\telse_node\030\003" - " \001(\0132\023.flyteidl.core.NodeH\000\022%\n\005error\030\004 \001" - "(\0132\024.flyteidl.core.ErrorH\000B\t\n\007default\"9\n" - "\nBranchNode\022+\n\007if_else\030\001 \001(\0132\032.flyteidl." - "core.IfElseBlock\"J\n\010TaskNode\0221\n\014referenc" - "e_id\030\001 \001(\0132\031.flyteidl.core.IdentifierH\000B" - "\013\n\treference\"\207\001\n\014WorkflowNode\0223\n\016launchp" - "lan_ref\030\001 \001(\0132\031.flyteidl.core.Identifier" - "H\000\0225\n\020sub_workflow_ref\030\002 \001(\0132\031.flyteidl." - "core.IdentifierH\000B\013\n\treference\"\247\001\n\014NodeM" - "etadata\022\014\n\004name\030\001 \001(\t\022*\n\007timeout\030\004 \001(\0132\031" - ".google.protobuf.Duration\022-\n\007retries\030\005 \001" - "(\0132\034.flyteidl.core.RetryStrategy\022\027\n\rinte" - "rruptible\030\006 \001(\010H\000B\025\n\023interruptible_value" - "\"#\n\005Alias\022\013\n\003var\030\001 \001(\t\022\r\n\005alias\030\002 \001(\t\"\322\002" - "\n\004Node\022\n\n\002id\030\001 \001(\t\022-\n\010metadata\030\002 \001(\0132\033.f" - "lyteidl.core.NodeMetadata\022&\n\006inputs\030\003 \003(" - "\0132\026.flyteidl.core.Binding\022\031\n\021upstream_no" - "de_ids\030\004 \003(\t\022,\n\016output_aliases\030\005 \003(\0132\024.f" - "lyteidl.core.Alias\022,\n\ttask_node\030\006 \001(\0132\027." - "flyteidl.core.TaskNodeH\000\0224\n\rworkflow_nod" - "e\030\007 \001(\0132\033.flyteidl.core.WorkflowNodeH\000\0220" - "\n\013branch_node\030\010 \001(\0132\031.flyteidl.core.Bran" - "chNodeH\000B\010\n\006target\"\335\001\n\020WorkflowMetadata\022" - "1\n\016queuing_budget\030\001 \001(\0132\031.google.protobu" - "f.Duration\022C\n\non_failure\030\002 \001(\0162/.flyteid" - "l.core.WorkflowMetadata.OnFailurePolicy\"" - "Q\n\017OnFailurePolicy\022\024\n\020FAIL_IMMEDIATELY\020\000" - "\022(\n$FAIL_AFTER_EXECUTABLE_NODES_COMPLETE" - "\020\001\"1\n\030WorkflowMetadataDefaults\022\025\n\rinterr" - "uptible\030\001 \001(\010\"\332\002\n\020WorkflowTemplate\022%\n\002id" - "\030\001 \001(\0132\031.flyteidl.core.Identifier\0221\n\010met" - "adata\030\002 \001(\0132\037.flyteidl.core.WorkflowMeta" - "data\0220\n\tinterface\030\003 \001(\0132\035.flyteidl.core." - "TypedInterface\022\"\n\005nodes\030\004 \003(\0132\023.flyteidl" - ".core.Node\022\'\n\007outputs\030\005 \003(\0132\026.flyteidl.c" - "ore.Binding\022)\n\014failure_node\030\006 \001(\0132\023.flyt" - "eidl.core.Node\022B\n\021metadata_defaults\030\007 \001(" - "\0132\'.flyteidl.core.WorkflowMetadataDefaul" - "tsB2Z0github.com/lyft/flyteidl/gen/pb-go" - "/flyteidl/coreb\006proto3" + ".core\032\035flyteidl/core/condition.proto\032\035fl" + "yteidl/core/execution.proto\032\036flyteidl/co" + "re/identifier.proto\032\035flyteidl/core/inter" + "face.proto\032\034flyteidl/core/literals.proto" + "\032\031flyteidl/core/types.proto\032\036google/prot" + "obuf/duration.proto\"f\n\007IfBlock\0223\n\tcondit" + "ion\030\001 \001(\0132 .flyteidl.core.BooleanExpress" + "ion\022&\n\tthen_node\030\002 \001(\0132\023.flyteidl.core.N" + "ode\"\266\001\n\013IfElseBlock\022$\n\004case\030\001 \001(\0132\026.flyt" + "eidl.core.IfBlock\022%\n\005other\030\002 \003(\0132\026.flyte" + "idl.core.IfBlock\022(\n\telse_node\030\003 \001(\0132\023.fl" + "yteidl.core.NodeH\000\022%\n\005error\030\004 \001(\0132\024.flyt" + "eidl.core.ErrorH\000B\t\n\007default\"9\n\nBranchNo" + "de\022+\n\007if_else\030\001 \001(\0132\032.flyteidl.core.IfEl" + "seBlock\"J\n\010TaskNode\0221\n\014reference_id\030\001 \001(" + "\0132\031.flyteidl.core.IdentifierH\000B\013\n\trefere" + "nce\"\207\001\n\014WorkflowNode\0223\n\016launchplan_ref\030\001" + " \001(\0132\031.flyteidl.core.IdentifierH\000\0225\n\020sub" + "_workflow_ref\030\002 \001(\0132\031.flyteidl.core.Iden" + "tifierH\000B\013\n\treference\"\247\001\n\014NodeMetadata\022\014" + "\n\004name\030\001 \001(\t\022*\n\007timeout\030\004 \001(\0132\031.google.p" + "rotobuf.Duration\022-\n\007retries\030\005 \001(\0132\034.flyt" + "eidl.core.RetryStrategy\022\027\n\rinterruptible" + "\030\006 \001(\010H\000B\025\n\023interruptible_value\"#\n\005Alias" + "\022\013\n\003var\030\001 \001(\t\022\r\n\005alias\030\002 \001(\t\"\322\002\n\004Node\022\n\n" + "\002id\030\001 \001(\t\022-\n\010metadata\030\002 \001(\0132\033.flyteidl.c" + "ore.NodeMetadata\022&\n\006inputs\030\003 \003(\0132\026.flyte" + "idl.core.Binding\022\031\n\021upstream_node_ids\030\004 " + "\003(\t\022,\n\016output_aliases\030\005 \003(\0132\024.flyteidl.c" + "ore.Alias\022,\n\ttask_node\030\006 \001(\0132\027.flyteidl." + "core.TaskNodeH\000\0224\n\rworkflow_node\030\007 \001(\0132\033" + ".flyteidl.core.WorkflowNodeH\000\0220\n\013branch_" + "node\030\010 \001(\0132\031.flyteidl.core.BranchNodeH\000B" + "\010\n\006target\"\347\001\n\020WorkflowMetadata\022;\n\022qualit" + "y_of_service\030\001 \001(\0132\037.flyteidl.core.Quali" + "tyOfService\022C\n\non_failure\030\002 \001(\0162/.flytei" + "dl.core.WorkflowMetadata.OnFailurePolicy" + "\"Q\n\017OnFailurePolicy\022\024\n\020FAIL_IMMEDIATELY\020" + "\000\022(\n$FAIL_AFTER_EXECUTABLE_NODES_COMPLET" + "E\020\001\"1\n\030WorkflowMetadataDefaults\022\025\n\rinter" + "ruptible\030\001 \001(\010\"\332\002\n\020WorkflowTemplate\022%\n\002i" + "d\030\001 \001(\0132\031.flyteidl.core.Identifier\0221\n\010me" + "tadata\030\002 \001(\0132\037.flyteidl.core.WorkflowMet" + "adata\0220\n\tinterface\030\003 \001(\0132\035.flyteidl.core" + ".TypedInterface\022\"\n\005nodes\030\004 \003(\0132\023.flyteid" + "l.core.Node\022\'\n\007outputs\030\005 \003(\0132\026.flyteidl." + "core.Binding\022)\n\014failure_node\030\006 \001(\0132\023.fly" + "teidl.core.Node\022B\n\021metadata_defaults\030\007 \001" + "(\0132\'.flyteidl.core.WorkflowMetadataDefau" + "ltsB2Z0github.com/lyft/flyteidl/gen/pb-g" + "o/flyteidl/coreb\006proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fcore_2fworkflow_2eproto = { false, InitDefaults_flyteidl_2fcore_2fworkflow_2eproto, descriptor_table_protodef_flyteidl_2fcore_2fworkflow_2eproto, - "flyteidl/core/workflow.proto", &assign_descriptors_table_flyteidl_2fcore_2fworkflow_2eproto, 2022, + "flyteidl/core/workflow.proto", &assign_descriptors_table_flyteidl_2fcore_2fworkflow_2eproto, 2063, }; void AddDescriptors_flyteidl_2fcore_2fworkflow_2eproto() { - static constexpr ::google::protobuf::internal::InitFunc deps[6] = + static constexpr ::google::protobuf::internal::InitFunc deps[7] = { ::AddDescriptors_flyteidl_2fcore_2fcondition_2eproto, + ::AddDescriptors_flyteidl_2fcore_2fexecution_2eproto, ::AddDescriptors_flyteidl_2fcore_2fidentifier_2eproto, ::AddDescriptors_flyteidl_2fcore_2finterface_2eproto, ::AddDescriptors_flyteidl_2fcore_2fliterals_2eproto, ::AddDescriptors_flyteidl_2fcore_2ftypes_2eproto, ::AddDescriptors_google_2fprotobuf_2fduration_2eproto, }; - ::google::protobuf::internal::AddDescriptors(&descriptor_table_flyteidl_2fcore_2fworkflow_2eproto, deps, 6); + ::google::protobuf::internal::AddDescriptors(&descriptor_table_flyteidl_2fcore_2fworkflow_2eproto, deps, 7); } // Force running AddDescriptors() at dynamic initialization time. @@ -4153,26 +4156,26 @@ ::google::protobuf::Metadata Node::GetMetadata() const { // =================================================================== void WorkflowMetadata::InitAsDefaultInstance() { - ::flyteidl::core::_WorkflowMetadata_default_instance_._instance.get_mutable()->queuing_budget_ = const_cast< ::google::protobuf::Duration*>( - ::google::protobuf::Duration::internal_default_instance()); + ::flyteidl::core::_WorkflowMetadata_default_instance_._instance.get_mutable()->quality_of_service_ = const_cast< ::flyteidl::core::QualityOfService*>( + ::flyteidl::core::QualityOfService::internal_default_instance()); } class WorkflowMetadata::HasBitSetters { public: - static const ::google::protobuf::Duration& queuing_budget(const WorkflowMetadata* msg); + static const ::flyteidl::core::QualityOfService& quality_of_service(const WorkflowMetadata* msg); }; -const ::google::protobuf::Duration& -WorkflowMetadata::HasBitSetters::queuing_budget(const WorkflowMetadata* msg) { - return *msg->queuing_budget_; +const ::flyteidl::core::QualityOfService& +WorkflowMetadata::HasBitSetters::quality_of_service(const WorkflowMetadata* msg) { + return *msg->quality_of_service_; } -void WorkflowMetadata::clear_queuing_budget() { - if (GetArenaNoVirtual() == nullptr && queuing_budget_ != nullptr) { - delete queuing_budget_; +void WorkflowMetadata::clear_quality_of_service() { + if (GetArenaNoVirtual() == nullptr && quality_of_service_ != nullptr) { + delete quality_of_service_; } - queuing_budget_ = nullptr; + quality_of_service_ = nullptr; } #if !defined(_MSC_VER) || _MSC_VER >= 1900 -const int WorkflowMetadata::kQueuingBudgetFieldNumber; +const int WorkflowMetadata::kQualityOfServiceFieldNumber; const int WorkflowMetadata::kOnFailureFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 @@ -4185,10 +4188,10 @@ WorkflowMetadata::WorkflowMetadata(const WorkflowMetadata& from) : ::google::protobuf::Message(), _internal_metadata_(nullptr) { _internal_metadata_.MergeFrom(from._internal_metadata_); - if (from.has_queuing_budget()) { - queuing_budget_ = new ::google::protobuf::Duration(*from.queuing_budget_); + if (from.has_quality_of_service()) { + quality_of_service_ = new ::flyteidl::core::QualityOfService(*from.quality_of_service_); } else { - queuing_budget_ = nullptr; + quality_of_service_ = nullptr; } on_failure_ = from.on_failure_; // @@protoc_insertion_point(copy_constructor:flyteidl.core.WorkflowMetadata) @@ -4197,9 +4200,9 @@ WorkflowMetadata::WorkflowMetadata(const WorkflowMetadata& from) void WorkflowMetadata::SharedCtor() { ::google::protobuf::internal::InitSCC( &scc_info_WorkflowMetadata_flyteidl_2fcore_2fworkflow_2eproto.base); - ::memset(&queuing_budget_, 0, static_cast( + ::memset(&quality_of_service_, 0, static_cast( reinterpret_cast(&on_failure_) - - reinterpret_cast(&queuing_budget_)) + sizeof(on_failure_)); + reinterpret_cast(&quality_of_service_)) + sizeof(on_failure_)); } WorkflowMetadata::~WorkflowMetadata() { @@ -4208,7 +4211,7 @@ WorkflowMetadata::~WorkflowMetadata() { } void WorkflowMetadata::SharedDtor() { - if (this != internal_default_instance()) delete queuing_budget_; + if (this != internal_default_instance()) delete quality_of_service_; } void WorkflowMetadata::SetCachedSize(int size) const { @@ -4226,10 +4229,10 @@ void WorkflowMetadata::Clear() { // Prevent compiler warnings about cached_has_bits being unused (void) cached_has_bits; - if (GetArenaNoVirtual() == nullptr && queuing_budget_ != nullptr) { - delete queuing_budget_; + if (GetArenaNoVirtual() == nullptr && quality_of_service_ != nullptr) { + delete quality_of_service_; } - queuing_budget_ = nullptr; + quality_of_service_ = nullptr; on_failure_ = 0; _internal_metadata_.Clear(); } @@ -4247,13 +4250,13 @@ const char* WorkflowMetadata::_InternalParse(const char* begin, const char* end, ptr = ::google::protobuf::io::Parse32(ptr, &tag); GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); switch (tag >> 3) { - // .google.protobuf.Duration queuing_budget = 1; + // .flyteidl.core.QualityOfService quality_of_service = 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); - parser_till_end = ::google::protobuf::Duration::_InternalParse; - object = msg->mutable_queuing_budget(); + parser_till_end = ::flyteidl::core::QualityOfService::_InternalParse; + object = msg->mutable_quality_of_service(); if (size > end - ptr) goto len_delim_till_end; ptr += size; GOOGLE_PROTOBUF_PARSER_ASSERT(ctx->ParseExactRange( @@ -4298,11 +4301,11 @@ bool WorkflowMetadata::MergePartialFromCodedStream( tag = p.first; if (!p.second) goto handle_unusual; switch (::google::protobuf::internal::WireFormatLite::GetTagFieldNumber(tag)) { - // .google.protobuf.Duration queuing_budget = 1; + // .flyteidl.core.QualityOfService quality_of_service = 1; case 1: { if (static_cast< ::google::protobuf::uint8>(tag) == (10 & 0xFF)) { DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( - input, mutable_queuing_budget())); + input, mutable_quality_of_service())); } else { goto handle_unusual; } @@ -4350,10 +4353,10 @@ void WorkflowMetadata::SerializeWithCachedSizes( ::google::protobuf::uint32 cached_has_bits = 0; (void) cached_has_bits; - // .google.protobuf.Duration queuing_budget = 1; - if (this->has_queuing_budget()) { + // .flyteidl.core.QualityOfService quality_of_service = 1; + if (this->has_quality_of_service()) { ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( - 1, HasBitSetters::queuing_budget(this), output); + 1, HasBitSetters::quality_of_service(this), output); } // .flyteidl.core.WorkflowMetadata.OnFailurePolicy on_failure = 2; @@ -4375,11 +4378,11 @@ ::google::protobuf::uint8* WorkflowMetadata::InternalSerializeWithCachedSizesToA ::google::protobuf::uint32 cached_has_bits = 0; (void) cached_has_bits; - // .google.protobuf.Duration queuing_budget = 1; - if (this->has_queuing_budget()) { + // .flyteidl.core.QualityOfService quality_of_service = 1; + if (this->has_quality_of_service()) { target = ::google::protobuf::internal::WireFormatLite:: InternalWriteMessageToArray( - 1, HasBitSetters::queuing_budget(this), target); + 1, HasBitSetters::quality_of_service(this), target); } // .flyteidl.core.WorkflowMetadata.OnFailurePolicy on_failure = 2; @@ -4409,11 +4412,11 @@ size_t WorkflowMetadata::ByteSizeLong() const { // Prevent compiler warnings about cached_has_bits being unused (void) cached_has_bits; - // .google.protobuf.Duration queuing_budget = 1; - if (this->has_queuing_budget()) { + // .flyteidl.core.QualityOfService quality_of_service = 1; + if (this->has_quality_of_service()) { total_size += 1 + ::google::protobuf::internal::WireFormatLite::MessageSize( - *queuing_budget_); + *quality_of_service_); } // .flyteidl.core.WorkflowMetadata.OnFailurePolicy on_failure = 2; @@ -4449,8 +4452,8 @@ void WorkflowMetadata::MergeFrom(const WorkflowMetadata& from) { ::google::protobuf::uint32 cached_has_bits = 0; (void) cached_has_bits; - if (from.has_queuing_budget()) { - mutable_queuing_budget()->::google::protobuf::Duration::MergeFrom(from.queuing_budget()); + if (from.has_quality_of_service()) { + mutable_quality_of_service()->::flyteidl::core::QualityOfService::MergeFrom(from.quality_of_service()); } if (from.on_failure() != 0) { set_on_failure(from.on_failure()); @@ -4482,7 +4485,7 @@ void WorkflowMetadata::Swap(WorkflowMetadata* other) { void WorkflowMetadata::InternalSwap(WorkflowMetadata* other) { using std::swap; _internal_metadata_.Swap(&other->_internal_metadata_); - swap(queuing_budget_, other->queuing_budget_); + swap(quality_of_service_, other->quality_of_service_); swap(on_failure_, other->on_failure_); } diff --git a/flyteidl/gen/pb-cpp/flyteidl/core/workflow.pb.h b/flyteidl/gen/pb-cpp/flyteidl/core/workflow.pb.h index 00da960a300..fca4776b206 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/core/workflow.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/core/workflow.pb.h @@ -33,6 +33,7 @@ #include #include #include "flyteidl/core/condition.pb.h" +#include "flyteidl/core/execution.pb.h" #include "flyteidl/core/identifier.pb.h" #include "flyteidl/core/interface.pb.h" #include "flyteidl/core/literals.pb.h" @@ -1464,14 +1465,14 @@ class WorkflowMetadata final : // accessors ------------------------------------------------------- - // .google.protobuf.Duration queuing_budget = 1; - bool has_queuing_budget() const; - void clear_queuing_budget(); - static const int kQueuingBudgetFieldNumber = 1; - const ::google::protobuf::Duration& queuing_budget() const; - ::google::protobuf::Duration* release_queuing_budget(); - ::google::protobuf::Duration* mutable_queuing_budget(); - void set_allocated_queuing_budget(::google::protobuf::Duration* queuing_budget); + // .flyteidl.core.QualityOfService quality_of_service = 1; + bool has_quality_of_service() const; + void clear_quality_of_service(); + static const int kQualityOfServiceFieldNumber = 1; + const ::flyteidl::core::QualityOfService& quality_of_service() const; + ::flyteidl::core::QualityOfService* release_quality_of_service(); + ::flyteidl::core::QualityOfService* mutable_quality_of_service(); + void set_allocated_quality_of_service(::flyteidl::core::QualityOfService* quality_of_service); // .flyteidl.core.WorkflowMetadata.OnFailurePolicy on_failure = 2; void clear_on_failure(); @@ -1484,7 +1485,7 @@ class WorkflowMetadata final : class HasBitSetters; ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; - ::google::protobuf::Duration* queuing_budget_; + ::flyteidl::core::QualityOfService* quality_of_service_; int on_failure_; mutable ::google::protobuf::internal::CachedSize _cached_size_; friend struct ::TableStruct_flyteidl_2fcore_2fworkflow_2eproto; @@ -2911,50 +2912,49 @@ inline Node::TargetCase Node::target_case() const { // WorkflowMetadata -// .google.protobuf.Duration queuing_budget = 1; -inline bool WorkflowMetadata::has_queuing_budget() const { - return this != internal_default_instance() && queuing_budget_ != nullptr; +// .flyteidl.core.QualityOfService quality_of_service = 1; +inline bool WorkflowMetadata::has_quality_of_service() const { + return this != internal_default_instance() && quality_of_service_ != nullptr; } -inline const ::google::protobuf::Duration& WorkflowMetadata::queuing_budget() const { - const ::google::protobuf::Duration* p = queuing_budget_; - // @@protoc_insertion_point(field_get:flyteidl.core.WorkflowMetadata.queuing_budget) - return p != nullptr ? *p : *reinterpret_cast( - &::google::protobuf::_Duration_default_instance_); +inline const ::flyteidl::core::QualityOfService& WorkflowMetadata::quality_of_service() const { + const ::flyteidl::core::QualityOfService* p = quality_of_service_; + // @@protoc_insertion_point(field_get:flyteidl.core.WorkflowMetadata.quality_of_service) + return p != nullptr ? *p : *reinterpret_cast( + &::flyteidl::core::_QualityOfService_default_instance_); } -inline ::google::protobuf::Duration* WorkflowMetadata::release_queuing_budget() { - // @@protoc_insertion_point(field_release:flyteidl.core.WorkflowMetadata.queuing_budget) +inline ::flyteidl::core::QualityOfService* WorkflowMetadata::release_quality_of_service() { + // @@protoc_insertion_point(field_release:flyteidl.core.WorkflowMetadata.quality_of_service) - ::google::protobuf::Duration* temp = queuing_budget_; - queuing_budget_ = nullptr; + ::flyteidl::core::QualityOfService* temp = quality_of_service_; + quality_of_service_ = nullptr; return temp; } -inline ::google::protobuf::Duration* WorkflowMetadata::mutable_queuing_budget() { +inline ::flyteidl::core::QualityOfService* WorkflowMetadata::mutable_quality_of_service() { - if (queuing_budget_ == nullptr) { - auto* p = CreateMaybeMessage<::google::protobuf::Duration>(GetArenaNoVirtual()); - queuing_budget_ = p; + if (quality_of_service_ == nullptr) { + auto* p = CreateMaybeMessage<::flyteidl::core::QualityOfService>(GetArenaNoVirtual()); + quality_of_service_ = p; } - // @@protoc_insertion_point(field_mutable:flyteidl.core.WorkflowMetadata.queuing_budget) - return queuing_budget_; + // @@protoc_insertion_point(field_mutable:flyteidl.core.WorkflowMetadata.quality_of_service) + return quality_of_service_; } -inline void WorkflowMetadata::set_allocated_queuing_budget(::google::protobuf::Duration* queuing_budget) { +inline void WorkflowMetadata::set_allocated_quality_of_service(::flyteidl::core::QualityOfService* quality_of_service) { ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); if (message_arena == nullptr) { - delete reinterpret_cast< ::google::protobuf::MessageLite*>(queuing_budget_); + delete reinterpret_cast< ::google::protobuf::MessageLite*>(quality_of_service_); } - if (queuing_budget) { - ::google::protobuf::Arena* submessage_arena = - reinterpret_cast<::google::protobuf::MessageLite*>(queuing_budget)->GetArena(); + if (quality_of_service) { + ::google::protobuf::Arena* submessage_arena = nullptr; if (message_arena != submessage_arena) { - queuing_budget = ::google::protobuf::internal::GetOwnedMessage( - message_arena, queuing_budget, submessage_arena); + quality_of_service = ::google::protobuf::internal::GetOwnedMessage( + message_arena, quality_of_service, submessage_arena); } } else { } - queuing_budget_ = queuing_budget; - // @@protoc_insertion_point(field_set_allocated:flyteidl.core.WorkflowMetadata.queuing_budget) + quality_of_service_ = quality_of_service; + // @@protoc_insertion_point(field_set_allocated:flyteidl.core.WorkflowMetadata.quality_of_service) } // .flyteidl.core.WorkflowMetadata.OnFailurePolicy on_failure = 2; diff --git a/flyteidl/gen/pb-go/flyteidl/admin/execution.pb.go b/flyteidl/gen/pb-go/flyteidl/admin/execution.pb.go index 5a8d4b4c8f2..26438903ebd 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/execution.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/execution.pb.go @@ -911,10 +911,12 @@ type ExecutionSpec struct { // Annotations to apply to the execution resource. Annotations *Annotations `protobuf:"bytes,8,opt,name=annotations,proto3" json:"annotations,omitempty"` // Optional: auth override to apply this execution. - AuthRole *AuthRole `protobuf:"bytes,16,opt,name=auth_role,json=authRole,proto3" json:"auth_role,omitempty"` - XXX_NoUnkeyedLiteral struct{} `json:"-"` - XXX_unrecognized []byte `json:"-"` - XXX_sizecache int32 `json:"-"` + AuthRole *AuthRole `protobuf:"bytes,16,opt,name=auth_role,json=authRole,proto3" json:"auth_role,omitempty"` + // Indicates the runtime priority of the execution. + QualityOfService *core.QualityOfService `protobuf:"bytes,17,opt,name=quality_of_service,json=qualityOfService,proto3" json:"quality_of_service,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } func (m *ExecutionSpec) Reset() { *m = ExecutionSpec{} } @@ -1022,6 +1024,13 @@ func (m *ExecutionSpec) GetAuthRole() *AuthRole { return nil } +func (m *ExecutionSpec) GetQualityOfService() *core.QualityOfService { + if m != nil { + return m.QualityOfService + } + return nil +} + // XXX_OneofWrappers is for the internal use of the proto package. func (*ExecutionSpec) XXX_OneofWrappers() []interface{} { return []interface{}{ @@ -1230,85 +1239,87 @@ func init() { func init() { proto.RegisterFile("flyteidl/admin/execution.proto", fileDescriptor_4e2785d91b3809ec) } var fileDescriptor_4e2785d91b3809ec = []byte{ - // 1268 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x57, 0xef, 0x72, 0xd3, 0x46, - 0x10, 0xb7, 0x1d, 0xdb, 0xd8, 0x6b, 0x6c, 0xcc, 0xd1, 0x06, 0x11, 0x02, 0x04, 0xcd, 0xb4, 0xc3, - 0xb4, 0x53, 0x7b, 0x12, 0x26, 0x1f, 0xca, 0x34, 0x1f, 0x6c, 0x27, 0xe0, 0xb4, 0x4e, 0x60, 0x2e, - 0xa4, 0x14, 0x3a, 0x1d, 0xf7, 0x2c, 0x5d, 0x12, 0xc1, 0x49, 0xa7, 0x9e, 0x4e, 0x50, 0x5e, 0xa0, - 0x2f, 0xd3, 0xef, 0x7d, 0x82, 0xbe, 0x51, 0xfb, 0x00, 0x1d, 0x9d, 0x4e, 0xb2, 0x24, 0x3b, 0x0d, - 0x4c, 0xf8, 0xe6, 0xd3, 0xfe, 0x76, 0xef, 0xf6, 0xdf, 0x6f, 0xd7, 0x70, 0xf7, 0x84, 0xbd, 0x97, - 0xd4, 0xb1, 0x59, 0x9f, 0xd8, 0xae, 0xe3, 0xf5, 0xe9, 0xef, 0xd4, 0x0a, 0xa5, 0xc3, 0xbd, 0x9e, - 0x2f, 0xb8, 0xe4, 0xa8, 0x93, 0xc8, 0x7b, 0x4a, 0xbe, 0x76, 0xbb, 0x80, 0xb7, 0xb8, 0xeb, 0x26, - 0xe0, 0xb5, 0xf5, 0x54, 0x68, 0x71, 0x41, 0xfb, 0xcc, 0x91, 0x54, 0x10, 0x16, 0x68, 0xe9, 0x9d, - 0xbc, 0xb4, 0x70, 0xd3, 0xda, 0xdd, 0xbc, 0xd8, 0xb1, 0xa9, 0x27, 0x9d, 0x13, 0x87, 0x8a, 0x44, - 0x7e, 0xca, 0xf9, 0x29, 0xa3, 0x7d, 0x75, 0x9a, 0x85, 0x27, 0x7d, 0x3b, 0x14, 0x24, 0xa3, 0x7f, - 0xaf, 0x28, 0x97, 0x8e, 0x4b, 0x03, 0x49, 0x5c, 0x3f, 0x06, 0x98, 0x7f, 0x97, 0x61, 0x75, 0x2f, - 0xb9, 0x74, 0x24, 0x28, 0x91, 0x14, 0xd3, 0xdf, 0x42, 0x1a, 0x48, 0x64, 0xc0, 0x15, 0x5f, 0xf0, - 0xd7, 0xd4, 0x92, 0x46, 0x79, 0xa3, 0xfc, 0xa0, 0x89, 0x93, 0x23, 0x5a, 0x85, 0xba, 0xcd, 0x5d, - 0xe2, 0x78, 0x46, 0x45, 0x09, 0xf4, 0x09, 0x21, 0xa8, 0x7a, 0xc4, 0xa5, 0xc6, 0x8a, 0xfa, 0xaa, - 0x7e, 0xa3, 0x4d, 0xa8, 0x06, 0x3e, 0xb5, 0x8c, 0xea, 0x46, 0xf9, 0x41, 0x6b, 0xeb, 0x4e, 0x2f, - 0x1f, 0xba, 0x5e, 0x7a, 0xf7, 0x91, 0x4f, 0x2d, 0xac, 0xa0, 0x68, 0x13, 0xea, 0x8e, 0xe7, 0x87, - 0x32, 0x30, 0x6a, 0x4a, 0xe9, 0xd6, 0x5c, 0x29, 0x8a, 0x42, 0x6f, 0x12, 0x87, 0xf0, 0x80, 0xf8, - 0x58, 0x03, 0xcd, 0xd7, 0x60, 0xa4, 0x96, 0x30, 0x65, 0x24, 0xf4, 0xac, 0xb3, 0xc4, 0x8f, 0x47, - 0x50, 0x71, 0x6c, 0xe5, 0x42, 0x6b, 0xeb, 0xab, 0x82, 0xa9, 0x17, 0x5c, 0xbc, 0x39, 0x61, 0xfc, - 0x5d, 0xaa, 0xbc, 0x9f, 0x46, 0x18, 0x57, 0x1c, 0x7b, 0x99, 0x47, 0xe6, 0x31, 0xdc, 0x5c, 0x88, - 0x58, 0xe0, 0x73, 0x2f, 0xa0, 0x97, 0xb9, 0xca, 0x7c, 0x09, 0xb7, 0x17, 0x20, 0x4f, 0xa8, 0xfc, - 0x04, 0x5e, 0x98, 0x7f, 0x95, 0xa1, 0x99, 0xca, 0x2e, 0x15, 0x8f, 0x24, 0x9b, 0x95, 0x0f, 0xcf, - 0xe6, 0x23, 0xb8, 0x62, 0x31, 0x1e, 0x84, 0x22, 0x8e, 0x62, 0x6b, 0x6b, 0xe3, 0x5c, 0xad, 0x51, - 0x8c, 0xc3, 0x89, 0x82, 0xf9, 0x2b, 0xb4, 0x53, 0xe1, 0xc4, 0x09, 0x24, 0xfa, 0x16, 0x20, 0x6d, - 0x91, 0xc0, 0x28, 0x6f, 0xac, 0xe4, 0xcb, 0xa3, 0x60, 0x0f, 0x67, 0xc0, 0xe8, 0x33, 0xa8, 0x49, - 0xfe, 0x86, 0x26, 0x35, 0x1b, 0x1f, 0x4c, 0x02, 0x9d, 0x79, 0x39, 0x0d, 0x19, 0x9f, 0xa1, 0x87, - 0x50, 0x7f, 0x4b, 0x58, 0x48, 0x03, 0x1d, 0xa2, 0xf3, 0xab, 0x6f, 0x5c, 0xc2, 0x1a, 0x8a, 0x10, - 0xac, 0x84, 0xc2, 0x89, 0x4d, 0x8f, 0x4b, 0x38, 0x3a, 0x0c, 0xeb, 0x50, 0xb5, 0x89, 0x24, 0xe6, - 0x08, 0xda, 0x83, 0x19, 0x17, 0xf2, 0x80, 0x4a, 0x12, 0x7d, 0x88, 0x5e, 0x62, 0x91, 0x30, 0xa0, - 0xba, 0xad, 0xe2, 0x03, 0x5a, 0x87, 0xa6, 0x2f, 0x1c, 0xcf, 0x72, 0x7c, 0xc2, 0xf4, 0x1b, 0xe7, - 0x1f, 0xcc, 0x7f, 0x6a, 0xd0, 0x2d, 0xc6, 0x29, 0x0a, 0x2d, 0x0f, 0xa5, 0xea, 0x94, 0xf8, 0xad, - 0x77, 0x8b, 0xa1, 0xc8, 0xfb, 0x36, 0x2e, 0xe1, 0x44, 0x01, 0x6d, 0x43, 0x8d, 0x0a, 0xc1, 0xc5, - 0x62, 0x2a, 0x95, 0x97, 0xe9, 0x5d, 0x7b, 0x11, 0x68, 0x5c, 0xc2, 0x31, 0x1a, 0x7d, 0x01, 0x2d, - 0x12, 0x39, 0x33, 0x8d, 0x3d, 0x80, 0xe8, 0x9d, 0xc3, 0x8a, 0x51, 0x1e, 0x97, 0x30, 0x28, 0xc1, - 0x48, 0x39, 0xf3, 0x18, 0x3a, 0x31, 0xcc, 0xd5, 0x4e, 0x1b, 0x57, 0x97, 0x57, 0x4c, 0x2e, 0x32, - 0xe3, 0x12, 0x6e, 0x93, 0x5c, 0xa8, 0x1e, 0xc3, 0x35, 0x8b, 0xbb, 0x7e, 0x28, 0xa9, 0x3d, 0xd5, - 0x9c, 0xb0, 0x72, 0x41, 0x56, 0xa2, 0xd7, 0xe0, 0x4e, 0xa2, 0xb5, 0xaf, 0x94, 0xd0, 0x77, 0x50, - 0xf3, 0xcf, 0x48, 0x40, 0x15, 0x0d, 0x75, 0xb6, 0xbe, 0xbc, 0xa8, 0xec, 0x7b, 0xcf, 0x22, 0x34, - 0x8e, 0x95, 0xa2, 0xaa, 0x0b, 0x24, 0x11, 0xd1, 0x23, 0x88, 0xd4, 0xa4, 0xb4, 0xd6, 0x8b, 0xa9, - 0xb5, 0x97, 0x50, 0x6b, 0xef, 0x79, 0x42, 0xad, 0xb8, 0xa9, 0xd1, 0x03, 0x89, 0xb6, 0xa1, 0x91, - 0x50, 0xb2, 0x51, 0xd7, 0x2f, 0x2f, 0x2a, 0xee, 0x6a, 0x00, 0x4e, 0xa1, 0xd1, 0x8d, 0x96, 0xa2, - 0x16, 0x75, 0xe3, 0x95, 0x8b, 0x6f, 0xd4, 0xe8, 0x81, 0x6a, 0x91, 0xd0, 0xb7, 0x13, 0xd5, 0xc6, - 0xc5, 0xaa, 0x1a, 0x3d, 0x90, 0x68, 0x08, 0x6d, 0x8f, 0x47, 0xdd, 0x6e, 0x91, 0xb8, 0xc1, 0x9a, - 0xaa, 0xc1, 0xd6, 0x8b, 0x49, 0x3b, 0xcc, 0x80, 0x70, 0x5e, 0x05, 0x3d, 0x82, 0xd6, 0x3b, 0x1d, - 0xcd, 0xa9, 0x63, 0x1b, 0xad, 0xa5, 0xd9, 0xca, 0xb0, 0x0a, 0x24, 0xe8, 0x7d, 0x7b, 0x78, 0x0d, - 0xda, 0x71, 0x79, 0x4e, 0x05, 0x0d, 0x42, 0x26, 0xcd, 0x1d, 0xe8, 0x1c, 0xbd, 0x0f, 0x24, 0x75, - 0xd3, 0x82, 0xf8, 0x1a, 0xae, 0xa7, 0x3d, 0x3d, 0xb5, 0x58, 0x18, 0x48, 0x2a, 0x74, 0x1f, 0x75, - 0xe9, 0xbc, 0x3f, 0xd4, 0x77, 0xf3, 0xcf, 0x2a, 0x5c, 0x4f, 0x53, 0x9a, 0x9a, 0x18, 0x41, 0xd5, - 0xe5, 0x76, 0xdc, 0x7d, 0x9d, 0xad, 0xfe, 0xb9, 0xec, 0x91, 0x28, 0x64, 0xbe, 0x70, 0x9b, 0x62, - 0xa5, 0xfc, 0xff, 0xdd, 0x1a, 0x8d, 0x4e, 0x8f, 0x06, 0xd2, 0xf1, 0x4e, 0x55, 0xb9, 0xb6, 0x71, - 0x72, 0x44, 0x3b, 0x70, 0x35, 0xb0, 0xce, 0xa8, 0x1d, 0xb2, 0x38, 0x3f, 0xd5, 0x0b, 0xf3, 0xd3, - 0x4a, 0xf1, 0x03, 0x89, 0x5e, 0xc1, 0xe7, 0x3e, 0x11, 0xd4, 0x93, 0x53, 0x8f, 0xdb, 0x74, 0x9a, - 0x7a, 0xac, 0x8b, 0xb2, 0x58, 0xd7, 0x87, 0xdc, 0xa6, 0xcb, 0xa8, 0xfc, 0x46, 0x6c, 0x24, 0x27, - 0x46, 0x3f, 0xc3, 0x0d, 0x41, 0x4f, 0xa8, 0xa0, 0x9e, 0x95, 0xb5, 0xdc, 0xfd, 0xe8, 0x41, 0x81, - 0x52, 0x33, 0x73, 0xe3, 0x4f, 0xe0, 0x5a, 0xa0, 0x32, 0x39, 0x67, 0x84, 0xeb, 0xcb, 0x29, 0x2b, - 0x9f, 0x70, 0xdc, 0x09, 0x72, 0x67, 0xf3, 0xa7, 0xcc, 0x48, 0x88, 0xf2, 0x81, 0x00, 0xea, 0x07, - 0x83, 0xc3, 0xe3, 0xc1, 0xa4, 0x5b, 0x42, 0x6d, 0x68, 0x1e, 0x8d, 0xc6, 0x7b, 0xbb, 0xc7, 0x93, - 0xbd, 0xdd, 0x6e, 0x39, 0x12, 0x1d, 0xbd, 0x3c, 0x7a, 0xbe, 0x77, 0xd0, 0xad, 0xa0, 0xab, 0xd0, - 0xc0, 0x7b, 0x93, 0xc1, 0xf1, 0xe1, 0x68, 0xdc, 0x5d, 0x41, 0x08, 0x3a, 0xa3, 0xf1, 0xfe, 0x64, - 0x77, 0xfa, 0xe2, 0x29, 0xfe, 0xe1, 0xf1, 0xe4, 0xe9, 0x8b, 0x6e, 0xd5, 0xfc, 0x11, 0xba, 0xd9, - 0xc2, 0x56, 0xf3, 0x66, 0xa1, 0x23, 0xca, 0x1f, 0xdd, 0x11, 0xe6, 0xbf, 0x2b, 0x99, 0x27, 0x1f, - 0xc5, 0x23, 0xb1, 0x15, 0xaf, 0x28, 0x53, 0x9f, 0x11, 0xef, 0x9c, 0x39, 0x93, 0xed, 0x91, 0x18, - 0xfd, 0x8c, 0x11, 0x0f, 0x6d, 0xa7, 0xcb, 0x51, 0xe5, 0x43, 0x88, 0x50, 0x83, 0xd1, 0x0e, 0x34, - 0xd2, 0xc0, 0xc7, 0x0c, 0x7a, 0xff, 0xc2, 0xc2, 0xc7, 0xa9, 0x0a, 0x1a, 0x17, 0xe3, 0x50, 0x5b, - 0x3e, 0xca, 0x8b, 0x01, 0x8c, 0x18, 0x3d, 0xcf, 0x0f, 0xf7, 0xa1, 0x65, 0x3b, 0x01, 0x99, 0x31, - 0x3a, 0x25, 0x8c, 0x29, 0x4e, 0x6c, 0x44, 0xc3, 0x43, 0x7f, 0x1c, 0x30, 0x86, 0x7a, 0x50, 0x67, - 0x64, 0x46, 0x59, 0xa0, 0x89, 0x6f, 0x75, 0x61, 0xaa, 0x29, 0x29, 0xd6, 0x28, 0xb4, 0x03, 0x2d, - 0xe2, 0x79, 0x5c, 0xea, 0xa7, 0xc5, 0x94, 0x77, 0x7b, 0x61, 0xd2, 0xcc, 0x21, 0x38, 0x8b, 0x47, - 0xdb, 0xd0, 0x24, 0xa1, 0x3c, 0x9b, 0x0a, 0xce, 0xa8, 0xae, 0x76, 0x63, 0x41, 0x39, 0x94, 0x67, - 0x98, 0x33, 0x8a, 0x1b, 0x44, 0xff, 0x1a, 0x1a, 0xb0, 0x9a, 0xf5, 0x6c, 0xca, 0xdf, 0x52, 0x21, - 0x1c, 0x9b, 0x06, 0xdf, 0x57, 0x1b, 0xd5, 0x6e, 0xcd, 0x74, 0xe1, 0x56, 0x1a, 0xd1, 0xe7, 0x54, - 0xb8, 0x8e, 0x97, 0xd9, 0xad, 0x2f, 0xb3, 0x83, 0xa5, 0xeb, 0x43, 0x25, 0xb3, 0x3e, 0x98, 0xeb, - 0xb0, 0xb6, 0xec, 0xba, 0x78, 0x31, 0x35, 0x7f, 0x81, 0x7b, 0xcb, 0x96, 0xcb, 0xdd, 0x28, 0xcb, - 0x9f, 0x60, 0xc1, 0xfc, 0xa3, 0x0c, 0x1b, 0xe7, 0xdb, 0xd7, 0xcb, 0xf1, 0x66, 0x71, 0x5b, 0xb9, - 0x59, 0x8c, 0xf2, 0xb1, 0x60, 0xd1, 0x9a, 0x32, 0x5f, 0x52, 0xfa, 0x85, 0x62, 0x3f, 0x57, 0x43, - 0xc3, 0x86, 0x0f, 0x5f, 0x6d, 0x9e, 0x3a, 0xf2, 0x2c, 0x9c, 0xf5, 0x2c, 0xee, 0xf6, 0xd9, 0xfb, - 0x13, 0xd9, 0x4f, 0xff, 0x41, 0x9d, 0x52, 0xaf, 0xef, 0xcf, 0xbe, 0x39, 0xe5, 0xfd, 0xfc, 0xdf, - 0xb5, 0x59, 0x5d, 0xb1, 0xee, 0xc3, 0xff, 0x02, 0x00, 0x00, 0xff, 0xff, 0xe6, 0x8d, 0xbd, 0xc1, - 0xf7, 0x0d, 0x00, 0x00, + // 1304 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x57, 0xdf, 0x72, 0xd3, 0x46, + 0x17, 0xb7, 0x1d, 0xdb, 0xd8, 0xc7, 0xd8, 0x98, 0xe5, 0xfb, 0x82, 0x08, 0x01, 0x82, 0x66, 0xbe, + 0x6f, 0x98, 0x76, 0x6a, 0x4f, 0xc2, 0xe4, 0xa2, 0x4c, 0x73, 0x61, 0x3b, 0x01, 0xa7, 0x75, 0x02, + 0x5d, 0x93, 0x52, 0xe8, 0x74, 0xd4, 0xb5, 0xb4, 0x4e, 0x04, 0x2b, 0xad, 0x58, 0xad, 0xa0, 0x79, + 0x81, 0xbe, 0x4c, 0xef, 0xfb, 0x02, 0xed, 0x1b, 0xf5, 0x05, 0x3a, 0x92, 0x56, 0xb2, 0x24, 0x3b, + 0x0d, 0x0c, 0xdc, 0x69, 0xf7, 0xfc, 0xce, 0xee, 0x9e, 0x7f, 0xbf, 0x73, 0x04, 0x77, 0xe7, 0xec, + 0x5c, 0x52, 0xdb, 0x62, 0x7d, 0x62, 0x39, 0xb6, 0xdb, 0xa7, 0xbf, 0x52, 0x33, 0x90, 0x36, 0x77, + 0x7b, 0x9e, 0xe0, 0x92, 0xa3, 0x4e, 0x22, 0xef, 0x45, 0xf2, 0x8d, 0xdb, 0x05, 0xbc, 0xc9, 0x1d, + 0x27, 0x01, 0x6f, 0x6c, 0xa6, 0x42, 0x93, 0x0b, 0xda, 0x67, 0xb6, 0xa4, 0x82, 0x30, 0x5f, 0x49, + 0xef, 0xe4, 0xa5, 0x85, 0x9b, 0x36, 0xee, 0xe6, 0xc5, 0xb6, 0x45, 0x5d, 0x69, 0xcf, 0x6d, 0x2a, + 0x12, 0xf9, 0x29, 0xe7, 0xa7, 0x8c, 0xf6, 0xa3, 0xd5, 0x2c, 0x98, 0xf7, 0xad, 0x40, 0x90, 0x8c, + 0xfe, 0xbd, 0xa2, 0x5c, 0xda, 0x0e, 0xf5, 0x25, 0x71, 0xbc, 0x18, 0xa0, 0xff, 0x55, 0x86, 0xf5, + 0x83, 0xe4, 0xd2, 0x91, 0xa0, 0x44, 0x52, 0x4c, 0xdf, 0x06, 0xd4, 0x97, 0x48, 0x83, 0x2b, 0x9e, + 0xe0, 0xaf, 0xa9, 0x29, 0xb5, 0xf2, 0x56, 0xf9, 0x41, 0x13, 0x27, 0x4b, 0xb4, 0x0e, 0x75, 0x8b, + 0x3b, 0xc4, 0x76, 0xb5, 0x4a, 0x24, 0x50, 0x2b, 0x84, 0xa0, 0xea, 0x12, 0x87, 0x6a, 0x6b, 0xd1, + 0x6e, 0xf4, 0x8d, 0xb6, 0xa1, 0xea, 0x7b, 0xd4, 0xd4, 0xaa, 0x5b, 0xe5, 0x07, 0xad, 0x9d, 0x3b, + 0xbd, 0xbc, 0xeb, 0x7a, 0xe9, 0xdd, 0x53, 0x8f, 0x9a, 0x38, 0x82, 0xa2, 0x6d, 0xa8, 0xdb, 0xae, + 0x17, 0x48, 0x5f, 0xab, 0x45, 0x4a, 0xb7, 0x16, 0x4a, 0xa1, 0x17, 0x7a, 0x93, 0xd8, 0x85, 0x47, + 0xc4, 0xc3, 0x0a, 0xa8, 0xbf, 0x06, 0x2d, 0x3d, 0x09, 0x53, 0x46, 0x02, 0xd7, 0x3c, 0x4b, 0xec, + 0x78, 0x04, 0x15, 0xdb, 0x8a, 0x4c, 0x68, 0xed, 0x7c, 0x51, 0x38, 0xea, 0x05, 0x17, 0x6f, 0xe6, + 0x8c, 0xbf, 0x4f, 0x95, 0x0f, 0x53, 0x0f, 0xe3, 0x8a, 0x6d, 0xad, 0xb2, 0x48, 0x3f, 0x81, 0x9b, + 0x4b, 0x1e, 0xf3, 0x3d, 0xee, 0xfa, 0xf4, 0x53, 0xae, 0xd2, 0x5f, 0xc2, 0xed, 0x25, 0xc8, 0x13, + 0x2a, 0x3f, 0x83, 0x15, 0xfa, 0x1f, 0x65, 0x68, 0xa6, 0xb2, 0x4f, 0xf2, 0x47, 0x12, 0xcd, 0xca, + 0x87, 0x47, 0xf3, 0x11, 0x5c, 0x31, 0x19, 0xf7, 0x03, 0x11, 0x7b, 0xb1, 0xb5, 0xb3, 0x75, 0xa1, + 0xd6, 0x28, 0xc6, 0xe1, 0x44, 0x41, 0xff, 0x05, 0xda, 0xa9, 0x70, 0x62, 0xfb, 0x12, 0x7d, 0x0d, + 0x90, 0x96, 0x88, 0xaf, 0x95, 0xb7, 0xd6, 0xf2, 0xe9, 0x51, 0x38, 0x0f, 0x67, 0xc0, 0xe8, 0x3f, + 0x50, 0x93, 0xfc, 0x0d, 0x4d, 0x72, 0x36, 0x5e, 0xe8, 0x04, 0x3a, 0x8b, 0x74, 0x1a, 0x32, 0x3e, + 0x43, 0x0f, 0xa1, 0xfe, 0x8e, 0xb0, 0x80, 0xfa, 0xca, 0x45, 0x17, 0x67, 0xdf, 0xb8, 0x84, 0x15, + 0x14, 0x21, 0x58, 0x0b, 0x84, 0x1d, 0x1f, 0x3d, 0x2e, 0xe1, 0x70, 0x31, 0xac, 0x43, 0xd5, 0x22, + 0x92, 0xe8, 0x23, 0x68, 0x0f, 0x66, 0x5c, 0xc8, 0x23, 0x2a, 0x49, 0xb8, 0x11, 0xbe, 0xc4, 0x24, + 0x81, 0x4f, 0x55, 0x59, 0xc5, 0x0b, 0xb4, 0x09, 0x4d, 0x4f, 0xd8, 0xae, 0x69, 0x7b, 0x84, 0xa9, + 0x37, 0x2e, 0x36, 0xf4, 0xbf, 0x6b, 0xd0, 0x2d, 0xfa, 0x29, 0x74, 0x2d, 0x0f, 0x64, 0x54, 0x29, + 0xf1, 0x5b, 0xef, 0x16, 0x5d, 0x91, 0xb7, 0x6d, 0x5c, 0xc2, 0x89, 0x02, 0xda, 0x85, 0x1a, 0x15, + 0x82, 0x8b, 0xe5, 0x50, 0x46, 0x56, 0xa6, 0x77, 0x1d, 0x84, 0xa0, 0x71, 0x09, 0xc7, 0x68, 0xf4, + 0x3f, 0x68, 0x91, 0xd0, 0x18, 0x23, 0xb6, 0x00, 0xc2, 0x77, 0x0e, 0x2b, 0x5a, 0x79, 0x5c, 0xc2, + 0x10, 0x09, 0x46, 0x91, 0x31, 0x8f, 0xa1, 0x13, 0xc3, 0x1c, 0x65, 0xb4, 0x76, 0x75, 0x75, 0xc6, + 0xe4, 0x3c, 0x33, 0x2e, 0xe1, 0x36, 0xc9, 0xb9, 0xea, 0x31, 0x5c, 0x33, 0xb9, 0xe3, 0x05, 0x92, + 0x5a, 0x86, 0xe2, 0x84, 0xb5, 0x4b, 0xa2, 0x12, 0xbe, 0x06, 0x77, 0x12, 0xad, 0xc3, 0x48, 0x09, + 0x7d, 0x03, 0x35, 0xef, 0x8c, 0xf8, 0x34, 0xa2, 0xa1, 0xce, 0xce, 0xff, 0x2f, 0x4b, 0xfb, 0xde, + 0xb3, 0x10, 0x8d, 0x63, 0xa5, 0x30, 0xeb, 0x7c, 0x49, 0x44, 0xf8, 0x08, 0x22, 0x15, 0x29, 0x6d, + 0xf4, 0x62, 0x6a, 0xed, 0x25, 0xd4, 0xda, 0x7b, 0x9e, 0x50, 0x2b, 0x6e, 0x2a, 0xf4, 0x40, 0xa2, + 0x5d, 0x68, 0x24, 0x94, 0xac, 0xd5, 0xd5, 0xcb, 0x8b, 0x8a, 0xfb, 0x0a, 0x80, 0x53, 0x68, 0x78, + 0xa3, 0x19, 0x51, 0x4b, 0x74, 0xe3, 0x95, 0xcb, 0x6f, 0x54, 0xe8, 0x41, 0x54, 0x22, 0x81, 0x67, + 0x25, 0xaa, 0x8d, 0xcb, 0x55, 0x15, 0x7a, 0x20, 0xd1, 0x10, 0xda, 0x2e, 0x0f, 0xab, 0xdd, 0x24, + 0x71, 0x81, 0x35, 0xa3, 0x02, 0xdb, 0x2c, 0x06, 0xed, 0x38, 0x03, 0xc2, 0x79, 0x15, 0xf4, 0x08, + 0x5a, 0xef, 0x95, 0x37, 0x0d, 0xdb, 0xd2, 0x5a, 0x2b, 0xa3, 0x95, 0x61, 0x15, 0x48, 0xd0, 0x87, + 0xd6, 0xf0, 0x1a, 0xb4, 0xe3, 0xf4, 0x34, 0x04, 0xf5, 0x03, 0x26, 0xf5, 0x3d, 0xe8, 0x4c, 0xcf, + 0x7d, 0x49, 0x9d, 0x34, 0x21, 0xbe, 0x84, 0xeb, 0x69, 0x4d, 0x1b, 0x26, 0x0b, 0x7c, 0x49, 0x85, + 0xaa, 0xa3, 0x2e, 0x5d, 0xd4, 0x47, 0xb4, 0xaf, 0xff, 0x5e, 0x85, 0xeb, 0x69, 0x48, 0xd3, 0x23, + 0x46, 0x50, 0x75, 0xb8, 0x15, 0x57, 0x5f, 0x67, 0xa7, 0x7f, 0x21, 0x7b, 0x24, 0x0a, 0x99, 0x1d, + 0x6e, 0x51, 0x1c, 0x29, 0xff, 0x7b, 0xb5, 0x86, 0xad, 0xd3, 0xa5, 0xbe, 0xb4, 0xdd, 0xd3, 0x28, + 0x5d, 0xdb, 0x38, 0x59, 0xa2, 0x3d, 0xb8, 0xea, 0x9b, 0x67, 0xd4, 0x0a, 0x58, 0x1c, 0x9f, 0xea, + 0xa5, 0xf1, 0x69, 0xa5, 0xf8, 0x81, 0x44, 0xaf, 0xe0, 0xbf, 0x1e, 0x11, 0xd4, 0x95, 0x86, 0xcb, + 0x2d, 0x6a, 0xa4, 0x16, 0xab, 0xa4, 0x2c, 0xe6, 0xf5, 0x31, 0xb7, 0xe8, 0x2a, 0x2a, 0xbf, 0x11, + 0x1f, 0x92, 0x13, 0xa3, 0x9f, 0xe0, 0x86, 0xa0, 0x73, 0x2a, 0xa8, 0x6b, 0x66, 0x4f, 0xee, 0x7e, + 0x74, 0xa3, 0x40, 0xe9, 0x31, 0x8b, 0xc3, 0x9f, 0xc0, 0x35, 0x3f, 0x8a, 0xe4, 0x82, 0x11, 0xae, + 0xaf, 0xa6, 0xac, 0x7c, 0xc0, 0x71, 0xc7, 0xcf, 0xad, 0xf5, 0x1f, 0x33, 0x2d, 0x21, 0x8c, 0x07, + 0x02, 0xa8, 0x1f, 0x0d, 0x8e, 0x4f, 0x06, 0x93, 0x6e, 0x09, 0xb5, 0xa1, 0x39, 0x1d, 0x8d, 0x0f, + 0xf6, 0x4f, 0x26, 0x07, 0xfb, 0xdd, 0x72, 0x28, 0x9a, 0xbe, 0x9c, 0x3e, 0x3f, 0x38, 0xea, 0x56, + 0xd0, 0x55, 0x68, 0xe0, 0x83, 0xc9, 0xe0, 0xe4, 0x78, 0x34, 0xee, 0xae, 0x21, 0x04, 0x9d, 0xd1, + 0xf8, 0x70, 0xb2, 0x6f, 0xbc, 0x78, 0x8a, 0xbf, 0x7b, 0x3c, 0x79, 0xfa, 0xa2, 0x5b, 0xd5, 0x7f, + 0x80, 0x6e, 0x36, 0xb1, 0xa3, 0x7e, 0xb3, 0x54, 0x11, 0xe5, 0x8f, 0xae, 0x08, 0xfd, 0xcf, 0x6a, + 0xe6, 0xc9, 0xd3, 0xb8, 0x25, 0xb6, 0xe2, 0x11, 0xc5, 0xf0, 0x18, 0x71, 0x2f, 0xe8, 0x33, 0xd9, + 0x1a, 0x89, 0xd1, 0xcf, 0x18, 0x71, 0xd1, 0x6e, 0x3a, 0x1c, 0x55, 0x3e, 0x84, 0x08, 0x15, 0x18, + 0xed, 0x41, 0x23, 0x75, 0x7c, 0xcc, 0xa0, 0xf7, 0x2f, 0x4d, 0x7c, 0x9c, 0xaa, 0xa0, 0x71, 0xd1, + 0x0f, 0xb5, 0xd5, 0xad, 0xbc, 0xe8, 0xc0, 0x90, 0xd1, 0xf3, 0xfc, 0x70, 0x1f, 0x5a, 0x96, 0xed, + 0x93, 0x19, 0xa3, 0x06, 0x61, 0x2c, 0xe2, 0xc4, 0x46, 0xd8, 0x3c, 0xd4, 0xe6, 0x80, 0x31, 0xd4, + 0x83, 0x3a, 0x23, 0x33, 0xca, 0x7c, 0x45, 0x7c, 0xeb, 0x4b, 0x5d, 0x2d, 0x92, 0x62, 0x85, 0x42, + 0x7b, 0xd0, 0x22, 0xae, 0xcb, 0xa5, 0x7a, 0x5a, 0x4c, 0x79, 0xb7, 0x97, 0x3a, 0xcd, 0x02, 0x82, + 0xb3, 0x78, 0xb4, 0x0b, 0x4d, 0x12, 0xc8, 0x33, 0x43, 0x70, 0x46, 0x55, 0xb6, 0x6b, 0x4b, 0xca, + 0x81, 0x3c, 0xc3, 0x9c, 0x51, 0xdc, 0x20, 0xea, 0x0b, 0x1d, 0x01, 0x7a, 0x1b, 0x10, 0x66, 0xcb, + 0x73, 0x83, 0xcf, 0x0d, 0x9f, 0x8a, 0x77, 0xb6, 0x49, 0x55, 0x52, 0xdf, 0x2b, 0x04, 0xe5, 0xfb, + 0x18, 0xf8, 0x74, 0x3e, 0x8d, 0x61, 0xb8, 0xfb, 0xb6, 0xb0, 0x33, 0xd4, 0x60, 0x3d, 0xeb, 0x28, + 0x83, 0xbf, 0xa3, 0x42, 0xd8, 0x16, 0xf5, 0xbf, 0xad, 0x36, 0xaa, 0xdd, 0x9a, 0xee, 0xc0, 0xad, + 0x34, 0x40, 0xcf, 0xa9, 0x70, 0x6c, 0x37, 0x33, 0xaa, 0x7f, 0xca, 0x48, 0x97, 0x4e, 0x23, 0x95, + 0xcc, 0x34, 0xa2, 0x6f, 0xc2, 0xc6, 0xaa, 0xeb, 0xe2, 0x39, 0x57, 0xff, 0x19, 0xee, 0xad, 0x9a, + 0x55, 0xf7, 0xc3, 0xa4, 0xf9, 0x0c, 0xf3, 0xea, 0x6f, 0x65, 0xd8, 0xba, 0xf8, 0x7c, 0x35, 0x6b, + 0x6f, 0x17, 0x87, 0x9f, 0x9b, 0xc5, 0xa0, 0x9d, 0x08, 0x16, 0x4e, 0x3d, 0x8b, 0x99, 0xa7, 0x5f, + 0xa8, 0x9d, 0x0b, 0x35, 0x14, 0x6c, 0xf8, 0xf0, 0xd5, 0xf6, 0xa9, 0x2d, 0xcf, 0x82, 0x59, 0xcf, + 0xe4, 0x4e, 0x9f, 0x9d, 0xcf, 0x65, 0x3f, 0xfd, 0x21, 0x3b, 0xa5, 0x6e, 0xdf, 0x9b, 0x7d, 0x75, + 0xca, 0xfb, 0xf9, 0xbf, 0xbf, 0x59, 0x3d, 0x22, 0xf1, 0x87, 0xff, 0x04, 0x00, 0x00, 0xff, 0xff, + 0x58, 0xff, 0x03, 0x47, 0x46, 0x0e, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/admin/execution.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/admin/execution.pb.validate.go index 468354bde98..e7f6b7b23ec 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/execution.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/execution.pb.validate.go @@ -1209,6 +1209,16 @@ func (m *ExecutionSpec) Validate() error { } } + if v, ok := interface{}(m.GetQualityOfService()).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return ExecutionSpecValidationError{ + field: "QualityOfService", + reason: "embedded message failed validation", + cause: err, + } + } + } + switch m.NotificationOverrides.(type) { case *ExecutionSpec_Notifications: diff --git a/flyteidl/gen/pb-go/flyteidl/admin/launch_plan.pb.go b/flyteidl/gen/pb-go/flyteidl/admin/launch_plan.pb.go index 0c8c9fb1b87..291e913544d 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/launch_plan.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/launch_plan.pb.go @@ -342,11 +342,13 @@ type LaunchPlanSpec struct { // Custom annotations to be applied to the execution resource. Annotations *Annotations `protobuf:"bytes,7,opt,name=annotations,proto3" json:"annotations,omitempty"` // Indicates the permission associated with workflow executions triggered with this launch plan. - Auth *Auth `protobuf:"bytes,8,opt,name=auth,proto3" json:"auth,omitempty"` // Deprecated: Do not use. - AuthRole *AuthRole `protobuf:"bytes,9,opt,name=auth_role,json=authRole,proto3" json:"auth_role,omitempty"` - XXX_NoUnkeyedLiteral struct{} `json:"-"` - XXX_unrecognized []byte `json:"-"` - XXX_sizecache int32 `json:"-"` + Auth *Auth `protobuf:"bytes,8,opt,name=auth,proto3" json:"auth,omitempty"` // Deprecated: Do not use. + AuthRole *AuthRole `protobuf:"bytes,9,opt,name=auth_role,json=authRole,proto3" json:"auth_role,omitempty"` + // Indicates the runtime priority of the execution. + QualityOfService *core.QualityOfService `protobuf:"bytes,16,opt,name=quality_of_service,json=qualityOfService,proto3" json:"quality_of_service,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } func (m *LaunchPlanSpec) Reset() { *m = LaunchPlanSpec{} } @@ -439,6 +441,13 @@ func (m *LaunchPlanSpec) GetAuthRole() *AuthRole { return nil } +func (m *LaunchPlanSpec) GetQualityOfService() *core.QualityOfService { + if m != nil { + return m.QualityOfService + } + return nil +} + // Values computed by the flyte platform after launch plan registration. // These include expected_inputs required to be present in a CreateExecutionRequest // to launch the reference workflow as well timestamp values associated with the launch plan. @@ -790,64 +799,67 @@ func init() { func init() { proto.RegisterFile("flyteidl/admin/launch_plan.proto", fileDescriptor_368a863574f5e699) } var fileDescriptor_368a863574f5e699 = []byte{ - // 943 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x56, 0xcd, 0x6e, 0xdb, 0x46, - 0x10, 0x8e, 0x14, 0x59, 0x96, 0x46, 0xb6, 0xec, 0x2e, 0x02, 0x87, 0x95, 0xd3, 0xc4, 0x25, 0x50, - 0x20, 0xfd, 0x09, 0x85, 0x3a, 0xf5, 0xa1, 0x3f, 0x29, 0x20, 0xb9, 0x06, 0x22, 0xd4, 0x49, 0x8d, - 0x75, 0x9a, 0x43, 0x2f, 0xc4, 0x8a, 0x1c, 0x49, 0x5b, 0x2f, 0xb9, 0x2c, 0x77, 0x99, 0x58, 0xe8, - 0xa5, 0xb7, 0xde, 0xfa, 0x1c, 0x45, 0xdf, 0xa5, 0xef, 0x54, 0x70, 0xb9, 0xa4, 0xfe, 0xe2, 0xa6, - 0x2d, 0xd0, 0x93, 0x39, 0x9e, 0xef, 0x9b, 0x9d, 0x99, 0x9d, 0xf9, 0x56, 0x70, 0x34, 0x11, 0x73, - 0x8d, 0x3c, 0x14, 0x7d, 0x16, 0x46, 0x3c, 0xee, 0x0b, 0x96, 0xc5, 0xc1, 0xcc, 0x4f, 0x04, 0x8b, - 0xbd, 0x24, 0x95, 0x5a, 0x92, 0x6e, 0x89, 0xf0, 0x0c, 0xa2, 0x77, 0xaf, 0x62, 0x04, 0x32, 0xc5, - 0xbe, 0xe0, 0x1a, 0x53, 0x26, 0x54, 0x81, 0xee, 0xdd, 0x5f, 0xf5, 0xf2, 0x10, 0x63, 0xcd, 0x27, - 0x1c, 0x53, 0xeb, 0x7f, 0x6f, 0xcd, 0x1f, 0x6b, 0x4c, 0x27, 0x2c, 0xc0, 0x0d, 0x77, 0x91, 0x8e, - 0x0a, 0x66, 0x18, 0x66, 0xa2, 0x74, 0x1f, 0xae, 0xb9, 0x03, 0x19, 0x45, 0xd2, 0x26, 0xda, 0x7b, - 0x30, 0x95, 0x72, 0x2a, 0xb0, 0x6f, 0xac, 0x71, 0x36, 0xe9, 0x6b, 0x1e, 0xa1, 0xd2, 0x2c, 0x4a, - 0x0a, 0x80, 0x7b, 0x0d, 0x77, 0xcf, 0x4d, 0x79, 0x17, 0x82, 0xc5, 0xa7, 0x29, 0x32, 0x8d, 0x14, - 0x7f, 0xca, 0x50, 0x69, 0xf2, 0x21, 0xd4, 0x79, 0xe8, 0xd4, 0x8e, 0x6a, 0x0f, 0x3b, 0xc7, 0xef, - 0x7a, 0x55, 0xc5, 0x79, 0x8e, 0xde, 0xa8, 0xaa, 0x81, 0xd6, 0x79, 0x48, 0x8e, 0xa1, 0xa1, 0x12, - 0x0c, 0x9c, 0xba, 0x01, 0xdf, 0xf7, 0x56, 0xdb, 0xe3, 0x2d, 0x4e, 0xb8, 0x4c, 0x30, 0xa0, 0x06, - 0xeb, 0xf6, 0xc0, 0xd9, 0x3c, 0x59, 0x25, 0x32, 0x56, 0xe8, 0xfe, 0x5e, 0x03, 0x58, 0x38, 0xff, - 0xe7, 0x4c, 0xc8, 0x97, 0xb0, 0x1d, 0x08, 0xa9, 0xb2, 0x14, 0x9d, 0xdb, 0x86, 0xf6, 0xfe, 0xcd, - 0xb4, 0xd3, 0x02, 0x48, 0x4b, 0x86, 0x8b, 0xd0, 0x5d, 0x78, 0xcf, 0xb9, 0xd2, 0xe4, 0x09, 0xec, - 0x2c, 0x4d, 0x8c, 0x72, 0x6a, 0x47, 0xb7, 0x1f, 0x76, 0x8e, 0x7b, 0x37, 0xc7, 0xa4, 0x1d, 0x51, - 0x7d, 0x2b, 0x72, 0x07, 0xb6, 0xb4, 0xbc, 0xc2, 0xd8, 0x94, 0xd0, 0xa6, 0x85, 0xe1, 0xfe, 0x52, - 0x83, 0xc6, 0x20, 0xd3, 0x33, 0xe2, 0x01, 0x61, 0x4a, 0x65, 0x11, 0x1b, 0x0b, 0xf4, 0x39, 0x8b, - 0xfc, 0x54, 0x0a, 0x34, 0xbd, 0x69, 0x3f, 0xbd, 0x45, 0xf7, 0x2b, 0xdf, 0x88, 0x45, 0x54, 0x0a, - 0x24, 0x5f, 0x43, 0xef, 0x2a, 0x1b, 0x63, 0x1a, 0xa3, 0x46, 0xe5, 0x2b, 0x4c, 0x5f, 0xf1, 0x00, - 0x7d, 0x16, 0x04, 0x32, 0x8b, 0x75, 0x71, 0xc6, 0xd3, 0x5b, 0xd4, 0x59, 0x60, 0x2e, 0x0b, 0xc8, - 0xa0, 0x40, 0x0c, 0x5b, 0xd0, 0x8c, 0x50, 0xcf, 0x64, 0xe8, 0xfe, 0xda, 0x58, 0x2e, 0x35, 0xef, - 0x1f, 0xf9, 0x02, 0x3a, 0xaf, 0x65, 0x7a, 0x35, 0x11, 0xf2, 0xb5, 0xff, 0x4f, 0x6e, 0x08, 0x4a, - 0xf4, 0x28, 0x24, 0xdf, 0xc2, 0x5e, 0xfe, 0x7f, 0x3d, 0xf7, 0x23, 0xd4, 0x2c, 0x64, 0x9a, 0xd9, - 0x4b, 0x73, 0x6f, 0xee, 0xd4, 0x33, 0x8b, 0xa4, 0xdd, 0x82, 0x5a, 0xda, 0x64, 0x08, 0xdd, 0x10, - 0x27, 0x2c, 0x13, 0xda, 0xe7, 0x71, 0x92, 0x69, 0x65, 0x6f, 0xf2, 0x70, 0x2d, 0x97, 0x0b, 0x96, - 0xb2, 0x08, 0x35, 0xa6, 0xcf, 0x58, 0x42, 0x77, 0x2d, 0x65, 0x64, 0x18, 0xe4, 0x2b, 0xd8, 0x99, - 0xf0, 0x6b, 0x0c, 0xcb, 0x08, 0x8d, 0x37, 0x56, 0x73, 0x5e, 0xec, 0x76, 0xce, 0xef, 0x18, 0xb8, - 0x65, 0x1f, 0x40, 0xc3, 0xdc, 0xc4, 0x56, 0xde, 0xd1, 0x61, 0xdd, 0xa9, 0x51, 0x63, 0x13, 0x0f, - 0x9a, 0x82, 0x8d, 0x51, 0x28, 0xa7, 0x69, 0xe2, 0x1d, 0x6c, 0x56, 0x97, 0x7b, 0xa9, 0x45, 0x91, - 0x27, 0xd0, 0x61, 0x71, 0x2c, 0x35, 0xd3, 0x5c, 0xc6, 0xca, 0xd9, 0x5e, 0x2f, 0xa3, 0x20, 0x0d, - 0x16, 0x10, 0xba, 0x8c, 0x27, 0x9f, 0x40, 0x83, 0x65, 0x7a, 0xe6, 0xb4, 0x0c, 0xef, 0xce, 0x06, - 0x2f, 0xd3, 0xb3, 0x22, 0xb9, 0x1c, 0x45, 0x4e, 0xa0, 0x9d, 0xff, 0x2d, 0x66, 0xa8, 0x6d, 0x28, - 0xce, 0x9b, 0x28, 0xf9, 0x24, 0xd1, 0x16, 0xb3, 0x5f, 0xee, 0x9f, 0x75, 0x78, 0x67, 0x63, 0x25, - 0xc8, 0x09, 0x6c, 0x29, 0xcd, 0x74, 0x31, 0x8c, 0xdd, 0xe3, 0x07, 0x7f, 0xb3, 0x7b, 0x39, 0x8c, - 0x16, 0x68, 0xf2, 0x0d, 0xec, 0xe1, 0x75, 0x82, 0x81, 0x5e, 0x74, 0xbe, 0xfe, 0xf6, 0xbb, 0xeb, - 0x96, 0x1c, 0xdb, 0xfe, 0x33, 0xd8, 0xaf, 0xa2, 0xc8, 0x4c, 0x2f, 0x8d, 0x40, 0x6f, 0x2d, 0xcc, - 0x4b, 0x96, 0xf2, 0x7c, 0x41, 0xf2, 0x28, 0xd5, 0xc9, 0xdf, 0x15, 0x14, 0xf2, 0x39, 0x40, 0x60, - 0xa4, 0x28, 0xf4, 0x99, 0xb6, 0x13, 0xd0, 0xf3, 0x0a, 0x11, 0xf5, 0x4a, 0x11, 0xf5, 0x5e, 0x94, - 0x22, 0x4a, 0xdb, 0x16, 0x3d, 0xd0, 0x39, 0x35, 0x4b, 0xc2, 0x92, 0xba, 0xf5, 0x76, 0xaa, 0x45, - 0x0f, 0xb4, 0xfb, 0x5b, 0x0d, 0xc8, 0xe6, 0x90, 0x93, 0xcf, 0xa0, 0x55, 0x6a, 0xbd, 0x5d, 0xad, - 0x8d, 0xcb, 0xb9, 0xb4, 0x7e, 0x5a, 0x21, 0xc9, 0x10, 0x76, 0x63, 0x99, 0xef, 0x5b, 0x60, 0x47, - 0xa8, 0x6e, 0xf4, 0xe7, 0xde, 0x3a, 0xf5, 0xf9, 0x12, 0x88, 0xae, 0x52, 0xdc, 0x9f, 0x97, 0x5f, - 0x85, 0xef, 0x4d, 0x9e, 0xff, 0xe1, 0x55, 0xa8, 0x06, 0xa2, 0xfe, 0x6f, 0x06, 0x62, 0xf5, 0x61, - 0x28, 0x0f, 0xb7, 0x0f, 0xc3, 0x05, 0xdc, 0x1d, 0x04, 0x9a, 0xbf, 0xc2, 0x25, 0xf5, 0xb4, 0x89, - 0x9d, 0x2c, 0x25, 0xf6, 0xc1, 0x46, 0xb1, 0x2c, 0xc2, 0xf0, 0xcc, 0x68, 0xc6, 0x6a, 0x92, 0xee, - 0x1f, 0x35, 0x38, 0x5c, 0x0f, 0x99, 0xcb, 0x78, 0x19, 0xd6, 0x81, 0xed, 0x24, 0x95, 0x3f, 0x62, - 0xa0, 0x0b, 0x91, 0xa5, 0xa5, 0x49, 0x0e, 0xa0, 0x19, 0xca, 0x88, 0xf1, 0x52, 0xa9, 0xad, 0x95, - 0x0b, 0xb8, 0xe0, 0x11, 0xd7, 0x66, 0xfe, 0x76, 0x69, 0x61, 0x2c, 0x64, 0xbd, 0xb1, 0x24, 0xeb, - 0xe4, 0x11, 0x6c, 0x2b, 0x99, 0x6a, 0x7f, 0x3c, 0xb7, 0x13, 0xb3, 0xb1, 0xb1, 0x97, 0x32, 0xd5, - 0xb4, 0x99, 0x83, 0x86, 0xf3, 0x8f, 0x3e, 0x86, 0xbd, 0xb5, 0xa6, 0x91, 0x1d, 0x68, 0x8d, 0x9e, - 0x0f, 0x4e, 0x5f, 0x8c, 0x5e, 0x9e, 0xed, 0xdf, 0x22, 0x00, 0x4d, 0xfb, 0x5d, 0x1b, 0x3e, 0xfe, - 0xe1, 0xd3, 0x29, 0xd7, 0xb3, 0x6c, 0xec, 0x05, 0x32, 0xea, 0x8b, 0xf9, 0x44, 0xf7, 0xab, 0x9f, - 0x0a, 0x53, 0x8c, 0xfb, 0xc9, 0xf8, 0xd1, 0x54, 0xf6, 0x57, 0x7f, 0x3d, 0x8c, 0x9b, 0x66, 0x52, - 0x1f, 0xff, 0x15, 0x00, 0x00, 0xff, 0xff, 0x2a, 0x2e, 0x32, 0x67, 0x04, 0x09, 0x00, 0x00, + // 983 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x56, 0xdd, 0x6e, 0xdb, 0x36, + 0x14, 0x8e, 0x5d, 0xc7, 0x49, 0x8e, 0x13, 0x27, 0x23, 0x8a, 0x54, 0x73, 0xba, 0x36, 0x13, 0x30, + 0xa0, 0xfb, 0xa9, 0x8c, 0xa5, 0xcb, 0xc5, 0x7e, 0x3a, 0xc0, 0xce, 0x02, 0xd4, 0x58, 0xd2, 0x66, + 0x4c, 0xd7, 0x8b, 0xdd, 0x18, 0xb4, 0x74, 0x1c, 0x73, 0xa1, 0x44, 0x45, 0xa4, 0xda, 0x04, 0xbb, + 0xd9, 0x13, 0xec, 0x39, 0x86, 0xbd, 0xcb, 0x6e, 0xf7, 0x3c, 0x83, 0x28, 0x4a, 0xb6, 0xa5, 0x06, + 0xdd, 0x06, 0xec, 0x2a, 0x62, 0xce, 0xf7, 0x1d, 0x9e, 0x9f, 0x8f, 0xe7, 0x18, 0xf6, 0xa7, 0xe2, + 0x46, 0x23, 0x0f, 0x44, 0x9f, 0x05, 0x21, 0x8f, 0xfa, 0x82, 0xa5, 0x91, 0x3f, 0x1b, 0xc7, 0x82, + 0x45, 0x5e, 0x9c, 0x48, 0x2d, 0x49, 0xb7, 0x40, 0x78, 0x06, 0xd1, 0xfb, 0xa0, 0x64, 0xf8, 0x32, + 0xc1, 0x3e, 0x5e, 0xa3, 0x9f, 0x6a, 0x2e, 0x2d, 0xbc, 0x77, 0x7f, 0xd9, 0x2c, 0xb8, 0xc6, 0x84, + 0x09, 0x65, 0xad, 0x0f, 0x96, 0xad, 0x3c, 0xc0, 0x48, 0xf3, 0x29, 0xc7, 0xc4, 0xda, 0x2b, 0xce, + 0x79, 0xa4, 0x31, 0x99, 0x32, 0x1f, 0x6b, 0xe6, 0x3c, 0x5a, 0xe5, 0xcf, 0x30, 0x48, 0x45, 0x61, + 0xde, 0xab, 0x98, 0x7d, 0x19, 0x86, 0x65, 0x60, 0x0f, 0x2f, 0xa4, 0xbc, 0x10, 0xd8, 0x37, 0xa7, + 0x49, 0x3a, 0xed, 0x6b, 0x1e, 0xa2, 0xd2, 0x2c, 0x8c, 0x73, 0x80, 0x7b, 0x0d, 0xf7, 0x4e, 0x4c, + 0xf6, 0x67, 0x82, 0x45, 0x47, 0x09, 0x32, 0x8d, 0x14, 0xaf, 0x52, 0x54, 0x9a, 0x7c, 0x0c, 0x4d, + 0x1e, 0x38, 0x8d, 0xfd, 0xc6, 0xa3, 0xce, 0xc1, 0xfb, 0x5e, 0x59, 0x90, 0x2c, 0x46, 0x6f, 0x54, + 0xe6, 0x40, 0x9b, 0x3c, 0x20, 0x07, 0xd0, 0x52, 0x31, 0xfa, 0x4e, 0xd3, 0x80, 0x1f, 0x78, 0xcb, + 0xd5, 0xf3, 0xe6, 0x37, 0x9c, 0xc7, 0xe8, 0x53, 0x83, 0x75, 0x7b, 0xe0, 0xd4, 0x6f, 0x56, 0xb1, + 0x8c, 0x14, 0xba, 0xbf, 0x37, 0x00, 0xe6, 0xc6, 0xff, 0x39, 0x12, 0xf2, 0x35, 0xac, 0xf9, 0x42, + 0xaa, 0x34, 0x41, 0xe7, 0x8e, 0xa1, 0x7d, 0x78, 0x3b, 0xed, 0x28, 0x07, 0xd2, 0x82, 0xe1, 0x22, + 0x74, 0xe7, 0xd6, 0x13, 0xae, 0x34, 0x79, 0x0a, 0x9b, 0x0b, 0x82, 0x52, 0x4e, 0x63, 0xff, 0xce, + 0xa3, 0xce, 0x41, 0xef, 0x76, 0x9f, 0xb4, 0x23, 0xca, 0x6f, 0x45, 0xee, 0xc2, 0xaa, 0x96, 0x97, + 0x18, 0x99, 0x14, 0x36, 0x68, 0x7e, 0x70, 0x7f, 0x6d, 0x40, 0x6b, 0x90, 0xea, 0x19, 0xf1, 0x80, + 0x30, 0xa5, 0xd2, 0x90, 0x4d, 0x04, 0x8e, 0x39, 0x0b, 0xc7, 0x89, 0x14, 0x68, 0x6a, 0xb3, 0xf1, + 0x6c, 0x85, 0xee, 0x94, 0xb6, 0x11, 0x0b, 0xa9, 0x14, 0x48, 0xbe, 0x85, 0xde, 0x65, 0x3a, 0xc1, + 0x24, 0x42, 0x8d, 0x6a, 0xac, 0x30, 0x79, 0xcd, 0x7d, 0x1c, 0x33, 0xdf, 0x97, 0x69, 0xa4, 0xf3, + 0x3b, 0x9e, 0xad, 0x50, 0x67, 0x8e, 0x39, 0xcf, 0x21, 0x83, 0x1c, 0x31, 0x5c, 0x87, 0x76, 0x88, + 0x7a, 0x26, 0x03, 0xf7, 0xaf, 0xd6, 0x62, 0xaa, 0x59, 0xfd, 0xc8, 0x57, 0xd0, 0x79, 0x23, 0x93, + 0xcb, 0xa9, 0x90, 0x6f, 0xc6, 0xff, 0xa4, 0x43, 0x50, 0xa0, 0x47, 0x01, 0xf9, 0x1e, 0xb6, 0xb3, + 0xff, 0xeb, 0x9b, 0x71, 0x88, 0x9a, 0x05, 0x4c, 0x33, 0xdb, 0x34, 0xf7, 0xf6, 0x4a, 0x9d, 0x5a, + 0x24, 0xed, 0xe6, 0xd4, 0xe2, 0x4c, 0x86, 0xd0, 0x0d, 0x70, 0xca, 0x52, 0xa1, 0xc7, 0x3c, 0x8a, + 0x53, 0xad, 0x6c, 0x27, 0xf7, 0x2a, 0xb1, 0x9c, 0xb1, 0x84, 0x85, 0xa8, 0x31, 0x39, 0x65, 0x31, + 0xdd, 0xb2, 0x94, 0x91, 0x61, 0x90, 0x6f, 0x60, 0x73, 0xca, 0xaf, 0x31, 0x28, 0x3c, 0xb4, 0xde, + 0x9a, 0xcd, 0x49, 0xfe, 0xb6, 0x33, 0x7e, 0xc7, 0xc0, 0x2d, 0x7b, 0x17, 0x5a, 0xa6, 0x13, 0xab, + 0x59, 0x45, 0x87, 0x4d, 0xa7, 0x41, 0xcd, 0x99, 0x78, 0xd0, 0x16, 0x6c, 0x82, 0x42, 0x39, 0x6d, + 0xe3, 0x6f, 0xb7, 0x9e, 0x5d, 0x66, 0xa5, 0x16, 0x45, 0x9e, 0x42, 0x87, 0x45, 0x91, 0xd4, 0x2c, + 0x1b, 0x2f, 0xca, 0x59, 0xab, 0xa6, 0x91, 0x93, 0x06, 0x73, 0x08, 0x5d, 0xc4, 0x93, 0xcf, 0xa0, + 0xc5, 0x52, 0x3d, 0x73, 0xd6, 0x0d, 0xef, 0x6e, 0x8d, 0x97, 0xea, 0x59, 0x1e, 0x5c, 0x86, 0x22, + 0x87, 0xb0, 0x91, 0xfd, 0xcd, 0x35, 0xb4, 0x61, 0x28, 0xce, 0xdb, 0x28, 0x99, 0x92, 0xe8, 0x3a, + 0xb3, 0x5f, 0xe4, 0x14, 0xc8, 0x55, 0xca, 0x44, 0xd6, 0x3b, 0x39, 0x2d, 0x34, 0xe5, 0xec, 0x18, + 0xfe, 0xc3, 0x4a, 0xbd, 0x7e, 0xc8, 0x81, 0x2f, 0xa6, 0x56, 0x57, 0x74, 0xe7, 0xaa, 0xf2, 0x1f, + 0xf7, 0xcf, 0x26, 0xbc, 0x57, 0x7b, 0x61, 0xe4, 0x10, 0x56, 0x95, 0x66, 0x3a, 0xd7, 0x76, 0x77, + 0xd1, 0x6f, 0xed, 0x29, 0x67, 0x30, 0x9a, 0xa3, 0xc9, 0x77, 0xb0, 0x8d, 0xd7, 0x31, 0xfa, 0x7a, + 0xde, 0xc8, 0xe6, 0xbb, 0xa5, 0xd0, 0x2d, 0x38, 0xb6, 0x9b, 0xc7, 0xb0, 0x53, 0x7a, 0x91, 0xa9, + 0x5e, 0x50, 0x54, 0xaf, 0xe2, 0xe6, 0x15, 0x4b, 0x78, 0xf6, 0xde, 0x32, 0x2f, 0xe5, 0xcd, 0x2f, + 0x72, 0x0a, 0xf9, 0x12, 0xc0, 0x37, 0x93, 0x2d, 0x18, 0x33, 0x6d, 0x05, 0xd5, 0xf3, 0xf2, 0x99, + 0xec, 0x15, 0x33, 0xd9, 0x7b, 0x59, 0xcc, 0x64, 0xba, 0x61, 0xd1, 0x03, 0x9d, 0x51, 0xd3, 0x38, + 0x28, 0xa8, 0xab, 0xef, 0xa6, 0x5a, 0xf4, 0x40, 0xbb, 0xbf, 0x35, 0x80, 0xd4, 0xdf, 0x0c, 0xf9, + 0x02, 0xd6, 0x8b, 0xd5, 0x61, 0x5f, 0x6a, 0xad, 0xd7, 0xe7, 0xd6, 0x4e, 0x4b, 0x24, 0x19, 0xc2, + 0x56, 0x24, 0xb3, 0xe7, 0xeb, 0x5b, 0x45, 0x36, 0xcd, 0x38, 0xbb, 0x5f, 0xa5, 0x3e, 0x5f, 0x00, + 0xd1, 0x65, 0x8a, 0xfb, 0xcb, 0xe2, 0x92, 0xf9, 0xd1, 0xc4, 0xf9, 0x1f, 0x96, 0x4c, 0x29, 0x88, + 0xe6, 0xbf, 0x11, 0xc4, 0xf2, 0x9e, 0x29, 0x2e, 0xb7, 0x7b, 0xe6, 0x0c, 0xee, 0x0d, 0x7c, 0xcd, + 0x5f, 0xe3, 0xc2, 0x30, 0xb6, 0x81, 0x1d, 0x2e, 0x04, 0xf6, 0x51, 0x2d, 0x59, 0x16, 0x62, 0x70, + 0x6c, 0x46, 0xd0, 0x72, 0x90, 0xee, 0x1f, 0x0d, 0xd8, 0xab, 0xba, 0xcc, 0xb6, 0x42, 0xe1, 0xd6, + 0x81, 0xb5, 0x38, 0x91, 0x3f, 0xa3, 0xaf, 0xf3, 0x99, 0x4d, 0x8b, 0x23, 0xd9, 0x85, 0x76, 0x20, + 0x43, 0xc6, 0x8b, 0xc1, 0x6f, 0x4f, 0xd9, 0x3e, 0x10, 0x3c, 0xe4, 0xda, 0xe8, 0x6f, 0x8b, 0xe6, + 0x87, 0xf9, 0x96, 0x68, 0x2d, 0x6c, 0x09, 0xf2, 0x18, 0xd6, 0x94, 0x4c, 0xf4, 0x78, 0x72, 0x63, + 0x15, 0x53, 0x1b, 0x00, 0xe7, 0x32, 0xd1, 0xb4, 0x9d, 0x81, 0x86, 0x37, 0x9f, 0x7c, 0x0a, 0xdb, + 0x95, 0xa2, 0x91, 0x4d, 0x58, 0x1f, 0x3d, 0x1f, 0x1c, 0xbd, 0x1c, 0xbd, 0x3a, 0xde, 0x59, 0x21, + 0x00, 0x6d, 0xfb, 0xdd, 0x18, 0x3e, 0xf9, 0xe9, 0xf3, 0x0b, 0xae, 0x67, 0xe9, 0xc4, 0xf3, 0x65, + 0xd8, 0x17, 0x37, 0x53, 0xdd, 0x2f, 0x7f, 0x79, 0x5c, 0x60, 0xd4, 0x8f, 0x27, 0x8f, 0x2f, 0x64, + 0x7f, 0xf9, 0xc7, 0xc8, 0xa4, 0x6d, 0x94, 0xfa, 0xe4, 0xef, 0x00, 0x00, 0x00, 0xff, 0xff, 0x0c, + 0xe5, 0x03, 0xf4, 0x72, 0x09, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/admin/launch_plan.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/admin/launch_plan.pb.validate.go index d40496cde7f..eb01edfd049 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/launch_plan.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/launch_plan.pb.validate.go @@ -530,6 +530,16 @@ func (m *LaunchPlanSpec) Validate() error { } } + if v, ok := interface{}(m.GetQualityOfService()).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return LaunchPlanSpecValidationError{ + field: "QualityOfService", + reason: "embedded message failed validation", + cause: err, + } + } + } + return nil } diff --git a/flyteidl/gen/pb-go/flyteidl/admin/matchable_resource.pb.go b/flyteidl/gen/pb-go/flyteidl/admin/matchable_resource.pb.go index 7410fc5f041..36977652518 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/matchable_resource.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/matchable_resource.pb.go @@ -6,6 +6,7 @@ package admin import ( fmt "fmt" proto "github.com/golang/protobuf/proto" + core "github.com/lyft/flyteidl/gen/pb-go/flyteidl/core" math "math" ) @@ -33,6 +34,8 @@ const ( MatchableResource_EXECUTION_QUEUE MatchableResource = 2 // Configures the K8s cluster label to be used for execution to be run MatchableResource_EXECUTION_CLUSTER_LABEL MatchableResource = 3 + // Configures default quality of service when undefined in an execution spec. + MatchableResource_QUALITY_OF_SERVICE_SPECIFICATION MatchableResource = 4 ) var MatchableResource_name = map[int32]string{ @@ -40,13 +43,15 @@ var MatchableResource_name = map[int32]string{ 1: "CLUSTER_RESOURCE", 2: "EXECUTION_QUEUE", 3: "EXECUTION_CLUSTER_LABEL", + 4: "QUALITY_OF_SERVICE_SPECIFICATION", } var MatchableResource_value = map[string]int32{ - "TASK_RESOURCE": 0, - "CLUSTER_RESOURCE": 1, - "EXECUTION_QUEUE": 2, - "EXECUTION_CLUSTER_LABEL": 3, + "TASK_RESOURCE": 0, + "CLUSTER_RESOURCE": 1, + "EXECUTION_QUEUE": 2, + "EXECUTION_CLUSTER_LABEL": 3, + "QUALITY_OF_SERVICE_SPECIFICATION": 4, } func (x MatchableResource) String() string { @@ -296,6 +301,7 @@ type MatchingAttributes struct { // *MatchingAttributes_ClusterResourceAttributes // *MatchingAttributes_ExecutionQueueAttributes // *MatchingAttributes_ExecutionClusterLabel + // *MatchingAttributes_QualityOfService Target isMatchingAttributes_Target `protobuf_oneof:"target"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` @@ -347,6 +353,10 @@ type MatchingAttributes_ExecutionClusterLabel struct { ExecutionClusterLabel *ExecutionClusterLabel `protobuf:"bytes,4,opt,name=execution_cluster_label,json=executionClusterLabel,proto3,oneof"` } +type MatchingAttributes_QualityOfService struct { + QualityOfService *core.QualityOfService `protobuf:"bytes,5,opt,name=quality_of_service,json=qualityOfService,proto3,oneof"` +} + func (*MatchingAttributes_TaskResourceAttributes) isMatchingAttributes_Target() {} func (*MatchingAttributes_ClusterResourceAttributes) isMatchingAttributes_Target() {} @@ -355,6 +365,8 @@ func (*MatchingAttributes_ExecutionQueueAttributes) isMatchingAttributes_Target( func (*MatchingAttributes_ExecutionClusterLabel) isMatchingAttributes_Target() {} +func (*MatchingAttributes_QualityOfService) isMatchingAttributes_Target() {} + func (m *MatchingAttributes) GetTarget() isMatchingAttributes_Target { if m != nil { return m.Target @@ -390,6 +402,13 @@ func (m *MatchingAttributes) GetExecutionClusterLabel() *ExecutionClusterLabel { return nil } +func (m *MatchingAttributes) GetQualityOfService() *core.QualityOfService { + if x, ok := m.GetTarget().(*MatchingAttributes_QualityOfService); ok { + return x.QualityOfService + } + return nil +} + // XXX_OneofWrappers is for the internal use of the proto package. func (*MatchingAttributes) XXX_OneofWrappers() []interface{} { return []interface{}{ @@ -397,6 +416,7 @@ func (*MatchingAttributes) XXX_OneofWrappers() []interface{} { (*MatchingAttributes_ClusterResourceAttributes)(nil), (*MatchingAttributes_ExecutionQueueAttributes)(nil), (*MatchingAttributes_ExecutionClusterLabel)(nil), + (*MatchingAttributes_QualityOfService)(nil), } } @@ -572,50 +592,56 @@ func init() { } var fileDescriptor_1d15bcabb02640f4 = []byte{ - // 712 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x55, 0xdd, 0x4e, 0xdb, 0x4a, - 0x10, 0x8e, 0x09, 0xe4, 0xc0, 0xe4, 0x00, 0x61, 0x0f, 0x3f, 0x06, 0xa4, 0x43, 0x8e, 0xa5, 0xd3, - 0xd2, 0x4a, 0x24, 0x6d, 0xb8, 0xa1, 0x55, 0x7b, 0x41, 0x22, 0x57, 0xa9, 0x1a, 0x4a, 0xd9, 0x24, - 0x12, 0xed, 0x4d, 0xb4, 0x71, 0x36, 0x8e, 0x9b, 0x8d, 0xd7, 0xd8, 0xbb, 0xa5, 0x56, 0x5f, 0xa2, - 0x2f, 0xd3, 0x9b, 0xbe, 0x47, 0xdf, 0xa7, 0xb2, 0x63, 0x27, 0xc6, 0xc4, 0x15, 0x77, 0x9e, 0xd9, - 0x99, 0xf9, 0xbe, 0x9d, 0xf9, 0x3c, 0x0b, 0x8f, 0x87, 0xcc, 0x17, 0xd4, 0x1a, 0xb0, 0x2a, 0x19, - 0x4c, 0x2c, 0xbb, 0x3a, 0x21, 0xc2, 0x18, 0x91, 0x3e, 0xa3, 0x3d, 0x97, 0x7a, 0x5c, 0xba, 0x06, - 0xad, 0x38, 0x2e, 0x17, 0x1c, 0x6d, 0xc4, 0x81, 0x95, 0x30, 0x50, 0x1b, 0x41, 0xa9, 0x43, 0xbc, - 0x31, 0x8e, 0xa2, 0xda, 0x0e, 0x35, 0x50, 0x09, 0xf2, 0x86, 0x23, 0x55, 0xa5, 0xac, 0x1c, 0xaf, - 0xe1, 0xe0, 0x33, 0xf0, 0x98, 0x8e, 0x54, 0x97, 0xa6, 0x1e, 0xd3, 0x91, 0x68, 0x17, 0x0a, 0x13, - 0x3a, 0xe1, 0xae, 0xaf, 0xe6, 0x43, 0x67, 0x64, 0x21, 0x15, 0xfe, 0xf2, 0x04, 0x77, 0x89, 0x49, - 0xd5, 0xe5, 0xf0, 0x20, 0x36, 0xb5, 0xef, 0x0a, 0xec, 0x26, 0xa1, 0xce, 0x85, 0x70, 0xad, 0xbe, - 0x14, 0xd4, 0x43, 0xaf, 0x60, 0x75, 0x40, 0x87, 0x44, 0x32, 0xe1, 0x85, 0xa8, 0xc5, 0x5a, 0xb9, - 0x72, 0x97, 0x67, 0x25, 0x4d, 0x12, 0xcf, 0x32, 0xd0, 0x19, 0x14, 0x98, 0x35, 0xb1, 0x84, 0x17, - 0xf2, 0x7b, 0x48, 0x6e, 0x14, 0xaf, 0xfd, 0x50, 0x60, 0xbf, 0xc1, 0xa4, 0x27, 0xa8, 0xbb, 0x80, - 0xd5, 0x47, 0x00, 0x32, 0xb3, 0x54, 0xa5, 0x9c, 0x3f, 0x2e, 0xd6, 0x5e, 0xa4, 0x6b, 0x67, 0xa6, - 0x57, 0xe6, 0x9f, 0xba, 0x2d, 0x5c, 0x1f, 0x27, 0x8a, 0x1d, 0xbc, 0x86, 0xcd, 0xd4, 0x71, 0xd0, - 0xe2, 0x31, 0xf5, 0xe3, 0xa6, 0x8f, 0xa9, 0x8f, 0xb6, 0x61, 0xe5, 0x0b, 0x61, 0x92, 0x46, 0x6d, - 0x9f, 0x1a, 0x2f, 0x97, 0xce, 0x14, 0xad, 0x02, 0xaa, 0xfe, 0x95, 0x1a, 0x52, 0x58, 0xdc, 0xbe, - 0x92, 0x54, 0x26, 0x59, 0x23, 0x58, 0x16, 0xc4, 0x9c, 0xf2, 0x5d, 0xc3, 0xe1, 0xb7, 0x76, 0x02, - 0x3b, 0xb3, 0xf8, 0x88, 0x70, 0x8b, 0xf4, 0x29, 0x9b, 0x43, 0x28, 0x09, 0x08, 0xed, 0x67, 0x1e, - 0xd0, 0x45, 0x20, 0x20, 0xcb, 0x36, 0x13, 0x95, 0xfb, 0xa0, 0x0a, 0xe2, 0x8d, 0x67, 0x8a, 0xea, - 0xdd, 0xe9, 0x4e, 0xd0, 0xf9, 0x47, 0x7f, 0xea, 0xfc, 0xbc, 0x52, 0x33, 0x87, 0x77, 0xc5, 0x62, - 0x25, 0x8c, 0xe1, 0xd0, 0x98, 0x12, 0x5c, 0x08, 0x33, 0x1d, 0xf0, 0x93, 0x07, 0x0f, 0xa1, 0x99, - 0xc3, 0xfb, 0x46, 0xe6, 0x80, 0x47, 0x70, 0x40, 0xe3, 0xb6, 0xf4, 0x6e, 0x82, 0x3e, 0x26, 0xb1, - 0xf2, 0x21, 0xd6, 0x71, 0x1a, 0x2b, 0xab, 0xf1, 0xcd, 0x1c, 0x56, 0x69, 0xd6, 0x50, 0x7a, 0xb0, - 0x37, 0x47, 0x8a, 0x2f, 0xc8, 0x82, 0x11, 0x84, 0x7f, 0x49, 0xb1, 0xf6, 0x7f, 0x26, 0x4c, 0x72, - 0x5e, 0xcd, 0x1c, 0xde, 0xa1, 0x8b, 0x0e, 0xea, 0xab, 0x50, 0x10, 0xc4, 0x35, 0xa9, 0xd0, 0x7e, - 0x29, 0x50, 0xbe, 0x88, 0xff, 0xfe, 0x39, 0x85, 0x06, 0xb7, 0x87, 0x96, 0x29, 0x5d, 0x12, 0xa4, - 0xa2, 0x7a, 0x4a, 0xda, 0x01, 0x05, 0x2d, 0x4d, 0xe1, 0xbe, 0x04, 0x92, 0x1a, 0x0e, 0x36, 0xc0, - 0x80, 0x4f, 0x88, 0x65, 0x47, 0xfa, 0x8c, 0xac, 0x60, 0x03, 0x38, 0x2e, 0xff, 0x4c, 0x0d, 0x11, - 0xad, 0x86, 0xd8, 0x44, 0x07, 0xb0, 0x7a, 0xcb, 0xdd, 0xf1, 0x90, 0xf1, 0xdb, 0x68, 0x39, 0xcc, - 0x6c, 0x74, 0x04, 0x45, 0x46, 0xa4, 0x6d, 0x8c, 0x7a, 0x0e, 0x23, 0xb6, 0xba, 0x12, 0x1e, 0xc3, - 0xd4, 0xf5, 0x81, 0x91, 0x60, 0x51, 0xfd, 0xdb, 0xb2, 0x3c, 0xb1, 0xe0, 0x6a, 0x98, 0xde, 0x48, - 0xea, 0x09, 0xf4, 0x06, 0xd6, 0x67, 0x9a, 0x11, 0xbe, 0x33, 0x15, 0xf5, 0x46, 0xed, 0xbf, 0x85, - 0xf7, 0x0a, 0x4a, 0xc4, 0x92, 0xc0, 0x7f, 0xc7, 0x79, 0x1d, 0xdf, 0xa1, 0xda, 0x37, 0x38, 0xca, - 0x44, 0xf2, 0x1c, 0x6e, 0x7b, 0x14, 0x5d, 0xc3, 0x86, 0x91, 0x6c, 0x68, 0xbc, 0x1e, 0x9e, 0x65, - 0x62, 0x65, 0x4c, 0x02, 0xa7, 0xea, 0x3c, 0xb5, 0x61, 0xeb, 0x1e, 0x3f, 0xb4, 0x05, 0xeb, 0x9d, - 0xf3, 0xf6, 0xbb, 0x1e, 0xd6, 0xdb, 0x97, 0x5d, 0xdc, 0xd0, 0x4b, 0x39, 0xb4, 0x0d, 0xa5, 0x46, - 0xab, 0xdb, 0xee, 0xe8, 0x78, 0xee, 0x55, 0xd0, 0x3f, 0xb0, 0xa9, 0x5f, 0xeb, 0x8d, 0x6e, 0xe7, - 0xed, 0xe5, 0xfb, 0xde, 0x55, 0x57, 0xef, 0xea, 0xa5, 0x25, 0x74, 0x08, 0x7b, 0x73, 0x67, 0x9c, - 0xd4, 0x3a, 0xaf, 0xeb, 0xad, 0x52, 0xbe, 0x7e, 0xfa, 0xe9, 0xb9, 0x69, 0x89, 0x91, 0xec, 0x57, - 0x0c, 0x3e, 0xa9, 0x32, 0x7f, 0x28, 0xaa, 0xb3, 0xa7, 0xc4, 0xa4, 0x76, 0xd5, 0xe9, 0x9f, 0x98, - 0xbc, 0x7a, 0xf7, 0x75, 0xe9, 0x17, 0xc2, 0xb7, 0xe4, 0xf4, 0x77, 0x00, 0x00, 0x00, 0xff, 0xff, - 0x18, 0x84, 0xb1, 0x80, 0x76, 0x06, 0x00, 0x00, + // 808 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x55, 0x5f, 0x73, 0xdb, 0x44, + 0x10, 0xb7, 0xe2, 0x34, 0x24, 0x1b, 0x9a, 0xaa, 0x47, 0x9b, 0xaa, 0xce, 0x40, 0x8c, 0x86, 0x3f, + 0x81, 0x99, 0xca, 0x90, 0xbe, 0x14, 0x06, 0x1e, 0x1c, 0x8d, 0x32, 0xf6, 0xe0, 0xe2, 0xe6, 0x6c, + 0x33, 0x2d, 0x2f, 0x9a, 0xb3, 0x72, 0x96, 0x85, 0x25, 0x9d, 0x22, 0xdd, 0xb5, 0x68, 0xf8, 0x08, + 0xbc, 0xf0, 0xc0, 0x57, 0xe1, 0xa3, 0xf0, 0x7d, 0x18, 0xfd, 0x57, 0x54, 0x8b, 0xc9, 0xdb, 0xed, + 0xde, 0xee, 0xfe, 0x76, 0x7f, 0xbb, 0xb7, 0x07, 0x5f, 0xae, 0xdc, 0x98, 0x53, 0xe7, 0xda, 0x1d, + 0x90, 0x6b, 0xcf, 0xf1, 0x07, 0x1e, 0xe1, 0xd6, 0x9a, 0x2c, 0x5d, 0x6a, 0x86, 0x34, 0x62, 0x22, + 0xb4, 0xa8, 0x16, 0x84, 0x8c, 0x33, 0x74, 0x54, 0x18, 0x6a, 0xa9, 0x61, 0xef, 0xa4, 0xe1, 0x68, + 0x31, 0xcf, 0x63, 0x7e, 0x66, 0xdc, 0xfb, 0xb8, 0xbc, 0xb4, 0x58, 0x48, 0x07, 0xf4, 0x77, 0x6a, + 0x09, 0xee, 0x14, 0xd7, 0xea, 0x1a, 0xe4, 0x39, 0x89, 0x36, 0x38, 0x47, 0x98, 0x05, 0xd4, 0x42, + 0x32, 0x74, 0xad, 0x40, 0x28, 0x52, 0x5f, 0x3a, 0x3b, 0xc0, 0xc9, 0x31, 0xd1, 0xd8, 0x81, 0x50, + 0x76, 0x32, 0x8d, 0x1d, 0x08, 0x74, 0x0c, 0x7b, 0x1e, 0xf5, 0x58, 0x18, 0x2b, 0xdd, 0x54, 0x99, + 0x4b, 0x48, 0x81, 0x0f, 0x22, 0xce, 0x42, 0x62, 0x53, 0x65, 0x37, 0xbd, 0x28, 0x44, 0xf5, 0x2f, + 0x09, 0x8e, 0xeb, 0x50, 0x43, 0xce, 0x43, 0x67, 0x29, 0x38, 0x8d, 0xd0, 0x0f, 0xb0, 0x7f, 0x4d, + 0x57, 0x44, 0xb8, 0x3c, 0x4a, 0x51, 0x0f, 0xcf, 0xfb, 0xda, 0xed, 0x1a, 0xb5, 0x66, 0x92, 0xb8, + 0xf4, 0x40, 0x2f, 0x60, 0xcf, 0x75, 0x3c, 0x87, 0x47, 0x69, 0x7e, 0x77, 0xf1, 0xcd, 0xed, 0xd5, + 0x7f, 0x24, 0x78, 0xaa, 0xbb, 0x22, 0xe2, 0x34, 0xdc, 0x92, 0xd5, 0x1b, 0x00, 0x52, 0x4a, 0x8a, + 0xd4, 0xef, 0x9e, 0x1d, 0x9e, 0x7f, 0xd7, 0x8c, 0xdd, 0xea, 0xae, 0x55, 0x47, 0xc3, 0xe7, 0x61, + 0x8c, 0x6b, 0xc1, 0x7a, 0x3f, 0xc2, 0x83, 0xc6, 0x75, 0x42, 0xf1, 0x86, 0xc6, 0x05, 0xe9, 0x1b, + 0x1a, 0xa3, 0x47, 0x70, 0xef, 0x2d, 0x71, 0x05, 0xcd, 0x69, 0xcf, 0x84, 0xef, 0x77, 0x5e, 0x48, + 0xaa, 0x06, 0x8a, 0x51, 0xf4, 0xf1, 0x4a, 0x50, 0x51, 0xcf, 0x1a, 0xc1, 0x2e, 0x27, 0x76, 0x96, + 0xef, 0x01, 0x4e, 0xcf, 0xea, 0x33, 0x78, 0x5c, 0xda, 0xe7, 0x09, 0x4f, 0xc8, 0x92, 0xba, 0x15, + 0x84, 0x54, 0x83, 0x50, 0xff, 0xdc, 0x05, 0xf4, 0x32, 0x19, 0x3e, 0xc7, 0xb7, 0x6b, 0x91, 0x97, + 0xa0, 0x70, 0x12, 0x6d, 0xca, 0x69, 0x34, 0x6f, 0xb1, 0x93, 0x30, 0xff, 0xc5, 0xff, 0x31, 0x5f, + 0x45, 0x1a, 0x75, 0xf0, 0x31, 0xdf, 0x3e, 0x09, 0x1b, 0x38, 0xb1, 0xb2, 0x04, 0xb7, 0xc2, 0x64, + 0x0d, 0xfe, 0xea, 0xce, 0x4d, 0x18, 0x75, 0xf0, 0x53, 0xab, 0xb5, 0xc1, 0x6b, 0xe8, 0x95, 0xcf, + 0xc1, 0xbc, 0x49, 0x78, 0xac, 0x63, 0x75, 0x53, 0xac, 0xb3, 0x26, 0x56, 0x1b, 0xf1, 0xa3, 0x0e, + 0x56, 0x68, 0x5b, 0x53, 0x4c, 0x78, 0x52, 0x21, 0x15, 0x05, 0xba, 0x49, 0x0b, 0xd2, 0x57, 0x72, + 0x78, 0xfe, 0x79, 0x2b, 0x4c, 0xbd, 0x5f, 0xa3, 0x0e, 0x7e, 0x4c, 0xb7, 0x36, 0x72, 0x0a, 0xe8, + 0x46, 0x10, 0xd7, 0xe1, 0xb1, 0xc9, 0x56, 0x66, 0x44, 0xc3, 0xb7, 0x8e, 0x45, 0x95, 0x7b, 0x69, + 0xec, 0xd3, 0x2a, 0x76, 0xb2, 0x02, 0xb4, 0xab, 0xcc, 0x70, 0xba, 0x9a, 0x65, 0x66, 0xa3, 0x0e, + 0x96, 0x6f, 0x1a, 0xba, 0x8b, 0x7d, 0xd8, 0xe3, 0x24, 0xb4, 0x29, 0x57, 0xff, 0x95, 0xa0, 0xff, + 0xb2, 0x58, 0x45, 0x55, 0x4d, 0x3a, 0xf3, 0x57, 0x8e, 0x2d, 0x42, 0x92, 0xe4, 0x82, 0x2e, 0x1a, + 0x6f, 0x25, 0xc1, 0x55, 0x9b, 0x35, 0xbd, 0x3f, 0x53, 0xf5, 0x47, 0x91, 0xac, 0x94, 0x6b, 0xe6, + 0x11, 0xc7, 0xcf, 0x07, 0x3e, 0x97, 0x92, 0x95, 0x12, 0x84, 0xec, 0x37, 0x6a, 0xf1, 0x7c, 0xd7, + 0x14, 0x22, 0xea, 0xc1, 0xfe, 0x3b, 0x16, 0x6e, 0x56, 0x2e, 0x7b, 0x97, 0x6f, 0x9b, 0x52, 0x46, + 0xa7, 0x70, 0xe8, 0x12, 0xe1, 0x5b, 0x6b, 0x33, 0x70, 0x89, 0x9f, 0x52, 0x71, 0x80, 0x21, 0x53, + 0xbd, 0x72, 0x89, 0xaf, 0xae, 0xe1, 0x93, 0x89, 0x13, 0xf1, 0x2d, 0xa5, 0x61, 0x7a, 0x23, 0x68, + 0xc4, 0xd1, 0x25, 0xdc, 0x2f, 0x87, 0x90, 0xc7, 0x41, 0xf6, 0x4a, 0x8e, 0xce, 0x3f, 0xdd, 0x5a, + 0x57, 0x12, 0xa2, 0x98, 0x31, 0xfc, 0x61, 0xe1, 0x37, 0x8f, 0x03, 0xaa, 0xfe, 0x01, 0xa7, 0xad, + 0x48, 0x51, 0xc0, 0xfc, 0x88, 0xa2, 0xd7, 0x70, 0x64, 0xd5, 0x09, 0x2d, 0xf6, 0xcd, 0x37, 0xad, + 0x58, 0x2d, 0x9d, 0xc0, 0x8d, 0x38, 0x5f, 0xff, 0x2d, 0xc1, 0xc3, 0xf7, 0x12, 0x44, 0x0f, 0xe1, + 0xfe, 0x7c, 0x38, 0xfb, 0xc9, 0xc4, 0xc6, 0x6c, 0xba, 0xc0, 0xba, 0x21, 0x77, 0xd0, 0x23, 0x90, + 0xf5, 0xc9, 0x62, 0x36, 0x37, 0x70, 0xa5, 0x95, 0xd0, 0x47, 0xf0, 0xc0, 0x78, 0x6d, 0xe8, 0x8b, + 0xf9, 0x78, 0xfa, 0xb3, 0x79, 0xb5, 0x30, 0x16, 0x86, 0xbc, 0x83, 0x4e, 0xe0, 0x49, 0xa5, 0x2c, + 0x9c, 0x26, 0xc3, 0x0b, 0x63, 0x22, 0x77, 0xd1, 0x67, 0xd0, 0xbf, 0x5a, 0x0c, 0x27, 0xe3, 0xf9, + 0x1b, 0x73, 0x7a, 0x69, 0xce, 0x0c, 0xfc, 0xcb, 0x58, 0x37, 0xcc, 0xd9, 0x2b, 0x43, 0x1f, 0x5f, + 0x8e, 0xf5, 0x61, 0xe2, 0x23, 0xef, 0x5e, 0x3c, 0xff, 0xf5, 0x5b, 0xdb, 0xe1, 0x6b, 0xb1, 0xd4, + 0x2c, 0xe6, 0x0d, 0xdc, 0x78, 0xc5, 0x07, 0xe5, 0x47, 0x65, 0x53, 0x7f, 0x10, 0x2c, 0x9f, 0xd9, + 0x6c, 0x70, 0xfb, 0x63, 0x5b, 0xee, 0xa5, 0x7f, 0xd6, 0xf3, 0xff, 0x02, 0x00, 0x00, 0xff, 0xff, + 0x62, 0xab, 0x32, 0x91, 0x2a, 0x07, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/admin/matchable_resource.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/admin/matchable_resource.pb.validate.go index 05193990085..bf8017d0133 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/matchable_resource.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/matchable_resource.pb.validate.go @@ -459,6 +459,18 @@ func (m *MatchingAttributes) Validate() error { } } + case *MatchingAttributes_QualityOfService: + + if v, ok := interface{}(m.GetQualityOfService()).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return MatchingAttributesValidationError{ + field: "QualityOfService", + reason: "embedded message failed validation", + cause: err, + } + } + } + } return nil diff --git a/flyteidl/gen/pb-go/flyteidl/core/execution.pb.go b/flyteidl/gen/pb-go/flyteidl/core/execution.pb.go index 11bc4b41eb5..521bbb12a15 100644 --- a/flyteidl/gen/pb-go/flyteidl/core/execution.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/core/execution.pb.go @@ -215,6 +215,38 @@ func (TaskLog_MessageFormat) EnumDescriptor() ([]byte, []int) { return fileDescriptor_1523842fd9084ee4, []int{4, 0} } +type QualityOfService_Tier int32 + +const ( + // Default: no quality of service specified. + QualityOfService_UNDEFINED QualityOfService_Tier = 0 + QualityOfService_HIGH QualityOfService_Tier = 1 + QualityOfService_MEDIUM QualityOfService_Tier = 2 + QualityOfService_LOW QualityOfService_Tier = 3 +) + +var QualityOfService_Tier_name = map[int32]string{ + 0: "UNDEFINED", + 1: "HIGH", + 2: "MEDIUM", + 3: "LOW", +} + +var QualityOfService_Tier_value = map[string]int32{ + "UNDEFINED": 0, + "HIGH": 1, + "MEDIUM": 2, + "LOW": 3, +} + +func (x QualityOfService_Tier) String() string { + return proto.EnumName(QualityOfService_Tier_name, int32(x)) +} + +func (QualityOfService_Tier) EnumDescriptor() ([]byte, []int) { + return fileDescriptor_1523842fd9084ee4, []int{6, 0} +} + // Indicates various phases of Workflow Execution type WorkflowExecution struct { XXX_NoUnkeyedLiteral struct{} `json:"-"` @@ -445,57 +477,190 @@ func (m *TaskLog) GetTtl() *duration.Duration { return nil } +// Represents customized execution run-time attributes. +type QualityOfServiceSpec struct { + // Indicates how much queueing delay an execution can tolerate. + QueueingBudget *duration.Duration `protobuf:"bytes,1,opt,name=queueing_budget,json=queueingBudget,proto3" json:"queueing_budget,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *QualityOfServiceSpec) Reset() { *m = QualityOfServiceSpec{} } +func (m *QualityOfServiceSpec) String() string { return proto.CompactTextString(m) } +func (*QualityOfServiceSpec) ProtoMessage() {} +func (*QualityOfServiceSpec) Descriptor() ([]byte, []int) { + return fileDescriptor_1523842fd9084ee4, []int{5} +} + +func (m *QualityOfServiceSpec) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_QualityOfServiceSpec.Unmarshal(m, b) +} +func (m *QualityOfServiceSpec) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_QualityOfServiceSpec.Marshal(b, m, deterministic) +} +func (m *QualityOfServiceSpec) XXX_Merge(src proto.Message) { + xxx_messageInfo_QualityOfServiceSpec.Merge(m, src) +} +func (m *QualityOfServiceSpec) XXX_Size() int { + return xxx_messageInfo_QualityOfServiceSpec.Size(m) +} +func (m *QualityOfServiceSpec) XXX_DiscardUnknown() { + xxx_messageInfo_QualityOfServiceSpec.DiscardUnknown(m) +} + +var xxx_messageInfo_QualityOfServiceSpec proto.InternalMessageInfo + +func (m *QualityOfServiceSpec) GetQueueingBudget() *duration.Duration { + if m != nil { + return m.QueueingBudget + } + return nil +} + +// Indicates the priority of an execution. +type QualityOfService struct { + // Types that are valid to be assigned to Designation: + // *QualityOfService_Tier_ + // *QualityOfService_Spec + Designation isQualityOfService_Designation `protobuf_oneof:"designation"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *QualityOfService) Reset() { *m = QualityOfService{} } +func (m *QualityOfService) String() string { return proto.CompactTextString(m) } +func (*QualityOfService) ProtoMessage() {} +func (*QualityOfService) Descriptor() ([]byte, []int) { + return fileDescriptor_1523842fd9084ee4, []int{6} +} + +func (m *QualityOfService) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_QualityOfService.Unmarshal(m, b) +} +func (m *QualityOfService) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_QualityOfService.Marshal(b, m, deterministic) +} +func (m *QualityOfService) XXX_Merge(src proto.Message) { + xxx_messageInfo_QualityOfService.Merge(m, src) +} +func (m *QualityOfService) XXX_Size() int { + return xxx_messageInfo_QualityOfService.Size(m) +} +func (m *QualityOfService) XXX_DiscardUnknown() { + xxx_messageInfo_QualityOfService.DiscardUnknown(m) +} + +var xxx_messageInfo_QualityOfService proto.InternalMessageInfo + +type isQualityOfService_Designation interface { + isQualityOfService_Designation() +} + +type QualityOfService_Tier_ struct { + Tier QualityOfService_Tier `protobuf:"varint,1,opt,name=tier,proto3,enum=flyteidl.core.QualityOfService_Tier,oneof"` +} + +type QualityOfService_Spec struct { + Spec *QualityOfServiceSpec `protobuf:"bytes,2,opt,name=spec,proto3,oneof"` +} + +func (*QualityOfService_Tier_) isQualityOfService_Designation() {} + +func (*QualityOfService_Spec) isQualityOfService_Designation() {} + +func (m *QualityOfService) GetDesignation() isQualityOfService_Designation { + if m != nil { + return m.Designation + } + return nil +} + +func (m *QualityOfService) GetTier() QualityOfService_Tier { + if x, ok := m.GetDesignation().(*QualityOfService_Tier_); ok { + return x.Tier + } + return QualityOfService_UNDEFINED +} + +func (m *QualityOfService) GetSpec() *QualityOfServiceSpec { + if x, ok := m.GetDesignation().(*QualityOfService_Spec); ok { + return x.Spec + } + return nil +} + +// XXX_OneofWrappers is for the internal use of the proto package. +func (*QualityOfService) XXX_OneofWrappers() []interface{} { + return []interface{}{ + (*QualityOfService_Tier_)(nil), + (*QualityOfService_Spec)(nil), + } +} + func init() { proto.RegisterEnum("flyteidl.core.WorkflowExecution_Phase", WorkflowExecution_Phase_name, WorkflowExecution_Phase_value) proto.RegisterEnum("flyteidl.core.NodeExecution_Phase", NodeExecution_Phase_name, NodeExecution_Phase_value) proto.RegisterEnum("flyteidl.core.TaskExecution_Phase", TaskExecution_Phase_name, TaskExecution_Phase_value) proto.RegisterEnum("flyteidl.core.ExecutionError_ErrorKind", ExecutionError_ErrorKind_name, ExecutionError_ErrorKind_value) proto.RegisterEnum("flyteidl.core.TaskLog_MessageFormat", TaskLog_MessageFormat_name, TaskLog_MessageFormat_value) + proto.RegisterEnum("flyteidl.core.QualityOfService_Tier", QualityOfService_Tier_name, QualityOfService_Tier_value) proto.RegisterType((*WorkflowExecution)(nil), "flyteidl.core.WorkflowExecution") proto.RegisterType((*NodeExecution)(nil), "flyteidl.core.NodeExecution") proto.RegisterType((*TaskExecution)(nil), "flyteidl.core.TaskExecution") proto.RegisterType((*ExecutionError)(nil), "flyteidl.core.ExecutionError") proto.RegisterType((*TaskLog)(nil), "flyteidl.core.TaskLog") + proto.RegisterType((*QualityOfServiceSpec)(nil), "flyteidl.core.QualityOfServiceSpec") + proto.RegisterType((*QualityOfService)(nil), "flyteidl.core.QualityOfService") } func init() { proto.RegisterFile("flyteidl/core/execution.proto", fileDescriptor_1523842fd9084ee4) } var fileDescriptor_1523842fd9084ee4 = []byte{ - // 563 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x93, 0xcd, 0x6e, 0xd3, 0x4c, - 0x14, 0x86, 0x3b, 0x89, 0x1b, 0x37, 0xa7, 0x9f, 0xa3, 0xf9, 0x46, 0x42, 0x4a, 0x41, 0xa0, 0xca, - 0x42, 0xa2, 0x12, 0xc2, 0x46, 0x61, 0xc9, 0x2a, 0x8d, 0x27, 0x95, 0x49, 0x3b, 0x2e, 0xfe, 0xa1, - 0xa2, 0x9b, 0xc8, 0x89, 0x27, 0xae, 0x55, 0x27, 0x53, 0x39, 0x8e, 0xa0, 0x3b, 0x24, 0xb8, 0x02, - 0x16, 0x48, 0xdc, 0x11, 0xd7, 0xc0, 0xd5, 0xa0, 0x99, 0xc6, 0x4d, 0x8c, 0xd8, 0x20, 0xb1, 0x89, - 0xe6, 0x9c, 0xf7, 0xfc, 0x3c, 0x6f, 0xe4, 0x03, 0x8f, 0x67, 0xf9, 0x6d, 0xc9, 0xb3, 0x24, 0xb7, - 0xa7, 0xa2, 0xe0, 0x36, 0xff, 0xc8, 0xa7, 0xab, 0x32, 0x13, 0x0b, 0xeb, 0xa6, 0x10, 0xa5, 0x20, - 0x46, 0x25, 0x5b, 0x52, 0x7e, 0xf8, 0x24, 0x15, 0x22, 0xcd, 0xb9, 0xad, 0xc4, 0xc9, 0x6a, 0x66, - 0x27, 0xab, 0x22, 0xde, 0x94, 0x9b, 0xdf, 0x11, 0xfc, 0x7f, 0x21, 0x8a, 0xeb, 0x59, 0x2e, 0x3e, - 0xd0, 0x6a, 0x94, 0xf9, 0x19, 0xc1, 0xee, 0xf9, 0x55, 0xbc, 0xe4, 0xc4, 0x80, 0x76, 0xc4, 0x1c, - 0x3a, 0x74, 0x19, 0x75, 0xf0, 0x0e, 0x01, 0x68, 0xbd, 0x8d, 0x68, 0x44, 0x1d, 0x8c, 0xc8, 0x3e, - 0xe8, 0x7e, 0xc4, 0x98, 0xcb, 0x4e, 0x70, 0x83, 0x74, 0x00, 0x82, 0x68, 0x30, 0xa0, 0xd4, 0x91, - 0x71, 0x53, 0xf6, 0xad, 0x63, 0xea, 0x60, 0x4d, 0xd6, 0x0e, 0xfb, 0xee, 0xa9, 0xd4, 0x76, 0xe5, - 0x10, 0x19, 0x50, 0x07, 0xb7, 0xa4, 0xd0, 0x3f, 0xf6, 0xfc, 0x90, 0x3a, 0x58, 0x97, 0x4d, 0xa1, - 0x7b, 0x46, 0x9d, 0xb1, 0x17, 0x85, 0x78, 0xcf, 0xfc, 0x8a, 0xc0, 0x60, 0x22, 0xe1, 0x1b, 0xae, - 0x4f, 0x7f, 0xcd, 0x55, 0xe3, 0x68, 0x6e, 0x73, 0x68, 0x5b, 0x1c, 0xbb, 0xdb, 0x1c, 0x0a, 0x2a, - 0x18, 0xb9, 0xe7, 0xe7, 0x7f, 0x82, 0xfa, 0x86, 0xc0, 0x08, 0xe3, 0xe5, 0xf5, 0x06, 0xea, 0xcb, - 0x3f, 0x80, 0xaa, 0x76, 0xd7, 0xa1, 0x30, 0xfc, 0xe7, 0x32, 0x37, 0x74, 0xfb, 0xa7, 0xee, 0xa5, - 0xec, 0x6c, 0x91, 0x03, 0x78, 0x70, 0xd1, 0x77, 0x43, 0x97, 0x9d, 0x8c, 0x87, 0x9e, 0x3f, 0xf6, - 0x69, 0xe0, 0x45, 0xfe, 0x80, 0x06, 0x58, 0x37, 0x7f, 0x20, 0xe8, 0xdc, 0x43, 0xd1, 0xa2, 0x10, - 0x05, 0x21, 0xa0, 0x4d, 0x45, 0xc2, 0xbb, 0xe8, 0x10, 0x1d, 0xb5, 0x7d, 0xf5, 0x26, 0x5d, 0xd0, - 0xe7, 0x7c, 0xb9, 0x8c, 0x53, 0xde, 0x6d, 0xa8, 0x74, 0x15, 0x92, 0x47, 0xd0, 0xe6, 0xb2, 0x6d, - 0xbc, 0x2a, 0xb2, 0x6e, 0x53, 0x69, 0x7b, 0x2a, 0x11, 0x15, 0x19, 0x79, 0x0d, 0xda, 0x75, 0xb6, - 0x48, 0xba, 0xda, 0x21, 0x3a, 0xea, 0xf4, 0x9e, 0x59, 0xb5, 0xaf, 0xcc, 0xaa, 0xef, 0xb5, 0xd4, - 0xef, 0x28, 0x5b, 0x24, 0xbe, 0x6a, 0x32, 0x2d, 0x68, 0xdf, 0xa7, 0xa4, 0xdb, 0x88, 0x8d, 0x98, - 0x77, 0xc1, 0xf0, 0x0e, 0xd9, 0x03, 0x2d, 0x0a, 0xa8, 0x8f, 0x91, 0xf4, 0x1d, 0xbc, 0x0f, 0x42, - 0x7a, 0x86, 0x1b, 0xe6, 0x4f, 0x04, 0xba, 0xfc, 0x8f, 0x4f, 0x45, 0x4a, 0x30, 0x34, 0x25, 0xcf, - 0x9d, 0x05, 0xf9, 0x94, 0xae, 0x16, 0xf1, 0xbc, 0xc2, 0x57, 0x6f, 0x32, 0x82, 0xce, 0xda, 0xc6, - 0x78, 0x26, 0x8a, 0x79, 0x5c, 0x2a, 0x03, 0x9d, 0xde, 0xd3, 0xdf, 0x40, 0xd7, 0x53, 0xad, 0xb3, - 0xbb, 0xe2, 0xa1, 0xaa, 0xf5, 0x8d, 0xf9, 0x76, 0x48, 0x9e, 0x43, 0xb3, 0x2c, 0x73, 0x65, 0x75, - 0xbf, 0x77, 0x60, 0xdd, 0x5d, 0x90, 0x55, 0x5d, 0x90, 0xe5, 0xac, 0x2f, 0xc8, 0x97, 0x55, 0xa6, - 0x0d, 0x46, 0x6d, 0x58, 0xdd, 0x9f, 0x0e, 0xcd, 0x41, 0xf0, 0x0e, 0x23, 0x69, 0xf4, 0x4d, 0xe0, - 0x31, 0xdc, 0x38, 0xee, 0x5d, 0xbe, 0x4c, 0xb3, 0xf2, 0x6a, 0x35, 0xb1, 0xa6, 0x62, 0x6e, 0xe7, - 0xb7, 0xb3, 0xd2, 0xbe, 0xbf, 0xe8, 0x94, 0x2f, 0xec, 0x9b, 0xc9, 0x8b, 0x54, 0xd8, 0xb5, 0x23, - 0x9f, 0xb4, 0xd4, 0xf2, 0x57, 0xbf, 0x02, 0x00, 0x00, 0xff, 0xff, 0xcb, 0xb8, 0xe5, 0x75, 0xfc, - 0x03, 0x00, 0x00, + // 695 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x94, 0xdf, 0x8e, 0xd2, 0x4e, + 0x14, 0xc7, 0xb7, 0xd0, 0xe5, 0xcf, 0xe1, 0x07, 0xbf, 0x71, 0xa2, 0x09, 0xab, 0xd1, 0x6c, 0xaa, + 0x89, 0x9b, 0x18, 0x5b, 0x83, 0xde, 0xa8, 0x57, 0x40, 0x87, 0xdd, 0x0a, 0xb4, 0xbb, 0xfd, 0x23, + 0x71, 0x6f, 0x08, 0xd0, 0xa1, 0xdb, 0x2c, 0x30, 0x58, 0x5a, 0x75, 0xef, 0x4c, 0xf4, 0x09, 0xbc, + 0x30, 0xf1, 0x8d, 0xbc, 0xf2, 0x01, 0x7c, 0x1a, 0x33, 0x03, 0xec, 0x52, 0x34, 0x1a, 0x13, 0x6f, + 0xc8, 0x9c, 0x39, 0xe7, 0x7b, 0xfa, 0xf9, 0x1e, 0x7a, 0x0a, 0xb7, 0xc7, 0x93, 0x8b, 0x98, 0x86, + 0xfe, 0x44, 0x1b, 0xb1, 0x88, 0x6a, 0xf4, 0x1d, 0x1d, 0x25, 0x71, 0xc8, 0x66, 0xea, 0x3c, 0x62, + 0x31, 0xc3, 0xe5, 0x75, 0x5a, 0xe5, 0xe9, 0x9b, 0x77, 0x02, 0xc6, 0x82, 0x09, 0xd5, 0x44, 0x72, + 0x98, 0x8c, 0x35, 0x3f, 0x89, 0x06, 0x57, 0xe5, 0xca, 0x17, 0x09, 0xae, 0xf5, 0x58, 0x74, 0x3e, + 0x9e, 0xb0, 0xb7, 0x64, 0xdd, 0x4a, 0xf9, 0x20, 0xc1, 0xee, 0xf1, 0xd9, 0x60, 0x41, 0x71, 0x19, + 0x8a, 0x9e, 0xa9, 0x93, 0x96, 0x61, 0x12, 0x1d, 0xed, 0x60, 0x80, 0xdc, 0x89, 0x47, 0x3c, 0xa2, + 0x23, 0x09, 0x97, 0x20, 0x6f, 0x7b, 0xa6, 0x69, 0x98, 0x87, 0x28, 0x83, 0x2b, 0x00, 0x8e, 0xd7, + 0x6c, 0x12, 0xa2, 0xf3, 0x38, 0xcb, 0x75, 0xab, 0x98, 0xe8, 0x48, 0xe6, 0xb5, 0xad, 0xba, 0xd1, + 0xe1, 0xb9, 0x5d, 0xde, 0x84, 0x07, 0x44, 0x47, 0x39, 0x9e, 0xa8, 0x37, 0x2c, 0xdb, 0x25, 0x3a, + 0xca, 0x73, 0x91, 0x6b, 0x74, 0x89, 0xde, 0xb7, 0x3c, 0x17, 0x15, 0x94, 0x4f, 0x12, 0x94, 0x4d, + 0xe6, 0xd3, 0x2b, 0xae, 0xf7, 0x7f, 0xcd, 0x95, 0xe2, 0xc8, 0x6e, 0x72, 0xc8, 0x1b, 0x1c, 0xbb, + 0x9b, 0x1c, 0x02, 0xca, 0x69, 0x1b, 0xc7, 0xc7, 0xbf, 0x82, 0xfa, 0x2c, 0x41, 0xd9, 0x1d, 0x2c, + 0xce, 0xaf, 0xa0, 0x3e, 0xfe, 0x03, 0xa8, 0xf5, 0xb3, 0xd3, 0x50, 0x08, 0xfe, 0x33, 0x4c, 0xc3, + 0x35, 0xea, 0x1d, 0xe3, 0x94, 0x2b, 0x73, 0x78, 0x0f, 0x6e, 0xf4, 0xea, 0x86, 0x6b, 0x98, 0x87, + 0xfd, 0x96, 0x65, 0xf7, 0x6d, 0xe2, 0x58, 0x9e, 0xdd, 0x24, 0x0e, 0xca, 0x2b, 0x5f, 0x25, 0xa8, + 0x5c, 0x42, 0x91, 0x28, 0x62, 0x11, 0xc6, 0x20, 0x8f, 0x98, 0x4f, 0xab, 0xd2, 0xbe, 0x74, 0x50, + 0xb4, 0xc5, 0x19, 0x57, 0x21, 0x3f, 0xa5, 0x8b, 0xc5, 0x20, 0xa0, 0xd5, 0x8c, 0xb8, 0x5e, 0x87, + 0xf8, 0x16, 0x14, 0x29, 0x97, 0xf5, 0x93, 0x28, 0xac, 0x66, 0x45, 0xae, 0x20, 0x2e, 0xbc, 0x28, + 0xc4, 0xcf, 0x41, 0x3e, 0x0f, 0x67, 0x7e, 0x55, 0xde, 0x97, 0x0e, 0x2a, 0xb5, 0xfb, 0x6a, 0xea, + 0x2d, 0x53, 0xd3, 0xcf, 0x55, 0xc5, 0x6f, 0x3b, 0x9c, 0xf9, 0xb6, 0x10, 0x29, 0x2a, 0x14, 0x2f, + 0xaf, 0xb8, 0x5b, 0xcf, 0x6c, 0x9b, 0x56, 0xcf, 0x44, 0x3b, 0xb8, 0x00, 0xb2, 0xe7, 0x10, 0x1b, + 0x49, 0xdc, 0xb7, 0xf3, 0xca, 0x71, 0x49, 0x17, 0x65, 0x94, 0xef, 0x12, 0xe4, 0xf9, 0x8c, 0x3b, + 0x2c, 0xc0, 0x08, 0xb2, 0x9c, 0x67, 0x69, 0x81, 0x1f, 0xb9, 0xab, 0xd9, 0x60, 0xba, 0xc6, 0x17, + 0x67, 0xdc, 0x86, 0xca, 0xca, 0x46, 0x7f, 0xcc, 0xa2, 0xe9, 0x20, 0x16, 0x06, 0x2a, 0xb5, 0x7b, + 0x5b, 0xa0, 0xab, 0xae, 0x6a, 0x77, 0x59, 0xdc, 0x12, 0xb5, 0x76, 0x79, 0xba, 0x19, 0xe2, 0x07, + 0x90, 0x8d, 0xe3, 0x89, 0xb0, 0x5a, 0xaa, 0xed, 0xa9, 0xcb, 0x0d, 0x52, 0xd7, 0x1b, 0xa4, 0xea, + 0xab, 0x0d, 0xb2, 0x79, 0x95, 0xa2, 0x41, 0x39, 0xd5, 0x2c, 0xed, 0x2f, 0x0f, 0xd9, 0xa6, 0xf3, + 0x12, 0x49, 0xdc, 0xe8, 0x0b, 0xc7, 0x32, 0x51, 0x46, 0x39, 0x85, 0xeb, 0x27, 0xc9, 0x60, 0x12, + 0xc6, 0x17, 0xd6, 0xd8, 0xa1, 0xd1, 0x9b, 0x70, 0x44, 0x9d, 0x39, 0x1d, 0xe1, 0x06, 0xfc, 0xff, + 0x3a, 0xa1, 0x09, 0x0d, 0x67, 0x41, 0x7f, 0x98, 0xf8, 0x01, 0x8d, 0x85, 0xe9, 0xdf, 0x12, 0x54, + 0xd6, 0x8a, 0x86, 0x10, 0x28, 0xdf, 0x24, 0x40, 0xdb, 0xcd, 0xf1, 0x33, 0x90, 0xe3, 0x90, 0x46, + 0xa2, 0xdb, 0xcf, 0x13, 0xd9, 0x2e, 0x57, 0xdd, 0x90, 0x46, 0x47, 0x3b, 0xb6, 0xd0, 0xe0, 0xa7, + 0x20, 0x2f, 0xe6, 0x74, 0x24, 0x66, 0x5d, 0xaa, 0xdd, 0xfd, 0x83, 0x96, 0xfb, 0xe0, 0x52, 0x2e, + 0x51, 0x9e, 0x80, 0xcc, 0x5b, 0x6d, 0x2f, 0x45, 0x01, 0xe4, 0x23, 0xe3, 0xf0, 0x68, 0xf9, 0x8f, + 0x77, 0x89, 0x6e, 0x78, 0x5d, 0x94, 0xe1, 0x73, 0xea, 0x58, 0x3d, 0x94, 0x6d, 0x94, 0xa1, 0xe4, + 0xd3, 0x45, 0x18, 0xcc, 0x84, 0xc1, 0x46, 0xed, 0xf4, 0x51, 0x10, 0xc6, 0x67, 0xc9, 0x50, 0x1d, + 0xb1, 0xa9, 0x36, 0xb9, 0x18, 0xc7, 0xda, 0xe5, 0xe7, 0x2f, 0xa0, 0x33, 0x6d, 0x3e, 0x7c, 0x18, + 0x30, 0x2d, 0xf5, 0x45, 0x1c, 0xe6, 0xc4, 0x9c, 0x1e, 0xff, 0x08, 0x00, 0x00, 0xff, 0xff, 0x3f, + 0x90, 0x47, 0xe7, 0x29, 0x05, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/core/execution.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/core/execution.pb.validate.go index 6b1b3e5bb3a..202cbc6db6a 100644 --- a/flyteidl/gen/pb-go/flyteidl/core/execution.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/core/execution.pb.validate.go @@ -385,3 +385,164 @@ var _ interface { Cause() error ErrorName() string } = TaskLogValidationError{} + +// Validate checks the field values on QualityOfServiceSpec with the rules +// defined in the proto definition for this message. If any rules are +// violated, an error is returned. +func (m *QualityOfServiceSpec) Validate() error { + if m == nil { + return nil + } + + if v, ok := interface{}(m.GetQueueingBudget()).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return QualityOfServiceSpecValidationError{ + field: "QueueingBudget", + reason: "embedded message failed validation", + cause: err, + } + } + } + + return nil +} + +// QualityOfServiceSpecValidationError is the validation error returned by +// QualityOfServiceSpec.Validate if the designated constraints aren't met. +type QualityOfServiceSpecValidationError struct { + field string + reason string + cause error + key bool +} + +// Field function returns field value. +func (e QualityOfServiceSpecValidationError) Field() string { return e.field } + +// Reason function returns reason value. +func (e QualityOfServiceSpecValidationError) Reason() string { return e.reason } + +// Cause function returns cause value. +func (e QualityOfServiceSpecValidationError) Cause() error { return e.cause } + +// Key function returns key value. +func (e QualityOfServiceSpecValidationError) Key() bool { return e.key } + +// ErrorName returns error name. +func (e QualityOfServiceSpecValidationError) ErrorName() string { + return "QualityOfServiceSpecValidationError" +} + +// Error satisfies the builtin error interface +func (e QualityOfServiceSpecValidationError) 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 %sQualityOfServiceSpec.%s: %s%s", + key, + e.field, + e.reason, + cause) +} + +var _ error = QualityOfServiceSpecValidationError{} + +var _ interface { + Field() string + Reason() string + Key() bool + Cause() error + ErrorName() string +} = QualityOfServiceSpecValidationError{} + +// Validate checks the field values on QualityOfService with the rules defined +// in the proto definition for this message. If any rules are violated, an +// error is returned. +func (m *QualityOfService) Validate() error { + if m == nil { + return nil + } + + switch m.Designation.(type) { + + case *QualityOfService_Tier_: + // no validation rules for Tier + + case *QualityOfService_Spec: + + if v, ok := interface{}(m.GetSpec()).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return QualityOfServiceValidationError{ + field: "Spec", + reason: "embedded message failed validation", + cause: err, + } + } + } + + } + + return nil +} + +// QualityOfServiceValidationError is the validation error returned by +// QualityOfService.Validate if the designated constraints aren't met. +type QualityOfServiceValidationError struct { + field string + reason string + cause error + key bool +} + +// Field function returns field value. +func (e QualityOfServiceValidationError) Field() string { return e.field } + +// Reason function returns reason value. +func (e QualityOfServiceValidationError) Reason() string { return e.reason } + +// Cause function returns cause value. +func (e QualityOfServiceValidationError) Cause() error { return e.cause } + +// Key function returns key value. +func (e QualityOfServiceValidationError) Key() bool { return e.key } + +// ErrorName returns error name. +func (e QualityOfServiceValidationError) ErrorName() string { return "QualityOfServiceValidationError" } + +// Error satisfies the builtin error interface +func (e QualityOfServiceValidationError) 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 %sQualityOfService.%s: %s%s", + key, + e.field, + e.reason, + cause) +} + +var _ error = QualityOfServiceValidationError{} + +var _ interface { + Field() string + Reason() string + Key() bool + Cause() error + ErrorName() string +} = QualityOfServiceValidationError{} diff --git a/flyteidl/gen/pb-go/flyteidl/core/workflow.pb.go b/flyteidl/gen/pb-go/flyteidl/core/workflow.pb.go index eb0625b678d..362ebe173a2 100644 --- a/flyteidl/gen/pb-go/flyteidl/core/workflow.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/core/workflow.pb.go @@ -690,8 +690,8 @@ func (*Node) XXX_OneofWrappers() []interface{} { // Metadata for the entire workflow. Defines execution behavior that does not change the final outputs of the workflow. type WorkflowMetadata struct { - // Total wait time a workflow can be delayed by queueing. - QueuingBudget *duration.Duration `protobuf:"bytes,1,opt,name=queuing_budget,json=queuingBudget,proto3" json:"queuing_budget,omitempty"` + // Indicates the runtime priority of workflow executions. + QualityOfService *QualityOfService `protobuf:"bytes,1,opt,name=quality_of_service,json=qualityOfService,proto3" json:"quality_of_service,omitempty"` // Defines how the system should behave when a failure is detected in the workflow execution. OnFailure WorkflowMetadata_OnFailurePolicy `protobuf:"varint,2,opt,name=on_failure,json=onFailure,proto3,enum=flyteidl.core.WorkflowMetadata_OnFailurePolicy" json:"on_failure,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` @@ -724,9 +724,9 @@ func (m *WorkflowMetadata) XXX_DiscardUnknown() { var xxx_messageInfo_WorkflowMetadata proto.InternalMessageInfo -func (m *WorkflowMetadata) GetQueuingBudget() *duration.Duration { +func (m *WorkflowMetadata) GetQualityOfService() *QualityOfService { if m != nil { - return m.QueuingBudget + return m.QualityOfService } return nil } @@ -903,70 +903,71 @@ func init() { func init() { proto.RegisterFile("flyteidl/core/workflow.proto", fileDescriptor_fccede37486c456e) } var fileDescriptor_fccede37486c456e = []byte{ - // 1036 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x56, 0x5f, 0x6f, 0xdb, 0xb6, - 0x17, 0xb5, 0xe3, 0xc4, 0xb6, 0xae, 0x63, 0xd7, 0x65, 0xf3, 0xfb, 0xcd, 0xc9, 0xda, 0x2e, 0x30, - 0x8a, 0x2d, 0x2d, 0x36, 0x3b, 0x48, 0x81, 0xec, 0x21, 0x43, 0x51, 0xab, 0x51, 0x10, 0x03, 0xf9, - 0xd3, 0xb1, 0x1e, 0xba, 0xed, 0x45, 0xa0, 0xad, 0x2b, 0x87, 0x88, 0x2c, 0x6a, 0x14, 0xd5, 0xcc, - 0xd8, 0xb7, 0xd9, 0xc3, 0x9e, 0xf6, 0x59, 0xf6, 0xb4, 0xef, 0xb2, 0xd7, 0x41, 0xd4, 0x1f, 0xc7, - 0xaa, 0xd3, 0xec, 0x8d, 0xe4, 0x3d, 0xf7, 0xf2, 0xf2, 0xf0, 0x1c, 0x51, 0xf0, 0xd8, 0xf5, 0xe6, - 0x0a, 0xb9, 0xe3, 0xf5, 0x27, 0x42, 0x62, 0xff, 0x46, 0xc8, 0x6b, 0xd7, 0x13, 0x37, 0xbd, 0x40, - 0x0a, 0x25, 0x48, 0x33, 0x8b, 0xf6, 0xe2, 0xe8, 0xce, 0x93, 0x65, 0xf0, 0x44, 0xf8, 0x0e, 0x57, - 0x5c, 0xf8, 0x09, 0x7a, 0xe7, 0xe9, 0x72, 0x98, 0x3b, 0xe8, 0x2b, 0xee, 0x72, 0x94, 0x69, 0xbc, - 0x90, 0xce, 0x7d, 0x85, 0xd2, 0x65, 0x13, 0x4c, 0xc3, 0x85, 0x56, 0x3c, 0xae, 0x50, 0x32, 0x2f, - 0x4c, 0xa3, 0xdb, 0xcb, 0x51, 0x35, 0x0f, 0x30, 0x0b, 0x3d, 0x9d, 0x0a, 0x31, 0xf5, 0xb0, 0xaf, - 0x67, 0xe3, 0xc8, 0xed, 0x3b, 0x91, 0x64, 0x8b, 0xbe, 0xba, 0xbf, 0x41, 0x6d, 0xe8, 0x9a, 0x9e, - 0x98, 0x5c, 0x93, 0x57, 0x60, 0xe4, 0x5d, 0x77, 0xca, 0xbb, 0xe5, 0xbd, 0xc6, 0xc1, 0x6e, 0x6f, - 0xe9, 0x90, 0x3d, 0x53, 0x08, 0x0f, 0x99, 0x6f, 0xfd, 0x1a, 0x48, 0x0c, 0x43, 0x2e, 0x7c, 0xba, - 0x48, 0x21, 0xfb, 0x60, 0xa8, 0x2b, 0xf4, 0x6d, 0x5f, 0x38, 0xd8, 0x59, 0xd3, 0xf9, 0x8f, 0x0a, - 0xf9, 0x17, 0xc2, 0x41, 0x5a, 0x8f, 0x51, 0xf1, 0xa8, 0xfb, 0x77, 0x19, 0x1a, 0x43, 0xd7, 0xf2, - 0x42, 0x4c, 0x3a, 0x78, 0x01, 0xeb, 0x13, 0x16, 0x62, 0xba, 0xf9, 0xff, 0x0b, 0xc9, 0x69, 0x9f, - 0x54, 0x63, 0xc8, 0xd7, 0xb0, 0x21, 0xd4, 0x15, 0xca, 0xce, 0xda, 0x6e, 0xe5, 0x13, 0xe0, 0x04, - 0x44, 0x0e, 0xc0, 0x40, 0x2f, 0xc4, 0xa4, 0xb7, 0xca, 0x9d, 0xbd, 0x9d, 0x96, 0x68, 0x3d, 0xc6, - 0xc5, 0xe3, 0x78, 0x07, 0x94, 0x52, 0xc8, 0xce, 0xba, 0xc6, 0x6f, 0x15, 0xf0, 0x56, 0x1c, 0x3b, - 0x2d, 0xd1, 0x04, 0x64, 0x1a, 0x50, 0x73, 0xd0, 0x65, 0x91, 0xa7, 0xba, 0x03, 0x00, 0x53, 0x32, - 0x7f, 0x72, 0xa5, 0xcb, 0xbc, 0x84, 0x1a, 0x77, 0xed, 0xb8, 0x6a, 0x7a, 0xae, 0x9d, 0x8f, 0x5a, - 0xcd, 0x19, 0xa0, 0x55, 0xae, 0x27, 0xdd, 0xf7, 0x50, 0x1f, 0xb1, 0xf0, 0x5a, 0x17, 0x78, 0x05, - 0x9b, 0x12, 0x5d, 0x94, 0xe8, 0x4f, 0xd0, 0xe6, 0x4e, 0x5a, 0x65, 0xbb, 0x58, 0x25, 0x57, 0xd4, - 0x69, 0x89, 0x36, 0xf2, 0x84, 0xa1, 0x63, 0x36, 0xc0, 0xc8, 0xa7, 0xdd, 0x3f, 0xca, 0xb0, 0xf9, - 0x3e, 0x15, 0xb2, 0xae, 0x6e, 0x42, 0xcb, 0x63, 0x91, 0x3f, 0xb9, 0x0a, 0x3c, 0xe6, 0xdb, 0x12, - 0xdd, 0xff, 0x52, 0xbf, 0xb9, 0x48, 0xa1, 0xe8, 0x12, 0x0b, 0xda, 0x61, 0x34, 0xb6, 0x33, 0x83, - 0xe8, 0x2a, 0x6b, 0xf7, 0x57, 0x69, 0x85, 0xd1, 0x38, 0xeb, 0x85, 0xa2, 0xbb, 0xdc, 0xe8, 0x5f, - 0x65, 0xd8, 0x8c, 0x1b, 0x3c, 0x47, 0xc5, 0x1c, 0xa6, 0x18, 0x21, 0xb0, 0xee, 0xb3, 0x59, 0x42, - 0xa2, 0x41, 0xf5, 0x38, 0xe6, 0x56, 0xf1, 0x19, 0x8a, 0x48, 0xa5, 0x97, 0xb4, 0xdd, 0x4b, 0xf4, - 0xde, 0xcb, 0xf4, 0xde, 0x3b, 0x4e, 0xf5, 0x4e, 0x33, 0x24, 0x39, 0x84, 0x9a, 0x44, 0x25, 0x39, - 0x86, 0x9d, 0x0d, 0x9d, 0xf4, 0xb8, 0xd0, 0x24, 0x45, 0x25, 0xe7, 0xef, 0x94, 0x64, 0x0a, 0xa7, - 0x73, 0x9a, 0x81, 0xc9, 0x97, 0xd0, 0xd4, 0xb6, 0x94, 0x51, 0xa0, 0xf8, 0xd8, 0xc3, 0x4e, 0x75, - 0xb7, 0xbc, 0x57, 0x8f, 0xd9, 0x58, 0x5a, 0x36, 0xff, 0x07, 0x8f, 0x96, 0x16, 0xec, 0x0f, 0xcc, - 0x8b, 0xb0, 0xdb, 0x87, 0x8d, 0x81, 0xc7, 0x59, 0x48, 0xda, 0x50, 0xf9, 0xc0, 0x64, 0x7a, 0x8e, - 0x78, 0x48, 0xb6, 0x60, 0x83, 0xc5, 0x21, 0x4d, 0x9a, 0x41, 0x93, 0x49, 0xf7, 0xcf, 0x0a, 0xac, - 0xeb, 0x2b, 0x6a, 0xc1, 0x5a, 0x7a, 0xed, 0x06, 0x5d, 0xe3, 0x0e, 0xf9, 0x16, 0xea, 0xb3, 0x94, - 0x95, 0x94, 0xe6, 0xcf, 0x57, 0x68, 0x39, 0x23, 0x8e, 0xe6, 0x60, 0xd2, 0x83, 0x2a, 0xf7, 0x83, - 0x48, 0x85, 0x9d, 0xca, 0x4a, 0xd3, 0x98, 0xdc, 0x77, 0xb8, 0x3f, 0xa5, 0x29, 0x8a, 0xbc, 0x80, - 0x87, 0x51, 0x10, 0x2a, 0x89, 0x6c, 0xa6, 0x9d, 0x63, 0x73, 0x27, 0xec, 0xac, 0xef, 0x56, 0xf6, - 0x0c, 0xfa, 0x20, 0x0b, 0xc4, 0x5b, 0x0d, 0x9d, 0x90, 0x1c, 0x41, 0x4b, 0x44, 0x2a, 0x88, 0x94, - 0xad, 0xbb, 0xd7, 0xe4, 0x56, 0x56, 0xd8, 0x46, 0x73, 0x40, 0x9b, 0x09, 0x76, 0x90, 0x40, 0xc9, - 0x21, 0x18, 0x8a, 0x85, 0xd7, 0x89, 0x3d, 0xab, 0xfa, 0x48, 0x9f, 0x15, 0xf2, 0x32, 0x3b, 0xc4, - 0x16, 0x55, 0x99, 0x35, 0x4c, 0x68, 0xe6, 0xa2, 0xd3, 0xb9, 0xb5, 0x95, 0x74, 0xdc, 0x16, 0xfc, - 0x69, 0x89, 0x6e, 0xde, 0xdc, 0x36, 0xc0, 0x77, 0xd0, 0x18, 0x6b, 0xb7, 0x26, 0x15, 0xea, 0x2b, - 0x75, 0xbb, 0xf0, 0xf3, 0x69, 0x89, 0xc2, 0x38, 0x9f, 0x99, 0x75, 0xa8, 0x2a, 0x26, 0xa7, 0xa8, - 0xba, 0xff, 0x94, 0xa1, 0x9d, 0x6d, 0x94, 0x8b, 0xf6, 0x35, 0xb4, 0x7e, 0x89, 0x30, 0xe2, 0xfe, - 0xd4, 0x1e, 0x47, 0xce, 0x14, 0x55, 0xee, 0xae, 0x3b, 0x75, 0xda, 0x4c, 0x13, 0x4c, 0x8d, 0x27, - 0x17, 0x00, 0xc2, 0xb7, 0x5d, 0xc6, 0xbd, 0x48, 0x26, 0x9f, 0xd5, 0xd6, 0x41, 0xff, 0x8e, 0xf3, - 0x65, 0xdb, 0xf6, 0x2e, 0xfd, 0x93, 0x24, 0xe1, 0xad, 0xf0, 0xf8, 0x64, 0x4e, 0x0d, 0x91, 0x2d, - 0x74, 0xbf, 0x87, 0x07, 0x85, 0x28, 0xd9, 0x82, 0xf6, 0xc9, 0x60, 0x78, 0x66, 0x0f, 0xcf, 0xcf, - 0xad, 0xe3, 0xe1, 0x60, 0x64, 0x9d, 0xfd, 0xd4, 0x2e, 0x91, 0x3d, 0x78, 0xa6, 0x57, 0x07, 0x27, - 0x23, 0x8b, 0xda, 0xd6, 0x8f, 0xd6, 0x9b, 0x1f, 0x46, 0x03, 0xf3, 0xcc, 0xb2, 0x2f, 0x2e, 0x8f, - 0xad, 0x77, 0xf6, 0x9b, 0xcb, 0xf3, 0xb7, 0x67, 0xd6, 0xc8, 0x6a, 0x97, 0xbb, 0xaf, 0xa1, 0x53, - 0xec, 0xe0, 0x38, 0xf9, 0x14, 0x86, 0xe4, 0x59, 0xd1, 0x34, 0xf1, 0xf9, 0xeb, 0x05, 0xcb, 0x74, - 0x7f, 0xaf, 0x2c, 0xb8, 0x1b, 0xe1, 0x2c, 0xf0, 0x98, 0x42, 0xf2, 0x3c, 0x97, 0xfd, 0xa7, 0xbe, - 0x23, 0xda, 0x11, 0x47, 0x1f, 0x39, 0xe2, 0x8b, 0x7b, 0x28, 0xba, 0xe5, 0x8a, 0x23, 0x30, 0xf2, - 0xe7, 0x36, 0x7d, 0x1b, 0x9e, 0x14, 0xc5, 0x37, 0x0f, 0xd0, 0x19, 0x66, 0x20, 0xba, 0xc0, 0x93, - 0xe7, 0xb0, 0x11, 0xcb, 0x26, 0xb1, 0xc5, 0x1d, 0x0f, 0x5e, 0x82, 0x20, 0xfb, 0x50, 0x4b, 0x54, - 0x9f, 0x59, 0xe3, 0x2e, 0xfb, 0x65, 0x30, 0x72, 0x08, 0x9b, 0xe9, 0xc5, 0xdf, 0x76, 0xc6, 0xca, - 0x3d, 0x1a, 0x29, 0x50, 0x4b, 0x7a, 0x04, 0x0f, 0xb3, 0xd3, 0xd9, 0xe9, 0xa3, 0x14, 0xa6, 0xd6, - 0xf8, 0xea, 0x1e, 0x5e, 0xb2, 0x8b, 0xa3, 0xed, 0x59, 0x61, 0xc5, 0x3c, 0xf8, 0x79, 0x7f, 0xca, - 0xd5, 0x55, 0x34, 0xee, 0x4d, 0xc4, 0xac, 0xef, 0xcd, 0x5d, 0xd5, 0xcf, 0xff, 0x3b, 0xa6, 0xe8, - 0xf7, 0x83, 0xf1, 0x37, 0x53, 0xd1, 0x5f, 0xfa, 0x15, 0x19, 0x57, 0xb5, 0xbe, 0x5f, 0xfe, 0x1b, - 0x00, 0x00, 0xff, 0xff, 0xb3, 0xab, 0x53, 0xa5, 0x4b, 0x09, 0x00, 0x00, + // 1050 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x56, 0x5b, 0x6f, 0xdb, 0x36, + 0x14, 0xf6, 0x25, 0xb1, 0xad, 0xe3, 0x24, 0x75, 0xd9, 0x6e, 0x73, 0xba, 0x5e, 0x02, 0xa3, 0xd8, + 0xd2, 0x62, 0xb3, 0x83, 0x14, 0xc8, 0x1e, 0x32, 0x14, 0xb3, 0x1a, 0x05, 0x31, 0x90, 0x4b, 0xcb, + 0x78, 0xe8, 0xb6, 0x17, 0x81, 0x96, 0x8e, 0x1c, 0x22, 0xb2, 0xe8, 0x52, 0x54, 0x52, 0x63, 0xaf, + 0xfb, 0x25, 0x7b, 0xd8, 0xd3, 0x7e, 0xcb, 0x9e, 0xf6, 0x83, 0x06, 0x51, 0x17, 0xc7, 0xaa, 0xd3, + 0xec, 0x4d, 0xe4, 0xf9, 0xce, 0xe1, 0xc7, 0x8f, 0xe7, 0x23, 0x05, 0x8f, 0x3d, 0x7f, 0xa6, 0x90, + 0xbb, 0x7e, 0xcf, 0x11, 0x12, 0x7b, 0xd7, 0x42, 0x5e, 0x7a, 0xbe, 0xb8, 0xee, 0x4e, 0xa5, 0x50, + 0x82, 0xac, 0x67, 0xd1, 0x6e, 0x1c, 0x7d, 0xf4, 0x64, 0x11, 0xec, 0x88, 0xc0, 0xe5, 0x8a, 0x8b, + 0x20, 0x41, 0x17, 0xc3, 0xf8, 0x11, 0x9d, 0xe8, 0x46, 0xf8, 0xe9, 0x62, 0x98, 0xbb, 0x18, 0x28, + 0xee, 0x71, 0x94, 0xcb, 0xd3, 0x79, 0xa0, 0x50, 0x7a, 0xcc, 0xc1, 0x34, 0x5c, 0x60, 0xea, 0x73, + 0x85, 0x92, 0xf9, 0x61, 0x1a, 0xdd, 0x5c, 0x8c, 0xaa, 0xd9, 0x14, 0xb3, 0xd0, 0xd3, 0xb1, 0x10, + 0x63, 0x1f, 0x7b, 0x7a, 0x34, 0x8a, 0xbc, 0x9e, 0x1b, 0x49, 0x36, 0xe7, 0xd5, 0xf9, 0x1d, 0xea, + 0x03, 0xcf, 0xf4, 0x85, 0x73, 0x49, 0x5e, 0x83, 0x91, 0x6f, 0xaa, 0x5d, 0xde, 0x2a, 0x6f, 0x37, + 0x77, 0xb7, 0xba, 0x0b, 0x1a, 0x74, 0x4d, 0x21, 0x7c, 0x64, 0x81, 0xf5, 0x71, 0x2a, 0x31, 0x0c, + 0xb9, 0x08, 0xe8, 0x3c, 0x85, 0xec, 0x80, 0xa1, 0x2e, 0x30, 0xb0, 0x03, 0xe1, 0x62, 0xbb, 0xa2, + 0xf3, 0x1f, 0x14, 0xf2, 0x4f, 0x85, 0x8b, 0xb4, 0x11, 0xa3, 0xe2, 0xaf, 0xce, 0xbf, 0x65, 0x68, + 0x0e, 0x3c, 0xcb, 0x0f, 0x31, 0x61, 0xf0, 0x12, 0x56, 0x1c, 0x16, 0x62, 0xba, 0xf8, 0x97, 0x85, + 0xe4, 0x94, 0x27, 0xd5, 0x18, 0xf2, 0x1d, 0xac, 0x0a, 0x75, 0x81, 0xb2, 0x5d, 0xd9, 0xaa, 0x7e, + 0x06, 0x9c, 0x80, 0xc8, 0x2e, 0x18, 0xe8, 0x87, 0x98, 0x70, 0xab, 0xde, 0xca, 0xed, 0xa8, 0x44, + 0x1b, 0x31, 0x2e, 0xfe, 0x8e, 0x57, 0x40, 0x29, 0x85, 0x6c, 0xaf, 0x68, 0xfc, 0xc3, 0x02, 0xde, + 0x8a, 0x63, 0x47, 0x25, 0x9a, 0x80, 0x4c, 0x03, 0xea, 0x2e, 0x7a, 0x2c, 0xf2, 0x55, 0xa7, 0x0f, + 0x60, 0x4a, 0x16, 0x38, 0x17, 0xba, 0xcc, 0x2b, 0xa8, 0x73, 0xcf, 0x8e, 0xab, 0xa6, 0xfb, 0x7a, + 0xf4, 0x09, 0xd5, 0x5c, 0x01, 0x5a, 0xe3, 0x7a, 0xd0, 0x79, 0x0f, 0x8d, 0x21, 0x0b, 0x2f, 0x75, + 0x81, 0xd7, 0xb0, 0x26, 0xd1, 0x43, 0x89, 0x81, 0x83, 0x36, 0x77, 0xd3, 0x2a, 0x9b, 0xc5, 0x2a, + 0x79, 0x47, 0x1d, 0x95, 0x68, 0x33, 0x4f, 0x18, 0xb8, 0x66, 0x13, 0x8c, 0x7c, 0xd8, 0xf9, 0xab, + 0x0c, 0x6b, 0xef, 0xd3, 0x3e, 0xd7, 0xd5, 0x4d, 0xd8, 0xf0, 0x59, 0x14, 0x38, 0x17, 0x53, 0x9f, + 0x05, 0xb6, 0x44, 0xef, 0xff, 0xd4, 0x5f, 0x9f, 0xa7, 0x50, 0xf4, 0x88, 0x05, 0xad, 0x30, 0x1a, + 0xd9, 0x99, 0x7f, 0x74, 0x95, 0xca, 0xdd, 0x55, 0x36, 0xc2, 0x68, 0x94, 0x71, 0xa1, 0xe8, 0x2d, + 0x12, 0xfd, 0xa7, 0x0c, 0x6b, 0x31, 0xc1, 0x13, 0x54, 0xcc, 0x65, 0x8a, 0x11, 0x02, 0x2b, 0x01, + 0x9b, 0x24, 0x22, 0x1a, 0x54, 0x7f, 0xc7, 0xda, 0x2a, 0x3e, 0x41, 0x11, 0xa9, 0xf4, 0x90, 0x36, + 0xbb, 0x49, 0xbf, 0x77, 0xb3, 0x7e, 0xef, 0x1e, 0xa4, 0xfd, 0x4e, 0x33, 0x24, 0xd9, 0x83, 0xba, + 0x44, 0x25, 0x39, 0x86, 0xed, 0x55, 0x9d, 0xf4, 0xb8, 0x40, 0x92, 0xa2, 0x92, 0xb3, 0x73, 0x25, + 0x99, 0xc2, 0xf1, 0x8c, 0x66, 0x60, 0xf2, 0x0d, 0xac, 0x6b, 0x5b, 0xca, 0x68, 0xaa, 0xf8, 0xc8, + 0xc7, 0x76, 0x6d, 0xab, 0xbc, 0xdd, 0x88, 0xd5, 0x58, 0x98, 0x36, 0xbf, 0x80, 0x07, 0x0b, 0x13, + 0xf6, 0x15, 0xf3, 0x23, 0xec, 0xf4, 0x60, 0xb5, 0xef, 0x73, 0x16, 0x92, 0x16, 0x54, 0xaf, 0x98, + 0x4c, 0xf7, 0x11, 0x7f, 0x92, 0x87, 0xb0, 0xca, 0xe2, 0x90, 0x16, 0xcd, 0xa0, 0xc9, 0xa0, 0xf3, + 0x77, 0x15, 0x56, 0xf4, 0x11, 0x6d, 0x40, 0x25, 0x3d, 0x76, 0x83, 0x56, 0xb8, 0x4b, 0x7e, 0x80, + 0xc6, 0x24, 0x55, 0x25, 0x95, 0xf9, 0xeb, 0x25, 0xbd, 0x9c, 0x09, 0x47, 0x73, 0x30, 0xe9, 0x42, + 0x8d, 0x07, 0xd3, 0x48, 0x85, 0xed, 0xea, 0x52, 0xd3, 0x98, 0x3c, 0x70, 0x79, 0x30, 0xa6, 0x29, + 0x8a, 0xbc, 0x84, 0xfb, 0xd1, 0x34, 0x54, 0x12, 0xd9, 0x44, 0x3b, 0xc7, 0xe6, 0x6e, 0xd8, 0x5e, + 0xd9, 0xaa, 0x6e, 0x1b, 0xf4, 0x5e, 0x16, 0x88, 0x97, 0x1a, 0xb8, 0x21, 0xd9, 0x87, 0x0d, 0x11, + 0xa9, 0x69, 0xa4, 0x6c, 0xcd, 0x5e, 0x8b, 0x5b, 0x5d, 0x62, 0x1b, 0xad, 0x01, 0x5d, 0x4f, 0xb0, + 0xfd, 0x04, 0x4a, 0xf6, 0xc0, 0x50, 0x2c, 0xbc, 0x4c, 0xec, 0x59, 0xd3, 0x5b, 0xfa, 0xaa, 0x90, + 0x97, 0xd9, 0x21, 0xb6, 0xa8, 0xca, 0xac, 0x61, 0xc2, 0x7a, 0xde, 0x74, 0x3a, 0xb7, 0xbe, 0x54, + 0x8e, 0x9b, 0x0d, 0x7f, 0x54, 0xa2, 0x6b, 0xd7, 0x37, 0x0d, 0xf0, 0x23, 0x34, 0x47, 0xda, 0xad, + 0x49, 0x85, 0xc6, 0xd2, 0xbe, 0x9d, 0xfb, 0xf9, 0xa8, 0x44, 0x61, 0x94, 0x8f, 0xcc, 0x06, 0xd4, + 0x14, 0x93, 0x63, 0x54, 0x9d, 0x3f, 0x2a, 0xd0, 0xca, 0x16, 0xca, 0x9b, 0xf6, 0x04, 0xc8, 0x87, + 0x88, 0xf9, 0x5c, 0xcd, 0x6c, 0xe1, 0xd9, 0x21, 0xca, 0x2b, 0xee, 0x64, 0xf7, 0xc0, 0xb3, 0xc2, + 0x1a, 0xef, 0x12, 0xe0, 0x99, 0x77, 0x9e, 0xc0, 0x68, 0xeb, 0x43, 0x61, 0x86, 0x9c, 0x02, 0x88, + 0xc0, 0xf6, 0x18, 0xf7, 0x23, 0x99, 0xdc, 0xb1, 0x1b, 0xbb, 0xbd, 0x5b, 0x36, 0x9b, 0x71, 0xe8, + 0x9e, 0x05, 0x87, 0x49, 0xc2, 0x5b, 0xe1, 0x73, 0x67, 0x46, 0x0d, 0x91, 0x4d, 0x74, 0xde, 0xc1, + 0xbd, 0x42, 0x94, 0x3c, 0x84, 0xd6, 0x61, 0x7f, 0x70, 0x6c, 0x0f, 0x4e, 0x4e, 0xac, 0x83, 0x41, + 0x7f, 0x68, 0x1d, 0xff, 0xda, 0x2a, 0x91, 0x6d, 0x78, 0xae, 0x67, 0xfb, 0x87, 0x43, 0x8b, 0xda, + 0xd6, 0x2f, 0xd6, 0x9b, 0x9f, 0x87, 0x7d, 0xf3, 0xd8, 0xb2, 0x4f, 0xcf, 0x0e, 0xac, 0x73, 0xfb, + 0xcd, 0xd9, 0xc9, 0xdb, 0x63, 0x6b, 0x68, 0xb5, 0xca, 0x9d, 0x9f, 0xa0, 0x5d, 0x64, 0x70, 0x90, + 0xdc, 0x8b, 0x21, 0x79, 0x5e, 0x74, 0x50, 0x2c, 0x44, 0xa3, 0xe0, 0x9f, 0xce, 0x9f, 0xd5, 0xb9, + 0x90, 0x43, 0x9c, 0x4c, 0x7d, 0xa6, 0x90, 0xbc, 0xc8, 0x3d, 0xf0, 0xb9, 0x4b, 0x45, 0xdb, 0x63, + 0xff, 0x13, 0x7b, 0x3c, 0xbb, 0x43, 0xa2, 0x1b, 0x16, 0xd9, 0x07, 0x23, 0x7f, 0x7b, 0xd3, 0x87, + 0xe2, 0x49, 0xb1, 0x13, 0x67, 0x53, 0x74, 0x07, 0x19, 0x88, 0xce, 0xf1, 0xe4, 0x05, 0xac, 0xc6, + 0x3d, 0x94, 0x78, 0xe4, 0x96, 0xd7, 0x2f, 0x41, 0x90, 0x1d, 0xa8, 0x27, 0x16, 0xc8, 0x7c, 0x72, + 0x9b, 0x17, 0x33, 0x18, 0xd9, 0x83, 0xb5, 0xf4, 0xe0, 0x6f, 0xda, 0x64, 0xe9, 0x1a, 0xcd, 0x14, + 0xa8, 0xfb, 0x7b, 0x08, 0xf7, 0xb3, 0xdd, 0xd9, 0xe9, 0x0b, 0x15, 0xa6, 0x3e, 0xf9, 0xf6, 0x0e, + 0x5d, 0xb2, 0x83, 0xa3, 0xad, 0x49, 0x61, 0xc6, 0xdc, 0xfd, 0x6d, 0x67, 0xcc, 0xd5, 0x45, 0x34, + 0xea, 0x3a, 0x62, 0xd2, 0xf3, 0x67, 0x9e, 0xea, 0xe5, 0x3f, 0x21, 0x63, 0x0c, 0x7a, 0xd3, 0xd1, + 0xf7, 0x63, 0xd1, 0x5b, 0xf8, 0x2f, 0x19, 0xd5, 0xf4, 0xa5, 0xfc, 0xea, 0xbf, 0x00, 0x00, 0x00, + 0xff, 0xff, 0x29, 0x6b, 0x27, 0xdf, 0x77, 0x09, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/core/workflow.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/core/workflow.pb.validate.go index c221a830b6e..897975561d4 100644 --- a/flyteidl/gen/pb-go/flyteidl/core/workflow.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/core/workflow.pb.validate.go @@ -801,10 +801,10 @@ func (m *WorkflowMetadata) Validate() error { return nil } - if v, ok := interface{}(m.GetQueuingBudget()).(interface{ Validate() error }); ok { + if v, ok := interface{}(m.GetQualityOfService()).(interface{ Validate() error }); ok { if err := v.Validate(); err != nil { return WorkflowMetadataValidationError{ - field: "QueuingBudget", + field: "QualityOfService", reason: "embedded message failed validation", cause: err, } diff --git a/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json b/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json index a0f651f8cf8..906f13dd9d5 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json +++ b/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json @@ -1141,7 +1141,7 @@ "parameters": [ { "name": "resource_type", - "description": " - TASK_RESOURCE: Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run", + "description": " - TASK_RESOURCE: Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run\n - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec.", "in": "query", "required": false, "type": "string", @@ -1149,7 +1149,8 @@ "TASK_RESOURCE", "CLUSTER_RESOURCE", "EXECUTION_QUEUE", - "EXECUTION_CLUSTER_LABEL" + "EXECUTION_CLUSTER_LABEL", + "QUALITY_OF_SERVICE_SPECIFICATION" ], "default": "TASK_RESOURCE" } @@ -1553,7 +1554,7 @@ }, { "name": "resource_type", - "description": " - TASK_RESOURCE: Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run", + "description": " - TASK_RESOURCE: Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run\n - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec.", "in": "query", "required": false, "type": "string", @@ -1561,7 +1562,8 @@ "TASK_RESOURCE", "CLUSTER_RESOURCE", "EXECUTION_QUEUE", - "EXECUTION_CLUSTER_LABEL" + "EXECUTION_CLUSTER_LABEL", + "QUALITY_OF_SERVICE_SPECIFICATION" ], "default": "TASK_RESOURCE" } @@ -2250,7 +2252,7 @@ }, { "name": "resource_type", - "description": " - TASK_RESOURCE: Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run", + "description": " - TASK_RESOURCE: Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run\n - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec.", "in": "query", "required": false, "type": "string", @@ -2258,7 +2260,8 @@ "TASK_RESOURCE", "CLUSTER_RESOURCE", "EXECUTION_QUEUE", - "EXECUTION_CLUSTER_LABEL" + "EXECUTION_CLUSTER_LABEL", + "QUALITY_OF_SERVICE_SPECIFICATION" ], "default": "TASK_RESOURCE" } @@ -2746,6 +2749,17 @@ "description": "- UPLOAD_ON_EXIT: All data will be uploaded after the main container exits\n - UPLOAD_EAGER: Data will be uploaded as it appears. Refer to protocol specification for details\n - DO_NOT_UPLOAD: Data will not be uploaded, only references will be written", "title": "Mode to use for uploading" }, + "QualityOfServiceTier": { + "type": "string", + "enum": [ + "UNDEFINED", + "HIGH", + "MEDIUM", + "LOW" + ], + "default": "UNDEFINED", + "description": " - UNDEFINED: Default: no quality of service specified." + }, "ResourcesResourceEntry": { "type": "object", "properties": { @@ -3153,6 +3167,10 @@ "auth_role": { "$ref": "#/definitions/adminAuthRole", "description": "Optional: auth override to apply this execution." + }, + "quality_of_service": { + "$ref": "#/definitions/coreQualityOfService", + "description": "Indicates the runtime priority of the execution." } }, "description": "An ExecutionSpec encompasses all data used to launch this execution. The Spec does not change over the lifetime\nof an execution as it progresses across phase changes.." @@ -3340,6 +3358,10 @@ }, "auth_role": { "$ref": "#/definitions/adminAuthRole" + }, + "quality_of_service": { + "$ref": "#/definitions/coreQualityOfService", + "description": "Indicates the runtime priority of the execution." } }, "description": "User-provided launch plan definition and configuration values." @@ -3424,10 +3446,11 @@ "TASK_RESOURCE", "CLUSTER_RESOURCE", "EXECUTION_QUEUE", - "EXECUTION_CLUSTER_LABEL" + "EXECUTION_CLUSTER_LABEL", + "QUALITY_OF_SERVICE_SPECIFICATION" ], "default": "TASK_RESOURCE", - "description": "Defines a resource that can be configured by customizable Project-, ProjectDomain- or WorkflowAttributes\nbased on matching tags.\n\n - TASK_RESOURCE: Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run" + "description": "Defines a resource that can be configured by customizable Project-, ProjectDomain- or WorkflowAttributes\nbased on matching tags.\n\n - TASK_RESOURCE: Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run\n - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec." }, "adminMatchingAttributes": { "type": "object", @@ -3443,6 +3466,9 @@ }, "execution_cluster_label": { "$ref": "#/definitions/adminExecutionClusterLabel" + }, + "quality_of_service": { + "$ref": "#/definitions/coreQualityOfService" } }, "description": "Generic container for encapsulating all types of the above attributes messages." @@ -4948,6 +4974,28 @@ }, "title": "Primitive Types" }, + "coreQualityOfService": { + "type": "object", + "properties": { + "tier": { + "$ref": "#/definitions/QualityOfServiceTier" + }, + "spec": { + "$ref": "#/definitions/coreQualityOfServiceSpec" + } + }, + "description": "Indicates the priority of an execution." + }, + "coreQualityOfServiceSpec": { + "type": "object", + "properties": { + "queueing_budget": { + "type": "string", + "description": "Indicates how much queueing delay an execution can tolerate." + } + }, + "description": "Represents customized execution run-time attributes." + }, "coreResourceType": { "type": "string", "enum": [ @@ -5266,9 +5314,9 @@ "coreWorkflowMetadata": { "type": "object", "properties": { - "queuing_budget": { - "type": "string", - "description": "Total wait time a workflow can be delayed by queueing." + "quality_of_service": { + "$ref": "#/definitions/coreQualityOfService", + "description": "Indicates the runtime priority of workflow executions." }, "on_failure": { "$ref": "#/definitions/WorkflowMetadataOnFailurePolicy", diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/README.md b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/README.md index 82c6f20bb9c..43e3e2a77f0 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/README.md +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/README.md @@ -212,6 +212,8 @@ Class | Method | HTTP request | Description - [CoreParameter](docs/CoreParameter.md) - [CoreParameterMap](docs/CoreParameterMap.md) - [CorePrimitive](docs/CorePrimitive.md) + - [CoreQualityOfService](docs/CoreQualityOfService.md) + - [CoreQualityOfServiceSpec](docs/CoreQualityOfServiceSpec.md) - [CoreResourceType](docs/CoreResourceType.md) - [CoreResources](docs/CoreResources.md) - [CoreRetryStrategy](docs/CoreRetryStrategy.md) @@ -253,6 +255,7 @@ Class | Method | HTTP request | Description - [ProtobufNullValue](docs/ProtobufNullValue.md) - [ProtobufStruct](docs/ProtobufStruct.md) - [ProtobufValue](docs/ProtobufValue.md) + - [QualityOfServiceTier](docs/QualityOfServiceTier.md) - [ResourcesResourceEntry](docs/ResourcesResourceEntry.md) - [ResourcesResourceName](docs/ResourcesResourceName.md) - [RuntimeMetadataRuntimeType](docs/RuntimeMetadataRuntimeType.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 e3db4874c39..401c29b5401 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api/swagger.yaml +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api/swagger.yaml @@ -976,7 +976,8 @@ paths: \ and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes\ \ cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task\ \ execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the\ - \ K8s cluster label to be used for execution to be run" + \ K8s cluster label to be used for execution to be run\n - QUALITY_OF_SERVICE_SPECIFICATION:\ + \ Configures default quality of service when undefined in an execution spec." required: false type: "string" default: "TASK_RESOURCE" @@ -985,6 +986,7 @@ paths: - "CLUSTER_RESOURCE" - "EXECUTION_QUEUE" - "EXECUTION_CLUSTER_LABEL" + - "QUALITY_OF_SERVICE_SPECIFICATION" x-exportParamName: "ResourceType" x-optionalDataType: "String" responses: @@ -1330,7 +1332,8 @@ paths: \ and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes\ \ cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task\ \ execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the\ - \ K8s cluster label to be used for execution to be run" + \ K8s cluster label to be used for execution to be run\n - QUALITY_OF_SERVICE_SPECIFICATION:\ + \ Configures default quality of service when undefined in an execution spec." required: false type: "string" default: "TASK_RESOURCE" @@ -1339,6 +1342,7 @@ paths: - "CLUSTER_RESOURCE" - "EXECUTION_QUEUE" - "EXECUTION_CLUSTER_LABEL" + - "QUALITY_OF_SERVICE_SPECIFICATION" x-exportParamName: "ResourceType" x-optionalDataType: "String" responses: @@ -1933,7 +1937,8 @@ paths: \ and limits.\n - CLUSTER_RESOURCE: Applies to configuring templated kubernetes\ \ cluster resources.\n - EXECUTION_QUEUE: Configures task and dynamic task\ \ execution queue assignment.\n - EXECUTION_CLUSTER_LABEL: Configures the\ - \ K8s cluster label to be used for execution to be run" + \ K8s cluster label to be used for execution to be run\n - QUALITY_OF_SERVICE_SPECIFICATION:\ + \ Configures default quality of service when undefined in an execution spec." required: false type: "string" default: "TASK_RESOURCE" @@ -1942,6 +1947,7 @@ paths: - "CLUSTER_RESOURCE" - "EXECUTION_QUEUE" - "EXECUTION_CLUSTER_LABEL" + - "QUALITY_OF_SERVICE_SPECIFICATION" x-exportParamName: "ResourceType" x-optionalDataType: "String" responses: @@ -2389,6 +2395,15 @@ definitions: - "UPLOAD_EAGER" - "DO_NOT_UPLOAD" default: "UPLOAD_ON_EXIT" + QualityOfServiceTier: + type: "string" + description: " - UNDEFINED: Default: no quality of service specified." + enum: + - "UNDEFINED" + - "HIGH" + - "MEDIUM" + - "LOW" + default: "UNDEFINED" ResourcesResourceEntry: type: "object" properties: @@ -2660,6 +2675,10 @@ definitions: nesting: 0 system_metadata: execution_cluster: "execution_cluster" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" disable_all: true inputs: literals: {} @@ -2959,6 +2978,10 @@ definitions: nesting: 0 system_metadata: execution_cluster: "execution_cluster" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" disable_all: true inputs: literals: {} @@ -3089,6 +3112,10 @@ definitions: nesting: 0 system_metadata: execution_cluster: "execution_cluster" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" disable_all: true inputs: literals: {} @@ -3244,6 +3271,9 @@ definitions: auth_role: description: "Optional: auth override to apply this execution." $ref: "#/definitions/adminAuthRole" + quality_of_service: + description: "Indicates the runtime priority of the execution." + $ref: "#/definitions/coreQualityOfService" description: "An ExecutionSpec encompasses all data used to launch this execution.\ \ The Spec does not change over the lifetime\nof an execution as it progresses\ \ across phase changes.." @@ -3271,6 +3301,10 @@ definitions: nesting: 0 system_metadata: execution_cluster: "execution_cluster" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" disable_all: true inputs: literals: {} @@ -3502,6 +3536,10 @@ definitions: fixed_inputs: literals: {} role: "role" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" auth: kubernetes_service_account: "kubernetes_service_account" assumable_iam_role: "assumable_iam_role" @@ -3909,6 +3947,10 @@ definitions: fixed_inputs: literals: {} role: "role" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" auth: kubernetes_service_account: "kubernetes_service_account" assumable_iam_role: "assumable_iam_role" @@ -4155,6 +4197,10 @@ definitions: fixed_inputs: literals: {} role: "role" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" auth: kubernetes_service_account: "kubernetes_service_account" assumable_iam_role: "assumable_iam_role" @@ -4362,6 +4408,9 @@ definitions: $ref: "#/definitions/adminAuth" auth_role: $ref: "#/definitions/adminAuthRole" + quality_of_service: + description: "Indicates the runtime priority of the execution." + $ref: "#/definitions/coreQualityOfService" description: "User-provided launch plan definition and configuration values." example: workflow_id: @@ -4373,6 +4422,10 @@ definitions: fixed_inputs: literals: {} role: "role" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" auth: kubernetes_service_account: "kubernetes_service_account" assumable_iam_role: "assumable_iam_role" @@ -4539,6 +4592,10 @@ definitions: domain: "domain" project: "project" attributes: + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" cluster_resource_attributes: attributes: key: "attributes" @@ -4564,6 +4621,10 @@ definitions: domain: "domain" project: "project" attributes: + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" cluster_resource_attributes: attributes: key: "attributes" @@ -4620,6 +4681,10 @@ definitions: domain: "domain" project: "project" attributes: + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" cluster_resource_attributes: attributes: key: "attributes" @@ -4647,12 +4712,14 @@ definitions: \ Applies to customizable task resource requests and limits.\n - CLUSTER_RESOURCE:\ \ Applies to configuring templated kubernetes cluster resources.\n - EXECUTION_QUEUE:\ \ Configures task and dynamic task execution queue assignment.\n - EXECUTION_CLUSTER_LABEL:\ - \ Configures the K8s cluster label to be used for execution to be run" + \ Configures the K8s cluster label to be used for execution to be run\n - QUALITY_OF_SERVICE_SPECIFICATION:\ + \ Configures default quality of service when undefined in an execution spec." enum: - "TASK_RESOURCE" - "CLUSTER_RESOURCE" - "EXECUTION_QUEUE" - "EXECUTION_CLUSTER_LABEL" + - "QUALITY_OF_SERVICE_SPECIFICATION" default: "TASK_RESOURCE" adminMatchingAttributes: type: "object" @@ -4665,9 +4732,15 @@ definitions: $ref: "#/definitions/adminExecutionQueueAttributes" execution_cluster_label: $ref: "#/definitions/adminExecutionClusterLabel" + quality_of_service: + $ref: "#/definitions/coreQualityOfService" description: "Generic container for encapsulating all types of the above attributes\ \ messages." example: + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" cluster_resource_attributes: attributes: key: "attributes" @@ -5099,6 +5172,10 @@ definitions: domain: "domain" project: "project" matching_attributes: + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" cluster_resource_attributes: attributes: key: "attributes" @@ -5143,6 +5220,10 @@ definitions: domain: "domain" project: "project" matching_attributes: + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" cluster_resource_attributes: attributes: key: "attributes" @@ -6240,7 +6321,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -7063,7 +7147,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -8136,7 +8223,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -8873,6 +8963,10 @@ definitions: domain: "domain" project: "project" matching_attributes: + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" cluster_resource_attributes: attributes: key: "attributes" @@ -8921,6 +9015,10 @@ definitions: domain: "domain" project: "project" matching_attributes: + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" cluster_resource_attributes: attributes: key: "attributes" @@ -9072,7 +9170,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -9895,7 +9996,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -10968,7 +11072,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -11860,7 +11967,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -12683,7 +12793,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -13756,7 +13869,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -14589,7 +14705,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -15412,7 +15531,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -16485,7 +16607,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -17845,7 +17970,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -18695,7 +18823,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -19518,7 +19649,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -20591,7 +20725,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: @@ -22389,6 +22526,27 @@ definitions: boolean: true float_value: 1.4658129805029452 integer: "integer" + coreQualityOfService: + type: "object" + properties: + tier: + $ref: "#/definitions/QualityOfServiceTier" + spec: + $ref: "#/definitions/coreQualityOfServiceSpec" + description: "Indicates the priority of an execution." + example: + tier: {} + spec: + queueing_budget: "queueing_budget" + coreQualityOfServiceSpec: + type: "object" + properties: + queueing_budget: + type: "string" + description: "Indicates how much queueing delay an execution can tolerate." + description: "Represents customized execution run-time attributes." + example: + queueing_budget: "queueing_budget" coreResourceType: type: "string" description: "Indicates a resource type within Flyte." @@ -22983,9 +23141,9 @@ definitions: coreWorkflowMetadata: type: "object" properties: - queuing_budget: - type: "string" - description: "Total wait time a workflow can be delayed by queueing." + quality_of_service: + description: "Indicates the runtime priority of workflow executions." + $ref: "#/definitions/coreQualityOfService" on_failure: description: "Defines how the system should behave when a failure is detected\ \ in the workflow execution." @@ -22994,7 +23152,10 @@ definitions: \ does not change the final outputs of the workflow." example: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" coreWorkflowMetadataDefaults: type: "object" properties: @@ -23180,7 +23341,10 @@ definitions: bindings: {} metadata: on_failure: {} - queuing_budget: "queuing_budget" + quality_of_service: + tier: {} + spec: + queueing_budget: "queueing_budget" failure_node: branch_node: if_else: 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 fe9462b51ef..c3c10c1c58d 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 @@ -1588,7 +1588,7 @@ Retrieve the customized resource attributes associated with a project-domain com * @param project Unique project id which this set of attributes references. * @param domain Unique domain id which this set of attributes references. * @param optional nil or *GetProjectDomainAttributesOpts - Optional Parameters: - * @param "ResourceType" (optional.String) - - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + * @param "ResourceType" (optional.String) - - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. @return AdminProjectDomainAttributesGetResponse */ @@ -2130,7 +2130,7 @@ Retrieve the customized resource attributes associated with a project, domain an * @param domain Unique domain id which this set of attributes references. * @param workflow Workflow name which this set of attributes references. * @param optional nil or *GetWorkflowAttributesOpts - Optional Parameters: - * @param "ResourceType" (optional.String) - - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + * @param "ResourceType" (optional.String) - - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. @return AdminWorkflowAttributesGetResponse */ @@ -2842,7 +2842,7 @@ AdminServiceApiService Retrieve a list of MatchableAttributesConfiguration objects. * @param ctx context.Context - for authentication, logging, cancellation, deadlines, tracing, etc. Passed from http.Request or context.Background(). * @param optional nil or *ListMatchableAttributesOpts - Optional Parameters: - * @param "ResourceType" (optional.String) - - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + * @param "ResourceType" (optional.String) - - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. @return AdminListMatchableAttributesResponse */ diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_execution_spec.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_execution_spec.go index 5a7b2979e76..0d567b1119a 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_execution_spec.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_execution_spec.go @@ -24,4 +24,6 @@ type AdminExecutionSpec struct { Annotations *AdminAnnotations `json:"annotations,omitempty"` // Optional: auth override to apply this execution. AuthRole *AdminAuthRole `json:"auth_role,omitempty"` + // Indicates the runtime priority of the execution. + QualityOfService *CoreQualityOfService `json:"quality_of_service,omitempty"` } diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_launch_plan_spec.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_launch_plan_spec.go index c66a17c649d..d8f63699a54 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_launch_plan_spec.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_launch_plan_spec.go @@ -23,4 +23,6 @@ type AdminLaunchPlanSpec struct { // Indicates the permission associated with workflow executions triggered with this launch plan. Auth *AdminAuth `json:"auth,omitempty"` AuthRole *AdminAuthRole `json:"auth_role,omitempty"` + // Indicates the runtime priority of the execution. + QualityOfService *CoreQualityOfService `json:"quality_of_service,omitempty"` } diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_matchable_resource.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_matchable_resource.go index 5afcdfcf868..6e2558cf77c 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_matchable_resource.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_matchable_resource.go @@ -8,7 +8,7 @@ */ package flyteadmin -// AdminMatchableResource : Defines a resource that can be configured by customizable Project-, ProjectDomain- or WorkflowAttributes based on matching tags. - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run +// AdminMatchableResource : Defines a resource that can be configured by customizable Project-, ProjectDomain- or WorkflowAttributes based on matching tags. - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. type AdminMatchableResource string // List of adminMatchableResource @@ -17,4 +17,5 @@ const ( AdminMatchableResourceCLUSTER_RESOURCE AdminMatchableResource = "CLUSTER_RESOURCE" AdminMatchableResourceEXECUTION_QUEUE AdminMatchableResource = "EXECUTION_QUEUE" AdminMatchableResourceEXECUTION_CLUSTER_LABEL AdminMatchableResource = "EXECUTION_CLUSTER_LABEL" + AdminMatchableResourceQUALITY_OF_SERVICE_SPECIFICATION AdminMatchableResource = "QUALITY_OF_SERVICE_SPECIFICATION" ) diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_matching_attributes.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_matching_attributes.go index 6f23780b267..8d831381a29 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_matching_attributes.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_admin_matching_attributes.go @@ -15,4 +15,5 @@ type AdminMatchingAttributes struct { ClusterResourceAttributes *AdminClusterResourceAttributes `json:"cluster_resource_attributes,omitempty"` ExecutionQueueAttributes *AdminExecutionQueueAttributes `json:"execution_queue_attributes,omitempty"` ExecutionClusterLabel *AdminExecutionClusterLabel `json:"execution_cluster_label,omitempty"` + QualityOfService *CoreQualityOfService `json:"quality_of_service,omitempty"` } diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_quality_of_service.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_quality_of_service.go new file mode 100644 index 00000000000..d735974d03c --- /dev/null +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_quality_of_service.go @@ -0,0 +1,16 @@ +/* + * 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 + +// Indicates the priority of an execution. +type CoreQualityOfService struct { + Tier *QualityOfServiceTier `json:"tier,omitempty"` + Spec *CoreQualityOfServiceSpec `json:"spec,omitempty"` +} diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_quality_of_service_spec.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_quality_of_service_spec.go new file mode 100644 index 00000000000..e7a8a8ad7af --- /dev/null +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_quality_of_service_spec.go @@ -0,0 +1,16 @@ +/* + * 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 + +// Represents customized execution run-time attributes. +type CoreQualityOfServiceSpec struct { + // Indicates how much queueing delay an execution can tolerate. + QueueingBudget string `json:"queueing_budget,omitempty"` +} diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_workflow_metadata.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_workflow_metadata.go index d4b18eba3d0..8181eb8667c 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_workflow_metadata.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_workflow_metadata.go @@ -11,8 +11,8 @@ package flyteadmin // Metadata for the entire workflow. Defines execution behavior that does not change the final outputs of the workflow. type CoreWorkflowMetadata struct { - // Total wait time a workflow can be delayed by queueing. - QueuingBudget string `json:"queuing_budget,omitempty"` + // Indicates the runtime priority of workflow executions. + QualityOfService *CoreQualityOfService `json:"quality_of_service,omitempty"` // Defines how the system should behave when a failure is detected in the workflow execution. OnFailure *WorkflowMetadataOnFailurePolicy `json:"on_failure,omitempty"` } diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_quality_of_service_tier.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_quality_of_service_tier.go new file mode 100644 index 00000000000..b156cc3b7e2 --- /dev/null +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_quality_of_service_tier.go @@ -0,0 +1,20 @@ +/* + * 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 +// QualityOfServiceTier : - UNDEFINED: Default: no quality of service specified. +type QualityOfServiceTier string + +// List of QualityOfServiceTier +const ( + QualityOfServiceTierUNDEFINED QualityOfServiceTier = "UNDEFINED" + QualityOfServiceTierHIGH QualityOfServiceTier = "HIGH" + QualityOfServiceTierMEDIUM QualityOfServiceTier = "MEDIUM" + QualityOfServiceTierLOW QualityOfServiceTier = "LOW" +) diff --git a/flyteidl/gen/pb-go/flyteidl/service/openapi.go b/flyteidl/gen/pb-go/flyteidl/service/openapi.go index f0a7193bf5b..d3a431db9f8 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\xfb\x73\x23\xb9\x91\x27\xfe\xbb\xff\x0a\x9c\xf6\x22\xa6\xdb\xa6\xa8\xb1\xf7\x11\xbe\xde\xd8\xf8\x06\x47\x62\xf7\x68\x47\x2d\x69\xf5\x98\x5e\xdf\x71\x43\x06\xab\x40\x12\x56\x11\xe0\x14\x50\x52\xd3\x8e\xf9\xdf\xbf\x81\x4c\x00\x85\x7a\x92\x45\x52\xaf\x1e\xee\xc5\x79\xd4\x24\x0b\x05\x24\x12\x89\x7c\x7e\xf2\x1f\xbf\x23\xe4\x40\x3d\xd2\xe9\x94\xa5\x07\x1f\xc8\xc1\x9f\xfa\xdf\x1f\xf4\xcc\x67\x5c\x4c\xe4\xc1\x07\x62\xbe\x27\xe4\x40\x73\x9d\x30\xf3\xfd\x24\x59\x6a\xc6\xe3\xe4\x48\xb1\xf4\x81\x47\xec\x88\xc6\x73\x2e\xfa\x8b\x54\x6a\x09\x0f\x12\x72\xf0\xc0\x52\xc5\xa5\x30\x3f\xb7\x7f\x12\x21\x35\x51\x4c\x1f\xfc\x8e\x90\x5f\x61\x78\x15\xcd\xd8\x9c\xa9\x83\x0f\xe4\xff\xe1\x43\x33\xad\x17\x6e\x00\xf3\xb7\x32\xbf\xfd\x1f\xf8\x6d\x24\x85\xca\x0a\x3f\xa6\x8b\x45\xc2\x23\xaa\xb9\x14\x47\x7f\x53\x52\xe4\xbf\x5d\xa4\x32\xce\xa2\x35\x7f\x4b\xf5\x4c\xe5\x6b\x3c\xa2\x0b\x7e\xf4\xf0\xc7\x23\x1a\x69\xfe\xc0\xee\x12\x9a\x89\x68\x76\xb7\x48\xa8\x50\x47\xff\xe0\xb1\x59\xe3\xdf\x58\xa4\x7f\x85\x7f\xc4\x72\x4e\xb9\xc0\xbf\x05\x9d\xb3\x5f\xfd\x38\x84\x1c\x4c\x99\x0e\xfe\x49\xc8\x41\xcc\x54\x94\xf2\x85\xb6\x54\xb9\x62\x3a\xe5\xec\x81\x11\x3d\x63\x04\x5f\x47\xf0\x75\xc4\xbc\x8e\x38\xaa\xa9\x05\x8b\xf8\x84\xb3\x98\x8c\x97\x84\x8b\x45\xa6\x49\xca\x7e\xc9\x98\xd2\x64\xc2\x13\xcd\x52\xd5\xb7\x24\x83\xb7\xc8\x05\x4b\x61\x9d\xa7\xb1\x79\xcb\x27\xa6\x07\x30\xf6\x19\x0c\x7d\x99\x50\x11\xfe\x3a\x65\x6a\x21\x85\x62\xaa\x30\x55\x42\x0e\xfe\xf4\xfd\xf7\xa5\x8f\xaa\x2b\x18\x10\x95\x45\x11\x53\x6a\x92\x25\xc4\x8d\x14\x4e\x06\x1e\x82\x4d\xa6\x95\xc1\x08\x39\xf8\xdf\x29\x9b\x98\x71\xfe\xe9\x28\x66\x13\x2e\xb8\x19\x57\x21\x2f\x05\xb3\x2d\x3c\xf5\xeb\xef\xea\xfe\xfe\x35\x58\xd1\x82\xa6\x74\xce\x0c\x59\xfc\xee\xe3\xff\x95\xd6\x62\xf6\xcb\xbc\x3c\xdf\xd3\xf2\xc4\x4b\xab\x3d\xa7\x73\x46\xe4\x04\xb6\xcb\x3e\x01\x7f\xa7\x4c\xc9\x2c\x8d\x18\x19\xb3\x44\x8a\xa9\x22\x5a\x56\x68\xc0\x61\x04\xc3\x6a\xe5\x6f\xcc\x56\xf2\x94\x99\xbd\xd2\x69\xc6\x4a\xdf\xea\xe5\x02\x26\xa9\x74\xca\xc5\x34\x24\xc5\xaf\xbd\xb5\x96\x86\x1c\xda\x61\x65\xf8\x40\xe3\xc2\x46\x62\xe0\x7e\x12\x51\x41\xc6\x8c\x98\x73\xc9\x63\x96\xb2\x98\x50\x45\x28\x51\xd9\x58\x31\x4d\x1e\xb9\x9e\x71\x61\xfe\x8d\xec\x1b\x39\x9a\xbd\x1e\xda\xc0\x9f\xed\x94\xb9\x55\x2c\x35\x13\x7f\xe0\x31\x8b\xc9\x03\x4d\x32\x46\x26\x32\x2d\x90\xa7\x3f\x12\x37\x33\x43\x87\xf9\x98\x0b\x38\x79\x86\x96\x8e\x43\xfe\xe0\xc8\xf5\x07\x62\xde\x47\x32\xc1\x7f\xc9\x58\xb2\x24\x3c\x66\x42\x9b\x73\xad\xca\xa3\xfd\x41\xc2\xfb\x69\x42\x0e\x89\xa1\x33\x4b\x35\xd0\x5b\x0a\xcd\xbe\x6a\x45\x0e\x49\xc2\xef\x19\xf9\xee\x8c\x2b\x4d\x06\x97\xa7\xdf\xf5\xc8\x77\x67\xb9\xe0\x50\xdf\x3d\x03\x85\xfd\xdf\xff\x13\x1c\x3d\x4d\xa7\xe5\x43\x77\x30\x30\xa7\xf9\x1a\xaf\x89\x7c\x84\xff\xf9\x5d\x38\x8e\xdd\xaf\x76\xd9\x9b\x0b\x5e\x2b\x75\xbb\xc8\xda\x8f\x4c\x47\xb3\x15\x82\x56\x6d\x29\x69\xcd\x76\x94\x45\xad\x7a\x5b\xb2\xd6\x2c\xe1\xa9\xe5\xed\x36\xc2\x96\x6a\x38\x05\x94\x0b\x3c\x34\xfe\x0c\x15\x77\x86\xbc\x9c\x58\xd9\x46\xde\x06\xab\x09\x44\xae\x93\xa4\x01\x25\x5e\xc9\x5a\x13\x3e\xe7\xab\xf6\xf1\x54\xc4\x46\xed\xb2\x42\x4e\x64\xf3\x31\x4b\xcd\xd2\x9d\xb8\x83\x15\x8e\x8d\xf8\xd3\x59\x2a\x58\xdc\xb0\xb4\x5f\x32\x96\x2e\x5b\xd6\x36\xa1\x89\x6a\x5a\x1c\x17\x9a\x19\xbd\xb6\xf4\xf5\x44\xa6\x73\xaa\xed\x0f\xfe\xed\x5f\xba\x2e\x5e\xcb\x7b\xb6\x6a\x9f\x4f\x71\xd7\x22\xaa\x60\xbb\xe7\x59\xa2\xf9\x22\x61\x64\x41\xa7\x4c\x59\x2a\x64\x89\x56\x3d\xf8\x99\xd1\xa5\x59\x7a\xe8\x6f\x1b\x78\x83\xbb\x65\x33\x05\x9f\x90\x89\x17\x64\x82\x7d\xd5\x30\xd2\x48\xc0\x3d\x0b\x24\x0a\x6f\x8f\x27\x20\xe5\x66\x7c\xa2\x64\xaa\xef\xc6\xcb\xfe\x3d\xab\xbc\xb7\x91\x5b\xa8\x20\x54\xeb\x94\x8f\x33\xcd\xcc\xba\xcd\x18\xee\x9e\x04\xd1\x87\x97\xb1\x32\x97\xef\xc5\xc9\xc5\xbb\x7b\xaa\x53\x39\xa5\xe2\xfd\x07\x32\x88\x63\x82\x13\x35\xbf\xe1\x31\x5e\xc9\x33\x96\xb2\x3e\xb9\x99\x71\x45\xd4\x4c\x66\x49\x4c\x04\x7b\x60\xa9\xa1\x2d\x9b\x2f\xf4\xf2\xd5\x51\x2b\xe6\x29\x8b\x80\x30\x5d\x4e\x98\x7f\xca\x10\xcd\x18\x3d\x4b\x24\xdd\x3d\x5b\x82\xe2\x52\x25\xdf\x33\xf0\x4b\xe9\x5b\x26\xb2\x79\xe9\xae\x80\xcf\x4f\x86\xd7\xc7\xc3\xf3\x93\xd3\xf3\x4f\xa5\x27\x8c\x1a\xe1\xbf\x2a\x7c\xf3\x3f\x15\xda\x4c\x68\x96\xc0\xa9\x0e\x46\x7b\x36\xc5\x25\x9a\xf1\x24\x4e\x99\x38\xd2\x54\xdd\xdf\xb1\xaf\x2c\xca\xf0\x9e\xfd\x47\xf1\x83\x3b\xa3\x7d\xca\x98\x15\x3f\x29\xfc\x23\x57\x77\x3a\x3f\xea\xad\xd2\xce\x4f\x82\x0d\xbb\xde\x73\xf0\x09\x8f\x6b\x7f\x0d\x9f\xac\x58\x83\xfb\x4d\xcb\x64\xdd\x4f\x1a\x67\xe5\x7e\x60\x15\xb8\xda\xdf\xa4\x4c\xa7\xcb\x3b\xaa\xb5\x39\xe5\x1b\xe8\x8c\xb0\xa5\xc4\xac\x96\xe4\xfb\x69\xd5\x47\x54\x14\x41\x76\x7b\xcd\xd1\xcc\x20\xff\xe5\x2a\x7d\xf1\x5c\xc6\x6c\xe8\x87\xfd\x28\xd3\x1b\xaa\xee\xdf\x82\xce\x58\x98\xf8\x73\xa8\x8d\x9b\x1e\xa0\x6f\xce\xa8\xdf\x50\x1c\xec\x5d\x00\xdb\x53\x72\x5d\x87\x81\x4c\x89\x5a\x2a\xcd\xe6\x2b\x5d\x07\x6f\x87\x10\x56\xde\xbf\xd6\x09\x97\xae\x9c\xdf\xc0\xa9\x2f\x5e\xa0\xfb\xe3\xdd\x81\x64\xbb\x72\xfc\xbd\xf6\x75\xba\x10\x4c\xfb\x52\xaf\xdd\xf6\xb9\x80\x83\xe5\x93\x57\xbf\xcc\x82\x6a\xb7\xeb\x49\x3e\x91\xd7\xa0\x71\xaf\x1c\xb5\xef\x60\x02\x2b\x4c\xbe\xa2\xeb\xd8\x9f\x3f\xf3\x68\xe8\x5c\x41\x8f\x99\x36\x36\xaf\xf5\x2d\xb1\x94\x44\x32\x45\x55\x30\x6e\x11\x6f\xcf\x67\xf4\xdd\x9e\x5f\x5f\x0e\x8f\x4f\x3f\x9e\x0e\x4f\xaa\x56\xdf\xcd\xe0\xfa\xa7\xea\xa7\x5f\x2e\xae\x7e\xfa\x78\x76\xf1\xa5\xfa\xcd\xd9\xe0\xf6\xfc\xf8\xc7\xbb\xcb\xb3\xc1\xf9\xda\x76\x62\x38\x81\x8e\xbb\xb9\x77\x80\xed\xd2\x01\xd6\xfb\x76\x3d\x60\x36\x7a\xb0\xbe\xf7\x8b\x24\x5c\x69\x43\x20\xfb\x24\x59\x50\xa5\xf0\xfe\xc5\x19\xf4\x47\xe2\xb3\x4c\x19\xe1\x62\x22\x89\x84\xe0\x90\xd2\x69\x16\x69\x2e\xa6\xfe\xa1\x0f\x64\x94\x7d\xff\xfd\x3f\x47\x67\x5c\xdc\xc3\x5f\xec\x35\x12\x67\xef\x1e\xdc\x84\x5a\x7b\xf7\x60\xf8\xdd\xdb\x70\x0f\xc6\x54\xd3\xa3\xd0\x2b\xf8\x34\xf9\x24\x18\xb9\xa4\x22\x26\x32\xd3\xe6\x4f\xf3\x5e\x32\x49\xe5\xdc\x9c\x1b\xf6\x95\x2b\x90\x12\x8f\x32\xbd\x9f\x24\xf2\x71\x3d\x6f\xd5\x27\xa6\xbd\xbf\xe7\x84\x6a\xfa\x16\x9c\x54\x5f\xec\x0a\xfd\xc4\x3f\x31\x6d\xe6\x7e\x65\xdf\xb2\x4f\x2d\xd9\xa7\x96\xbc\x6c\x6a\xc9\xab\xf2\x14\x3d\xbd\xec\x2b\xba\x95\x50\x00\x36\x44\x3d\x1a\x83\x1a\x0d\x31\x8b\x20\x24\xf1\x94\x42\xb3\x18\x08\x58\x21\x30\x0b\x4e\xf2\xb7\x22\x34\x0b\x93\x7e\x7e\x81\xf9\x9b\xf0\xe1\xef\x5d\xf4\x1b\x12\xea\x4d\xca\xd5\x35\xaf\x8c\x67\x73\xb0\x3f\xbd\x9c\xaf\x84\xbf\xbb\xc4\xbb\x3b\x04\xb8\xd7\x8e\x68\xaf\x08\x61\xd7\xc6\xac\xeb\x82\xd4\xd5\xa8\x74\x6d\x18\x7a\xab\xb8\x73\xd7\x2b\x69\xfd\x88\xf3\x27\xa6\x6f\xa8\xba\x7f\x73\x57\x52\x61\xd2\xcf\x7f\x25\xfd\x46\x03\xcd\xfb\xc8\xf2\x13\x92\xee\x5b\xbf\xc8\x5e\x6f\xec\xf8\x37\x10\x2c\xde\x47\x87\x3b\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\x56\xe0\xf1\x0a\xd5\xe9\x83\x85\x54\xed\xea\xff\x71\xca\xa8\x66\x84\x96\x5c\x4d\x04\x06\x24\x29\x8b\x64\x1a\x1b\xb5\x9f\x92\xc5\x8c\x2a\x46\x74\x4a\x85\xe2\xab\x54\x7f\x1c\x15\x7c\x3b\x66\x9c\xb7\xa0\xf5\x17\x1c\x51\x30\xeb\xe7\xd2\xf9\xc7\x32\xae\x1c\x0d\x3c\x35\x75\xdf\xb4\x8b\x97\x9d\x2d\x1d\xea\xd0\xd6\x59\xf9\x13\x72\xb3\x11\x65\x1b\x72\x73\xd1\x4a\xdd\x09\x37\x83\x59\xf8\x56\xb8\xb9\x60\xc3\xfe\xb6\xb8\xb9\x6e\xe9\xaf\x81\x9b\x5d\x00\x74\x43\x8e\xae\xc6\x4f\x77\xc2\xd5\x3e\x68\xf9\x56\x38\xbb\x12\x65\xfd\x6d\x71\x77\xd3\xf2\x5f\x96\xc3\xbd\xef\x75\x57\xbc\xbd\x9a\x71\x3d\x01\xde\x02\xd3\xfa\xc9\xe2\xdc\x7f\x33\xdc\x5a\x59\xf7\x2b\x61\xd3\xa3\x94\x61\x4d\x55\x27\x7e\xbd\xb2\x0f\x75\xe6\x58\xf7\xe0\x9e\x67\xdf\x12\xcf\xba\x5d\x7b\x3d\x5c\xdb\x94\xc1\xd5\xbd\xce\xb0\x25\x2d\x4b\x91\x39\xd5\xd1\xcc\x7c\x89\x21\xa1\x35\xc1\x28\xf2\xc2\xc2\x37\xc5\xdd\xcf\x51\x4d\xf8\x6d\x3b\x7f\xf7\x4e\xdf\xdf\x20\xe8\xcf\xab\xc9\x50\xde\x57\x45\xec\xb0\x2a\x82\xab\x7d\x55\xc4\xbe\x2a\x62\x5d\x02\xed\xab\x22\xf6\x55\x11\xc1\x77\x6f\xa3\x2a\xe2\xe9\x0b\x22\x76\x53\xf5\xf0\xa6\x94\xe8\xbd\x02\xbd\x57\xa0\xf7\xa5\x0d\x7e\x69\xbb\x12\x60\xee\xe9\x83\x98\x25\x4c\xb3\x56\xf1\x73\xc3\xd2\xb9\xb1\x0d\x0a\x00\xbf\x35\x41\x83\x1c\x3b\xc8\x73\x10\xb8\x37\xda\xe4\x92\x1f\xfb\x6d\x4a\x27\x3f\xfd\x7d\x25\xd6\x5e\x5c\xed\xc5\xd5\x26\x4b\x7b\x3d\x5e\xd9\xe0\x30\xbf\xa8\x5b\x36\x80\x0b\xbe\xe3\xf1\x6e\x10\x83\xbd\xda\x18\xe2\x05\xe7\xa4\x28\x40\xb6\x6e\xe6\xa4\xcd\xc1\x77\x4f\xe3\x37\xe1\xa7\x35\x72\x24\x1e\x0a\xcd\xf5\xd2\x67\xa9\xa5\x7b\xe0\xe0\x3d\x70\xf0\xfa\x6b\xdd\x7b\x08\x77\xe8\x21\xdc\x03\x07\xef\x7d\x60\x7b\x1f\xd8\xd3\xfb\xc0\x5e\xca\xa1\xfd\xcc\xc7\xf2\xb9\x54\xb4\xcd\x12\x93\x44\x4c\x52\x36\xe5\x4a\xb3\xd4\x50\xaf\x56\x29\x5b\x9d\xa9\xf4\x56\x5b\xe1\xac\x9d\xf7\x11\xbe\xf6\xe0\x5f\xd6\x98\xfe\x95\xbd\x45\xe1\xa8\x8f\x69\xec\xfb\x5e\x80\xea\x34\xa7\x4b\x32\xa3\x0f\x8c\x4c\x28\x4f\xd0\x30\xb2\xd2\xb1\x65\x85\x6d\x13\xfa\x3f\xdd\x26\x44\x8b\xd3\x49\xd9\x84\xa5\x4c\x44\x28\xed\x51\xf9\x89\x68\x42\x18\x28\xa5\xf8\x9b\x99\x31\x53\x93\x94\xd1\x78\x49\xc6\x8c\x09\xcf\x36\x35\x9a\x42\xc3\x9c\x77\xa2\xb4\xbe\xb8\x99\x56\xe5\x9e\xd7\x62\xa4\x3d\x49\xf6\x4c\xbd\x48\xd8\xde\x38\x53\x7f\x7a\x5b\xa2\x62\x9f\x44\xb3\x77\xaa\xbd\xbc\x53\x6d\x9f\x44\xb3\x37\x91\x5f\x81\x89\xbc\x4f\xa2\xd9\x27\xd1\xec\x1d\x08\x6b\x53\x6b\xef\x40\x08\xbf\x7b\x1b\x49\x34\x4f\xd8\xa7\xf6\xb9\x34\xec\xbd\x82\xed\x7e\xb7\x57\xb0\xf7\x0a\xf6\x37\xaa\x60\xbf\x0e\x0a\xef\xb5\xeb\xbd\x76\xbd\xd7\xae\xf7\xda\xf5\x5e\xbb\xde\x6b\xd7\xf6\xa9\x5d\x6a\xd7\xf0\x97\x43\x03\xdd\x3a\x63\xbd\x7b\x94\xeb\x13\xd3\x6f\x35\xc4\xb5\x57\xa9\xf7\x2a\xf5\xeb\x56\xa9\x5f\xcd\x82\xbe\x3d\x74\xbf\x3d\x3e\x5e\xe5\x7e\xfc\x16\xf0\xf1\xdc\xd3\x07\x8b\xac\xfd\xfa\xbb\x5d\xc4\xae\x5c\x42\x69\xaa\x33\xb0\x34\xd6\xb8\x0a\xc9\x40\x93\xb9\x34\x7a\xb7\x60\x85\xdf\x38\x9e\xc7\x24\x82\x29\x7f\x60\x82\xb8\xb4\xe0\x9e\x95\x6c\x3d\x30\x7e\x7f\x75\x02\xce\xd6\x69\x50\x4d\x28\xd1\x7c\xce\xfa\xe4\x74\x82\x0c\x14\xd1\x24\x21\x8a\x69\x55\xca\x3c\x31\x0a\x99\x7d\x48\xc4\xf9\x5c\xdd\xbb\x79\x9e\x88\x80\x3f\xeb\xb9\xf3\x97\x25\x1a\x4f\xa3\x1b\xfc\x91\x27\x89\x99\x83\x65\x5a\x10\x3e\x73\x96\x26\xee\xc9\xc2\x6b\xdd\x8f\xe7\x34\x36\xd6\x44\x30\x85\xbc\xa0\x24\xfc\x3d\x88\x79\xae\x7c\x2a\x45\xe1\x79\x7c\xba\x4f\xac\xdd\x87\x38\x56\x6b\x4d\x63\x46\x63\x23\xf6\xa3\x19\x8b\xb3\x84\x11\xaa\x94\x8c\x38\xd5\x2c\x26\x1c\xaf\x05\xc2\xb5\xb3\x12\xdd\x8f\xdc\xab\x63\xae\xe8\x38\x61\xb1\xa5\x31\xcb\x33\x3b\x5a\x67\xce\x15\x19\x33\x43\x62\x73\xf3\x14\xa9\x3f\xc3\x4b\xa9\x66\x36\xc1\x54\x58\x75\x26\x4c\xe0\x44\x5a\x94\x2a\x64\xce\xb7\xaa\x57\xe1\xec\xf7\xe5\x36\x7b\x2d\x6b\xaf\x65\x75\x5a\xd0\x37\xa5\x65\xbd\xa2\x6c\x34\x27\x90\x5e\x34\x1b\x0d\x62\x56\x46\xf2\xdf\x79\xa7\x94\xda\xcc\x5e\xf7\x7e\xbf\xcf\x6e\xc8\x81\x1f\xf1\x58\x8a\x09\x9f\x66\xa9\x75\xc0\x8f\xcd\x89\x5d\x19\x18\xab\x19\xe7\x4d\xdc\x38\xf5\x53\x7f\xae\x8b\xa7\x8b\x0d\x41\x0e\x89\xd1\xae\xef\xae\x86\xd7\x17\xb7\x57\xc7\xc3\x0f\x64\xb0\x58\x24\x1c\x1d\xfb\x51\xa6\xb4\x9c\xf3\xbf\x9b\x65\x20\x76\xad\x97\xdc\x56\x0d\x51\xa0\x70\x40\x24\x41\xf5\x47\x82\x1c\x92\xe3\xb3\xdb\xeb\x9b\xe1\x55\xc3\x80\x96\x09\xa0\x63\x0b\x9b\x2f\x12\xd0\x4a\xee\xb3\x31\x4b\x05\xd3\x4c\x91\x28\xc9\x20\xad\xd9\xc7\x17\x70\xd0\xe1\x7f\x0f\x8f\x6f\x6f\x4e\x2f\xce\xef\xfe\xeb\x76\x78\x3b\xfc\x40\x1c\x37\x99\x61\xcd\xbc\xcc\x2c\xe2\xa5\xa0\x73\x63\xfe\x14\x41\x76\x7f\xc9\x58\x06\x4a\x10\x9f\x8a\x39\x13\xba\x3c\xa2\x9b\xf0\xd9\xe0\x87\xe1\x59\x71\xe4\x19\x23\x3f\xfd\x39\x9f\x54\x42\xc7\x2c\xb1\x01\x0f\xf0\xe7\x1b\x81\x9d\xbf\xc8\x46\x42\xb2\x8a\x98\x7c\x6e\x5b\xaa\xb0\xa1\x55\xeb\xa8\xbc\x43\xd5\x5f\x94\xc8\xdd\xf6\x83\x02\xf5\xd6\x36\xb6\x8a\x33\x7c\x36\x49\x67\x0e\x48\x7c\x07\x19\xd2\x9c\xa9\xa3\x7f\x14\x0e\xca\xaf\x4f\x06\xbc\x41\x82\x6a\x41\x2b\xf9\x56\xf5\xcc\xcb\x1f\x78\x0b\xf2\x2e\x9c\xee\x4b\xca\xb6\x1d\xe9\x13\xaf\xcb\x65\xd1\x5d\x5b\xdb\x5b\x1d\x7b\xab\xa3\x9e\x32\xfb\x74\x89\x06\x0a\xef\xea\xda\xd9\xc4\xcb\x37\xe1\x2c\x89\x55\xc5\x4d\x53\xb8\x36\x56\xba\x64\xde\xee\x8d\xf1\xbc\x4e\x99\x2e\xba\xf1\x95\xf7\x9f\x5b\x87\xba\xd9\xad\x39\xd3\x14\x5a\x10\x6a\x49\x32\x98\xfa\xfe\x16\xaa\x92\x79\x7f\x0b\xed\x6f\xa1\x46\xca\xec\x6f\xa1\x37\xec\xbc\xaa\x91\xdc\x2f\xea\xbd\x5a\x65\xd3\x6d\x85\x7f\x53\xe3\xda\xaa\xda\x72\x8a\xa8\x19\x4d\xb1\xd3\x49\x24\xe7\x73\x29\x82\xc8\xeb\x72\xc1\x7a\xc4\x07\xdb\xc0\x4d\x01\xd3\x58\xe5\xf9\xca\x5f\xc3\xdf\x86\xcf\x2b\xa0\xcb\x73\x64\x85\xef\xed\xc0\x15\x04\xda\x03\x05\xed\x81\x82\xf6\x79\xda\x7b\xa0\xa0\x76\x6e\xd9\x67\x22\xef\x33\x91\xc3\xef\xf6\x40\x41\xaf\x08\x28\xa8\xd8\x43\x1c\x73\xae\xeb\x9a\xee\xff\x5a\xfd\x26\x8c\x5c\x54\x5a\xae\xdb\x80\x06\xf6\x23\xdf\x3e\x35\xbb\xd8\xa2\x75\x55\x64\x23\x6c\xea\xf9\xca\xf5\xda\x49\xb2\xd4\x8c\xc7\x49\xb5\x1b\xe9\x33\xa4\x0e\xd5\x6d\xf4\xb7\xe8\x4b\xa9\x61\xdb\xbd\x63\x65\x25\xa1\xbe\x55\x40\xdf\x5c\x2e\xbd\x21\xa7\xff\x7a\xc2\xdb\x81\x9e\xdf\x35\x88\xf0\xfa\xef\xbd\x20\xaf\xff\x7a\xdb\x3a\xf6\xa2\xec\xde\xb4\x7e\xbd\x20\x1b\xdf\x86\xb7\x22\x9c\xf1\x73\xf8\x2b\x5a\x77\xff\x9b\x93\xeb\x6d\xbc\xbc\x97\xee\x6b\x92\xeb\x5b\x95\xf1\x7b\x7f\xc6\x2e\xfd\x19\xbd\x6f\xd7\xa1\xb1\xaf\x3b\x6f\x21\xce\xde\xdb\xb3\x09\xb5\xf6\xde\x9e\xf0\xbb\xb7\x51\x77\x6e\xef\xea\x3b\xbc\xea\x83\x24\xf5\xa3\x7f\xe4\x7f\x07\x8a\x74\xf0\x61\x4d\xc8\xaf\x43\x62\x8e\x4b\x7f\x66\x71\xae\x7e\xe4\x83\xd7\x24\xec\xd8\x39\x1c\x3a\xa5\x24\x0f\x5e\xaf\xcc\xdf\xb9\xc4\x47\x4f\xe0\xc9\xb7\x95\xed\xde\x30\xf5\xe7\xcd\xeb\xa9\x72\xc2\x2a\xd5\x09\x52\x06\xbc\x3e\xcd\x31\x9b\xfb\x71\xc6\xe1\x9a\x04\x38\x17\xb8\x4a\x82\x0d\x77\x75\x72\x14\x12\xda\x9b\x74\x8e\xe7\x56\xa7\x2a\xec\xbe\xde\xc2\x2d\x8f\xbe\xdd\x75\xbf\x78\x26\xc4\x0a\xbe\x7f\xd1\xac\x88\x16\x99\xb9\x9b\x84\x88\xe7\x93\x8f\x9f\x98\xfe\xf6\x84\xe3\x27\xa6\x9f\x4b\x32\x6e\x2a\x0e\x5b\x45\x42\x8e\x3e\xff\x4a\xa4\xc1\x66\xa2\xef\x6d\xad\x71\x5f\xd7\xb5\xaf\xeb\xfa\xad\xd7\x75\xb9\xa7\xd7\xe9\x3d\x7a\x02\x3f\x79\xc6\xab\x0a\x5f\xf8\xed\xdd\x56\xb8\xae\xfd\x85\xb5\xbf\xb0\xba\xad\xf1\xb5\xaa\xe8\x8e\x9f\x5f\x83\x8a\xde\xa9\xd4\x1e\xa3\x77\x79\x17\x1f\xc7\xfe\x2b\x23\x74\x97\xee\x65\x6f\x47\x08\xa9\xae\x72\x66\xab\x72\xad\x55\xbd\xb7\xae\xf2\x86\x5b\x35\xb1\xa3\x32\xc9\xdd\xaf\x2f\x2b\xa2\xec\xb5\x53\xdd\xcd\xfc\xb9\x84\xfd\x6b\x11\x11\xf9\xba\x5f\x54\x28\x18\x1d\xb7\x9c\xf2\x55\xcc\x24\xb8\x6b\x4d\x02\x5b\xf1\xdb\x42\x41\x7b\xfb\x4f\x4b\x89\x62\xc5\xef\x6c\xea\x18\x7c\x0d\x53\x2e\xcf\xc3\x7d\x18\xbe\xd0\x7d\x96\x8f\xec\x3e\x71\x28\xa1\xf0\x61\xca\x74\xba\xbc\xa3\xda\xd8\x11\x7a\xfb\xec\xb4\xa2\xd5\xb0\x22\x3b\xed\x86\xaa\xfb\x37\x99\x9d\x56\x9c\xf8\x13\x9f\xd9\xb5\x79\xf2\x9b\xcb\x6b\x58\xf7\x84\xed\x73\x1c\x36\x20\xdd\xb7\x9a\xef\xd0\x26\x42\x5f\xcd\x0c\x4b\x52\xfc\x5b\x3c\xb9\xc5\x3b\x69\x7f\x44\xdb\x68\xf4\xcd\x21\xd8\x95\x54\x8d\x15\x6b\x7b\x23\x48\x76\x65\x6d\x69\xd7\xb3\x7a\x9a\x14\xa8\x60\x37\xf6\x68\xc7\xdf\x28\xda\xf1\x7a\xc6\xcd\xda\x96\xcd\xba\x66\xcd\x7a\x36\x4d\xb3\x41\xb3\x45\x26\x75\xd1\xce\xd8\x34\x93\xba\xa0\xc7\xbf\x09\x6f\x4d\x61\xc6\xcf\x91\x49\xfd\x1b\x35\x3d\xf6\x76\xc7\x93\xd0\xed\x5b\x35\x3a\x5e\xb9\xc5\xb1\xcf\x01\xdf\x65\x0e\xf8\x3e\x05\x7c\x9f\x02\xbe\x2e\x81\xf6\x29\xe0\xfb\x14\xf0\xe0\xbb\xb7\x91\x02\x6e\xed\xc5\x6d\xb3\x17\xeb\x54\xf6\x5c\xa1\x2d\x00\xc3\x6c\xae\xbe\x9f\xc6\x6f\x42\x6f\x0f\xf0\x9a\xbc\x65\x9d\x3e\x87\xfe\xbe\x07\x26\xda\x03\x13\xed\x95\xb8\xdf\x92\x12\xb7\xd7\x53\x36\xa1\xd6\x5e\x4f\x09\xbf\xdb\x03\x13\xbd\x22\x60\x22\xa3\x38\x15\xf2\xd6\x56\xa6\x4f\x1d\xa7\x8c\x6a\xec\x4e\x96\xe6\x99\x54\x25\x05\xac\x4d\xbb\xc2\x01\x8c\x7e\xf5\x16\x94\x2b\x33\x4f\x9c\xf1\x1a\x79\x54\xe1\x0b\x0f\xfe\x65\x8d\x89\x5f\xd9\xbb\x12\x0e\xf4\x98\xc6\xbe\x27\x1c\x28\x48\x73\xba\x24\x33\xfa\xc0\xc8\x84\xf2\x04\xdd\x54\x56\x06\xb6\xac\xad\x6d\x42\xff\xa7\xdb\x84\x68\x71\x3a\x79\x52\xaa\x91\xe9\xa8\xe2\x44\x34\x21\x0c\x21\x54\xe1\x37\xd0\xb0\xce\xb6\x07\x1c\x33\x26\x82\x0c\xc7\x75\xe7\xbc\x13\xd5\xf4\xc5\x93\xd1\x42\xbe\x79\xf1\x3c\xb4\xe6\x26\xcf\xbb\xb3\xb9\xb6\x31\xb4\xd4\x9f\xde\x8a\x28\x78\x0e\xb3\xea\x1b\x0e\x7d\xec\xc3\x1b\xbf\x4d\xc4\xf5\x57\xa3\x92\xef\x0d\xdd\x1d\x1a\xba\x50\xba\xf2\x8d\x5a\xba\xfb\x70\x45\x0b\x71\xf6\x6e\x80\x4d\xa8\xb5\x77\x03\x84\xdf\xbd\x9d\x70\x45\xb3\xf6\xbc\x59\x3b\xc1\x27\xd4\xa3\xf7\x6a\xf4\x5e\x8d\xde\xab\xd1\xdf\xac\x1a\xfd\x3a\x28\xbc\xd7\xa1\xf7\x3a\xf4\x5e\x87\xde\xeb\xd0\x7b\x1d\x7a\xaf\x43\xdb\xa7\x76\xa2\x43\xc3\x5f\xae\x80\x78\x37\xd5\xc2\xeb\x45\xa4\x6c\xb9\xf0\x5b\x51\x9e\xf7\x8a\xf3\x5e\x71\x7e\xdd\x8a\xf3\xab\x59\xd0\xb7\x57\x23\xb8\xaf\xb2\xab\xdc\x82\xdf\x6c\x95\x9d\x6f\x26\xb0\x01\x50\x72\xe1\x33\x37\xd0\x73\xc3\x27\xf7\x9c\x64\xa4\x22\x26\x6e\x12\x9d\xc0\x94\xbf\xd8\x87\xde\x16\xf8\x5a\x75\xd6\x7b\x08\x65\x12\xec\xda\x1e\x42\xf9\x09\xd7\xed\xce\xd9\x8a\x95\x3b\x1e\x45\xef\xd5\x1b\x5d\xf6\x8b\xa7\xf9\x34\x9f\xf4\x17\x4d\xfa\xa9\xbd\x39\x2a\x05\x17\x79\x2b\xaa\xe7\x47\x8e\xde\xe6\x6a\xf8\xc4\xf4\xb7\x72\x2f\xec\xd1\xa3\xf7\x60\x9c\x1b\x37\x99\xea\x24\xe1\xdf\xd6\x12\xf7\x00\xd9\x7b\x80\xec\x3d\x40\xb6\x7f\xeb\x73\x00\x64\x6f\x73\x23\xe3\xeb\xbf\x95\x4b\x79\x0f\x92\xbd\xbf\x97\xf7\xf7\x72\xed\x12\x5f\xa1\xc1\xf5\x2a\x20\xc0\xbd\xc1\xb5\xab\xd2\xf6\x30\x94\xe5\x85\xf1\x4e\x2b\xdc\x1d\x25\xf7\x55\xee\xf6\xff\xf6\x55\xee\xeb\x2c\x6e\x5f\xe5\xbe\x4f\x5c\xda\x57\xb9\xef\x53\x73\xf6\xa9\x39\xfb\x2a\xf7\xb7\x52\xe5\xee\x14\xa8\x5d\x54\xba\xd7\x28\x63\xab\xab\xdd\xbf\x54\x2d\x83\x57\xab\x68\xb9\xb9\xee\xab\xde\xf7\x55\xef\xdb\xf2\xce\xab\xb0\xc9\x9e\xa4\xfa\xbd\x46\x0c\x6c\x6b\x88\xbd\x8d\x2a\x78\x37\xdb\x7d\x09\xcf\x3e\x13\xf1\xf5\x67\x22\xbe\xba\x12\x9e\x57\xa3\xb6\xef\x8d\xe1\x1d\x1a\xc3\xfb\x2a\x9e\x7d\x15\xcf\xde\x55\xb0\x36\xb5\xf6\xae\x82\xf0\xbb\xb7\x51\xc5\xb3\x5a\x9b\xde\x49\x35\xfc\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\xf6\xa9\x9d\xe9\xd4\xbb\xad\x8e\xef\x18\xc5\x0a\x2a\x2e\xde\x92\x32\xbd\x57\xa4\xf7\x8a\xf4\xeb\x56\xa4\x5f\xcd\x82\xf6\x95\xf2\xfb\x4a\xf9\xca\x37\xaf\xb7\x52\xfe\x77\x96\x11\x0e\x02\xd9\xef\x2f\x89\x83\x1f\x12\x39\xbe\x59\x2e\x98\xf9\xef\x09\x9f\x33\xa1\x40\x63\xe1\x7a\x19\x5e\x9c\x0d\x04\xae\x92\xf6\xe0\xfa\xf4\xfc\xd3\x59\x58\x43\x72\xf0\xf9\xf6\xec\xe6\xf4\x72\x70\x75\xe3\x66\xe8\x57\x15\xd2\xc2\x3e\x57\xb8\xfb\x8f\xe5\x7c\x41\x53\xae\xa4\x18\x7e\x5d\xa4\x4c\x99\xa9\x5d\xc0\x6d\x2b\xd3\xcd\x66\x37\xfc\xaf\x70\x66\xe7\xc5\x7f\x7e\xba\x29\xfe\xab\xb0\x8a\xb3\x9b\xe2\xbf\x86\xad\xab\x09\x06\x2e\x9f\xa0\x43\xf2\xe9\xe6\x03\xf9\x04\x51\xff\x94\xdc\xcc\xa8\x80\x0a\xa5\xb3\x9b\x0f\xe4\x8c\x29\x05\x9f\xe4\x0f\x6b\xae\x13\x58\xdb\x0f\x5c\xd0\x74\x49\xdc\xf2\xb1\x18\x89\x82\x3b\xd0\x91\xa6\x4c\x3c\xf1\xb7\x4c\x80\xc2\x9a\x53\xef\x4c\x4e\x79\x44\x93\xed\x88\x38\x38\x0f\xcf\xcb\xc1\xc5\x55\x2b\x29\xc2\x5f\x57\x69\x31\x38\x3f\x81\x22\x2c\x37\xd5\x9a\x95\x9f\x33\xa5\x59\x6c\x2e\xc0\x18\x99\xd7\xd8\x1a\x6c\x19\x5c\x8c\x7f\x93\x5c\xb0\x98\x64\xca\xa8\x6b\x83\xf3\x13\x72\x44\x2e\xae\x46\xe2\x22\x8d\xd1\x5f\xc0\xcc\x8d\x82\xb6\x0a\x57\x44\x48\x4d\xf8\x7c\x21\x53\x4d\x85\x36\x97\xa9\x11\x64\xd2\x52\x44\x11\x9a\x32\x72\x2c\xe7\xf3\x4c\x53\xcd\x1f\x58\x85\xa8\x02\x8d\x80\x6b\xa6\x4f\x63\xf0\x40\xd6\xd0\x50\x8e\x0b\x8a\xce\xc1\x22\x35\xe3\x6b\x5e\xd2\xfe\x0e\x78\x5c\x51\x07\xdd\x10\x34\x4d\x69\x51\x0c\x1e\x70\xcd\xe6\xe5\xdf\xaf\x99\x29\xf6\x6b\xad\x6e\x7d\x42\x35\x3d\x93\x34\xe6\x62\x8a\x75\x70\x67\x5c\xb3\x94\x26\x9f\xe9\xe2\xa3\x73\x70\x6c\xc0\x1f\xff\x79\x7d\x71\x1e\x32\xc8\x5f\x06\x9f\xcf\xc2\x7f\x5f\x5e\x5d\xdc\x5c\xb4\xf2\x4c\x61\x84\x2a\xd3\x98\xaf\x3f\xc0\xff\x92\x23\x62\x46\xf7\xca\xc2\x9c\x69\x1a\x53\x4d\xc9\x3b\xac\x15\xf1\x19\xe5\x5c\x24\xc0\x23\x8b\x94\xcf\xb9\xd9\x57\x6b\xa5\xbd\x07\x66\x22\x29\x33\x27\x84\x09\xed\xb9\x04\x1f\xc0\xba\x2f\xb8\xe9\x34\x15\x31\x4d\x63\xf2\x37\x25\x85\xbf\xf7\xf0\xe7\x54\xb9\x0f\x58\x4c\x0e\xc9\x4c\xeb\x85\xfa\x70\x74\xf4\xf8\xf8\xd8\x37\xbf\xee\xcb\x74\x7a\x64\xfe\x38\x64\xa2\x3f\xd3\xf3\x04\x0e\x3c\x50\xe1\x03\xb9\x4c\xa5\x96\xe6\x85\x94\x28\x96\x72\x9a\x40\x35\xda\x18\x4f\xbb\x9c\x90\xbf\x46\x32\x65\xfd\x7c\x63\xfe\x8a\x66\x08\x8b\x09\x17\x64\x92\x2c\x35\xe3\x71\x72\x64\x7e\x54\x73\x74\xca\xfb\x49\x62\x16\xf1\xd8\xde\xdd\x4c\x44\x32\x06\x97\x07\x7e\xc7\x85\x2f\xb0\x61\x36\x7a\xe0\xc9\x69\xed\xfa\x31\x23\x73\x1a\x33\x42\x1f\x28\x4f\xb0\x4c\x54\xa2\x97\x0a\xe9\xcc\x52\xd5\x27\x23\x71\x8a\x9a\x4e\x66\xb4\x3a\xc8\xf7\x02\xdb\xc5\xfd\x76\x61\x56\x1c\xc9\x84\x8c\xb3\x89\xd1\x0a\x82\x6b\xa9\x47\xb8\x36\xb4\x48\x59\x24\xe7\x73\x26\xd0\x91\x65\x06\x82\x27\x81\x64\x76\xba\xfd\x91\x00\x06\xa0\x22\x46\x16\x88\x25\x9c\x6c\xc1\x8c\x86\x2c\x96\xf8\x9a\x71\x36\x29\x44\x47\xb4\x24\x29\xa3\x31\xe1\x7a\x24\x06\x89\xb1\xa5\xe6\x52\xb3\x30\x71\x0d\x5c\xa9\x05\x8a\x83\x44\x48\xd9\x22\xa1\x91\x2b\x04\x4c\x64\x44\x13\x32\xe1\x09\xb3\xed\x91\x83\x01\xde\x81\x7a\x6f\x88\xc6\x15\x89\xe5\xa3\x48\x24\xb5\xeb\x28\x3f\xf6\xbe\x28\x5c\x7c\x43\xf1\x61\x9a\xca\x14\xfe\xe7\x27\x2e\xe2\xcd\x0e\xe1\xed\xf9\x4f\xe7\x17\x5f\x0a\xe7\xf0\xf6\x7a\x78\x15\xfe\xfb\xfa\x2f\xd7\x37\xc3\xcf\xad\x07\xb1\x3c\x4a\xce\x5a\x30\x3d\x50\xfb\x3e\x90\x6b\x24\x82\x4c\x89\x51\xe4\x1b\x16\xf5\xd9\xf2\x52\xfe\x81\x8c\xd9\x66\x6b\xfb\x3c\x38\xbf\x1d\x14\x44\xca\xf5\xf1\x8f\xc3\x93\xdb\xb3\x82\x22\xe7\xd6\x17\x7c\x72\x35\x44\x35\x2d\xfc\xec\xf8\xc7\xd3\xb3\x93\x3b\xaf\xd8\xb5\x51\xa3\xf4\xde\xb2\x60\xba\x41\x01\x34\x93\x31\x19\x2f\xc3\x62\xb5\xbc\x68\xf8\x91\x2a\x92\x80\x33\x9e\xc5\xfd\x11\xde\xfc\x38\xea\x07\x90\x43\xf6\x65\xc1\x13\x73\x19\xb3\x9e\xfd\x8d\xb9\xb6\xb0\xb6\xda\x28\xd7\xe0\xa3\xa8\x1b\xd8\xbc\x9d\x0a\xc2\x45\xcc\x1f\x78\x9c\xd1\x04\x6b\xa0\x3d\x8d\x3e\x90\x01\x51\xe6\x87\x99\x39\xc0\x29\x9f\x4e\xc1\xac\x2c\x4d\x15\x47\xb3\x8f\x02\x25\xe1\x39\xdf\x0e\x1c\x8e\xb4\x79\xad\xf5\x47\x70\x23\x0e\x8c\x1c\xc6\x07\xa1\xe6\xbb\x38\x62\x4a\xf5\x8c\xa5\x75\x53\x73\xfb\xf2\x01\xbd\x88\x0d\xcb\x82\xa3\x97\x67\x95\x82\x88\x52\x68\x0d\x2f\x52\xf6\xc0\x65\x16\x3c\x6a\xcb\xd3\x0b\x9b\x5b\x3b\x7c\x4e\x00\x20\x9b\x84\x39\xe6\xc3\x14\xb9\xf9\xf4\xe2\x5a\xa7\x54\xb3\xe9\xf2\xc4\x9e\xec\xcd\xb9\xf8\xe4\xe2\xcb\xf9\xd9\xc5\xe0\xe4\x6e\x38\xf8\x54\x3c\x98\xfe\x9b\xeb\x9b\xab\xe1\xe0\x73\xf1\xab\xbb\xf3\x8b\x9b\x3b\xf7\x8b\x56\x76\x6d\x78\x41\xf5\x3e\x2d\xfe\xf0\x03\x31\x92\x11\x24\x98\x43\xb2\x09\xc4\xd8\x98\x4d\x64\x8a\xe2\x78\xee\xe2\x4e\x20\xf9\x89\xa7\x2c\x8b\x81\xf6\xa5\x55\x7c\x20\x27\x0d\x43\xa2\x3f\x43\xa7\x8c\xce\x41\x9c\x53\x41\x86\x22\x3e\xbc\x98\x1c\x5e\xe3\x87\x73\x9a\xde\xb3\xd4\x3f\xfa\x98\x72\xad\x19\xb8\x61\xb9\xf5\xd0\x12\xea\xa6\x6c\xee\x1b\xc8\x2b\xce\x5f\xd0\x27\x57\x46\x3c\x9b\xdf\xfb\xbb\xc7\x30\x6a\xcc\x34\xe5\x89\xb2\x93\x2d\xd0\xf5\x03\x39\xa3\xe9\x94\x11\x54\xe4\x14\x79\x27\x27\x13\x1c\xec\x3d\x4e\xc3\x5c\x35\x85\x55\xd4\x88\x48\xc3\x1a\xee\xfa\x82\xf7\xd9\x1f\x7b\x2d\xad\xca\x55\xb7\x8b\xed\x78\xea\xf6\x12\x28\x7e\x71\x7e\x37\xfc\xef\xd3\x82\xc5\x62\xbf\xa9\xe1\x35\x58\x38\x7e\xdd\x7e\x17\xd4\x8f\x5d\x65\xa7\xe2\x0f\x6b\xd8\x29\x5b\xb8\x9d\x9f\x18\x1b\xa8\x86\x97\xd8\x57\xae\x71\x63\xc2\x79\x97\x58\x28\x1f\x46\x19\xbd\x81\x2e\x16\x8c\x1a\x05\xa4\xba\xdb\x45\x75\xad\x61\xef\xf1\x4d\xe1\x3b\xec\x26\xbb\xf7\xf4\x88\x14\xc9\x32\xbc\xeb\x4b\x1c\xb9\x06\x0f\xe0\x58\x15\x0e\xb8\x72\x11\x4d\xf7\xc7\x50\xe8\xb4\xd6\x02\x5f\xd7\xb4\xb0\xfe\x9d\x82\x6d\x51\xef\x06\xae\xbc\xfb\xbc\xec\xb0\xab\xba\xc9\xad\x93\xc7\xbc\xa4\x9f\x5b\x1c\xa1\x7f\x18\xd4\xeb\x26\xe3\xa6\xc6\x4f\x93\x93\xec\x67\x70\xff\xcd\x33\x05\xc4\xa7\x18\x69\x22\xf7\x7f\x56\xe4\x97\x8c\x42\x25\x41\x9f\x5c\x33\x36\x12\x4e\xcf\x9e\x72\x3d\xcb\xc6\xfd\x48\xce\x8f\x72\x6c\x91\x23\xba\xe0\x73\x6a\xee\x21\x96\x2e\x8f\xc6\x89\x1c\x1f\xcd\xa9\xd2\x2c\x3d\x5a\xdc\x4f\x21\xa8\xe0\x5c\x55\x47\x7e\xd8\xa9\xfc\xa7\xb3\x7f\xfe\xfe\xf0\xec\xcf\xdf\x1f\x54\x2d\xa7\x26\x7e\x1f\x8a\x88\x2e\x54\x96\xd8\xe0\x63\x1a\xd2\x06\xc4\x19\x50\xa2\xbf\x62\xbf\xcf\x8b\xdb\xb5\x9d\xa2\x77\x7c\x79\x5b\xf0\x64\x14\xff\xf9\x79\xf8\xf9\xe2\xea\x2f\x05\x45\xe9\xe6\xe2\x6a\xf0\xa9\xdd\xa3\x51\xd1\x04\x4b\x64\xf8\x49\xc8\x47\x51\x5c\xbd\x2a\x2f\x3a\x13\x9a\xcf\x99\x53\x04\xed\x3f\x6f\x70\xa5\x1b\xac\xfc\xe2\xe6\xc7\xa2\x2c\xfb\x78\xf6\x97\x9b\xe1\xdd\xf5\xc9\x4f\xad\x2b\xc1\xc7\x0a\x33\xbb\x86\xc8\xc9\xb1\x4c\xb2\xb9\x08\xff\xde\x7c\x6e\xa7\xe7\x37\xc3\x4f\xe5\xd9\x5d\x0c\x6e\x8a\x64\xbf\x2a\x06\xe4\x0e\x7e\xb8\xb8\x38\x1b\x0e\x0a\x7b\x79\x32\xb8\x19\xde\x9c\x7e\x2e\xf8\xa2\x4e\x6e\xaf\x06\x37\xa7\x17\xe7\xad\xcb\x74\x33\xa8\x59\xa8\x59\x56\xb8\xcc\x5d\xcb\x99\xb5\x8e\xf9\xc0\x26\xbb\xe0\x41\x39\x0c\x2a\xa1\x31\x8e\x05\xb6\xc5\xa1\xb7\xec\x23\x9c\x69\xad\xac\xd1\xc5\x6d\x22\xcd\xb2\xae\x75\xa3\xdb\x44\xde\x8d\x9f\x02\xcc\xcb\x86\xbb\x69\x92\xc8\x47\x4c\x39\x98\x73\xcd\x62\x07\x4b\x61\x7e\xa2\x48\x94\xa5\x29\x13\x3a\x59\xf6\x6b\xc4\x49\x71\x5b\x64\xaa\x4f\x7c\x50\x7a\x33\x6d\xb2\x2e\xc2\x5b\x8d\xed\xd6\x2b\x8a\xa5\x78\xae\x9b\x16\xb4\x9f\x91\xd3\xcf\x4c\x29\x3a\x65\xdb\xb8\x84\xea\x84\xd4\xf5\xcf\xe1\x3f\xc1\xe5\xb3\x8e\x00\x2a\xcc\xd0\x45\x2f\x9d\x4c\xb9\x10\x1f\x29\x4f\xb2\x94\x5d\xca\x84\x47\x1b\xba\xb0\x3f\x0e\x4e\xcf\xee\x4e\x3f\x7f\x1e\x9e\x9c\x0e\x6e\x86\x67\x05\x51\x09\xdf\x0d\x3e\xde\x0c\xaf\xee\x10\x15\x69\xf0\xc3\xd9\xf0\xee\xfc\xe2\x64\x78\x7d\x77\x7c\xf1\xf9\xf2\x6c\xb8\xc2\x33\xdc\x38\x78\x55\x8f\x2a\xff\xf4\x43\xe5\x13\xc2\x6d\xe6\x8a\x8d\xc6\xa0\x71\xa6\x25\xd4\x03\x82\x5b\x4a\xa2\x7b\x8a\x12\x61\x14\x11\xf3\x31\xb8\x38\xcc\xaf\x5d\x5c\xbb\x4f\x4e\xf5\x77\x49\x42\x68\xa6\xe5\x9c\x82\x6d\x95\x2c\x47\x82\x8e\x65\xaa\x41\xaf\xf6\x7c\x4c\xd2\x4c\x08\x63\xd8\x99\xc1\x10\x0b\x2c\x4a\x18\x15\x24\x5b\x04\x39\x59\xd6\x42\x98\x70\x61\x06\x02\xe5\x1d\x8d\xc1\xfc\x95\xb9\x7d\x65\xec\xb7\x91\xc0\xf2\x45\x34\xd9\xd6\xa1\xf0\x87\xb5\x7e\xd5\x48\x9d\x39\xbd\x67\x86\x2a\xf3\x2c\x9a\x19\x25\x71\x9a\x1a\x5b\x16\xb5\xc8\x88\x0a\x74\x09\xda\x9f\x1b\x15\x6f\x24\x8c\x26\x48\x13\xa7\xac\xc6\x6c\xc1\x44\xcc\x44\xc4\x31\x13\x0b\xbc\x69\xde\xa8\x9c\xa6\x74\x31\x23\x4a\x82\x17\x0a\xc8\x0e\xe6\x3a\x3e\x44\x24\x12\xdf\x16\x6c\xc2\xd7\xa1\xae\x99\x66\xc6\x72\xbd\x00\x23\x14\xa9\x0c\x0f\x3b\x45\xd3\x19\x58\x88\xae\x36\x5f\x24\x0c\x5e\x69\x49\x0e\x9b\x61\x68\x5d\xd8\x0f\xb3\x4d\x75\x9b\x30\x12\xf9\x9c\xa9\xb2\x33\xea\xd7\xe8\xb0\xf6\x48\x91\x1f\xa9\x88\x13\x33\x8a\xb3\x56\x8a\x67\x11\xd2\x09\x06\x86\x6b\xdc\x69\xdc\xe6\x5e\x89\x68\xa6\x3a\x5d\x2c\xed\xe9\x73\x14\xbc\x91\x87\xb9\x9b\x16\xd8\xdb\xe6\xce\x01\x75\x17\xd4\xf0\x40\x22\x2d\x95\xf0\xe7\x19\x42\xb8\x12\x98\x4d\x83\xa6\xbb\x48\xb9\x88\xf8\x82\x26\x1b\x5d\x83\xa5\x80\xaa\x2d\x95\x7d\xc7\x27\x86\x7d\xde\x57\x9c\x2b\x9a\xa5\x73\xc8\x23\xb5\xd3\xf4\x5b\xb8\xea\x8a\xc1\xdd\x31\x8c\x4c\x8b\x11\xc0\x0d\xf6\x06\x5d\xe7\x4d\xcb\x2d\x8d\x62\xdf\x8e\xb1\x1b\x9a\x5c\xd6\x8f\x59\x47\xb0\xe0\xcb\x5f\xdb\xb6\xfa\x33\x5d\x98\x2d\x46\x30\x37\x42\xf3\x35\xda\xf4\x50\x8b\xc3\xeb\xfc\xcf\x81\x43\xca\x87\xe2\xd7\x57\xf7\x73\x12\xda\x08\x42\xf5\x25\x05\xc7\x5c\x90\xb9\x6b\x59\x72\x92\x69\x73\x9a\x28\xb8\xf6\xc8\x3b\xd6\x9f\xf6\xc9\xc5\xcf\xc3\xab\xab\xd3\x93\x61\x8f\x0c\x2e\x2f\x87\xe7\x27\x3d\xc2\x74\xf4\xde\x85\xb8\xac\xc7\x7f\x24\xb4\xb4\xa6\xec\x92\xcc\xe4\x23\x88\x32\x96\x4e\x59\x61\xcd\x2e\x3c\x00\xf5\xd8\x53\xae\x74\x6a\x83\x14\x22\x0e\xd1\x0b\xf9\xbc\x6c\x93\x20\x87\x64\x7a\xb6\x0d\x6b\x50\xa5\xb2\x39\x1d\x27\xec\x8e\xd3\xf9\x5d\x2a\x93\x55\x67\xb8\xf6\x48\xe5\x66\xdc\x9d\xc2\xe8\xf6\x1d\x8d\x22\x99\x09\xbd\xf6\x68\xab\xf6\xf1\x04\xc8\xa4\xc8\xc2\x1c\x28\x88\x8d\x56\xf1\xfe\x82\x5b\x2a\x82\x78\x2d\xf8\x08\x41\x64\x24\x79\x46\x35\x6c\x49\x13\x2d\xaf\x8a\x14\xd8\xd3\x13\xe9\x59\x47\xae\x63\xc4\xdd\x74\x16\x71\x80\x8c\xb8\x0d\xfd\xea\x46\x69\x1b\x89\x3c\xb9\xb8\x3a\x46\x39\x55\x07\x38\x89\x31\x83\x12\x7e\x38\x84\xa4\x4a\x40\xa9\xc8\x8f\xe6\x20\xa3\xfc\xf8\x25\x93\x9a\xaa\xf7\xfd\x91\x30\xc2\xf0\x9e\x2d\x31\x8e\x6d\xc4\xcd\xef\xcd\x15\x78\xa8\x98\x50\x10\xf7\xfc\x3d\x9a\xe6\x46\x60\x3e\xd0\x94\x1b\xd6\x42\x8d\x10\xf1\x59\x8b\x58\x98\x10\xaa\xb2\x83\x5a\x69\x97\x47\x02\x73\x00\x4d\xf7\x1d\x4e\x7f\xca\x34\x64\xa7\x69\xae\x41\x55\x89\x11\x00\xb6\x32\xf5\x95\x56\x11\x70\xc5\x09\x66\xd6\x6d\x15\x64\xdf\xe4\xc8\x74\xb5\x6b\xcb\xc7\x81\xab\x45\x42\x97\x15\x0f\xd9\xaa\x63\x74\x6e\x36\x67\x41\x23\x96\x67\xf6\xb9\x24\xc8\x48\xce\xe7\xe0\x80\x74\xd9\xfc\x31\x9f\x80\x27\x52\x9b\x23\x46\xc6\x4c\x3f\x82\xdf\xdb\x7d\x4a\xec\x51\x07\x35\x98\x0a\x44\xd7\x05\x6e\x19\x19\x5a\xc5\x19\x58\x9b\xa3\x83\x1e\x19\x1d\xc4\xec\x81\x25\x72\x31\x67\x42\x9b\x0f\x98\xae\x15\x68\xc3\x39\xe5\xc9\xb9\xd4\xde\x95\xba\xcd\xb6\xa4\x2c\xe2\x0b\xce\x84\x56\x77\xcc\x8c\xfb\xa4\x89\x10\xab\x4c\x7b\x57\x32\x00\x33\x21\x34\x8e\x8d\x45\x00\xa0\x92\x6e\x92\xd6\x11\x81\xf9\x23\x9e\x00\xeb\xf1\xb0\x0f\x79\xee\x96\x8d\xeb\x5d\x1c\x91\x4c\x3d\x86\x8e\x7f\x71\x0e\x03\xd8\xca\xb5\x16\x54\x34\x07\xab\x73\xd6\x4d\xd5\x70\x6b\x50\x86\xcd\x5d\xb8\xde\x3c\x8b\x94\xb9\x36\xcf\xb5\x4e\x4d\x85\xd5\x2d\x0e\x59\x3a\x57\x6d\x6c\x34\xb0\x1c\x80\x64\x2b\x67\x1c\x25\x52\x65\xe9\x9a\xfe\xa3\xe2\xa4\x8f\xed\xa3\x6d\xf3\x1e\x86\x9a\x60\x96\x68\xd5\x49\xd9\xac\x21\x7c\x9e\xab\x82\x28\x3b\x70\xb8\xb5\xbd\x65\xed\xaf\x7b\x84\x8b\x28\xc9\x20\xbb\xc3\x58\xf0\x2e\x54\x2a\x62\x92\x5f\x6d\x23\xe1\xd3\x3b\xa8\x22\x8f\x2c\x01\x8f\x81\xb1\x2a\x41\x6c\xdb\xe9\xda\x91\x58\x4c\x94\xa6\x9a\xf5\x88\xcc\xb4\x19\xac\x87\x20\xdc\x76\x0b\x0e\xc7\x14\x4a\x6c\xf2\xd6\x1a\x23\x71\xab\x5c\x6c\xcf\x57\x46\x20\xaf\xa3\x00\xe3\x82\x7c\x62\x1a\x46\x81\x52\xb5\x70\x81\x08\x36\x5e\x2b\x82\xca\xb4\xdf\xe2\x44\xd9\x95\x74\xd8\xf9\x3c\x29\xe4\x87\x44\x8e\x5b\xf7\x7d\x40\xe6\x68\x96\xd8\xb7\x38\xaf\x4b\x6e\x90\x06\x29\xfd\xab\x78\x94\xa5\x69\x21\x59\x6f\xc5\xf1\x2f\x26\x92\xb4\xb3\x27\xa4\x71\x70\x81\x49\x35\x90\xfb\x54\x9e\xa7\x75\x55\xac\x9a\x23\x18\xd4\x77\x6f\xc7\x6c\xc7\xf9\xce\xab\xae\x8a\x55\x4c\x50\x74\x71\x3c\xf5\x62\xe0\x80\xe8\x19\xe3\x29\x59\x6b\x59\xee\xfc\xde\xe1\x99\x5f\x9f\x69\x72\xde\x6e\xf2\x54\xa0\x10\xf1\x02\xc2\x4c\xcc\x96\xd6\x15\x90\xf1\xfb\x23\x51\x9a\x84\xf5\x7d\x29\x02\xec\xe5\x4e\x43\x41\xf6\xf7\xc8\x84\x7f\xb5\x83\xba\x24\x98\xfc\xa7\x81\xb5\xd5\xe0\x83\x99\xd1\x2a\xdb\x75\xb8\x1f\x2f\xe1\xf9\x56\x27\x83\x54\xc6\xa0\x8e\x8c\x62\x95\xb2\x48\xa6\x46\x24\xc2\x6b\x7d\x88\x62\xe5\xdd\xa8\x69\x6a\x88\x42\x57\x59\x5d\x85\x79\xe4\xa5\xa6\x31\xd5\xec\xd0\x18\xee\x2b\x82\xb3\x0b\x69\x5e\x43\xf8\xdc\xd8\x16\x41\x4e\x5f\x2e\x61\xc7\x6c\x4a\x85\xf3\xe6\x36\xcc\xd6\x89\xf6\x2d\x0e\xb3\xd1\xac\xe8\xdc\x98\x99\xa0\x47\x98\x09\x15\xe7\xa1\x16\x40\xce\xd6\x79\x58\xcb\xfb\xb9\xa8\xa6\x5b\xc8\xf6\x48\xbd\x23\xa0\x61\xb2\x19\x74\x34\x7a\x35\x93\x4d\xa8\xd2\xc4\xce\xa9\x61\xc6\xa1\x36\xbb\x83\x64\xe4\x36\x54\xea\xd0\x70\xe8\xa2\x9c\x87\x53\x24\x8a\x69\xcd\x2d\x7a\x72\xa6\x98\x4d\x21\x99\xb3\x74\xea\x14\x3e\x04\xd4\xf3\x47\xdb\x22\xeb\x39\x39\x1a\xca\x12\xf0\xeb\x57\x87\xee\x93\x81\xa8\x24\xc2\x39\x1f\x46\x81\x5e\x28\xb5\x69\xf2\x48\x97\x8a\x2c\x52\xcc\x3b\x41\x67\xbf\x5b\x3c\x38\xed\x8a\x0f\x39\x0f\x9d\x51\xa8\x30\xda\x42\xc0\xd0\x0b\x66\xd6\xb0\x59\x01\x74\xfa\xfa\xc2\x6e\x4d\xdd\xbf\xe4\x88\xae\x03\x52\xf7\x26\x50\xad\xa4\xab\x28\xb3\x79\xae\x68\x98\x22\x61\x6b\xa0\x40\xb7\xb4\xd6\xc5\xb0\xe8\xc4\x6e\x52\xf8\xc0\x05\x72\x46\xc7\x2c\xd9\xda\x79\xbd\x91\xab\x1e\x5e\x6d\xab\xd3\x8c\xf9\xcd\xd0\x19\xcf\xc8\xe3\x8c\xa5\x65\xd1\xe6\x9c\x38\x69\xb6\x9e\x6b\x3e\x5f\x67\x01\x0f\x72\x8b\x85\xba\x72\xcb\xcd\xe5\x77\x53\x29\x66\x78\x91\xe4\xb5\x98\xf5\xb7\x48\xd9\x7d\xb3\xcd\x1c\x82\xa2\xc9\xda\x29\x90\x5d\x94\x4d\xee\xc4\x1b\xe4\x79\x66\x4d\x88\x90\xd3\x09\x11\x52\x30\xc2\x55\xfe\x63\x5d\x0c\x42\x92\x29\x13\x2c\x85\x5c\x47\x97\x39\x51\x05\x20\x7e\x66\xa3\x7c\xe0\x8d\x49\x32\xe1\x2c\x89\x15\x11\xcc\xd8\x34\x34\x5d\x42\xbe\x3b\x0a\xb4\x75\x74\xa3\x5d\x69\xab\x35\xd7\x87\x55\x23\x5d\x09\x21\x40\x1e\x18\x4d\xac\x34\x2f\x82\xf5\x00\xf6\x47\xf6\x21\x9b\x85\x36\x12\xde\x0a\x06\xfe\xe3\xca\x58\x77\x7d\x02\xdb\xa6\xf3\xa7\xcc\x1d\x63\x3e\x70\x7b\xd8\x73\xba\xac\x42\xc0\x80\x2e\xb6\xbf\xbb\xb7\x72\x3a\x16\x13\xbe\x5d\x61\xca\x94\x3f\x30\x51\xdb\x98\xc8\x31\x45\x52\x70\x43\xb6\x4b\x1d\x8b\x60\xfc\x0a\xfc\x54\xeb\x53\xca\x6c\x72\x56\xf1\x5c\x21\x3e\x71\x6e\x64\x27\x4b\x1f\xc4\x09\x4d\x15\x5b\xab\x82\xfd\x65\xa8\x22\xbf\x17\x52\xff\x3e\x28\xe7\x71\xe6\x30\x02\x5c\x5b\xd7\x44\xaf\x50\xd9\xca\x5d\x6e\xb2\x65\x12\x42\xfd\x59\x8d\x57\x53\x7e\xdb\x1a\xb2\x3c\xa8\xf2\xa4\xda\xdb\xb0\x1a\x68\x6e\x82\x06\x40\x74\x9b\x9d\xf9\x00\x9e\xa3\xb5\x02\x41\x36\x48\x19\x84\x4d\x84\x24\x73\x99\xb2\x12\xc2\x0e\x0a\x6f\x9f\x89\x81\xc8\x26\xeb\x73\x69\x8d\x3b\x0c\x51\x43\xf2\x63\x5e\x70\x83\xb5\xbb\xbf\x76\x91\x62\x31\x2f\xa6\x99\xb7\x70\xc0\x8a\x22\x9e\x7a\x93\x7c\x93\xb4\x88\x26\x9d\xd4\x3b\xa2\x43\x28\xf1\xa6\xd2\x95\xfe\x48\x7c\x94\xa9\xbd\x3b\x95\x2d\x0b\x1d\xd3\xe8\xfe\x90\x89\x98\xd0\x4c\xcf\xb0\x84\xc4\xfa\x8e\x97\x76\x67\x8d\x5e\x00\x2c\xe0\x4b\x14\xb8\x8a\x68\x6a\x85\xfe\x84\x3e\x48\x37\x8b\x91\x08\x06\x81\xc2\x53\x28\x6e\x07\x00\xae\x26\x05\x82\x01\x98\x48\x13\x2d\xea\x60\xa6\x2a\x20\x53\xed\x67\x26\x84\xaa\x19\xc1\xfb\x58\x2c\x98\x52\xa3\x03\x9c\x75\x89\x42\xa7\xce\x1f\xe5\xec\x1b\x15\x02\xf6\xfb\x5f\xf6\x6c\xc2\x13\x7a\x64\xec\x2a\x8c\x9a\xf2\xbd\x93\x9d\x85\x82\x9a\x49\x96\x42\xea\x52\xdd\x98\xef\xa2\x19\x4f\x72\x1f\xf5\xfb\x9e\x3d\x8f\x38\x64\xc2\x1e\x58\x82\x85\x97\x51\xca\xe6\x4c\xd8\x68\xfb\xf7\xe4\x3f\x10\x7e\x89\xfc\x71\x24\x3e\x81\x58\x4d\x92\x65\x8f\xf0\x49\x3e\x32\xd5\xa5\x61\xee\x6b\x27\x60\xb6\x0c\x25\x4b\x61\x22\xb8\xdf\x33\xfa\xc0\x46\xc2\x0d\xf3\x1f\xe4\x9e\xfc\x81\xfc\xb1\xc9\x91\x63\x8b\xa7\x9e\xda\xce\x07\x2e\x76\xef\x0a\x24\x43\xcf\xaa\x8f\x20\x39\x9c\x1b\xa0\xd8\x9d\xd2\x9b\x6a\x5e\xc1\xf5\x15\x5f\x5c\x3c\xc8\x6a\xf4\x2a\x3c\xb9\x34\x65\x42\xdf\x09\x19\xb3\x3b\x56\x13\xba\x6a\x11\x14\xe6\x52\x3f\x97\x31\x5b\x19\x78\xf2\x0a\xf2\x17\x70\x5d\xa8\x6c\xec\xb7\x03\x72\xe2\xbc\xd1\x5d\x64\xb0\xfa\x09\xfb\x8a\x8c\x4d\xa6\xbb\x69\xac\xec\xc2\x6a\x57\x3d\x90\xe8\x76\x02\xf5\xf1\x1a\xec\x7b\x0a\xe9\x47\xe5\x53\x58\xf6\x10\x9b\x1f\x9b\x95\xdb\x3b\x27\xa8\x35\x81\x2a\xf5\x94\x4f\xb9\xd1\xb6\xd7\x8f\xc7\x81\x10\xdc\xc4\xcd\x8d\x45\x9d\x6b\xf9\xb9\x73\x52\x2c\x12\xaa\x0d\x97\x1f\x7a\xb6\xcb\x63\x4c\x63\x99\x95\x75\x6e\x4b\x00\xae\xc2\xc4\x28\xab\x5e\x2f\x8d\x08\x9e\x62\xd2\x0d\x9b\x71\xac\x0b\x1b\x1c\x9f\x11\x73\x28\xe4\x9c\x21\xf8\x96\x21\x5a\xa6\x67\x32\xe5\x7f\x6f\x0c\xc8\x36\x6b\xd8\x79\x20\x2d\x68\xfa\x09\xf3\x2c\xea\xda\xc0\xa3\xa8\x19\xe8\x82\x21\x51\x67\xe1\x90\xb1\x79\x3e\x05\xe5\x63\x92\x25\x58\x73\x1c\xc9\x34\x46\x28\x48\x55\x6c\x31\x9a\xba\x66\xb5\x98\xb2\xe5\x06\xe4\xb6\x78\xc4\x56\x35\x47\x33\x2a\xa6\xed\x7a\xe4\x7f\x65\x2c\xdb\x51\xd2\x8c\x85\x1a\x79\xa1\x70\x3c\x9d\xaa\xbc\xdf\x2e\xd2\xc6\x88\xe4\x52\x8b\x5f\x1b\x90\xa7\xea\x3e\x77\xa8\xf9\x1a\x02\x34\xa3\xcb\xf6\xfc\x1a\xce\x97\x2b\x7b\xfc\x76\xe0\x7e\x79\x8e\x78\x7d\x55\x3f\xaa\x91\x3f\xc0\x7f\xb6\x9a\xf7\x59\xbd\x1b\x5e\x86\x97\xf4\x8e\x5d\x7b\x3a\x3a\x58\xd2\x6e\x52\x76\x86\x56\xb8\x56\x83\x9b\xf5\xdc\x71\x5d\xf4\xa3\x74\x66\x09\x7c\xf7\x1d\x84\xb1\xb6\x76\xdf\x06\x6e\xc9\x3c\x15\x11\x73\x51\x5d\x96\xf8\xd3\xba\x5a\x8a\x81\xc1\x62\x36\x6c\x10\x17\x6c\xca\x52\x0e\x66\xb4\xc1\xed\x54\x35\x84\xea\xe7\xe6\xbe\x5e\x77\x2a\xad\xe1\x90\x35\x83\x1b\x60\xd1\xb7\x1d\xdb\x33\x9b\x6d\x54\x0c\x0b\x60\x0a\x85\x0c\x02\xa3\x10\x21\xc8\x14\xd1\x29\x85\xec\x3d\x29\xd4\x48\x7c\x41\x2d\x96\x2b\xb4\x17\x2d\xa0\x0d\x98\xa3\x16\x3d\x03\x84\xa7\x2d\xb6\xd7\x33\x2a\x6c\x21\x42\x5d\x08\xc2\x43\xd0\xf9\x93\x10\x06\x21\xea\x5e\x06\x2f\xb2\xaa\x7b\xed\x90\x8e\xd0\x61\x86\x6c\x29\xa3\xb1\xc9\x57\xcc\x15\x64\xba\xd2\xa4\xd1\x66\x1c\x4b\x99\x30\x2a\x9a\xd4\xea\xda\xaf\x2b\xde\x22\x1e\x66\x31\x1a\xab\xcf\x68\x66\x69\xc6\x8c\x4d\x41\xb1\x14\x23\x58\x17\x05\xa4\x58\xed\xc1\x48\xd0\x30\x34\x13\x8d\x57\x04\x44\x7a\xe1\xc9\x1f\xb3\xa4\x53\xa6\x09\x3e\xd0\xca\x45\xf0\x93\x1c\x8c\x74\xad\xf4\xf6\x30\x01\xa2\xb6\x18\x60\xd5\xc4\xc2\x12\x82\x56\xd7\x70\x31\x0d\x7f\xc3\x29\x66\x7a\x56\x9b\xf4\xdc\x36\x41\x97\x75\xbd\x8e\xc6\xfa\x01\xb4\x47\x22\x1f\x58\x9a\x72\xac\xd4\xb6\x33\x5d\x3f\xcc\x55\x59\x78\x31\xb3\x01\x70\x76\xe6\x20\x10\x55\x0e\x53\xe0\x1c\x53\xfe\x3a\x2a\xbc\x0e\x0a\x90\xe0\xe1\x58\x32\x15\x68\x80\x30\x53\x3c\x5e\x7c\xc2\x8c\x96\x38\x12\x46\x05\x0e\xb5\x55\xac\x63\x72\x65\x4d\xe6\xa5\x51\x2a\x95\xb2\xc9\x0a\x38\x8e\xea\xb7\x5e\x74\x37\xb6\xca\x64\x17\x61\xa8\xe7\xcb\x5b\xac\xc2\xa6\xe7\x38\x23\x0d\x8a\xd1\x98\xf9\x8a\x9a\x46\xb1\xb4\x6d\x4a\x93\xe3\x35\x92\x32\xaa\xac\x69\x0e\x99\x3f\xa5\x9c\x87\x0e\x6a\x8c\x9f\x33\x66\x00\x1e\xfa\x1a\xb6\x80\x85\x6c\x85\x2a\x22\x16\x73\x45\x78\x9a\x32\x80\xa2\x1c\x27\x36\xe2\x54\xe0\x1a\x9e\xb7\xe5\xcb\x29\xe2\xad\x50\x7c\x33\x88\x71\xc5\xe7\xe6\x80\x40\x69\xbe\x90\x87\x72\x01\x66\x4d\xf9\x57\x50\x80\xc8\x27\x86\x13\xc3\xae\x80\x46\xf7\x3b\x04\x64\x5d\x26\x74\x9d\x1f\xde\x0d\x02\x7e\x7b\x16\xe3\x36\x22\xe7\x8e\x0e\x06\x3f\x5c\x5c\xdd\x0c\x4f\x46\x07\x79\x74\xd5\x65\xe2\xb8\x5b\xc7\xd7\x47\x49\x31\x12\x3e\x46\xe2\x21\xf3\x61\x2f\x09\x8d\xe3\xbc\x1c\x08\xf3\xf3\xee\xd0\xd7\xbb\xee\xa9\x58\x19\x26\xa9\x0e\xf3\x91\x7f\x65\xf1\x15\xd5\x5b\x05\x57\x5a\x83\xd7\x6b\x39\x11\x6b\x59\x3c\x13\xbc\xe2\xc8\x6a\x11\xb1\x7e\x29\xb7\xe6\xb9\xf5\x39\x18\x4f\x02\xec\x95\xf3\x46\x29\x92\x66\xc2\x18\xbe\xd4\x77\x32\x98\x00\x0f\x88\x68\xd9\x23\x90\xad\x6e\xb8\x76\x49\xfe\x44\xe6\x5c\x40\x66\x69\x1b\x6d\x6f\x8b\x0b\xe9\x82\x29\x75\x7a\x7e\x5b\x44\x7c\xfc\xf1\xe2\xb6\x88\x94\x32\xf8\x4b\x3b\x3a\x54\x71\x84\x36\x6f\x43\xbe\xc6\x20\x7b\x47\x22\x29\x3c\x69\xea\x16\x7a\x56\xd6\x23\xbe\xad\xda\xbd\xc4\xab\x34\xbb\x2e\xdb\x0b\x72\x37\x5e\x45\xc5\x9e\x5d\xe9\x76\xc5\x7a\x68\xf9\x5d\x16\xcd\xc9\x27\xbd\xa0\x6b\xe3\xb3\x9b\x67\x1a\xe4\x0b\x00\xd3\xba\xfe\xfa\xed\x9c\x9f\x9f\x8f\xea\x92\xc4\x3b\x68\x6f\x24\x7f\xda\x39\x28\x94\xf5\xd1\x2e\xe8\x98\x27\x10\x7d\x92\x41\xb9\x54\x5d\x51\x7b\x7f\x24\xc2\x96\x2b\x78\x67\x1a\x1e\x70\x15\x71\x5c\x4c\x89\x14\x8c\xc8\x14\x23\x8d\x5e\x1c\xf6\xc2\x5c\xfd\x72\xae\x99\x9e\x91\xa5\xcc\x52\xff\xc6\xca\x7b\x2c\xf7\xa9\x19\x75\xd9\x08\x4e\xcf\xb4\xb1\xb2\xb0\xa4\x11\xc6\x5b\xa4\x2c\xb7\x05\xe1\xc5\xec\x81\x09\xf2\x68\xec\x3e\x1a\x94\x8a\x07\x59\x60\x46\x25\x15\xdf\x69\x9f\xea\xc1\x13\xdb\x84\x98\xfa\x38\x51\xee\x09\x52\x94\xdb\x91\xdb\x19\x78\x07\xe9\xfc\x50\x9f\xb0\x19\xf3\xc1\x93\x4d\xce\x0d\x8b\x30\x66\x78\x20\x74\xb5\x60\xca\x71\x2d\xcb\xb2\xaf\x0b\x16\x6d\x92\x83\x7d\xe9\x40\xf5\xdb\x9c\x2d\x61\xa0\xcf\xe2\x8d\xd8\xad\xd3\xd2\xb9\x7e\xca\xb3\x5d\x31\xcf\x4e\x95\x10\x66\xa2\x3f\xdb\xd2\xc1\x8e\xf3\x74\xb5\x10\x93\x54\xce\xd7\x9b\xe2\xf3\x64\xff\xde\x54\xf2\x68\x0b\xde\x8b\x57\x92\xf6\xbb\x7a\x96\x4d\xf9\xbe\xab\xa4\xde\xcf\x78\x2f\xfa\xd4\x7e\xa8\x72\x66\x08\x2f\xeb\x63\x3a\x36\xd5\x36\x7c\x67\x78\x67\xf9\xe8\x86\xcb\x82\x29\x9d\x82\x42\xdc\x64\xcc\x88\xd5\x86\x30\xf5\xb5\x3e\x67\x17\xae\xcf\x3a\x87\x6d\x10\xfa\xb5\x95\x4b\x86\x78\x4a\xd3\xb9\xaf\x53\x2d\xd7\x1e\x97\xc8\xb5\x42\x1a\xed\x2a\x07\xf3\x09\xf2\x74\xeb\x6c\xdd\x42\xee\xb0\xcd\x91\xd8\x4d\x81\x5e\xe9\x86\x6e\x9d\x58\xa1\x42\x2f\x9c\x90\x05\xdb\x0b\xab\xd2\xaa\x5b\x59\xb8\xf9\x10\x85\xd3\xf9\x85\x37\xb4\x92\x5d\x67\xf9\x52\x6a\x35\x09\xef\x78\x70\xb2\xcc\xe9\x32\xc8\xdd\xb2\xb8\x2a\x70\x39\x73\xe1\xff\x55\x14\xb5\x8e\x99\x43\x16\xad\xcb\x9f\xe8\x93\x1f\x96\xfe\x5a\xa4\x49\x12\xce\x44\x59\x64\x61\xd7\xff\xde\x1c\x05\xb8\xc4\xc8\xe9\xf9\xe0\xf8\xe6\xf4\xe7\x21\xe4\x25\x2d\x65\x46\x1e\xb9\x32\x16\xc2\x48\x80\xbb\x12\xe1\xa8\xb1\x7b\x13\xfe\xb0\x07\xbf\x82\x6c\x45\x95\x8d\xe7\xdc\xd8\x53\xf9\x22\x6f\x41\x22\x5c\xb9\xdc\x35\x3c\xc7\xe6\x01\xb8\xb6\x5d\x56\x5c\x5d\x02\xfa\x8a\xf3\xb1\x81\x19\x9c\x0f\xb2\x6d\xe2\x5b\x10\x4d\x79\xda\xd4\xb7\x40\xcd\x0e\xcd\x9a\xda\xe3\xb5\xcf\x7d\xab\x3f\x94\xc5\x02\x50\xa8\xd2\xe5\x4a\x97\x2e\x93\xe6\xb2\xcf\x7c\x0b\x76\x91\xf8\xe6\xb4\xed\x2e\xd9\x10\xee\x91\x7a\x6d\xe7\xda\xc3\x29\xd7\xaa\x60\x97\x8d\xfa\xcd\x6b\x2b\xbf\x09\xa0\xe3\x37\x8e\x51\x75\x31\xb7\xf2\x04\xf2\x90\x15\x82\x04\x89\x62\xe2\x35\x2b\x8b\x6e\x21\x35\x04\x87\x23\x80\x27\xab\x64\x66\x8c\x44\xbd\xde\xd0\xce\x63\xdb\xc6\x79\x77\x5a\xa6\xe3\x77\xe4\xca\xaf\xc2\x7a\x44\xbe\xf8\xc4\x36\x34\x46\x7d\xd3\x1d\x56\x3a\x57\xce\xff\xda\x60\x05\x80\xba\xb0\x49\x8a\x50\xcd\xa9\x5c\x33\x0a\xbb\xf2\x5c\xd8\x2b\xf3\x69\x2c\xa8\x2d\xc3\xd5\x50\xa9\xba\xfb\xfa\x5a\x70\x62\xf6\xc0\x43\x6e\xe3\x51\xd0\x61\x21\x00\x36\x58\x8b\x72\x6b\x60\x04\x35\xc8\x30\x6c\xec\x18\xa2\x6a\xc3\xe1\x91\x89\x47\x30\x2e\x49\x37\xaf\xee\x64\x22\x66\xa9\x60\x54\xcf\x9e\x2f\xfc\x79\xbc\xad\xcb\xf0\xd9\x42\xa1\xc7\x3b\x01\x26\x2b\x85\x45\x3b\x46\x44\x3b\x24\x0f\xe7\x08\x4e\x15\x23\xaa\x0e\xbf\x31\xcf\xc2\xb6\x76\x56\x11\x1d\xeb\x29\x22\xbb\xeb\xdf\x2f\x6d\x36\x89\x77\x68\x01\x8e\x65\x01\x50\xc4\x76\xf0\x6c\xbf\x24\x74\x43\x2c\x67\x1d\x70\x60\xd4\xda\x0b\x48\xad\xf8\x89\xfd\xa0\x01\xd1\xb7\xf4\x58\x79\xb5\xa1\xa9\x21\x96\x65\x4b\x9d\xa6\x71\xc2\x14\x28\x91\x68\x3d\x94\xf4\xc4\x36\x2b\x66\x24\x7e\x94\x8f\xec\x81\xa5\x3d\x42\x35\x99\x4b\xa3\x1b\x08\x16\xb6\xb6\xa3\xc5\xc2\x5a\x74\x92\x53\x72\x4e\xe7\x2c\x1e\xc2\x0d\x13\x24\xab\x59\x5b\xca\xfa\x29\xeb\x6a\x97\xa0\x1e\xc7\xb6\xe8\xb1\x13\x1d\x09\x1a\x41\xe7\x1e\x88\x16\x41\x86\x24\x77\x0b\x83\x13\xf5\x7b\xef\x45\xfd\x7d\x9f\xdc\x98\xab\x90\xab\xe2\x7c\x83\x1c\xe8\xa6\xb9\x8d\xc4\x34\x95\xd9\xc2\xeb\xba\x72\x0c\x4a\x36\x7a\x53\x6b\xbc\xa8\x30\x19\xe7\x42\x8d\x68\x6c\x2e\xda\x76\xc6\x29\x58\x63\xaf\xcc\xb9\x50\x4c\x28\x0c\x19\xc8\xdc\x3f\x3e\x50\x65\x93\x11\x80\x8d\x9a\xc1\x0e\x76\xe7\x8d\xad\x60\xcd\x29\x50\xf3\xbc\x11\x5c\xc8\x2e\x69\x10\x3e\x1d\x1c\x07\xce\xc8\xae\x4f\x8b\xca\x5f\x6b\x3b\x1f\x81\xe0\x60\xf5\x40\xef\x0d\x7b\xbf\x7e\x99\x5d\x69\x96\x97\x59\xba\x90\x90\x57\x9c\x2c\x5d\x2e\x96\xcd\x95\x5e\xc8\x45\x86\x99\xe6\x3c\x0c\x5b\xd5\x4e\x88\x2b\xfd\x99\xea\x68\x66\x34\x8c\x3c\x67\x78\x17\xe5\x7f\x05\x41\xfa\xb4\x16\x4d\xcd\x0a\x8e\xc3\xb7\x37\x58\xeb\x6b\x1b\xab\x58\x41\xe8\x32\x12\xe0\x5f\x49\x42\xe6\xe6\xad\x05\x40\xbb\x00\xf5\xa8\x96\xd6\x05\xcc\xa0\x9d\x87\x6e\xb7\xd0\x38\xa1\xd3\x05\x17\x24\xe8\x75\x65\x7d\xd2\xb5\x47\x3a\x4b\xf9\x46\x8a\xa5\xf5\x69\xb0\x07\x26\x74\x6e\xa2\xcc\xe9\x82\x70\x23\xb7\xcd\xcd\x93\x4e\x59\x8f\x3c\xba\x4e\xfe\x84\x92\x2c\xe5\xee\x84\x81\x5d\xd1\xb2\x7d\x45\xc5\xfe\x08\x63\x0c\x98\x65\x15\xd1\x00\x2e\xcb\x76\xf8\x89\x74\x46\x7d\x24\x18\x76\x38\xe1\xe2\xde\xbc\x0c\xcb\xf8\x9d\xff\x38\x35\xf2\x4d\xa6\x2e\x8b\xb6\xb0\xa7\x2b\x39\x6f\x8b\x5d\x6e\x46\xac\x5c\x75\x14\xb8\x98\x06\xf9\xff\xf5\x66\xd5\x3a\xe5\xf8\xb5\x4f\xae\x87\x26\x50\xfb\xa8\xd3\x27\x36\x79\xb6\x25\x65\x7a\x63\xa8\xd2\x42\x26\x86\xcd\x3c\xb0\x1a\x49\x58\x99\x61\x95\x73\xa8\xab\xe2\xd8\xb9\xca\x6a\x28\xff\xee\xff\x42\x10\x24\x24\xcd\xbf\x13\x99\x8e\x04\x7e\xde\xf3\x78\x09\xe6\x07\x79\x69\x53\x43\x31\xb0\xe7\x27\x07\x7e\xba\x99\x5e\x79\x33\xb8\xfe\xe9\xee\x6a\x78\x7d\x71\x7b\x75\x5c\x50\x2e\x8f\xcf\x6e\xaf\x6f\x86\x57\xb5\xdf\x21\x7c\xfa\xe9\xc5\xf9\xdd\x7f\xdd\x0e\x6f\x1b\xbe\x72\x03\x9c\x0d\x7e\x18\x9e\xb5\x2a\xa9\xf5\x73\x68\x42\x8b\xa5\xa5\x86\xc1\x39\x6a\x83\xbb\x54\xc7\x4b\xbb\x45\xfc\xef\x60\x0e\x5f\x22\x5d\x0f\x7b\xee\x2f\x04\x08\x3d\x34\x47\xd9\x39\x44\xf2\x53\x30\x12\xde\x63\xe5\xe5\xb6\xa6\x53\xe5\x7a\xaf\x15\x66\xfb\x81\x0c\x16\xb6\xbf\x9a\x2c\xbe\x54\x53\x75\x9f\xcf\xd4\x39\x2a\x61\x6f\xa1\xf3\x83\xb2\xdd\xc6\x4a\x64\x2e\x0e\x68\xd7\x04\x53\xb0\x0e\x9b\x98\xe4\xc8\xbc\x15\x8c\x57\x3b\x68\x69\x7f\xa0\x5b\x2a\x12\x47\xe1\xbc\xa0\x4c\x68\x29\xe8\x9c\x47\xf8\x41\xa9\x52\xc6\xd6\xd0\xcc\x99\xd0\xe5\x11\x0b\xdb\x5a\x1c\x79\xc6\xc8\x4f\x7f\xce\x27\x05\x66\xb6\x35\x5b\xb3\x0a\xe4\x97\xfd\xc2\x63\x9d\x54\x99\xbb\x28\x9b\xb6\xaa\x4d\x52\xf7\x77\xbe\x63\xf5\x46\xc2\xf2\x86\xaa\xfb\x1a\x94\xe1\x5a\xf9\x63\xd7\xbf\xe5\x1b\x9b\xa1\x8d\xeb\x3d\x72\x8e\xae\x77\xb0\x81\x9b\xbd\xb3\xb1\x30\x6c\xc5\x2b\xdd\x8a\x93\x12\xd0\xce\xda\xef\x2b\x00\xf5\xac\x2f\x95\xa1\xb6\x97\x47\x41\x13\x30\x60\x31\x0f\x1d\xe4\xb0\x2c\xb1\xb7\x8a\x2d\x77\xa2\x63\xf9\x50\xa8\xa7\x9b\x63\xaf\x92\x5a\x4d\x2c\xb0\xf7\xb6\xe1\xc0\x62\xbb\xf4\xb5\xb5\x31\xb7\xf9\xd0\x6a\xa6\x76\x0f\xd6\xb5\xe7\xca\x8b\x59\x95\x94\xb5\x81\x67\x37\x18\xdd\xbb\x76\xd7\x51\xc1\x4e\x60\x4f\xc7\xe0\xb7\xcf\x21\x25\x11\xb9\x18\x0c\xb5\xd0\xe8\xee\xe5\x21\x6c\x54\xcd\xfc\xa5\x79\xe4\xee\x51\x72\x84\x9e\x80\xa3\xe0\x9e\x58\x2e\xcc\x05\x31\x1f\xdb\x34\xdf\xf6\x8d\x0e\x68\xf3\x2a\xa1\x94\xfc\xb2\x5e\x0c\x49\xa9\x6e\x06\x6f\x16\x47\x09\xdb\x34\x79\xde\x30\xcb\x75\xd4\xfe\x83\x5b\xd1\x1f\x90\xa5\xb2\x86\x9a\x81\x60\x34\x5f\x6c\x48\x0e\x01\x84\xdd\x26\x28\x5b\xa4\x07\x45\x0e\x49\xc2\xef\x19\xf9\x0e\x62\x65\x83\xcb\xd3\xef\x7a\xe4\xbb\x30\x1f\xef\xbb\x0e\xe2\x2f\xc7\x48\xb3\xf3\xb6\x80\x4a\xa0\x16\x15\x52\x3d\x3e\x42\x56\x4e\x30\xcd\x41\x80\xad\x0e\xf5\x00\x9a\xa5\x08\xfb\x03\xf1\x7d\x1f\x43\xb6\xde\xba\x55\xb2\x31\x3f\x32\x5b\x43\xd3\x98\xf1\xaa\xd9\xc2\x3b\x8e\x6b\xb6\x0b\xc2\x15\xf9\xc7\x03\x0f\xfd\x9d\x83\xf9\xa8\x06\xe6\xdd\xc7\xf6\xeb\x56\x55\xb0\xa6\x1c\x31\x6b\x37\x65\x15\xe3\xbd\x35\x76\x5b\x23\x8a\x3e\xa8\xa3\x88\xeb\x2a\xbb\xe7\xb2\x97\xe0\xb2\x5d\x24\x90\x14\x27\xd7\xfd\x36\x3b\x46\x85\x28\x18\xc6\x15\xe9\x19\x0d\xd7\xc9\xe9\x22\xe6\xd1\x6a\x94\xbf\x8e\x1e\xf7\x80\x26\xab\x5d\xee\xd7\x18\xaa\x41\xd7\x77\x75\xae\xe5\xa9\x0e\xb4\x45\x61\x90\x1c\x53\x3c\x35\x9f\x33\xdb\x3f\x37\x0f\x2f\xd9\xf3\x0a\xec\x06\x57\x95\xc5\xb9\xc6\x97\xa4\xd1\x8c\x3f\xd4\xe7\xb1\xb6\x6e\xf0\x16\x81\xb9\xf3\xc1\xe7\xe1\xc9\xdd\xf0\xfc\xe6\xf4\xe6\x2f\x77\xd5\x18\x5d\xf1\xeb\xab\xe3\x1f\x4f\x7f\xae\xeb\x38\x7f\xf7\x69\x78\x3e\xbc\x1a\xdc\x0c\xdb\xfb\x29\xb7\xbd\xac\x0e\xe2\xce\x26\xda\xc8\x1c\xb0\x2e\x76\x70\x58\xae\xe8\x1b\xdd\x0c\x3a\x95\x09\xe1\x5a\x91\x07\xae\xb8\x2d\x59\xb0\xca\xde\xed\xa9\xf3\x7c\xd4\xbc\xfd\x43\x90\xab\xd8\xc3\x4a\xe8\xfc\x25\xdc\xfa\x44\x43\x45\xd0\x86\xe3\x44\x8c\x09\x00\x24\xe8\x22\xd2\xaf\x79\x89\x25\xd8\x07\x32\xb0\x5b\x5b\x37\xbe\x90\xc4\xa8\xa1\x2c\xc5\xd9\x63\xac\xce\x4f\xdd\xf7\xa2\xcf\x69\xfc\x81\x20\x52\x4d\x80\xb9\xe7\x07\xc4\x3e\xf9\x29\x13\xdf\x69\xc2\xbe\x2e\x12\x1e\x71\x1d\xe0\x00\xca\x94\xcc\xa9\xa0\x53\x67\x7e\x64\x8a\xa5\x2b\xa4\xc7\xce\x82\x77\xbb\xb0\x22\x9b\xf2\x84\x42\x4b\xc9\xb2\x8b\x87\xe1\xd1\xd2\x26\x88\x3f\x99\x0d\xda\x10\x04\xa8\x40\x95\xac\x3b\xa5\x1d\x99\xaf\x2b\x32\x93\x6c\x66\xa2\x8d\xfe\x51\x65\xaf\xbb\x47\xbc\xb8\x5e\x47\x1c\xb1\x86\x0f\x5f\x38\x90\x58\xc0\xfa\xda\x59\x4b\x8e\xbb\xd5\x91\xa6\x7a\x27\xd6\xee\xda\x64\xe4\xd8\xd5\x95\x06\x19\xce\xec\x3c\x6f\x86\x3e\xec\xd6\x8d\xa0\x40\xc4\xd5\x9d\x08\xa0\x5f\x11\x55\x0d\x6d\x08\x00\x0f\x24\x7e\x2d\xcd\x08\xaa\x25\x2b\xc5\xc9\xbd\x70\x27\x82\xd2\x64\x5e\x4f\x3b\x82\x95\x74\x7b\xbd\x35\x49\x35\x13\x5d\xa3\x0d\x81\x4f\x99\x05\xd4\xc1\x6e\x22\x1f\xca\x94\x78\x9c\x80\x44\x72\x31\x20\x73\xa8\xd6\x71\x5d\x96\x73\xf5\x0a\xde\xe7\xd2\x5a\x6c\x1d\x0b\x68\x3c\xc5\x6e\x4e\xcd\x42\x71\xf8\xc0\x84\xde\x89\xbe\x00\x43\xd4\xa4\x14\xaf\xe7\x3f\x43\x1c\xad\xd3\x93\x5c\x4c\x78\xe4\xd9\x20\xf0\xa6\x53\x1a\x01\xe0\x1e\xf6\x92\xb3\x1d\xe4\x9a\x62\x06\x66\x69\xeb\x6d\x11\xfc\xb4\x4a\x97\x15\x59\x3e\x96\xda\x39\x70\x60\x9e\x41\x20\x23\xe8\x4a\xdd\xa9\xca\xad\x70\x33\x8b\x18\xd0\x28\x82\xf6\x0f\xa8\x2c\x96\xf7\x1c\xdf\x39\xa3\xaa\xfc\xca\x95\x5b\xbe\x41\x71\x4c\x61\x98\x4f\x4c\x9f\x50\x4d\x77\x82\xc9\xdd\x21\x57\x19\x26\x72\x9b\x26\x2b\x3b\x5c\x5d\x23\x68\x61\x96\x26\xb9\x8f\x80\x12\x73\xa1\xf5\x83\x84\x12\x28\x21\x28\x50\x14\x27\xd3\x20\x07\xba\xf7\xe4\x7a\xca\xa9\xda\xd9\x6c\x54\xea\x82\xad\xc7\xb3\x14\x2f\xe6\xfa\x9d\xb5\x80\x29\x20\x3b\x6d\xdc\x4b\x15\xca\xe0\x5c\xbd\x2c\xe4\xa9\xd4\xde\xeb\xcd\xfc\xb3\xad\x3b\xad\x88\xff\xfa\x64\x5e\xb5\x82\xf4\x2e\x2c\x60\x5f\x6d\xb5\xa9\xaf\xcc\x62\xe8\x78\x0e\x84\x62\x48\x9d\x72\x06\x55\xfa\x89\x2f\xed\x29\x4a\x3a\x6b\x35\xaf\x64\x2c\x73\xad\x9e\xac\xe9\x41\x0b\xac\xd2\xdc\x81\x97\x17\xfd\x04\x91\xdb\x00\x26\x97\xc2\x71\x69\x6d\x0b\xb3\xab\x2e\xa4\xa0\x3a\x3f\x19\x6f\xb7\xf4\x1a\x0b\x79\x7b\xbd\x00\x05\x4e\x15\x13\xd5\x8c\xc0\xc8\x14\x4b\xd1\x77\xe6\xd3\xf4\x6b\x60\xf9\x1a\xe3\x89\xb5\x4d\x57\xdb\xe2\xfb\x95\xe6\xaf\xf5\x9a\x06\x3a\x29\xc9\xbb\x07\x9a\x70\xa3\xf1\xf5\x5d\x55\xd6\x7b\xf2\x1f\x00\xb3\xf7\xef\x0d\x46\x13\x9d\xb2\xf4\x2e\xce\x0a\xc1\xf9\x55\x93\xba\x34\x0f\x9d\x64\x7a\x59\x5f\xdd\x56\x30\x78\x12\x1a\xdd\x77\xa9\xf8\x33\xbf\x6f\x18\x76\xf5\x09\x0c\xbc\xd5\xc5\x8b\xa0\xa1\x9e\x8e\x95\xea\xe9\x6c\x2c\x33\x7c\x3f\xc6\x1d\x05\xa0\x30\x06\xde\x02\x1b\x82\x1d\x98\x39\xf7\xc9\x47\x84\xaa\x81\x4b\x0d\x5f\x11\xc9\x2c\x89\x47\x82\x7d\x35\xe6\x7e\x21\x0b\xa9\x06\x5e\xc4\x66\xc3\xd9\x37\xd5\x4b\x82\x12\xd0\xe5\x56\x37\xcc\x8b\x17\x3f\x56\xf7\xb4\xba\xe4\x7a\x26\xdb\x4a\x97\x7f\x25\xad\x8f\x8f\x8d\x42\x2b\x74\xb2\xec\x11\xbf\xc8\x12\x5b\x24\xec\x81\xa5\x74\xca\x6c\x6b\xe4\x00\x4a\x86\x6e\xd0\x09\xf9\xb2\x92\x48\xf1\xb6\xdb\x79\x57\xf2\x33\x9e\x96\x8d\x6d\x33\xf4\x95\x7a\xd1\xfa\xf1\xa9\xf5\x65\xda\x8d\x5c\x1c\x62\x77\x05\xe1\x7b\x94\xfb\xa0\x43\x42\x95\xe2\x93\x65\xd0\x7c\xdc\xfb\xe0\x21\x45\xc2\x23\x16\x15\x91\xad\x6a\x75\x8d\x42\x5e\xe7\x6e\x92\x06\xb7\xcf\xdf\xb1\xf6\xb3\x4b\x26\xe1\x71\x58\x10\x03\x88\xb2\x95\x04\xe2\x35\x41\x6f\xb7\x4d\xeb\xb1\x33\xb3\xc9\x2d\xbb\x9b\x98\xcb\x97\xdd\x2c\xfb\xb0\x35\x21\x7d\xa5\x7c\x28\xef\xfd\x09\x4b\xd8\x2b\xe9\x89\x57\x65\x84\x56\x5a\xe7\xc5\xd7\xcf\xb6\xff\xdb\xcd\x67\x83\xb8\x54\x43\x0a\xfb\x0e\xf6\xfb\x85\xa3\x1b\x0d\xb3\xfb\xc4\xd6\xf1\xee\xac\xe4\xc5\x8d\xce\x55\x93\x70\xdc\x82\xd8\x3b\x0b\x69\x3e\xf1\x82\x9a\xf6\xfa\x9a\x69\xe5\x14\xd7\x80\xd3\xd1\x67\x62\xcf\xe9\xa1\xcb\x66\xcc\x73\x03\x3b\x6c\xf8\x2b\x09\xb6\xd9\xd9\x5d\x59\xc0\xa0\xa7\x13\x87\xab\xb7\xab\x0b\xbf\xe5\xf3\xdd\xc0\x23\x6a\xc7\xd8\xc5\xed\xff\xb4\xaa\x59\x85\x30\x6b\x1a\x17\xd7\x55\x2c\x9a\xee\x35\x97\xa9\x14\x77\xec\xab\xb1\x39\xd5\xa6\x29\x49\xb7\x8a\x29\x32\xf8\x72\x4d\xd4\x52\x68\xfa\xf5\x03\x19\x1d\x7c\x46\xc0\x5d\xf2\xa3\xcc\x52\x45\x4e\xe8\xf2\x50\x4e\x0e\xe7\x52\xe8\x19\xf9\x0c\xff\x6b\x3f\x7a\x64\xec\x9e\xfc\x85\xd1\x74\x74\x30\x12\x50\xf7\x6d\x7b\x2f\x7a\x50\x9c\x19\x85\xb0\x9a\xb2\x58\xbe\x7f\xfc\x57\x07\xe6\x6b\x5e\xf3\xfd\xd1\x1f\xff\x95\xfc\x1e\xfe\xdf\xff\x47\x7e\x3f\x3a\x68\xb8\x97\xba\x25\x37\xe5\x68\xcb\xb5\xa3\xdd\xf3\xe8\x5e\x4e\x26\x77\x9a\xcf\x19\x22\x79\xdc\xd1\xb4\xb1\x3b\x5b\xc7\xe4\x6a\x6e\x01\x46\x10\x22\x31\xaf\x78\xb4\x2f\xc5\xf0\xa3\x53\xc2\x7c\x53\x7f\x2c\x40\x14\x45\x60\x0d\xae\xe0\x29\x16\x13\x39\x99\x74\xf1\x01\xba\x02\xab\x2a\x7c\x59\x1e\xc8\x0e\xe1\x72\xbc\x51\x17\xba\x22\xe4\x2a\x38\xe2\xaa\x8f\xe4\x1b\xb3\x8a\x61\x81\x4f\x6a\x11\x5f\xcb\x74\x2b\x11\x7e\xcf\x2a\xfe\xb2\x4e\x0e\x70\x87\xfc\x11\xa2\x2e\x41\x84\x4c\xa6\xbe\x42\x01\x03\x1a\x16\x14\x63\x24\x6e\x2e\x4e\x2e\xde\xdd\x53\x9d\xca\x29\x15\xef\x3f\x90\x41\x1c\xdb\x06\x3d\xc4\x3a\xfd\x0c\xf3\xcc\x58\xca\xfa\x24\xec\xb6\x21\x0c\xe1\x6a\x3d\xda\xa1\x3e\xcc\x53\x16\xd5\x19\xae\xf5\x87\xdd\x90\xef\xc4\x3f\xd2\x90\x7a\x54\x80\x37\xf1\x2f\xc8\x81\x03\x60\xad\xf7\x6c\x69\x1b\x72\x96\xd7\xbb\x49\xcf\xa1\xeb\x05\x8b\x8c\xf5\x8b\x4d\xca\xd2\x98\x01\x79\xb0\xcd\x3b\x57\xda\x05\x5f\x6b\x0f\x55\xb1\xf1\xda\x36\x09\xd1\xe5\xa2\xae\x2d\x38\x05\xfb\xf4\xe5\xb2\xc1\x15\x06\x96\x1a\x40\xa6\xd4\x88\x8d\x0d\x33\x7b\x6d\x0f\xa8\xb0\x75\x4d\xa6\x58\x7a\x38\xa1\x91\xa1\x5e\xa9\x95\x5c\x28\xaa\xea\xe8\x78\x43\xd5\xfd\x6e\x1d\x4d\x5b\xc3\x6b\xf0\x38\x2f\x47\x47\x6e\xac\xf6\x2d\xb6\x97\x88\xa6\xea\xbe\x29\x05\xa5\x33\x22\xb6\x21\x85\xcb\xce\x6a\x9b\x9f\x1d\x39\xa8\xba\xb3\x3d\x4b\x40\x31\x0d\x0a\x52\xe6\x74\x81\x6d\x5d\xe0\x82\xe1\x09\x8b\xcb\x99\xc0\xe5\xf9\xaf\x62\x03\xac\x6a\x09\xfc\x44\x90\x6b\x3a\x37\x6a\x73\x0c\xb1\x39\x2a\x96\x78\x90\xcc\x85\x45\xd5\xbd\xf2\x18\x2f\x44\xcd\x69\x92\xf4\x48\xca\x32\xe8\xcb\xd3\x23\x8a\x25\x93\x43\x57\x48\x18\x93\x44\x4e\x79\x44\x13\x32\x4e\x64\x74\xaf\x46\xc2\xdc\x20\x62\x8a\x17\xdf\x22\x95\x11\x53\x2a\xb8\x72\xf3\xf0\xeb\x22\x95\x71\x16\x21\xb0\x35\x36\x96\xe0\x4a\xf3\xa8\x84\x66\x6c\x24\x22\xb4\xa1\x8b\x28\x18\x18\x90\xb1\x3a\xc7\xbe\xb2\x29\x67\x98\x88\x9a\xb9\xd6\x48\x50\x28\x45\x13\xfe\x77\xec\x6b\x48\x1f\xb8\xac\xcd\x39\x0d\xb7\x6c\x1b\xd5\xd0\x6e\xcf\x9d\x2e\x9e\x86\x15\xfc\x7c\x6c\x1f\x83\x33\xd4\xc6\x31\x57\x45\x76\xf6\xdc\xe0\xd9\xdc\xd7\x33\x39\xa6\xc8\xc1\x9f\x5d\xcd\x18\xfe\xc4\x85\x55\x5f\x59\xde\x15\x4c\xb9\x21\xdb\x6a\x15\x4f\x1f\x23\x9e\xb2\x2d\xd3\x0e\x1c\x70\x30\xba\x43\x9c\xb5\x80\x13\xe6\x8a\x78\x30\x4c\xe2\xc8\x63\x68\x6f\xae\x91\x9e\x07\x39\xa6\x8a\x2c\x92\x6c\xca\x45\xde\x5e\xd3\xc8\xc3\x91\x00\x6c\x22\xf3\x92\x12\x62\x6e\x95\xa3\x5e\x31\xb0\xf1\x6e\x84\x63\x47\x7c\x63\x47\xe4\x2e\x4c\x5e\xe4\x5b\xd7\x86\x72\xe3\x6a\x96\xb4\x2e\x5c\x6f\xfb\xcd\x9b\x6f\x1f\x78\x8e\xb1\x15\xbc\xa8\x71\x6f\x37\xf6\x52\x94\x66\x55\xc9\x63\xe1\x13\x64\x32\x98\x1b\x84\x2a\x6d\x93\x9e\xa6\x19\xbd\x48\x66\x70\xdb\x46\x5e\x52\x8d\x8d\x56\xd8\x5c\x6a\x44\x96\x41\x90\x17\x8b\xfd\x62\xb1\x63\xc6\x89\x1c\xc3\xbd\x02\xf8\x2f\xb0\xee\x02\x3c\x9f\x5d\x37\x8b\xc9\xbb\xe0\x9a\xf0\xe9\x3a\xef\x9b\x22\xee\xbb\x4b\x4f\x2e\x17\x8f\x36\x26\x29\x17\x01\x21\xfa\xe4\x32\x77\x37\x95\x57\x35\xa1\x46\x72\x37\xf5\x84\xee\x96\xd2\x5c\xd8\xfd\x1d\xa4\x34\x97\x96\xd1\x80\x15\x23\x77\xd1\xb6\xb6\x7d\x51\x67\x72\x7d\x3b\x12\x13\x18\x51\xff\x28\x6c\x8e\x63\xb3\x65\xdd\x16\xbd\xae\x74\xed\x12\xa0\xc8\xcb\xa6\x6b\x97\x26\xf3\x9a\xd3\xb5\x4b\x53\x7d\xbd\xe9\xda\x35\x13\x5d\x23\x5d\x1b\xdd\xed\x77\x86\xa9\xd7\x13\x0a\x8b\x54\x6a\x39\xce\x26\xd7\x70\x9b\xac\x03\x97\x8a\xc2\xd9\xe9\x39\xb6\x4a\x06\x66\x8b\x3a\x50\x37\x45\x2c\xcc\xea\x2e\x2d\x79\xcd\xac\xee\x82\x48\xdb\x67\x75\xfb\xac\xee\x2a\x5d\x5e\x63\x56\x77\x69\xcf\xd7\xcb\xea\xae\xdb\xf2\x0d\x62\x18\x85\x61\xbe\x99\xac\xee\x12\x45\x5f\x73\x56\x77\x69\xaa\xbb\xcb\xea\xae\xdf\xd9\x6e\x59\xdd\xb5\xd7\x7f\x33\xff\x6c\x9b\x73\x07\xf8\x59\xcf\x9c\xd5\x5d\x58\xc0\x3e\xab\x7b\xcb\x1e\x1a\x45\x16\xb4\x33\x00\x00\x67\x9b\x28\x5c\x96\x75\x2d\x79\xdd\xa0\xd2\xee\x80\xa3\x9e\x36\xb6\x0a\x5e\xa8\x75\xb5\xee\x41\x81\x0e\xca\x42\x8a\x9a\xeb\xcf\xe5\xda\x06\x7d\x66\xf7\x48\x2f\xdb\x62\x70\x94\x88\xec\xbd\x57\xb0\x71\x4d\x2c\x57\x03\x84\xb7\x05\x03\x5a\xc8\x82\x4d\x21\x00\x9b\x5b\x4f\x22\xb6\xe3\x6e\x86\xfd\x5d\xf8\xdf\x46\x82\x6c\xdb\x79\x24\x5a\x64\x9b\x64\xc7\x4e\x37\x7b\x6c\xce\xe6\x32\x5d\x15\x7e\x6c\x30\x67\x65\x4a\xa7\xab\x32\x72\xd7\xa5\xde\xb6\x54\x73\x70\x9c\xdd\xfc\x1b\x37\xee\xa9\x56\x83\xcb\xb5\x66\x09\x3d\xe0\xa0\x93\xd6\xc6\x58\x7c\x88\x6b\xc3\x28\x4a\x43\xe1\x41\xf5\x85\xe0\x5e\x55\x2c\x3d\x0c\x2a\x09\x8a\x7e\xcd\xea\x0c\x0a\x74\x77\x0a\xda\x16\x64\xcf\xd2\xc6\x18\xff\x1a\x32\x76\x80\x40\xce\x46\xfb\x0b\x01\x13\xca\x9c\x36\x5e\xd6\xe4\xa3\xad\x67\x52\x63\xc3\xec\x2e\x8e\x61\xfe\x77\xbf\xd1\x13\x9e\x30\x42\xa3\x88\x29\x44\x31\xb1\x39\x20\x08\x58\x99\xa5\xc9\x36\xbb\xca\xc5\x14\xd6\x6d\x94\xc9\xa0\x45\x87\x67\x1e\xbc\x33\x66\xa9\xcc\xa6\x33\x67\x65\xb9\x2e\x8e\x75\x7b\xf9\xa5\x0a\xd0\xfc\xc6\x02\x02\xa5\xbe\x4e\x65\x26\xe8\x1e\x31\x75\x24\x79\xe6\xa8\x69\xdd\x3a\x3a\x70\x47\x21\x77\x28\x3f\xfe\xce\x8f\x8d\x5a\x09\x54\x0a\x8d\xc4\xa0\x90\x65\xe4\x20\x71\xc6\xcb\x3c\x5b\x01\xaf\xf6\x90\xc9\xa0\x6d\xb1\xb5\x5e\xa0\x4f\x90\xf9\x0b\xd4\x10\x78\xc8\xc6\x53\x5d\xcc\x14\x12\x2d\x58\x7c\x48\xa3\x65\x94\xf0\x28\x50\x49\xa7\x29\x5d\xcc\xda\x38\x71\x9f\xf6\xff\x52\x69\xff\x6b\x82\xb5\xb7\xa6\x8a\x84\x70\xe7\x6f\xba\x1c\xa1\xca\x8e\xfb\x4a\x84\x0e\x2c\xb9\xdd\x7c\x76\xce\x89\x6f\xa9\x30\xa2\x99\xf3\x5e\x38\x09\xbd\x3a\xb1\x97\x2c\x87\xa8\xb9\x2f\x36\xa3\xee\xcb\x16\x41\xac\xb5\x8c\xc6\x54\xc3\x35\xea\x1f\x0a\xbd\xb5\xfc\xbd\xbf\xa2\x1a\xa2\x99\x4a\xaf\x84\x07\x77\x99\x1f\xd5\x24\x6d\x56\xe7\x48\x75\x51\x15\xbb\xa5\x4b\xf9\x8d\x7a\x5b\x29\x53\x7e\xda\x1b\xa6\x4d\x0d\x82\x1e\x00\x33\x99\x40\xbf\xf0\x02\xb5\xfc\x0b\x7c\xe6\x85\x27\x90\xdb\x0c\x68\x0e\x0b\xaa\x6b\x0e\x36\xd1\x96\x1c\xe5\x37\xf1\xdb\x48\x90\x5a\x61\x0f\x75\x4c\x92\x0a\x89\xba\x5d\xa2\xd4\x96\xf6\x4d\xb7\x64\xa9\xb6\x66\xbf\xe5\xfd\xde\x20\xac\x57\x01\xf6\xd8\x07\x85\x7d\x50\xb8\x9e\x36\xaf\x31\x30\x5c\x6d\x76\xb9\x66\x70\xb8\x69\xfb\x77\xc1\x49\x3b\x0c\x12\xbf\x70\xe8\xb5\x35\xea\x1a\x30\xd8\xcb\xc6\xb2\xdb\xc2\xd8\xab\xd9\xac\x36\x2e\xd7\xbc\xa7\x9d\xc2\xc3\x2b\x6a\x1c\xdc\x5b\xb6\x8d\xe1\xf9\xbc\xfb\x27\x8d\xe3\x79\x3f\x63\xf0\xc4\x9a\xb1\xbc\xbc\x30\x60\x1f\xcf\x7b\xd2\x78\x5e\x0d\xa1\x57\xc7\xf4\x0a\x0a\xc2\xb3\x06\x62\xdc\x9b\x9f\x23\x18\xb3\x4a\xa9\xca\xc6\x77\x4f\x7e\x8e\x6a\xd7\xbc\xee\x71\xfa\xe2\xf7\xd6\x01\xa3\x13\x36\x1f\xb3\x38\x06\xa3\x4b\x4b\x22\xa1\xf0\x2a\x67\x01\xc1\x90\x59\xf3\x16\xf9\x14\x7a\x04\xf1\x18\x13\x32\x17\x14\xb0\x5e\xfc\x1d\x8a\x59\x7a\x23\x01\xfb\x9b\x24\x2c\x75\x3a\x7b\x4a\xde\x29\x2e\x22\x16\xea\xf1\x29\x89\x25\x53\xe2\x3b\x8d\xd8\xff\x54\x2c\xc9\xbd\x90\x8f\x09\x8b\xa7\xb0\x43\xe5\xc9\x1c\x12\xce\x7a\x84\x6b\xff\x58\xca\x68\x34\x33\xe2\x72\x64\xe6\x0e\x6e\x6d\xbc\xec\x99\x7d\x36\xb5\x95\xe7\x81\xc9\xa0\xde\xf7\x09\x39\x15\x64\x42\x8d\x51\xac\xb2\x71\x3e\x7e\x2c\x8d\x82\x00\xb7\x7f\xb8\xf0\x7c\x90\x27\x0b\xc4\xd5\x06\xde\x1a\xb4\x57\xc3\x00\x83\x84\xd3\xad\x1c\xe3\x0f\x74\x9b\x52\xc0\xcf\x99\xd2\xd8\x4e\x11\x9a\x6a\xdb\xf9\xda\xa4\x66\x5f\xf6\x0c\x28\x41\x58\x42\x2c\x64\xdc\xd8\xca\xbe\xb4\x94\xae\x73\xc9\xa3\x18\x16\x9c\xc8\x9a\x44\x30\x2e\x92\x3b\x96\x8f\x42\xe9\x94\xd1\x39\x4c\x44\xd9\xae\xb0\x13\x8c\x57\xa0\xb3\x81\xa7\x78\x03\x77\xd9\xe2\x33\x2e\xee\xcd\xee\xe6\x85\xde\x12\xaa\x68\xcd\x9b\x6b\x36\xed\x07\x2e\x68\xba\x55\xe3\x39\x44\xa2\xdf\xc8\x94\x1f\x2f\x9b\x2a\xe1\x35\x5d\x55\xf6\xde\xc5\x70\x57\x7c\x6e\xee\x45\xf3\x3a\x02\xa2\x0e\x61\xe5\x28\xd1\x74\x6a\xe8\x33\x63\xc9\x22\x00\x89\x5a\xd0\x54\xfb\x8e\x16\xb6\xfa\x33\x92\xf3\x79\x26\xa0\x60\xd7\xda\x02\x8f\xb6\xcc\xcf\xfa\x85\xf2\xc1\xfb\x23\x71\xaa\xbf\x53\xe6\x7c\x49\x31\x4d\x96\x84\xc6\x0f\x5c\xe5\x45\xf7\x91\x14\x2a\x9b\xb3\xd4\xbe\x82\x2b\x6c\x89\x80\xdd\xda\x09\x75\xbc\x62\xe6\x66\x14\x2f\x87\x58\x68\xef\x86\x29\x19\xb3\x89\xb9\x74\x17\x34\x55\xce\x07\x51\xe3\x3f\xb0\x9b\x1b\x1b\x5a\xbd\xd8\x99\xfc\x39\x3c\x76\x64\x9e\x9f\x50\x6a\x75\xda\xa3\xf2\xf9\x74\x7d\x44\x9a\xcf\xe6\xb8\xb2\x28\xd2\x7e\x31\x59\x2a\x9c\x54\xda\x2d\x94\x4d\x3d\xd7\xf5\x41\xc1\xa1\x31\xef\x71\x0a\x0d\x4e\xae\x93\xb7\xa8\xb4\x40\x3b\x6b\x74\x01\x84\x67\xd3\x36\xf1\x55\x9a\x6a\x1e\x59\xdd\x29\xc7\xd5\xc5\xa7\x9b\xb7\x76\x5d\xc0\xd3\xa6\xed\x55\x11\x4d\xaa\x3b\xdc\x4c\xcb\x6b\xfc\x7d\xbb\xec\xb3\xc7\x0d\xc7\x6e\x4d\x83\x88\x64\x92\x74\xa9\xab\x2f\xad\xfc\x38\x7f\xbc\x7d\x46\xf9\x7b\xcc\x06\xb8\xbd\x80\x53\x83\x58\x00\x34\xb1\x9a\x85\xd2\x76\x97\xc2\x1f\xa1\x0c\x5d\x12\x91\xcd\xc7\x2c\x1d\x09\x39\x01\xb8\x85\xa4\xc9\x6c\x5c\xa4\x72\xce\xbb\x14\x26\x5d\xc0\x36\x5f\xb9\x60\xcf\x0a\x6f\x96\x0b\x09\x99\x53\x64\xd9\xcb\xbe\x11\x3b\xc6\x08\xd4\x33\x5a\xce\xd0\x9c\x2e\x36\x22\x78\xa5\x69\x7b\x85\xd2\x73\x34\x5d\x2d\xf5\xa0\x1a\x9a\x01\x88\x01\x10\xf9\x91\x2e\xf3\x64\x91\x2e\xc7\xe9\x1a\x75\x11\xa6\xf2\xa6\xd7\x96\xcb\x82\x13\xe3\x83\x65\xb8\x5f\x48\x85\x75\x4e\xd0\x71\x1d\x1b\x76\x3e\x4b\x6e\xcd\x4f\xa9\x64\x87\xc7\x3e\xd4\xaf\xbb\xdc\x86\xc5\xc3\x10\x8c\x48\x60\x3a\xed\xa4\xfa\x5c\xe0\x9c\x9d\xd3\xa8\x34\x0e\x41\x5b\xce\xf9\xca\x2f\xeb\x47\x7d\x06\x9a\x59\xb6\x5e\x8b\x58\x5b\xe6\x9f\x75\xeb\x32\xe1\xde\x58\xd3\x54\x22\x38\xef\x5d\x3a\xd7\xac\xb6\x21\x26\x46\x77\x41\xb5\x52\x4e\x26\x89\xa4\xc6\x52\xb3\xb1\xeb\x09\x4f\x98\xea\x93\xd3\x1a\x7b\x22\x6c\xfc\x84\xe5\xad\x10\x09\x71\xfa\x4e\x96\x72\x9b\x95\xc1\x52\xe6\xb5\x1a\xc2\x2d\xe8\x70\xee\x72\x48\x99\x99\x33\x30\x30\x68\xf2\x33\x63\xe2\xcd\x70\x00\x0e\x0e\xaa\x39\xd5\xda\x4c\x09\x6c\x3b\xae\xd1\x17\x11\xb3\x05\x13\xb1\x7f\x40\x62\x47\x52\x1a\x61\xbb\xd8\x7c\x56\x0d\x5b\xba\x0b\xe4\x93\xf5\x63\xf4\xee\xad\xa5\xb6\xcc\xbf\x0b\xff\x5b\x9e\xe1\x4d\x71\xf4\xce\xb3\xf3\x7a\x79\x77\xe7\xfe\x47\x78\xd4\x39\x93\x28\x99\xa4\x0c\xfc\x8d\x73\x9f\x17\x28\x62\x96\x2a\x2d\x25\xdc\x50\xd7\x27\x3f\x1d\xdd\x9e\x12\xa6\x23\xc0\x61\x1d\x89\x48\x3d\xf4\x8c\x42\xfb\x4b\xc6\xb4\xf9\xb8\x09\x84\x67\xce\x84\x02\x49\xc0\xd7\xc5\xe3\x76\x84\x31\xff\x3d\x29\x3e\xdf\xc2\xf2\x41\xe7\x68\x04\xac\x02\xde\x75\xc0\x18\xc0\xa6\x50\x8d\x5d\x68\x99\x59\xd8\x0f\x29\x13\x46\xc5\xb0\x0e\xfd\x6c\x83\x68\xb0\xf8\x5b\x26\x3a\xaa\x49\xc7\xf9\x43\xc1\x2c\x1a\xb4\xb0\xf9\x82\xa6\x5c\x75\x1b\xde\x3d\x53\x3b\xfa\x2a\x21\xe2\xe8\x4a\xc9\x18\x29\x45\x72\xa0\x38\xa2\x53\xc6\x40\x84\x78\x7e\xb2\x77\x3d\xdc\xf2\x01\x35\x82\x87\xfa\x23\xf1\xd9\xf9\x3f\xf3\x4f\x55\xde\x28\x7a\x3e\x06\xd0\x95\x0c\x6c\xa6\xe2\x28\x30\x6c\xcc\x95\xff\x00\x6a\xf1\x55\x96\x68\x84\x46\x9a\x70\x41\x13\x3f\x51\xfc\xa6\x4e\x4a\xa4\x54\x44\x33\xe8\xbf\xb5\x4d\x84\x76\x72\xc7\x92\x2e\xba\xe3\xe9\x64\x98\x28\xc3\xdf\xd1\x7d\xc3\xe9\xfc\x83\x83\x54\xeb\xb0\x41\xf9\x62\x40\x73\x73\x00\x31\x68\x95\xa0\x9f\x2e\x41\xa0\x25\x46\xc0\xc9\x56\x4e\x0e\xc0\x64\x4a\xb3\x8b\x56\xb7\xb6\xed\xe4\xa0\x0d\xa4\x73\xcb\x8d\xe1\x2d\x84\xea\x91\x48\x33\x01\x15\xd5\xde\x7f\x4e\x89\x62\x29\x47\x47\x76\x24\x05\xea\x00\xd6\x79\x32\x35\x62\xc2\x68\x7e\xd8\x30\x51\x80\x45\x25\x33\x65\x64\x08\x9d\x33\x6d\x2e\xa8\x77\x80\xf9\x87\x11\x8c\x1e\x59\xa4\x7c\xae\xf9\x03\xf3\x30\x08\xe1\xce\xd5\x32\xf3\x36\xd1\xad\x05\x4b\xa9\x5e\x17\x55\xa1\xee\xed\x17\x6e\x84\xda\x03\x9b\xb0\x89\xbe\xab\xf5\xbb\xb4\x98\x18\x66\x44\x11\x37\x64\x91\xf1\xe9\x6c\x07\x23\xae\x7f\xea\xff\x64\xfd\x62\xe6\xa8\x07\x37\x7e\x2a\xa5\x46\x7e\xcb\x65\x12\x71\xd4\x04\x75\xc1\xbe\x14\x91\x98\xcc\xa6\x72\xd8\x55\x73\x86\xef\x85\x7c\x14\xde\xb6\x36\x6a\xc3\x90\x02\x38\x98\x17\x2c\x36\x4e\x81\xa7\x7a\xe5\x79\x2e\xa0\x0d\xbd\x92\x3a\x8e\xb0\x57\x2f\x20\x28\x26\x4b\x92\x23\x4a\x15\x9e\x5b\xe7\x7a\x43\xbb\xd3\x9d\x5d\x5c\xb0\x05\x51\xd1\x6c\x61\x6d\x63\xdb\x83\xd2\x27\x79\x80\x7b\xd5\xbc\xaa\x4f\xbe\x38\x4d\x0e\xc2\x40\x39\x12\x9a\xed\xb3\x9b\xd0\xa5\x6b\x7a\x5e\x47\xd8\x5d\x24\xf8\xef\x3a\x36\xd3\x4e\x60\x9f\xb9\x59\x43\xe5\xc2\x85\x2a\x04\x5a\x58\x6b\xc6\x8e\xed\x85\x6d\x1f\xba\x66\xed\x39\x09\x1f\x01\x55\x05\xdb\xe9\x83\xb7\x4a\x8a\x64\xf9\xbf\x70\xb3\x20\xb1\xdf\x77\xde\xb5\x58\x1e\xd6\x87\x69\xce\x0f\xf8\xe0\x84\xd4\xe6\x52\x9c\xf0\x24\x81\x18\x4b\x9f\x0c\x00\x17\x0c\x10\x9f\x8c\x22\xef\x82\x77\x7c\x2a\xe4\xaa\x10\x43\x03\x33\x45\x01\x33\x5d\x37\x33\x93\x02\x6e\xf2\x51\x85\x1d\x71\xd4\x0e\x52\xf0\x8c\x6c\xa1\xd5\x32\xb2\xf5\x13\xef\x3a\x5c\xc6\x2f\x11\xae\xab\x4c\x37\x34\x8d\xeb\xa7\xfe\x29\xa3\x29\x15\x1a\x82\x50\x16\x3d\x36\xb5\x81\x5e\x68\xa1\xcd\xbe\x42\xb4\x56\xa0\x61\x07\x1f\x85\x9b\xeb\x9c\xee\x53\xfe\xc0\x04\xe1\x71\x8f\xf0\x3e\xeb\xf7\x2c\xfa\xae\xca\xc6\xf9\x2f\x67\x54\x11\x3a\x12\x95\x44\xb2\x3e\x19\x24\x4a\xda\x27\x98\x88\x12\xc0\xe1\x0b\xe2\x65\x9e\xf3\xad\x9b\x08\x1a\x28\xdb\xad\xcc\x87\x97\xf6\x8b\xe0\xc1\x91\xa0\x0a\xbd\xd2\x09\x9c\xf4\xfc\xf3\x15\xfd\xcd\x9f\xb4\xce\xb8\x72\x0d\x3d\xd9\x26\x21\xa0\x5c\xdb\x06\xc1\x2f\x60\x63\xf2\x04\xbf\x91\xf0\xec\x4c\xde\x51\x9d\x30\xaa\x34\xf9\xe3\xfb\x4e\xc1\x19\xb7\xbe\x5c\xb8\xda\xd3\x9b\xa7\xa1\xb8\xd0\x77\x13\x4c\x30\xc0\x10\x11\x0a\x8d\x91\x7d\x62\x4a\xcf\x6c\xb3\x96\xe4\x81\xab\x0c\x90\x0d\x83\xb4\x2a\xc4\xa6\xe3\x5a\x39\x98\x15\xf4\x53\x36\x88\x11\x87\x14\x6b\xfd\x97\x76\x5a\x35\x8c\xd5\x43\x92\x73\x54\x76\x21\xb3\x39\x0f\x42\xcf\x8c\x96\x6b\x05\xab\x8b\xdb\x04\x10\x58\x83\x24\x29\x06\x7e\x8d\x82\x13\x33\x61\x16\x0c\xb8\x8c\x7d\x12\x36\x11\x55\x79\xac\xb0\x08\xcd\xec\xcf\x8a\x51\x9c\x47\xc2\x67\xa7\x86\x63\xd7\x2a\x3b\x75\xe6\xe2\x33\xea\xc0\x35\xaf\x3f\x43\x80\xcc\x35\x74\xe1\x66\x94\xf1\x16\xf7\x4a\xc5\x44\x6f\x51\x8d\x77\xfd\x82\xf5\x35\xe5\x7a\x73\x17\x6e\xd9\x47\x59\x63\x3d\x37\x6c\x6e\xa0\x5a\x6c\xb1\xa9\x79\xd0\xfa\xb9\x1c\xb8\x85\xa9\x9f\xc6\x90\x51\xb6\x5a\x08\xe6\x19\x5a\x4e\x74\x80\xdd\xca\xe3\x20\xc7\x24\x08\xc0\x43\x2a\x91\x93\x7b\xf6\x97\x4d\x78\x58\x6f\x7b\xf9\xbd\x7c\xfd\x6e\x29\x3e\x0a\x5d\x5d\x78\xb3\xae\x37\x88\xff\x46\x23\x26\xa2\x25\xbe\xc9\xe1\xfa\xe5\x7a\x1c\x28\x7b\x41\x05\x27\x05\xdb\xbc\x56\x3b\xb4\x58\xb7\x7d\x32\x84\x7b\xc6\x41\xdf\xd2\x89\xf3\x2f\x04\x3f\x1e\x09\x63\x98\x98\x2b\x5e\xe1\xa4\xdd\xf8\x45\x16\xaf\x3b\x01\x98\xba\xbf\x95\x6b\x66\xbe\x1a\x1c\xa0\xc9\x98\x70\x95\x03\x30\x06\x54\x5a\x93\xe1\xf4\x03\x89\x65\x74\xcf\xd2\xa3\x94\xc5\x5c\x7d\x00\x57\xb9\x6e\xf4\xd1\xcd\x8d\xb1\xbd\xb5\xa2\xb1\x29\xfa\x3c\xbe\xdf\x66\x1f\xe1\xbd\xc5\x8c\x86\x30\x01\x6b\xc2\x65\x15\x62\xaa\xa1\x85\xbe\x20\x4c\xe8\x74\xb9\x90\x5c\x68\x97\x25\x11\x95\x08\xe1\x0c\x0d\xa3\xb3\x35\xe5\xe2\xa4\xbb\x08\xa9\x6d\xb8\xec\x9b\x19\x53\xcc\xc5\x0f\x70\x51\x5a\x12\x44\x85\x46\x71\xb1\xa0\x7a\xa6\x20\x2f\xb2\x48\x03\x6b\x73\xc1\xa3\x86\x42\x74\x01\xe1\x07\x74\x52\xe4\x0f\xf9\x84\x3f\xa5\x79\x92\x8c\x84\x60\x2c\x56\x04\x70\x8a\xbe\xab\xcd\xbf\x35\x8f\xf6\x08\x8d\x63\xf2\xbf\xdf\x7d\x3c\xfb\xcb\xcd\xf0\xee\xf4\xfc\xf2\xf6\xe6\xee\xe3\xe9\xd9\xf0\x7d\xcf\x7f\x78\x71\x7b\xe3\x3f\x45\x07\xcb\x03\x4b\xc9\x9c\xde\x83\x85\x27\x14\xaa\x7f\x90\x16\x17\xce\xd4\x95\x3b\x99\x6f\x14\x73\xa9\x26\x56\x4d\xf1\x05\x2f\x76\x0f\x57\x94\x24\x76\xb0\x7d\xaf\xfc\x23\xed\x3c\xe8\x98\xc7\xbf\xc2\xa9\x81\x73\x26\xb4\x91\x31\x36\x67\x2d\x37\x7d\x73\x86\x63\x62\xca\x45\x53\x40\x9c\x89\x87\xa7\xd4\xe1\x7f\x62\xcb\x9f\x8d\x75\x7d\x49\x79\xba\x36\xef\x0d\xc5\x03\x4f\xa5\x80\xa5\x79\xaf\x56\xde\xa1\x83\xc1\x82\x4b\x87\x4a\xa1\x2e\x0c\x21\x97\x45\x63\xd2\x85\x98\xf0\xc6\xf4\xaa\x17\x5b\xee\x00\xdd\xc4\xec\xab\x4e\xa9\x6d\x08\xaa\xac\xb8\xa1\x0f\x94\x27\x90\x30\xe3\x2e\x9a\x9c\x07\xb1\xf1\xc3\x07\xc2\x12\x3a\x96\x29\xa4\xd1\x62\x84\xcf\x0d\x61\x09\x06\x10\xe8\x7e\xa0\xa6\xc4\x0d\x99\x3e\x5d\x43\x9e\xc2\x3d\x74\x29\xd3\x75\x6e\x72\xf3\x33\xa0\x82\x5c\x18\x93\xac\x24\x44\xed\x35\x3b\x61\x14\x91\x90\x15\x48\x1a\x95\x2d\xcc\x3a\x6c\x32\x48\x92\x14\x40\xb7\xcc\x19\x50\x7d\xeb\x1c\xcf\x7f\x29\x05\xf9\xe9\xcf\x8a\x8c\x33\x3d\x12\xc5\x31\xa4\x80\xfe\x3b\x3f\x50\x1d\xcd\xde\x8f\xc4\x85\x31\x18\x7f\xfa\x73\x43\x41\x4e\x4c\x35\xbd\xab\xe7\xaf\x66\x9a\x9c\x50\x4d\xcf\x24\x8d\xb9\x98\x1e\xe3\xa3\xf5\xb4\xf8\x61\x78\x33\xf8\x40\x2e\xac\x35\xee\x7b\xc6\xe6\x65\x5c\xc1\x40\x20\x5b\x61\x21\x4e\x20\x80\x54\x16\x5e\x8a\x5b\x67\x17\x28\x42\xe6\xee\x19\x09\x20\x25\x0a\x48\xae\xc9\x42\x5a\x84\x14\x63\x60\x49\x92\x66\xc2\x3a\xa5\xad\x4f\xd0\x50\x07\x38\xd2\x6f\x86\x55\xad\x40\x35\xa9\xca\xed\x91\x00\x53\xdb\x27\xad\x27\x32\xa2\x09\x44\xcb\x0f\x03\xef\x9c\x31\xc0\x65\x06\xa9\xc7\x10\xa6\x12\xcb\x62\x52\x8b\xc3\xaf\xcb\xf5\xab\x70\xa3\xc0\x94\x87\x7d\xb4\xb0\x2e\x73\x69\x84\x47\x7f\x24\x4e\x27\x18\x4c\x4f\x90\x3a\xe6\x41\x26\xcc\xf4\x3d\x59\xcc\xb7\x4e\xb4\x00\xc4\x2d\x56\xbc\xd2\x08\x1c\xf1\x62\x09\xa9\x50\x00\x9d\x21\x21\x28\x93\x0b\x5a\xcb\x94\x95\x5d\xf4\xd7\x5b\xf8\xd8\x48\x60\x10\xbf\xb0\x31\x96\x5a\xe5\xd7\x4b\x01\x39\x06\xf9\xd5\xe7\x95\x85\x85\xcd\x39\xb0\x7a\xfb\x22\x65\x87\xae\x15\x82\xf9\x34\x20\xaa\xb9\x2d\xfb\xe4\x2a\x34\x95\x63\x19\x65\x73\x57\xd3\x0a\x39\xda\x36\x38\x6d\x2f\x44\xcf\x22\x78\x49\xd7\xb2\xfc\xef\xc2\xff\xd6\xea\x99\x97\x5b\x36\xd0\xf1\x6c\x75\xb7\x28\x8e\x54\x18\x8d\x0b\xcd\xa6\xe5\xfa\xcc\x2e\x50\x41\xe7\x90\xd1\x06\x7d\xbc\xa1\xb3\x8e\x24\xb6\x23\xb3\x2d\x60\x59\xc8\xf8\x3b\x45\x4e\x2f\x8d\xc2\x61\x0c\x4c\x7f\x4e\x32\xa5\x31\x34\x0b\xe9\xa9\xf8\x34\xa6\xc7\xf5\xc8\xf7\x64\x94\x7d\xff\xfd\x3f\x47\xe4\xab\xfb\xe3\xdf\xfe\xf5\x5f\xff\xf9\xdf\x36\x69\x14\x05\xe3\xe6\x34\xb2\xe5\xe3\x65\x0d\x24\xdc\x81\xaa\x34\xd9\x62\x17\xec\x21\x69\x22\xbf\xb5\xbe\x1b\xd3\x9b\xeb\xbe\xce\x73\x26\x12\x3a\xb5\xa7\x50\x85\xa7\x87\x14\x8e\x0f\x9e\x72\x38\x30\x4c\xf7\x8a\xa7\xd8\xeb\x96\x56\x81\xfe\x5f\x2d\x45\x6c\x77\x86\x9b\x37\xcb\xed\xe0\x89\xd7\x66\xcd\x20\xe4\x9d\x75\xb7\x69\x08\xd7\xbd\x77\x97\x90\x4c\x62\x96\xe2\x9c\xbc\x87\xcc\xfb\xed\xe0\xfc\xb2\xaf\x8b\x44\xc6\xae\x99\xbe\x62\x0b\x0a\xf7\xb5\x39\xaf\x7d\x32\x12\xc3\xaf\xd4\x88\xd7\x9e\xc3\x80\xc7\x86\x65\x10\xe8\x98\xd0\x88\x11\x54\x8d\xdf\x7d\xfd\x60\x3e\xeb\x91\xe5\x07\xc8\xc1\xe8\x91\xbf\x7f\xb0\xa5\x4f\x34\xd5\x77\xe6\xa3\xf7\x4e\xb7\xb5\x43\xc0\xac\xb9\x22\xa3\x83\xa3\x07\x9a\x22\x08\xe8\x91\x45\x09\x3a\xb0\x02\xd0\x83\x63\x85\xda\x70\x22\xe5\xbd\xcd\x50\xa9\x3c\x69\xff\xd3\x47\x0e\xf7\x81\x0a\xdc\x7d\x9b\x6c\x64\x34\xb7\x43\xf8\x01\x23\xfd\xc5\x98\xf4\xff\xa6\xa4\x20\xfd\x25\x9d\x27\xf6\x53\xf7\xad\x4d\xa0\xa1\xca\xa6\x81\xc7\x46\xa8\x3d\x70\x99\xa9\x64\x89\xbe\xc9\x1f\x12\x39\x86\x75\x7d\x76\x6b\xc5\x14\x14\x98\x68\x7e\x49\xe4\xf7\x8a\x5d\x08\x37\x16\x33\x8d\xb1\x1c\x0c\xfa\x0b\x98\x9f\x60\x2c\xbd\x6e\x59\x5f\xfd\x9c\xfe\x1b\x23\xb1\x40\x15\x97\xb8\x8e\xfe\x58\x43\x2c\x9b\x77\x39\x21\x5f\xc9\x3b\x2b\x86\xde\x9b\xbb\xc0\x26\xfc\x20\x1d\xea\x5e\xb0\xf4\x2f\xf8\x4b\xf0\x02\x2e\x08\x96\x22\xb4\x3c\xf9\xf7\xa3\x7e\xbf\xef\x9f\x3e\x37\x6b\xf9\xbf\x84\x6b\xc5\x92\x09\x8e\xe4\x6e\x9a\xe5\x48\x7c\x36\x76\x4b\xe8\x2f\xce\x0b\x78\x01\xf4\x3b\x92\x09\x39\xcc\x7d\xa8\xb1\x8c\x14\xf9\x27\xa3\x49\x06\xb4\x84\x0f\x8d\xe9\x54\x7f\xae\x6c\xef\x87\x67\x3a\x58\xd6\x07\x5d\x3e\x5a\x61\x59\xa6\xb7\x25\xa9\xd1\x40\x62\xfe\xc0\xe3\xcc\x31\x83\x61\x9d\x23\x5b\xba\x09\x6d\x19\x34\xfb\xaa\xe1\xab\xfa\xc5\xd5\x27\x83\xd5\x2b\x71\x15\x91\x9b\x97\xb1\x22\x5f\x37\x10\xc0\xd6\x2f\x5a\xe9\x80\xeb\xec\x85\x01\x0b\x73\xc1\x88\x10\x2b\x41\x65\xf3\x39\x4d\x97\x47\xf9\x71\xab\x32\x67\x0e\x99\x03\x72\x26\x71\x04\x80\xa0\x69\x62\xcf\x96\xcd\x1b\x08\xba\xc7\xcd\x7c\xea\x20\x89\x59\xc4\x63\x9b\xb4\x48\x11\xcf\x8f\x89\x48\xc6\x96\xaf\xf3\x8a\x8b\xa2\x62\xe1\x7f\x53\x55\x29\x5c\x29\x95\xca\xfd\x5f\x42\x63\x19\x96\xfd\x85\x7b\xb8\x41\x84\xcb\x3b\xa5\x8d\xb0\x9c\x76\x08\x48\x9e\x5e\x5c\xbb\x67\xd6\xbf\x78\x81\x0e\x45\xd5\x9a\x3a\xc3\xcc\x39\x01\x52\xfa\x98\x5f\xc1\x90\x4d\x81\x0e\x91\xcc\xd7\xa3\xe0\xbf\x8f\xe5\x25\x4f\xcc\xcd\x05\x3c\xde\x1f\x89\xc2\xc7\x3d\xc2\x12\x3e\xe7\xc2\xe7\x87\xa2\x7c\x97\x13\xd4\x72\xef\xb9\x36\x5b\xa6\xe2\x7b\x23\xc2\x5c\x69\x5f\x60\xfa\x0c\xc4\xd2\xb1\x8e\x8f\x05\x59\xa3\x3f\x53\x66\x5e\xb9\x59\x6c\x74\x4e\x33\xc4\xa1\xd5\x1b\x79\xc0\x78\x70\x7e\x47\xc2\x8c\xe6\xce\xd2\x94\x09\x96\x3a\xdc\x39\x37\x5e\x30\xdc\x21\xe8\xe9\xdc\x25\xdf\xc3\x08\xf0\x0e\x9a\x69\x69\xc4\x4d\x44\x93\x64\xe9\xd5\xd4\x1a\x25\x65\x58\xea\xb9\xd2\x3d\x57\x13\x5a\x78\xdc\x09\x19\xb3\x8e\x80\x0c\x35\x3d\x2d\xac\xe3\xd7\xc5\x0b\x53\x86\xf9\xb4\x20\x27\x9a\x0a\x08\x98\x52\x1d\x9d\xa1\xb5\xcd\x61\xec\x38\x00\x0b\xf9\xb8\x69\x83\xbe\x5c\xa6\xc1\x28\xce\x2c\x08\xea\x1f\x0a\xb4\x2f\x36\xb0\xd9\x4a\x47\x8f\x37\x73\x07\xe3\xda\x23\x20\x7b\xde\xea\x92\x4c\x53\x99\x2d\x7c\x91\x90\x4b\x97\xc6\x6d\xb0\x37\xda\xa9\x98\xc8\x0f\x56\xab\x3e\xe3\xe2\x1e\xef\xc2\xa7\xda\x23\xdf\x2a\x26\xf8\xdc\x49\x30\xa4\xf8\xa1\xed\x17\x66\x66\xad\x34\x8d\xee\x11\xc0\xa3\xad\xd5\x50\xd7\x66\x49\xf9\x7d\x99\x25\x89\x7d\x6d\x2e\x3e\x73\x28\xd3\x07\x4e\x09\x25\xb7\x57\xa7\xf5\xef\xbe\xe7\x55\xef\x79\xbd\xec\x2c\x32\x08\xfc\xcf\x4f\xbc\x53\x9e\x5b\x09\x70\x86\x15\x58\xdd\xbb\x00\x9a\x20\x14\x4a\xb2\x7b\xcb\x70\x9d\x91\x41\x77\xf3\x1a\x4e\xad\x5f\x7c\xfe\xe2\x13\xfb\xf0\x67\xf3\x6c\xfd\x8e\x7c\x86\x64\x50\x5f\x31\x37\xa7\xc2\x2c\xd0\xbd\xb5\xc1\x47\x84\x62\x71\xa3\x29\xdd\x2e\x36\x9a\x10\xbe\xb1\x15\xbc\xcc\x8f\xe0\x5e\xe5\x46\x79\x44\xa7\x11\x4d\xd0\xe0\xd2\x33\x50\xc4\x7b\xe4\x3a\x9a\xb1\x39\x85\x1c\x83\x79\x51\x21\x07\xbd\xe4\x5d\x42\xd3\x29\x6a\x09\x8a\x69\xf5\xbe\x66\x87\x73\x74\xa5\x2d\x76\x78\x03\xf8\xbf\xd0\xdf\x0e\x25\x03\x6d\x12\xc0\xcf\xb2\x58\x12\xee\x85\x93\x7b\xbf\xbb\x3b\x8c\xb9\x8a\x8f\xc0\x8d\x99\x62\xbf\xb6\xd8\xa8\x62\xcd\xb5\x72\x5b\x22\x4e\x86\x4d\xae\x1d\xec\x24\x82\x6f\xd8\xb9\x8d\x19\xc0\x03\x34\xcf\x61\x6b\x8c\xc9\x70\x0a\x16\xd2\xae\x69\x06\x23\x31\x70\x3f\xf1\xb9\xe9\xa0\xdf\xa4\x18\x25\x85\xac\x24\xcc\xc1\x03\x1d\x23\xe8\x36\x64\x17\xd7\xb0\x08\x41\xe7\xdb\xc8\xfa\x5b\xa3\xe3\x78\x70\x10\xb4\xee\x9c\xb2\xeb\xd6\xd1\xf0\x66\x8b\x16\xbc\xc5\xcb\xaf\xdd\x12\x4b\xc0\xc3\x75\x2f\x5e\x25\x7c\x87\xbe\xee\xc8\x0e\x14\x62\x1d\x63\xe6\x52\xb2\xcc\xf3\x64\x0c\xc5\x51\x2f\x2d\xbd\xac\x70\x58\x27\x98\x5f\xbf\x9d\x43\x0f\xcd\x98\x9d\x67\xa8\xe8\x19\x13\xa0\x09\xae\x3f\x32\x14\x29\x74\xf7\xc6\xd1\x3c\x11\x3f\x37\x5c\x7c\x70\x21\x13\xdc\xe2\x62\x59\x5b\x35\x08\x14\x3b\x9f\x4e\xfe\x3c\x57\x44\x51\xcd\xd5\x84\xd7\x6a\xc8\x61\x55\xc3\x36\x54\xef\xd4\x1f\xd0\x6d\x73\x1b\xab\xfa\x84\xb7\x3e\xf9\xc8\x53\xa5\x83\x25\x69\xe9\x8b\x12\x9a\x3a\x0e\x19\xe3\xf6\x29\xe3\x4b\x6e\x05\xc1\xef\x5b\x83\x6e\x3e\xb9\xb1\x4f\x06\xb9\x99\x8d\x65\x19\x68\x40\xaf\x58\x11\x4b\x14\xdb\x84\xf9\xd6\xb2\x49\xc0\x1d\x0d\x0c\x44\x40\x5c\x2a\xf3\x79\x8e\xed\xe1\xa7\xf9\x08\xf5\x03\xf4\x9e\x35\xf5\x29\xec\xda\xe3\x72\x65\x6b\xcb\x81\x37\x39\x24\x5a\x1d\x9b\x4c\x70\xfd\x63\x97\x57\xc2\xf0\xc9\x91\x21\xb9\x6d\x1a\x8d\xae\xc1\x09\xf0\xa1\xad\xa5\x79\x9c\x49\x15\x9e\x33\xb7\x7f\xb0\x99\x3a\xcd\x98\x4b\x4f\x84\xac\x4f\x4f\x60\x0c\x12\x09\x19\x96\xda\xc0\xac\xfd\x21\xc5\xb4\x06\xbf\xdf\xc4\xde\x0d\x48\x06\x70\xd7\xb8\xa1\xaa\xa7\xb9\x10\x10\xde\xe2\x38\xdf\xb3\x55\x7d\x3d\xda\x36\xcd\x9f\xdc\x86\x6b\xac\x2b\x90\x49\xe3\x59\xea\x94\xff\x0a\xde\x06\x1e\x41\x91\x3c\x5e\xbb\x0b\xca\xeb\x22\x1b\xd6\xab\xf6\x5a\xe1\x1e\x76\x8d\xf3\x60\x97\xbb\x21\xc6\x43\x82\x4f\x3b\x1f\xa0\x7c\x74\xd8\x0e\xbb\x40\x44\xc8\xfd\x9b\xeb\xa1\x21\x20\xf3\x28\xec\x86\x85\xf3\xea\xc6\x23\x05\x12\xa3\x5b\xd8\x06\x7e\x15\x04\x89\xb1\x98\x4a\x4e\x3c\x80\x05\xc6\xf7\x11\xeb\x46\x4e\x6a\xfe\x30\x56\x8c\x7a\x1f\xf6\xf0\xb6\xef\xc8\x6b\xaa\x9a\x59\x70\x37\x78\x09\x8e\x14\x4f\x79\x1f\xba\x33\x13\xde\x87\x5d\x08\x5f\xcf\x54\x79\xf8\x1d\x53\xca\x69\x2a\x33\xe1\xea\xcd\xa5\x60\x72\x02\x5e\x51\x08\x34\x38\xbb\x1f\x4a\x51\x85\xd4\x41\xfa\x78\xca\x16\x98\xbc\x08\x1a\x6a\x33\xb9\xb7\xc4\x5c\x58\x45\xe7\xa7\xc0\x5c\xd8\x96\xee\xf6\xe0\xbc\x10\xc1\xb7\xad\xa4\xc7\xa3\xd4\x41\xcc\xc2\xef\x57\x1a\xe3\x5e\x0e\x80\xf5\x1d\xa2\xe6\x62\xb5\x24\xe4\x4c\xb0\x43\x2d\x0f\xa1\xec\x06\x8a\x39\x10\x05\xa5\x09\x1b\x10\x9c\x18\x5d\xae\x03\xf3\xfb\x35\xe6\x89\x89\x32\x5f\x83\x89\xda\xbb\x57\x11\xd7\x31\x03\x94\x19\x01\xcd\x6f\xc1\x3e\x5b\x79\x73\x74\x74\x71\x84\x5b\xd9\xee\xe3\xb4\x15\xfe\x25\x84\x0a\x1f\xdf\xa4\x81\x10\xe8\x13\x48\x06\x99\xc9\xb9\x34\xd7\xb6\xcc\x54\xf0\x25\x66\x13\xc1\x65\xd3\xd2\x2f\x64\x81\x65\xb6\x2f\xb7\x1a\x73\xb4\xcc\x57\xa8\x3b\x86\x3f\x5a\x0d\xd3\x13\xac\x64\x5c\x84\x39\x59\x31\x7f\x8f\x4f\xd1\xce\x37\xe0\x40\x9b\xf3\xe9\xcc\xa2\x2f\xda\xaa\x73\xfe\x77\x63\x41\x1a\x96\xf2\x89\x3b\xbe\x3f\x32\x46\xda\x81\xa1\x44\x5d\xdb\xa9\xc6\x00\x46\x17\x94\x95\x0e\x7d\xa2\x83\x2a\xcc\x3c\x5e\x6e\x88\xec\x63\x96\xae\x46\xc8\x3f\xf8\x90\x43\x7f\x2e\x17\xac\x47\xc6\x19\x7c\x7f\x7e\x71\x13\xfa\x86\xb8\x80\xaf\x0f\xa3\x19\x8b\xee\x21\xc5\x0d\x85\x22\x92\xcb\x61\xb8\x8e\x97\x23\x91\x03\xcc\x69\xe9\x1c\x1d\x4b\x5f\xc1\xef\x51\x2c\x64\x4a\x62\xae\x16\x09\x5d\x12\xf6\x55\x33\x81\x91\xb1\x9a\x66\xfd\x86\x59\x36\x33\x5b\x00\x01\xcf\x4a\x01\xa7\x87\xc1\xbf\xdc\x22\x3c\xd0\xb7\x4f\xf3\xa8\x53\x3b\xb6\xc6\x54\xd8\x26\x42\xd6\x84\xe5\x18\xc0\xdb\xe3\x8e\x86\xae\x52\x5f\x4e\x21\x4a\x75\x11\xa3\x03\x97\x78\x02\x1e\x94\x91\x43\xc2\x36\xff\x46\x24\x5d\x96\x3e\xb0\x78\x24\x8a\x05\x2b\xf6\x2a\xcb\x77\x99\xe4\x18\x5f\x4d\xa2\xb3\x3b\x90\x90\xa1\xb3\xc7\xb9\x69\x0d\xde\x41\x92\x6e\x5e\x9d\xeb\x73\x2b\x5a\x30\xc7\xea\xb1\xb4\x9f\x00\x1c\x6b\x6d\xe7\x47\x0e\x2a\x66\x11\x81\x2c\xe4\x1f\xc3\xf0\x7d\x02\x49\x8f\x9e\x31\x7d\x3a\x3e\xd6\xea\xf9\x98\xb3\x8d\x41\x57\x12\x22\xeb\xc6\x18\x09\x97\x38\x37\xc9\x92\x04\xeb\xaf\x1b\x3b\xef\x63\x79\x8e\x8b\xf1\xbe\x5c\x0d\x84\xb7\x6b\x49\x80\xc2\x16\xf4\xa9\x5f\xc4\x90\xea\x14\x2d\x73\x64\x7f\x60\x5e\x26\x54\x06\xb9\x40\x0e\x81\x09\x32\x54\xa7\x4c\x13\xa3\x77\xc4\x59\x82\x99\x60\x90\x5a\x0b\xb5\x3e\x34\x49\x08\xd7\x6a\x24\x7c\x69\x12\x22\xa3\xc2\x55\xe0\x72\x6f\x63\xab\x0b\xc2\x2b\x60\x58\x8b\xd3\x0b\x17\x04\x8f\xb8\x2e\x4c\x09\x3c\x95\xcb\x10\xb6\x64\xb1\x60\x14\xb3\x16\x5c\xa3\xb8\x50\x1b\x2c\x6f\x83\x0d\xf1\x03\x7c\x6a\x73\xc7\xc6\x5d\x70\x2f\xc2\xe7\x76\xde\x94\x3e\x19\xe0\xea\x8c\x2a\xe8\x30\x44\x71\xb6\x36\x5b\xd2\xc6\x13\x8c\xbe\xa5\x95\x07\xbc\xf7\x1a\xf5\x82\xa6\x9a\x47\x59\x42\xd3\x64\x69\xa4\xcb\x24\x4b\x08\x9f\x04\x70\xa8\xb0\x09\x58\x99\x02\x6d\x2d\x24\xdc\x11\x2e\xeb\x45\xd1\x39\x0b\x92\xf4\xac\xe1\x99\x04\x4e\x44\x44\xdb\x40\xef\x94\x19\xeb\x7d\x9f\x9c\x94\xc1\x6f\xe1\x58\x04\x15\xad\x5c\xa1\x04\xf4\xf3\x0d\x92\x4b\x10\x44\x97\x4f\x8c\xb2\xfb\x5d\x70\xf0\x9a\x50\xd6\xa9\xba\xef\xe8\xa1\xbc\xa1\xea\x7e\xa5\x97\xf2\xb4\x36\xb9\xec\x06\xc0\xbb\x0b\x7e\x4b\x7f\x22\x56\x74\x14\xeb\x38\xc9\xb0\x1a\x78\x83\x89\x7e\x09\xd0\xb1\xcb\x93\x9d\xb7\xa0\xaf\xc2\x3e\x76\x9c\x6a\x80\x8c\xd4\x7d\xa2\x01\xe7\x84\xfe\xe8\x46\xca\xae\x36\x2e\xbf\x14\x30\x8a\x88\x99\x97\x51\xec\x19\x46\x30\x4a\x8d\x17\x60\x0e\x16\xcc\x08\xf0\x64\xfc\x61\x1b\x33\x92\x70\x71\xef\xf2\x59\xcd\xce\xf7\x08\xcd\x47\x87\xc3\x87\xb3\x47\x66\x6e\xd0\x6c\x7c\xbe\xc1\x6e\x42\xc2\xeb\xe5\x04\xd5\x6e\xae\x5f\x77\xcd\xf3\xab\x19\xb1\x6e\x1d\xeb\x6f\x4b\x6b\xd8\xce\x2b\xb1\x2e\x56\x87\x17\x4c\xb1\x99\xfc\x72\x15\x7d\x2f\x67\xb4\xbe\x6b\x49\x49\x0b\x3c\x60\x22\x9b\x1f\x7c\x20\xff\x2f\xa7\xcc\xed\xf9\xc9\xf0\xe3\xe9\xf9\xf0\x24\x60\xe0\x83\xff\xba\x1d\xde\x16\x3f\xb9\xba\x3d\x3f\x3f\x3d\xff\x14\x7e\x74\x7d\x7b\x7c\x3c\x1c\x9e\x14\x7f\xf7\x71\x70\x7a\x56\xfa\x9d\xf9\xa8\xf8\xa3\xc1\x0f\x17\x57\x37\xc5\x8f\xae\x7f\x3a\xbd\xbc\x2c\x7e\x74\x73\xfa\x79\x78\x72\x77\x71\x7b\xe3\x68\xfd\x3f\x01\x85\xa1\x90\x01\xa2\xbb\x7e\xfe\xb5\x24\xda\x05\xb8\x61\xd7\xf8\x73\x50\xad\x3c\x49\x39\x13\x71\xb2\xcc\x5b\x73\x9a\x43\x57\x0a\x52\x86\x22\x9d\xcf\x99\xcc\xb6\xc9\x19\x30\xa6\xaf\x7c\x30\x26\x75\x42\xec\x68\x36\xeb\xaa\xd4\xda\x3a\x78\x6b\xca\x74\x5a\x75\x83\xb5\x66\x59\xe8\x74\xe9\xf3\x78\x5a\xf3\x07\x7c\x19\x86\x7d\x09\x59\x98\x9b\xb0\x79\x2e\x70\xe1\xa6\xd9\x42\xf3\x71\xd5\xd1\xd4\xb1\x3c\xa1\xbb\x65\x87\x35\x7a\xf5\xd9\xd5\xe7\xf5\x82\xce\x81\x85\x6d\x89\xc8\x03\x9e\xe9\xf5\x77\xe0\xd2\x3f\x52\xcf\x7a\xc7\x0e\x60\xd0\x98\xcc\x9a\x8a\x86\xe2\xeb\x8e\x20\xe8\x39\x22\x52\x9a\xb7\x22\xb0\x37\x95\xb3\x22\xf2\x8a\xce\x4d\x2c\x6b\x0b\x8a\x26\xe2\xbc\x6f\xb3\x05\x4b\x0b\x10\x11\x6b\x36\xa1\x04\x33\xfd\xe4\xb7\x4c\x2b\xcf\xdb\xac\x53\x50\xfd\x10\x95\xc6\x96\xad\xe1\xb5\x0c\x50\x4f\x8d\xa1\xba\x1d\xa3\xd2\x7b\xd5\x33\x87\xd4\xf6\x20\xed\x4e\x1e\x75\x57\x34\x4a\x80\xd4\x01\x58\x37\xf6\x07\x04\x10\x22\x18\x36\xf7\xc5\x59\xcd\x02\xe5\xc0\x03\x8b\xc9\x61\xd8\x04\x20\x3e\x84\xfc\xc1\x91\x68\xb2\x30\x6b\x00\xf4\x43\x0e\xb8\x74\xf8\x88\xdb\xec\x7d\x0d\xf5\x9b\x8f\xa0\x23\xf6\x7a\x49\x15\xc4\xfd\xbc\x4f\x9a\x5d\x99\x76\x5f\xc6\x14\x5d\x48\x70\xb6\x3c\xf0\x63\x53\x8a\x97\xbf\x0b\xbb\x79\x5c\xd7\xf2\xb6\xd2\x62\x59\x29\xea\x2c\x33\xaa\x30\x07\xd1\x75\x54\xca\x51\xff\xf3\x76\x0f\x4d\x46\x8b\x07\x09\xdb\x61\xe5\x59\x93\x05\xd9\xc3\x8c\x00\xdf\xb9\x29\x44\x56\xf2\x28\x71\xdd\x18\xdf\xef\x86\xc7\xe3\xa2\x4e\xee\x81\xc0\x4a\x68\x66\x74\xfa\x45\x42\x31\x91\x68\x46\x15\xb2\xb4\x73\x52\xd2\x31\x4f\xb8\x86\x2c\x4c\x34\xef\x4b\x14\x96\x29\x99\xd3\xf4\xde\x55\xff\xd0\xbc\x06\xa0\x8d\xe9\xb7\x0c\xa4\xe5\xe0\xa2\xcf\x19\x4a\xcb\x8f\xec\xba\xbe\x81\x9c\x2d\x6d\x18\x2d\xdf\x0e\x6c\x7f\xa3\x65\x00\x94\xda\x6d\x67\xed\x88\x97\xe5\xc7\x0b\xf4\xae\xb9\xa8\xbb\xfb\x6c\x6d\x69\x6b\x07\x31\x5f\x2e\x7c\xad\x3d\x59\x93\x44\xd2\x06\xa8\x53\x37\x36\xd6\xb1\x36\x8d\x1d\xcb\x6c\xdc\x54\x35\x85\xb3\x6a\x1f\xbd\xcd\x00\x73\xe7\x76\x57\x0a\x5d\x28\x00\xa9\x66\xd0\x35\x77\x23\x82\xe6\x4d\x77\xeb\x07\xb7\xb5\x42\x6b\xaf\xb9\xc2\x68\x39\xe2\x81\xaf\xcd\xba\x59\x2e\x58\x0d\xb4\x76\x21\x77\x79\x43\x63\xee\xfa\x72\x78\x7c\xfa\xf1\xb4\x64\x49\x0d\xae\x7f\x0a\xff\xfd\xe5\xe2\xea\xa7\x8f\x67\x17\x5f\xc2\xcf\xce\x06\xb7\xe7\xc7\x3f\xde\x5d\x9e\x0d\xce\x57\xd8\x5b\xd5\x57\x54\xdd\x1d\x79\xe9\x47\x9e\x47\x6d\xee\x06\x9b\xfa\x0b\xa6\x6e\xcd\xf9\xba\xaa\x01\x58\xd9\xb4\x9d\xeb\x93\xb9\x34\xfd\x24\xdd\x1f\x43\xa1\xd3\x65\x17\xe0\x1d\x12\x33\x05\xf7\x90\xf5\x5e\x16\x41\x5f\x98\x02\x5f\xb0\x1b\xfd\x1c\x04\x9b\xf3\xae\xdb\x10\x8d\xa5\x23\xe0\x2d\xf0\xc6\x36\x8c\x89\x61\xb8\xd7\x4a\x87\x30\x07\x10\xa8\x30\x96\x99\x88\x1d\xba\xf5\x9c\x8b\xa3\x39\xfd\xfa\xde\xad\x34\xef\x76\x0d\x75\xa0\xd8\x52\x2c\x31\x5a\xc7\x92\xa4\x99\x68\x27\xd7\x48\xb4\xd0\x6b\xf5\xcd\x80\xbd\xde\xf9\xdf\x41\xc5\xc9\xf5\x51\xf4\x18\x3f\xb0\x65\xdd\xfe\x55\xea\xf9\xd1\x2b\x6d\x75\x60\x18\x64\x91\x32\x68\xe6\xe0\xfd\xd1\x09\xc6\x19\xfc\xbf\x21\xde\x59\xc0\xf8\xa9\xbb\x93\x8a\xb6\xf8\x56\xe7\xa6\xd6\x0b\xf0\x04\x88\x0c\xf6\x4d\x66\xd3\xd0\x27\xe0\x6a\x62\x6d\x7c\x37\xc6\xe2\x14\xb3\x5b\x7f\x93\x63\x32\x81\x70\xb8\x85\xf0\x4c\x59\x04\xee\x0d\xb3\x17\xae\x80\x0c\xd2\x6a\x2b\x8e\x06\xc7\x03\x09\x53\xe0\x6c\x03\x38\x7c\xf6\x4b\x66\x73\xe7\xfe\xf8\x7d\xb7\xa2\x3c\x9d\x2e\x89\x2b\x55\x0d\xc3\xf1\x36\x1b\xc5\xfa\xec\x60\x5e\x99\xe0\x75\xb0\xdb\x57\x08\x04\xff\xbc\xfd\x36\x4a\x2f\xb5\xff\x5c\x99\xb1\x70\xe3\xca\x60\xf0\xf7\x4f\x56\x1f\xf1\x73\xa9\x2c\xc2\xbe\x0e\x02\x91\x76\x74\x15\x64\xdd\x1b\xcb\xe8\x91\xa6\x31\x3a\x06\xc0\x47\xd4\x27\x3f\xca\x47\xf6\xc0\xd2\x1e\x89\x58\xaa\xa9\x4d\x57\x36\x67\x2d\x49\xe0\x40\xd9\x71\x46\x02\x62\xf3\x98\xfb\x2d\x00\xfe\x54\xf3\xe9\xcc\x28\x8f\xd6\x08\xb5\x2d\x13\x14\xd3\x90\x6a\xc8\xbe\x2e\x58\x84\x49\x19\x4d\x91\xe8\x49\x42\x1f\xaa\xf9\xd7\x9b\xa4\xd6\x06\x5d\x21\x5c\xcb\x5a\x5b\xb3\xd2\xea\x94\x72\xcd\x05\x50\x6a\x2e\x96\x7a\x26\x45\x8f\x4c\x65\x42\xc5\xb4\xdf\xef\x13\xa6\xa3\xfe\xfb\x4e\x8c\x6e\x07\x0c\x5e\x97\x47\xd4\x12\xa9\x58\xb2\xf4\x48\x0e\x3e\xf3\xc1\x50\x19\x32\x2d\x14\x47\xf3\xa6\x86\xfb\xaf\xcb\x19\xba\xcf\xeb\x26\xab\xd7\x4a\x3b\xa7\xfa\x34\x8c\x53\xee\x35\xb9\x6a\x24\xfc\x7d\xbd\xa6\xdd\x21\x75\xcd\xa1\x26\xe5\x29\x6c\x0d\x15\x54\x52\x74\xcd\xcb\xfa\x59\x36\x21\x85\x6e\x54\x72\x50\x3b\x92\x4d\x10\xdf\x28\x53\xa9\xca\xd1\x35\x1c\xe7\x93\xfa\xb6\x2a\x6f\x4a\xb2\x79\x15\xee\x7e\x57\x5a\x54\x3e\x49\xfc\xeb\x18\x5e\xb7\x3e\xb6\x9c\x07\x44\x95\x29\x66\x53\xd9\xf9\xa2\xdf\x03\x99\x09\xa4\x65\xca\x15\x14\x5a\x6c\x92\xf0\xe4\x87\xc1\xa1\xc1\x3d\x6b\x6c\x18\x84\xa8\xb6\xcd\x40\x21\x87\xcb\xf7\xf4\xc4\x47\x14\xaa\x3a\xe0\xd3\x6d\x96\x0c\x79\x92\xe8\x46\x56\xcf\xf9\xc5\xf9\x30\x34\x65\x4e\xcf\x6f\x86\x9f\x86\x57\x85\x18\xd4\xd9\xc5\xe0\xa6\x10\x6f\xba\xb9\x2a\x85\xa9\x7e\xb8\xb8\x38\x1b\x0e\xce\xc3\x8f\x4e\x06\x37\xc3\x9b\xd3\xcf\x85\xc1\x4f\x6e\xaf\x06\x37\xa7\x17\x85\xdf\xfd\x70\x7a\x3e\xb8\xfa\x4b\xf8\xc9\xf0\xea\xea\xe2\xaa\xf4\xbe\xdb\xe3\xf6\x48\x56\x61\x19\xf5\x3b\x91\x2b\xcb\x41\xbe\x6c\x9d\x52\x78\x43\xd5\xfd\x8e\xa3\xaf\x90\x6d\xd0\x25\x7a\x5a\x1b\x2c\x2d\x08\xa5\x98\xdd\x6d\x16\x98\x6d\x0a\x2e\xd7\xbe\xc7\xe8\x83\xcb\x3b\xaa\x35\x9b\x2f\xb6\xc3\x1b\x5b\xff\xe0\x74\x8b\xf9\x82\x49\xb3\x46\xcc\xb7\xb0\xab\xaf\x27\xe6\x5b\x13\xce\xad\xc6\x7c\x4f\xcf\x4f\x6f\x4e\x07\x67\xa7\xff\xb7\x34\xe2\x97\xc1\xe9\xcd\xe9\xf9\xa7\xbb\x8f\x17\x57\x77\x57\xc3\xeb\x8b\xdb\xab\xe3\xe1\xf5\x9a\x11\xdf\xaa\x8f\xe5\x90\x84\xef\xf9\x40\x6e\xa4\xc7\xa1\xb0\x5a\xa1\x6d\xc9\x63\x28\x0e\x2d\x8e\xb9\x86\x34\x5c\x2e\xa6\x3d\x00\xc4\xfa\x40\x86\x69\x7a\x3a\xa7\x53\x76\x99\x25\x49\x8f\x78\xdc\xbb\xe3\x94\x51\x0d\x3f\xbb\x94\xf1\x69\xf0\xdc\x48\x90\x43\x52\xbb\x0c\x78\xbf\xc5\x97\xc3\xd7\xf7\xec\xfb\x83\x00\x87\x77\x90\x58\x34\x34\x8f\xe4\xf9\x81\xfc\x40\xa3\x7b\x39\xb1\x40\x19\x3d\x6f\xe2\x92\x5f\x32\xa9\x29\x61\x5f\x23\xc6\x62\xd7\x6e\xa3\xcc\x27\x67\x72\x2b\x7c\xb8\x2e\x7d\x15\xc3\x33\xbd\x3a\x54\x5e\xfb\x9c\xad\x6c\xb8\xeb\x02\xce\x64\x57\xf9\x19\x1f\xb5\x78\x4c\xb5\xa3\x6b\x9d\xec\xc0\x7f\x77\x26\xa7\xf5\x59\xc4\x90\x18\x65\x53\x9f\x73\x1c\x01\x88\x06\xc8\x29\x51\x5c\xdc\x8f\xc4\x17\x63\xd0\xca\x2c\xc5\x8f\xb4\x4c\x21\x21\x7d\x92\x64\x6a\xc6\x00\x07\xb2\x47\x1e\x19\x99\xd3\x25\x46\x05\x8a\x3d\x62\x80\x65\x0c\x73\xc2\xd3\x09\x17\x46\x5a\x2c\xb8\xd3\x20\xcb\x5b\xbf\x0b\x03\x33\xe6\xca\xdb\xd9\x4f\x18\xaa\xc9\x3d\x85\x8f\x33\x06\x79\xbf\x01\xc2\xb4\x6b\x4e\x81\x92\x1b\x6a\xcc\xa4\xbc\xcf\x16\xb6\xb5\x38\x55\xf7\xdf\xb9\x2c\x3a\x20\xf7\x83\xe4\x31\x89\xb3\x45\x12\x74\xf6\x7f\x94\x69\x63\xd6\x03\x5a\x3a\x1d\xb2\x1e\x4a\xf6\x7b\xdb\xc2\x6a\xcc\xa8\xc0\x6a\x6b\xc9\x7f\x78\xe2\x0c\x90\x00\xd5\x26\x53\x2c\x3d\xd4\x29\x9f\x4e\x41\x6f\x74\x4e\x99\xd7\x9f\x22\xe2\x78\x73\x79\xb7\xbd\xff\x21\x74\x55\x27\xd8\x95\xc3\x43\x35\x18\x9e\x5a\x2c\x92\xa5\x4b\xdc\x44\x02\xba\x63\xbf\xc8\x52\xc4\x13\x9d\x10\x3f\xa1\xc6\x10\xed\x22\x65\xe6\x2d\xf1\x1d\x02\x05\x6d\x0f\x60\x74\x3a\x41\xd8\x4c\x04\x26\xf1\x8b\xc8\xc1\x4a\xdc\x0d\x97\xbf\xdb\x95\x55\x60\x45\xb3\xc0\xa6\xf4\x8f\xc2\xb5\xeb\xa7\x0a\x5d\x23\x42\x82\x6e\xe2\x4b\x2d\xa0\x29\x38\x02\xb9\xb9\x3e\xef\xb6\x42\xd3\xfa\x38\x11\x2d\xfe\xe5\x53\x7a\xbc\xa0\x86\x4c\xd5\x62\xdb\xe0\xb2\x88\xdc\xb6\xee\xc2\xe7\x3f\x6c\xaa\x11\xb7\xdb\x74\xd3\x44\x8e\x11\x69\xad\x52\x91\x11\xde\x3a\xdd\x1c\x98\xae\xb9\x71\xf1\xce\x72\x99\x4d\x10\x2a\x97\x2d\x95\xee\x85\x16\x7c\x3b\x2d\x59\xd9\x9e\x60\x99\x96\x01\xb6\x9d\x59\xdc\x69\xa9\x45\x5c\x1f\xf3\x97\x4f\xe3\x5a\xa0\x94\xfc\xc4\x38\xca\x37\x49\xe7\x1a\x1f\x4a\xa7\x8a\x9b\x45\xca\x9c\xf7\x6c\xc9\xb4\x77\x9a\x25\x2e\xbf\x7a\xb9\x28\x76\x05\x0b\xa3\x06\xce\x2f\xe8\xe2\x11\x0c\x0a\x00\x82\xbe\x23\x52\x30\xa1\x95\x45\x08\x1f\x09\x3b\xb8\xab\xdf\xf3\x10\x38\x36\x10\x82\x84\xe9\x59\x1b\xc4\xa2\xad\x2a\x99\x3c\x20\x20\x61\x4e\x13\x2d\x21\xbf\xde\x4c\xf0\xd8\x88\x73\xa3\xbc\x50\x11\xe7\x7d\x23\x66\x6c\x24\x4a\x45\x6c\x29\x9b\x72\xa5\xe1\x62\x71\x1c\x1b\x3e\xbf\xb3\xc2\x9e\x82\xbe\xd3\x46\xfa\xc6\xc2\x9e\x55\x82\x6b\x42\xa3\x2e\x09\xf6\xcb\x05\x8b\x4f\xfd\x73\xed\xcc\x50\x70\x9d\xc4\x41\x68\xa9\x70\xc8\x91\x07\x1c\x9e\x32\x54\x47\x29\x0f\x05\xe6\x37\xc9\x83\x2a\xf9\x86\x59\x66\x8b\xa6\xd4\x35\x4d\x53\xbe\x63\x16\x44\xbb\x0b\x2e\xef\x52\x83\x5b\xaf\x4b\x45\x52\x69\x8c\xaf\xc1\x23\x13\xca\x93\x2c\x6d\x54\x11\x90\x2d\x77\x5e\x76\x78\x0c\xc3\x92\xba\x5d\xf3\x7e\xe9\xe0\x18\x79\x9f\xb4\x6f\x9c\x9b\x64\x53\x2e\x54\x91\xeb\x9b\x1b\x48\x54\x9a\xe9\xac\xd8\xf0\xbc\xff\xce\xfa\xb2\x78\x80\x87\x5d\xc1\xe2\x21\x0e\xd1\x8c\xe0\x64\x95\xb6\x60\xee\x23\x71\x03\x77\x35\x56\xd5\xf9\x63\x46\x11\x71\x38\x55\x1a\x5a\x9c\xd6\xae\xb7\x20\xcf\x8b\x9c\xba\x55\x42\x4b\x5d\xfd\xdb\xea\xc4\xb9\xcf\x74\xd1\x56\x9a\xb4\xf5\x88\xab\xb6\xc1\x7b\x37\xcb\xc7\xb0\xdc\xe2\xa0\x86\x7a\x3e\xf9\xef\x59\x82\x78\x5d\x0a\xa5\x7d\x0e\xa8\x85\x18\xa8\x54\xb9\x16\x14\xd3\xf0\xd1\xee\x69\xc0\x79\xf4\xca\x82\x63\xe3\x80\x63\x4c\xdc\x0c\x73\x4d\xb7\xa8\xb2\xf5\x1b\xe3\xc6\x6a\xd9\x8e\x2d\xf3\xe0\xf2\xd4\xe5\x67\x4c\x83\xfb\xb9\x42\xa2\xae\x59\x70\x0f\x61\xda\x2f\xdc\x0d\x79\xaf\xe8\xb5\x34\x66\x9f\xfd\xf6\x73\x31\x77\xbb\x40\x62\xc9\xd7\x4a\x72\xaf\xa2\xef\x81\xd2\x12\x33\x21\x35\x23\x94\x08\x9e\x1c\x89\x2c\x49\x8e\xce\xa1\x55\xa7\x52\x7c\x8a\x9d\x80\x10\x3b\x1f\xa2\x84\x39\x1e\x4c\xc1\x55\x16\x1c\x01\xb8\x22\xcd\x94\xd0\x8b\xa7\x8d\xc4\x34\x5b\x90\x2c\x47\xc2\x3c\x81\x2a\x16\xc2\x68\xf0\xbc\xdf\x3e\xbc\xcd\xe3\xf4\xe3\xbb\x8c\x6d\x2c\x96\xe1\xe0\x35\x0c\xd6\x56\x0a\xb4\x55\x48\x73\x8f\x11\xf9\x6a\x30\x22\x65\xea\x41\xeb\xd7\x47\x8b\x6c\x3e\x54\x1b\xc3\x35\x7a\x45\xcc\x87\x04\xd6\xe0\xc7\x97\x0c\x07\x3c\x65\x61\xd8\xd6\x55\x60\x8e\x52\xbb\xf0\x8a\xfe\x92\xb1\x8c\x8b\xe9\xdd\x38\x8b\xa7\x6c\x2b\x1f\x9d\xd4\x34\x21\x8f\x94\x6b\x70\xd1\x85\x6a\xbb\x3d\x17\x31\x4b\xe8\x12\x2b\x29\xcc\x5b\x59\x33\x5e\x89\x14\x77\x56\x33\x5f\x4f\x99\x28\x13\xe4\x42\x7c\xc4\xc7\x2f\x65\xc2\xa3\x76\x5f\x9d\xbb\x7a\x00\x56\xa0\xe2\xa9\x05\x00\x0e\x8b\x2c\x4c\x9d\xb9\x80\x4e\x28\xcd\x22\x9d\x9b\x9e\x55\x0e\xef\xe2\xca\xf8\x1c\xb4\x24\xb1\x9e\x29\xcd\xd3\x10\x8b\x22\x2f\xe7\x72\x31\x35\x8f\x0d\x02\xa7\x2f\x96\x0c\x83\x2d\xd1\x8c\x8a\x29\xb3\x3d\x52\x8c\x1e\xe3\x8a\xb2\x4b\x36\x51\xcb\x8d\xe0\x66\x73\x82\xdc\xb8\x55\xea\xea\x2e\x3d\x65\xad\xde\x43\x17\x81\x74\x5e\xf7\xb0\xcb\x78\x61\x12\x36\xbb\x0e\xe5\x20\x74\xe6\xd3\xc5\x1d\x44\xe4\x10\x97\xc0\x67\xbb\x4c\x65\xd4\xd7\x33\x80\xd3\xc2\x6c\x94\x2d\xb6\xcf\x04\xe4\xe3\xb1\xaf\x08\x69\x90\x2c\xc3\x51\xa1\xf8\x15\x46\xec\x98\xa5\x00\x7e\x08\x5f\x9f\xbc\x92\x41\x9a\x77\x73\x5b\xc7\x20\xd6\x7f\x2c\x12\x2a\xee\xf0\xf0\xbd\x80\x6b\x30\xa8\x41\x69\x82\xc7\x0a\x7a\xf1\xef\x66\x9e\xfe\xd6\xbb\x2a\x54\x86\x85\xcd\xb9\x7b\x65\x08\x5d\xa7\xa5\x41\x06\x65\xde\x0e\xd7\x76\xa4\x60\x5f\xeb\x92\x7c\x56\xbb\x37\x69\xc9\x99\xe1\xdb\x40\xac\xf0\x6f\x3a\x0e\x78\xad\x3e\xce\x75\x76\xbe\xc4\xe0\xe5\x6d\xef\xee\x5e\xab\x5c\x9e\x1b\xb9\xd8\x56\x4c\xeb\x69\xdd\x6c\x8d\xe6\x64\xd5\xdd\xf6\xa5\xd8\xe4\xd9\xdc\xc4\x18\x2e\x63\x44\x49\xa3\xe3\x3a\x6b\xb7\xbe\xc6\xa8\x94\xdb\xf2\xa4\x98\x2a\xc5\x12\xf2\xb5\x93\xc4\x10\x55\x89\x9c\xe6\xbd\x87\x7a\x64\x74\x80\x9c\xa5\x46\x07\x88\x43\xe8\x4a\xd5\x1c\x64\x53\xb1\x8d\x4a\xd9\x19\x8d\x71\xa2\xe0\x06\x11\x81\xcb\xa4\x4c\x97\x06\xcf\xce\x4b\x62\x25\x05\x19\x74\x18\x4a\x1e\xe3\x00\x56\x51\x47\xfb\x63\xe9\x80\x94\xa0\x9c\x3a\xcd\x22\x9d\x2f\xd8\xe3\xce\xfc\xe0\x1e\x34\x24\x5a\x64\xd0\xc2\x2e\xce\x1b\x59\xc9\x74\x24\xdc\x68\x39\xfc\xe3\x20\x49\x2a\x43\x55\x21\x97\x02\x5e\x05\x00\x36\x97\xdb\x0e\x35\x13\xe6\x47\x90\xfd\x57\x91\x03\xd0\x04\x72\xcc\xf2\x22\xdb\x3e\xc9\x41\xbf\xa0\x8e\xb3\x84\x2e\x14\x82\x0b\x25\x89\x43\xd6\x41\xbc\x9a\x00\x4e\x45\x65\xd0\x9d\x64\x92\x19\x71\xe4\xdf\xae\xe5\x48\x00\xd0\x54\x41\x95\x82\x06\x2f\xca\xf5\x47\x57\xac\xd2\xf4\xd2\x92\xed\x3b\x9f\xe2\x6f\x3f\x38\x31\x42\xc4\x3c\x65\xcc\xfd\x52\x81\x37\xc4\x32\x21\xe3\xa2\x47\x96\x32\x4b\x0b\xea\xf3\x48\xfc\xcd\x90\xc7\xa1\x27\xd9\x6d\x95\x13\x3c\xc4\xae\x20\x9e\xbc\xfb\x2b\x0e\xfa\xee\x5f\xdf\xff\xf5\x3d\x62\xd3\x65\x2a\x33\x12\xb6\x57\xbc\x42\xdc\x44\xcd\x96\x42\xbe\x8f\x6f\x4d\xe6\x1a\x9e\xe4\xaf\x68\xc5\x59\xb0\x1a\xf1\xae\x51\xc5\x73\x2f\xdc\x80\x44\x54\x47\xb3\x43\x6a\x79\x2f\x44\x94\xe2\x2a\xc7\xac\x37\x1a\x3a\xb4\xcd\x2e\xe2\xdc\x63\x91\x09\xf1\x1d\x47\x55\x91\x0e\x86\x5f\xb0\x3d\x93\xd5\x0a\x4b\xb5\xd9\xee\x4d\xc0\x9c\x79\x75\xf0\x97\x5c\x32\xb8\x9f\xbb\x9a\x89\xa0\x01\x1a\xba\x0b\x8d\x19\x1f\x93\x11\xe6\x18\x8f\x0e\xdc\xf6\x8f\xc4\x62\xdc\x4f\x96\x13\xdd\x87\x8c\xe7\xbe\x21\x4b\x7f\xd8\xda\xc5\x09\x2f\xa1\xbb\xb8\xaa\x95\xaf\x20\x77\xa3\x5e\x5f\xaf\xef\x78\xea\xf8\x37\xad\xaf\xb4\xa0\xb9\xef\xe9\x73\x5d\x8c\x07\x30\xef\x3f\x60\x18\xe3\xe9\x39\xc4\x20\x2a\xe2\x50\xb1\xca\xcf\x27\xc0\x57\x99\x8b\xce\xb7\xea\xa2\x82\x26\x4b\xa8\x5c\xea\x8d\x04\x76\x11\x64\x31\xa1\xd1\x32\x4a\x78\x64\xd1\x7f\x8a\xba\x10\x7b\x60\x42\x17\x12\x2c\x87\xe6\x93\xe7\x52\x87\x9a\x52\x3b\xeb\xa9\x7f\xdb\xa0\x0a\x79\xa4\xb6\xa2\x07\xa5\xcc\x26\x16\xaf\x20\xed\x88\xf7\xe0\x5f\x0f\xa2\x39\x76\xc6\xa2\x4c\xf9\x94\x0b\xaa\x65\x4a\xde\x81\x2b\x38\x49\x58\xfa\xde\xb7\x95\x02\x2a\xd6\x4f\x63\xd6\xa9\x99\x43\x0d\xf4\x4f\xfd\x65\x1b\x45\x59\x9a\xb2\xf8\xae\x9a\x51\xd7\xb5\x36\xb6\x3d\xdf\xc8\xa8\xd6\x7c\xce\x94\xa6\xf3\x05\x49\xf3\x16\x51\xbe\x8a\xcb\x52\x26\x41\x22\x10\x37\xb1\x1e\xe1\x90\x34\xe7\x43\xf7\x23\x61\x83\xf6\xb8\x6f\x32\xad\x01\x7d\x28\xaf\x12\x7b\xdd\x6d\x98\xaf\x68\x41\xf0\x3a\x36\xee\x2a\x3b\x0f\xaf\xce\x5c\x5e\x45\x7e\x11\x14\x24\x2b\x2c\x14\x1a\x21\x1a\x45\xd4\xf7\x8e\xf5\xa9\x61\x23\x91\xa7\x65\x1d\x27\x32\x8b\x89\x75\x9d\x5a\x47\x64\xda\x27\x9c\xf5\x7b\x44\xfd\xf3\x87\xa3\xa3\x7e\x7f\x47\xbd\x20\x8a\xed\xe2\xea\x39\x1c\x1b\xba\xd5\xa5\x3d\xae\x38\x5a\x05\xec\xb7\xbb\x6e\x96\x87\x2b\x6b\x01\x6e\x09\x2d\xf3\x62\x52\x4f\xf9\x95\x0b\x9a\x32\xa1\xef\x20\x51\xbd\xdb\x0b\xe1\x45\x97\xf0\x78\x21\xc7\x7a\x2d\xb3\x27\xc7\x8e\xb4\x45\xaa\x54\xdd\x93\x77\x1c\xa2\x0a\xef\xad\x31\x6e\x74\xe5\x36\x48\xb7\xaa\x04\x6e\x9b\xcd\x33\x89\xe2\xa6\x22\x82\x75\xa6\x5f\x78\x76\xeb\x0b\x64\x9b\xda\x83\x56\x3f\xd8\x89\xc7\x27\x86\x7c\x82\x53\x41\x22\x39\x1f\x1b\x21\x6e\x58\xdd\x3b\x26\xa0\x84\x60\xe0\xf2\x50\x7d\x12\x9d\xcb\xbb\x43\x84\x8f\x52\x16\xbf\xf7\xf0\x87\x59\x72\xc8\xa2\xa5\xbb\xa9\xa9\x7f\x18\xb2\xf3\x13\x94\x49\xd4\x1f\xf5\x41\x79\x05\x39\x62\xf6\x3d\x8f\xee\x99\xb9\xe7\x26\x39\xb2\x4f\x28\xdd\xfc\xfd\xe6\xd3\x06\x47\x02\x28\x84\x39\x2a\xcc\xae\xfb\x8e\x23\x2e\x2a\x33\x3a\x4d\x90\x87\x26\x09\xd7\xdf\xa9\x7a\xe2\x3c\x75\x4d\x47\x3d\x2d\x60\x7c\x9f\x79\x6c\x6b\x8b\xbd\x6a\x81\xca\x18\x48\xe4\x3f\x79\x79\xa8\x58\x24\x85\xcf\x56\xde\xc9\x45\x5f\x53\xef\x51\x3f\x5d\xf8\xae\x52\x94\xbc\x4a\xeb\xd8\x52\xf9\xc9\x15\x9f\x45\x2a\x23\x5b\x64\xad\x89\x82\x58\x2e\xa4\x2c\x99\x77\xf7\xc8\x9c\x72\x61\x8f\x01\xb4\xd0\x24\x31\x1b\x67\xd3\x69\xe3\x9d\x9c\xc8\xe9\x93\x3a\x08\x5c\x75\x44\xa3\x83\xc0\xaf\x30\x69\xcb\xf8\x5f\xc1\xa1\xdf\x90\xf2\xd5\x9a\x21\xb7\x0b\xf5\xe9\xd4\xbd\x09\x8d\xc0\x09\x87\x5e\xf9\xcf\xa0\x31\xed\x48\xfd\x3b\x5d\x47\xfd\x73\x5e\x04\x88\x6a\xdb\x7e\xdc\xce\xce\xfb\x0d\xe9\x85\x98\x25\x78\x67\x9e\x7c\xd2\x54\x41\x9f\xdc\x0c\x87\x15\x93\x00\x8d\x6c\x8a\x15\x80\x08\xec\x3e\x77\x10\x64\xfb\xaa\x8a\x84\xad\x41\x34\xae\xe5\x9c\x11\x78\x95\xc2\x7a\x35\x62\xc3\xf2\x3d\xf0\x3a\x9a\x05\xda\xb6\xad\x89\x15\xfe\xd6\xad\x86\x91\xce\xbc\x7b\x04\x79\x27\xd8\x23\x31\xb2\xb6\x17\xba\x61\x82\xed\xe9\x11\xa6\xa3\xf7\x46\xb7\x29\x44\x6d\x52\x16\xc9\x34\x86\x82\x91\x29\x4d\x63\x88\xe6\x59\x86\x4f\x68\x74\x0f\xa8\x5c\x70\x1d\xe1\x1b\x5d\x00\xd1\xd6\x54\xa0\xfb\x32\x1f\x8d\x8b\x28\x85\xb4\x61\x07\xfa\xe1\xe7\x87\x8f\x2b\x42\xa3\x54\x2a\xf4\x44\x39\x30\x26\x4c\xd9\x01\xf5\xeb\x81\xc7\x19\x4d\xf0\x8d\x5d\x62\x86\x97\x96\x21\x5c\x76\x49\xe0\x04\x03\x29\x59\x80\x3f\xf8\x28\x53\x5b\x1f\x01\x14\xbf\xb4\x28\x0b\x3f\xf2\x07\xd6\x23\xd7\x0b\x9a\xde\xf7\xc8\xc9\x52\xd0\x39\x8f\xfe\x53\x8e\xeb\xfc\x29\x95\x74\x8d\xad\x55\xe2\xdd\x23\x1a\xd7\x1f\xf4\x2f\x95\x50\x3d\x69\x02\x06\x78\x9b\xde\x94\x86\x4c\x9a\x6f\xfd\x52\x5f\x11\x93\xdb\x3b\x46\x76\x7a\x01\xd6\x1a\xca\xce\xcd\x41\xe3\x39\x17\x05\x5b\xed\x55\x39\x5b\xcb\x9b\x5a\x97\xb9\x56\x10\xc6\x6b\x59\xb7\xbb\xd0\x1c\x2f\xa9\xb1\x72\x8c\x41\x39\x97\x1a\x7b\x92\x43\x6d\x2d\xb3\x55\xd6\xa8\x4e\x42\xeb\x25\xae\xf0\x9b\x26\x58\xd2\x28\x91\x6a\xed\x0c\xaa\xea\x86\x1d\xdb\xc7\x5b\xb5\x13\x39\x5f\x40\xf4\x25\x65\x2a\x4b\xb4\xaa\xb1\xd7\x2a\x6e\xeb\x9d\x04\xf2\xab\xd3\xfd\xcc\x34\x3d\xa9\xf8\xb5\xf2\x66\xf3\x61\xfe\x0c\x14\x87\x0d\x5b\x78\xba\xe9\x8a\x1d\x86\xf1\x0b\x73\xb6\x5d\x63\x2b\xdb\xbc\x83\x8b\x69\xd2\x84\x77\x3f\x12\xb6\xf7\x47\x20\xfb\x68\x5e\xe3\xe4\x14\x32\x57\xe6\xfa\x58\xe8\x7b\xe0\x1b\x87\xd8\x44\x18\x6a\x0d\x76\xaf\x17\xc1\x5d\xde\x03\xd0\x2e\x4c\x0c\x12\x80\xd9\x36\x12\x2a\x1b\x1f\xe6\xe9\x2a\x32\x05\xe9\x0a\xa0\x1b\x0b\x9a\x02\x86\xc0\x8c\x27\xf1\x61\x4d\xfa\x1a\x6a\x39\xd0\x32\xc4\x03\xd4\x8d\x19\x60\x50\xc1\x8e\x63\x7b\x3e\x8c\x96\xfa\xb5\xfb\x71\xc6\x99\x26\xcc\xb7\x60\xe0\xca\x3a\x8f\x4a\x9a\x44\x41\x5e\x14\x7c\x03\x2f\xed\x11\x5c\x2d\x2f\x9a\x4a\x18\xbf\x7d\x39\x51\xa0\xd9\x3a\x72\xe2\xa6\xe8\x85\x73\xa7\x86\x0a\x2f\x39\x9a\x48\xa5\xee\xd0\x85\xf6\x84\x99\x83\x5f\x7c\x99\xbe\x2b\x3c\x53\x0b\xfa\x28\x6c\x92\x48\x27\xc8\xdd\xf5\xe4\x43\x3d\x36\x8a\x91\x0f\xa5\x6f\x42\x49\x61\xae\x23\x08\xf2\x73\x5f\x10\xda\x0b\x2a\xdf\xa1\x1d\x53\x5e\xe5\x93\x9b\x3f\x23\x91\x67\x2f\xe5\xfd\x63\xa3\xb2\xe0\xb6\x49\x41\x31\x04\x5a\x59\xcf\x65\x34\xf4\xb0\x2a\xd2\x1a\x29\x87\x63\x0a\xf0\xd0\x5a\xa7\x7c\x9c\xe9\x0a\x4c\x4f\xe1\x34\xd7\x06\x39\x76\x61\x1d\x9c\x3e\x7d\xbb\x93\xfa\x6b\x23\x6f\x17\x93\xa7\x2a\x95\x97\x1e\xc0\x96\x3d\x3f\x54\x49\xb7\xea\xab\x00\x4b\x6c\x7d\x0e\xaf\x54\x78\x5a\x1c\x2d\xcc\x41\x0e\x50\xe0\x0b\x89\x14\x40\xc2\x1c\x25\xdf\x27\x99\x04\x85\x30\x46\x44\xd1\x29\x23\x73\x16\xf3\xac\x5c\xdc\xb7\x3a\x7a\xf6\xaa\xcc\xce\x75\x38\xcb\x18\xe0\xde\x10\x3d\x07\x63\xe1\xd1\xdc\xda\x98\x82\x06\x4e\x8f\x7a\xa0\x8d\x20\x0d\x94\xea\xef\x94\x8f\xc6\x15\x29\xe6\x5c\x4c\x67\x5c\xe9\x9f\x4b\x08\xd7\x1b\xd4\x90\x25\xd9\xd3\xe5\xfe\xb9\xa9\xe2\x34\x83\x27\x5a\x73\xdc\xae\x0a\xed\x81\x81\xc9\xd0\x5d\x01\x39\x22\xae\xba\xce\xcc\xbb\x8b\x00\xff\xab\xa7\xd7\x5f\x6d\x03\xe3\x94\x2e\x16\x2c\x25\xb6\x89\x71\xb9\x2d\x31\x96\xaa\xc1\x5b\x46\x02\x15\xa6\xff\xbc\xbe\x38\xcf\x25\x77\x6e\x47\x95\x86\x86\x9f\x01\xe9\xfa\xf5\x3b\x77\x9e\x25\x49\xe3\xce\xad\x81\x20\x77\x7b\x76\x76\xf7\xf3\xe0\xec\x76\xd8\x8e\xd0\x96\xff\xac\x91\x26\x7e\x26\x96\x26\x78\x8d\x69\xb8\xba\xb2\x39\xb3\x0e\x2c\x50\x46\xec\xaa\x31\xc1\x21\x4b\x92\x62\xb5\xd1\x48\xfc\xd5\x8e\x03\x09\x70\x99\x40\x35\x73\x24\x48\x2b\xe1\x8a\xef\x87\x9f\xfd\xd5\x0c\xfe\x57\x7c\xf6\x90\xe4\x8b\xf8\x40\xce\xfd\x5b\x1b\xe8\x6a\x9d\xae\x5b\x1c\x07\x2c\x7a\x7a\xae\x7a\xca\xcd\x8e\xc7\xad\x70\xe0\x89\xb6\x0c\x72\x27\xa7\x03\x69\xf7\xd7\xa2\x09\xe3\x6b\xbe\x63\x94\xf3\x30\x6e\x0f\xab\xe0\xb0\xc1\xbd\x2f\x14\x1b\x09\xcc\x27\x80\xb6\xc6\xb2\x79\x4e\xe4\x54\x60\x66\x63\x42\xc5\x34\xa3\x53\xa6\x7a\xc4\xbd\x7c\x24\x7c\x13\x5d\x0b\xda\xe2\x9b\xb3\x50\x80\xa2\x2f\xb2\x10\xba\x3a\xd9\x57\x3a\x5f\x40\x08\x46\x8c\x84\x5d\x93\x98\xe6\xc3\xa3\x17\xf4\x3f\xaf\xfd\x72\x0c\xa7\xf9\x81\x6c\x21\x9f\x18\x09\xdc\x5c\xac\xe2\x74\xba\x1d\x38\x80\xa0\x6b\x76\x81\x75\x69\xca\x5c\xed\x30\xc8\xf4\x29\x68\x99\x88\xdb\xed\x42\x8c\x46\xd2\x07\xc0\x33\xe8\x70\xc6\x29\xad\x96\x27\x6e\x33\xdc\x99\xb0\x73\xab\xe7\xfa\xad\xef\x00\x73\xe0\xea\x7b\x25\xb4\xb3\x6d\x2e\xc6\x56\x48\xf3\x9c\xa1\x44\xf9\x08\x93\x72\x2a\x3a\x04\xaf\x77\xd0\x17\x62\xed\x29\xe1\xef\x5b\x27\xd5\xa1\x9d\xc4\xda\xaf\xb5\x25\xe8\x6d\xaf\x35\x16\x4e\xfb\x4b\x77\x60\x22\x15\x26\x65\x1f\x58\x45\x8c\x2c\x6a\xe8\xdc\xb1\x75\x4c\xac\x4c\x22\x27\x7d\xda\x26\x94\x70\xb5\xd1\x74\x72\xfd\x69\xed\x19\x79\x0d\xc1\x5e\x76\x9d\x24\xac\xbd\xe7\x0a\x02\xb6\x41\x4c\xda\xdc\x2c\xeb\x96\x61\x1c\xc5\x8b\x00\x88\x47\x6a\x13\x3c\x7a\x9e\x89\x7a\xf9\xce\xf5\x10\x73\x3e\x4b\x95\x11\x97\x56\xde\x59\xa9\x6d\xcc\x9c\x91\x70\xe5\x03\x4e\x1c\x0f\x5c\x1b\xac\xd4\x7f\x8a\x71\xc6\x05\x26\xdf\x82\xc6\xaa\xf3\xfe\x69\x54\x8f\x04\xd4\xeb\x0b\x30\x21\xc7\x0a\xaa\xa7\x6c\x55\xba\xfd\x22\x80\xf8\xa2\xc2\xe3\xde\xaf\x90\x79\x25\x35\xa0\x70\xcf\xff\xce\xfc\xff\x5f\x7f\xf7\xff\x07\x00\x00\xff\xff\xd3\x73\xa6\xd1\x8e\x10\x03\x00") +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") func adminSwaggerJsonBytes() ([]byte, error) { return bindataRead( @@ -92,7 +92,7 @@ func adminSwaggerJson() (*asset, error) { return nil, err } - info := bindataFileInfo{name: "admin.swagger.json", size: 200846, mode: os.FileMode(420), modTime: time.Unix(1562572800, 0)} + info := bindataFileInfo{name: "admin.swagger.json", size: 202889, 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/ExecutionOuterClass.java b/flyteidl/gen/pb-java/flyteidl/admin/ExecutionOuterClass.java index d02a7080274..0e344e51e17 100644 --- a/flyteidl/gen/pb-java/flyteidl/admin/ExecutionOuterClass.java +++ b/flyteidl/gen/pb-java/flyteidl/admin/ExecutionOuterClass.java @@ -14897,6 +14897,31 @@ public interface ExecutionSpecOrBuilder extends */ flyteidl.admin.Common.AuthRoleOrBuilder getAuthRoleOrBuilder(); + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + boolean hasQualityOfService(); + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + flyteidl.core.Execution.QualityOfService getQualityOfService(); + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder(); + public flyteidl.admin.ExecutionOuterClass.ExecutionSpec.NotificationOverridesCase getNotificationOverridesCase(); } /** @@ -15040,6 +15065,19 @@ private ExecutionSpec( break; } + case 138: { + flyteidl.core.Execution.QualityOfService.Builder subBuilder = null; + if (qualityOfService_ != null) { + subBuilder = qualityOfService_.toBuilder(); + } + qualityOfService_ = input.readMessage(flyteidl.core.Execution.QualityOfService.parser(), extensionRegistry); + if (subBuilder != null) { + subBuilder.mergeFrom(qualityOfService_); + qualityOfService_ = subBuilder.buildPartial(); + } + + break; + } default: { if (!parseUnknownField( input, unknownFields, extensionRegistry, tag)) { @@ -15367,6 +15405,39 @@ public flyteidl.admin.Common.AuthRoleOrBuilder getAuthRoleOrBuilder() { return getAuthRole(); } + public static final int QUALITY_OF_SERVICE_FIELD_NUMBER = 17; + private flyteidl.core.Execution.QualityOfService qualityOfService_; + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public boolean hasQualityOfService() { + return qualityOfService_ != null; + } + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public flyteidl.core.Execution.QualityOfService getQualityOfService() { + return qualityOfService_ == null ? flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; + } + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder() { + return getQualityOfService(); + } + private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { @@ -15406,6 +15477,9 @@ public void writeTo(com.google.protobuf.CodedOutputStream output) if (authRole_ != null) { output.writeMessage(16, getAuthRole()); } + if (qualityOfService_ != null) { + output.writeMessage(17, getQualityOfService()); + } unknownFields.writeTo(output); } @@ -15448,6 +15522,10 @@ public int getSerializedSize() { size += com.google.protobuf.CodedOutputStream .computeMessageSize(16, getAuthRole()); } + if (qualityOfService_ != null) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(17, getQualityOfService()); + } size += unknownFields.getSerializedSize(); memoizedSize = size; return size; @@ -15493,6 +15571,11 @@ public boolean equals(final java.lang.Object obj) { if (!getAuthRole() .equals(other.getAuthRole())) return false; } + if (hasQualityOfService() != other.hasQualityOfService()) return false; + if (hasQualityOfService()) { + if (!getQualityOfService() + .equals(other.getQualityOfService())) return false; + } if (!getNotificationOverridesCase().equals(other.getNotificationOverridesCase())) return false; switch (notificationOverridesCase_) { case 5: @@ -15541,6 +15624,10 @@ public int hashCode() { hash = (37 * hash) + AUTH_ROLE_FIELD_NUMBER; hash = (53 * hash) + getAuthRole().hashCode(); } + if (hasQualityOfService()) { + hash = (37 * hash) + QUALITY_OF_SERVICE_FIELD_NUMBER; + hash = (53 * hash) + getQualityOfService().hashCode(); + } switch (notificationOverridesCase_) { case 5: hash = (37 * hash) + NOTIFICATIONS_FIELD_NUMBER; @@ -15728,6 +15815,12 @@ public Builder clear() { authRole_ = null; authRoleBuilder_ = null; } + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = null; + } else { + qualityOfService_ = null; + qualityOfServiceBuilder_ = null; + } notificationOverridesCase_ = 0; notificationOverrides_ = null; return this; @@ -15796,6 +15889,11 @@ public flyteidl.admin.ExecutionOuterClass.ExecutionSpec buildPartial() { } else { result.authRole_ = authRoleBuilder_.build(); } + if (qualityOfServiceBuilder_ == null) { + result.qualityOfService_ = qualityOfService_; + } else { + result.qualityOfService_ = qualityOfServiceBuilder_.build(); + } result.notificationOverridesCase_ = notificationOverridesCase_; onBuilt(); return result; @@ -15863,6 +15961,9 @@ public Builder mergeFrom(flyteidl.admin.ExecutionOuterClass.ExecutionSpec other) if (other.hasAuthRole()) { mergeAuthRole(other.getAuthRole()); } + if (other.hasQualityOfService()) { + mergeQualityOfService(other.getQualityOfService()); + } switch (other.getNotificationOverridesCase()) { case NOTIFICATIONS: { mergeNotifications(other.getNotifications()); @@ -17069,6 +17170,159 @@ public flyteidl.admin.Common.AuthRoleOrBuilder getAuthRoleOrBuilder() { } return authRoleBuilder_; } + + private flyteidl.core.Execution.QualityOfService qualityOfService_; + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder> qualityOfServiceBuilder_; + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public boolean hasQualityOfService() { + return qualityOfServiceBuilder_ != null || qualityOfService_ != null; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public flyteidl.core.Execution.QualityOfService getQualityOfService() { + if (qualityOfServiceBuilder_ == null) { + return qualityOfService_ == null ? flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; + } else { + return qualityOfServiceBuilder_.getMessage(); + } + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public Builder setQualityOfService(flyteidl.core.Execution.QualityOfService value) { + if (qualityOfServiceBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + qualityOfService_ = value; + onChanged(); + } else { + qualityOfServiceBuilder_.setMessage(value); + } + + return this; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public Builder setQualityOfService( + flyteidl.core.Execution.QualityOfService.Builder builderForValue) { + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = builderForValue.build(); + onChanged(); + } else { + qualityOfServiceBuilder_.setMessage(builderForValue.build()); + } + + return this; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public Builder mergeQualityOfService(flyteidl.core.Execution.QualityOfService value) { + if (qualityOfServiceBuilder_ == null) { + if (qualityOfService_ != null) { + qualityOfService_ = + flyteidl.core.Execution.QualityOfService.newBuilder(qualityOfService_).mergeFrom(value).buildPartial(); + } else { + qualityOfService_ = value; + } + onChanged(); + } else { + qualityOfServiceBuilder_.mergeFrom(value); + } + + return this; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public Builder clearQualityOfService() { + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = null; + onChanged(); + } else { + qualityOfService_ = null; + qualityOfServiceBuilder_ = null; + } + + return this; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public flyteidl.core.Execution.QualityOfService.Builder getQualityOfServiceBuilder() { + + onChanged(); + return getQualityOfServiceFieldBuilder().getBuilder(); + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + public flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder() { + if (qualityOfServiceBuilder_ != null) { + return qualityOfServiceBuilder_.getMessageOrBuilder(); + } else { + return qualityOfService_ == null ? + flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; + } + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 17; + */ + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder> + getQualityOfServiceFieldBuilder() { + if (qualityOfServiceBuilder_ == null) { + qualityOfServiceBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder>( + getQualityOfService(), + getParentForChildren(), + isClean()); + qualityOfService_ = null; + } + return qualityOfServiceBuilder_; + } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { @@ -20148,7 +20402,7 @@ public flyteidl.admin.ExecutionOuterClass.WorkflowExecutionGetDataResponse getDe "CHEDULED\020\001\022\n\n\006SYSTEM\020\002\022\014\n\010RELAUNCH\020\003\022\022\n\016" + "CHILD_WORKFLOW\020\004\"G\n\020NotificationList\0223\n\r" + "notifications\030\001 \003(\0132\034.flyteidl.admin.Not" + - "ification\"\234\003\n\rExecutionSpec\022.\n\013launch_pl" + + "ification\"\331\003\n\rExecutionSpec\022.\n\013launch_pl" + "an\030\001 \001(\0132\031.flyteidl.core.Identifier\022-\n\006i" + "nputs\030\002 \001(\0132\031.flyteidl.core.LiteralMapB\002" + "\030\001\0223\n\010metadata\030\003 \001(\0132!.flyteidl.admin.Ex" + @@ -20157,18 +20411,20 @@ public flyteidl.admin.ExecutionOuterClass.WorkflowExecutionGetDataResponse getDe "sable_all\030\006 \001(\010H\000\022&\n\006labels\030\007 \001(\0132\026.flyt" + "eidl.admin.Labels\0220\n\013annotations\030\010 \001(\0132\033" + ".flyteidl.admin.Annotations\022+\n\tauth_role" + - "\030\020 \001(\0132\030.flyteidl.admin.AuthRoleB\030\n\026noti" + - "fication_overridesJ\004\010\004\020\005\"b\n\031ExecutionTer" + - "minateRequest\0226\n\002id\030\001 \001(\0132*.flyteidl.cor" + - "e.WorkflowExecutionIdentifier\022\r\n\005cause\030\002" + - " \001(\t\"\034\n\032ExecutionTerminateResponse\"Y\n\037Wo" + - "rkflowExecutionGetDataRequest\0226\n\002id\030\001 \001(" + - "\0132*.flyteidl.core.WorkflowExecutionIdent" + - "ifier\"u\n WorkflowExecutionGetDataRespons" + - "e\022(\n\007outputs\030\001 \001(\0132\027.flyteidl.admin.UrlB" + - "lob\022\'\n\006inputs\030\002 \001(\0132\027.flyteidl.admin.Url" + - "BlobB3Z1github.com/lyft/flyteidl/gen/pb-" + - "go/flyteidl/adminb\006proto3" + "\030\020 \001(\0132\030.flyteidl.admin.AuthRole\022;\n\022qual" + + "ity_of_service\030\021 \001(\0132\037.flyteidl.core.Qua" + + "lityOfServiceB\030\n\026notification_overridesJ" + + "\004\010\004\020\005\"b\n\031ExecutionTerminateRequest\0226\n\002id" + + "\030\001 \001(\0132*.flyteidl.core.WorkflowExecution" + + "Identifier\022\r\n\005cause\030\002 \001(\t\"\034\n\032ExecutionTe" + + "rminateResponse\"Y\n\037WorkflowExecutionGetD" + + "ataRequest\0226\n\002id\030\001 \001(\0132*.flyteidl.core.W" + + "orkflowExecutionIdentifier\"u\n WorkflowEx" + + "ecutionGetDataResponse\022(\n\007outputs\030\001 \001(\0132" + + "\027.flyteidl.admin.UrlBlob\022\'\n\006inputs\030\002 \001(\013" + + "2\027.flyteidl.admin.UrlBlobB3Z1github.com/" + + "lyft/flyteidl/gen/pb-go/flyteidl/adminb\006" + + "proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -20265,7 +20521,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_admin_ExecutionSpec_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_ExecutionSpec_descriptor, - new java.lang.String[] { "LaunchPlan", "Inputs", "Metadata", "Notifications", "DisableAll", "Labels", "Annotations", "AuthRole", "NotificationOverrides", }); + new java.lang.String[] { "LaunchPlan", "Inputs", "Metadata", "Notifications", "DisableAll", "Labels", "Annotations", "AuthRole", "QualityOfService", "NotificationOverrides", }); internal_static_flyteidl_admin_ExecutionTerminateRequest_descriptor = getDescriptor().getMessageTypes().get(13); internal_static_flyteidl_admin_ExecutionTerminateRequest_fieldAccessorTable = new diff --git a/flyteidl/gen/pb-java/flyteidl/admin/LaunchPlanOuterClass.java b/flyteidl/gen/pb-java/flyteidl/admin/LaunchPlanOuterClass.java index d67d72217b7..65080c0fe45 100644 --- a/flyteidl/gen/pb-java/flyteidl/admin/LaunchPlanOuterClass.java +++ b/flyteidl/gen/pb-java/flyteidl/admin/LaunchPlanOuterClass.java @@ -4478,6 +4478,31 @@ public interface LaunchPlanSpecOrBuilder extends * .flyteidl.admin.AuthRole auth_role = 9; */ flyteidl.admin.Common.AuthRoleOrBuilder getAuthRoleOrBuilder(); + + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + boolean hasQualityOfService(); + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + flyteidl.core.Execution.QualityOfService getQualityOfService(); + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder(); } /** *
@@ -4633,6 +4658,19 @@ private LaunchPlanSpec(
 
               break;
             }
+            case 130: {
+              flyteidl.core.Execution.QualityOfService.Builder subBuilder = null;
+              if (qualityOfService_ != null) {
+                subBuilder = qualityOfService_.toBuilder();
+              }
+              qualityOfService_ = input.readMessage(flyteidl.core.Execution.QualityOfService.parser(), extensionRegistry);
+              if (subBuilder != null) {
+                subBuilder.mergeFrom(qualityOfService_);
+                qualityOfService_ = subBuilder.buildPartial();
+              }
+
+              break;
+            }
             default: {
               if (!parseUnknownField(
                   input, unknownFields, extensionRegistry, tag)) {
@@ -4959,6 +4997,39 @@ public flyteidl.admin.Common.AuthRoleOrBuilder getAuthRoleOrBuilder() {
       return getAuthRole();
     }
 
+    public static final int QUALITY_OF_SERVICE_FIELD_NUMBER = 16;
+    private flyteidl.core.Execution.QualityOfService qualityOfService_;
+    /**
+     * 
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public boolean hasQualityOfService() { + return qualityOfService_ != null; + } + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public flyteidl.core.Execution.QualityOfService getQualityOfService() { + return qualityOfService_ == null ? flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; + } + /** + *
+     * Indicates the runtime priority of the execution. 
+     * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder() { + return getQualityOfService(); + } + private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { @@ -5000,6 +5071,9 @@ public void writeTo(com.google.protobuf.CodedOutputStream output) if (authRole_ != null) { output.writeMessage(9, getAuthRole()); } + if (qualityOfService_ != null) { + output.writeMessage(16, getQualityOfService()); + } unknownFields.writeTo(output); } @@ -5044,6 +5118,10 @@ public int getSerializedSize() { size += com.google.protobuf.CodedOutputStream .computeMessageSize(9, getAuthRole()); } + if (qualityOfService_ != null) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(16, getQualityOfService()); + } size += unknownFields.getSerializedSize(); memoizedSize = size; return size; @@ -5101,6 +5179,11 @@ public boolean equals(final java.lang.Object obj) { if (!getAuthRole() .equals(other.getAuthRole())) return false; } + if (hasQualityOfService() != other.hasQualityOfService()) return false; + if (hasQualityOfService()) { + if (!getQualityOfService() + .equals(other.getQualityOfService())) return false; + } if (!unknownFields.equals(other.unknownFields)) return false; return true; } @@ -5146,6 +5229,10 @@ public int hashCode() { hash = (37 * hash) + AUTH_ROLE_FIELD_NUMBER; hash = (53 * hash) + getAuthRole().hashCode(); } + if (hasQualityOfService()) { + hash = (37 * hash) + QUALITY_OF_SERVICE_FIELD_NUMBER; + hash = (53 * hash) + getQualityOfService().hashCode(); + } hash = (29 * hash) + unknownFields.hashCode(); memoizedHashCode = hash; return hash; @@ -5333,6 +5420,12 @@ public Builder clear() { authRole_ = null; authRoleBuilder_ = null; } + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = null; + } else { + qualityOfService_ = null; + qualityOfServiceBuilder_ = null; + } return this; } @@ -5400,6 +5493,11 @@ public flyteidl.admin.LaunchPlanOuterClass.LaunchPlanSpec buildPartial() { } else { result.authRole_ = authRoleBuilder_.build(); } + if (qualityOfServiceBuilder_ == null) { + result.qualityOfService_ = qualityOfService_; + } else { + result.qualityOfService_ = qualityOfServiceBuilder_.build(); + } onBuilt(); return result; } @@ -5476,6 +5574,9 @@ public Builder mergeFrom(flyteidl.admin.LaunchPlanOuterClass.LaunchPlanSpec othe if (other.hasAuthRole()) { mergeAuthRole(other.getAuthRole()); } + if (other.hasQualityOfService()) { + mergeQualityOfService(other.getQualityOfService()); + } this.mergeUnknownFields(other.unknownFields); onChanged(); return this; @@ -6781,6 +6882,159 @@ public flyteidl.admin.Common.AuthRoleOrBuilder getAuthRoleOrBuilder() { } return authRoleBuilder_; } + + private flyteidl.core.Execution.QualityOfService qualityOfService_; + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder> qualityOfServiceBuilder_; + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public boolean hasQualityOfService() { + return qualityOfServiceBuilder_ != null || qualityOfService_ != null; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public flyteidl.core.Execution.QualityOfService getQualityOfService() { + if (qualityOfServiceBuilder_ == null) { + return qualityOfService_ == null ? flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; + } else { + return qualityOfServiceBuilder_.getMessage(); + } + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public Builder setQualityOfService(flyteidl.core.Execution.QualityOfService value) { + if (qualityOfServiceBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + qualityOfService_ = value; + onChanged(); + } else { + qualityOfServiceBuilder_.setMessage(value); + } + + return this; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public Builder setQualityOfService( + flyteidl.core.Execution.QualityOfService.Builder builderForValue) { + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = builderForValue.build(); + onChanged(); + } else { + qualityOfServiceBuilder_.setMessage(builderForValue.build()); + } + + return this; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public Builder mergeQualityOfService(flyteidl.core.Execution.QualityOfService value) { + if (qualityOfServiceBuilder_ == null) { + if (qualityOfService_ != null) { + qualityOfService_ = + flyteidl.core.Execution.QualityOfService.newBuilder(qualityOfService_).mergeFrom(value).buildPartial(); + } else { + qualityOfService_ = value; + } + onChanged(); + } else { + qualityOfServiceBuilder_.mergeFrom(value); + } + + return this; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public Builder clearQualityOfService() { + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = null; + onChanged(); + } else { + qualityOfService_ = null; + qualityOfServiceBuilder_ = null; + } + + return this; + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public flyteidl.core.Execution.QualityOfService.Builder getQualityOfServiceBuilder() { + + onChanged(); + return getQualityOfServiceFieldBuilder().getBuilder(); + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + public flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder() { + if (qualityOfServiceBuilder_ != null) { + return qualityOfServiceBuilder_.getMessageOrBuilder(); + } else { + return qualityOfService_ == null ? + flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; + } + } + /** + *
+       * Indicates the runtime priority of the execution. 
+       * 
+ * + * .flyteidl.core.QualityOfService quality_of_service = 16; + */ + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder> + getQualityOfServiceFieldBuilder() { + if (qualityOfServiceBuilder_ == null) { + qualityOfServiceBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder>( + getQualityOfService(), + getParentForChildren(), + isClean()); + qualityOfService_ = null; + } + return qualityOfServiceBuilder_; + } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { @@ -12779,55 +13033,57 @@ public flyteidl.admin.LaunchPlanOuterClass.ActiveLaunchPlanListRequest getDefaul static { java.lang.String[] descriptorData = { "\n flyteidl/admin/launch_plan.proto\022\016flyt" + - "eidl.admin\032\034flyteidl/core/literals.proto" + - "\032\036flyteidl/core/identifier.proto\032\035flytei" + - "dl/core/interface.proto\032\035flyteidl/admin/" + - "schedule.proto\032\033flyteidl/admin/common.pr" + - "oto\032\037google/protobuf/timestamp.proto\"n\n\027" + - "LaunchPlanCreateRequest\022%\n\002id\030\001 \001(\0132\031.fl" + - "yteidl.core.Identifier\022,\n\004spec\030\002 \001(\0132\036.f" + - "lyteidl.admin.LaunchPlanSpec\"\032\n\030LaunchPl" + - "anCreateResponse\"\225\001\n\nLaunchPlan\022%\n\002id\030\001 " + - "\001(\0132\031.flyteidl.core.Identifier\022,\n\004spec\030\002" + - " \001(\0132\036.flyteidl.admin.LaunchPlanSpec\0222\n\007" + - "closure\030\003 \001(\0132!.flyteidl.admin.LaunchPla" + - "nClosure\"Q\n\016LaunchPlanList\0220\n\014launch_pla" + - "ns\030\001 \003(\0132\032.flyteidl.admin.LaunchPlan\022\r\n\005" + - "token\030\002 \001(\t\"T\n\004Auth\022\034\n\022assumable_iam_rol" + - "e\030\001 \001(\tH\000\022$\n\032kubernetes_service_account\030" + - "\002 \001(\tH\000B\010\n\006method\"\244\003\n\016LaunchPlanSpec\022.\n\013" + - "workflow_id\030\001 \001(\0132\031.flyteidl.core.Identi" + - "fier\022;\n\017entity_metadata\030\002 \001(\0132\".flyteidl" + - ".admin.LaunchPlanMetadata\0223\n\016default_inp" + - "uts\030\003 \001(\0132\033.flyteidl.core.ParameterMap\022/" + - "\n\014fixed_inputs\030\004 \001(\0132\031.flyteidl.core.Lit" + - "eralMap\022\020\n\004role\030\005 \001(\tB\002\030\001\022&\n\006labels\030\006 \001(" + - "\0132\026.flyteidl.admin.Labels\0220\n\013annotations" + - "\030\007 \001(\0132\033.flyteidl.admin.Annotations\022&\n\004a" + - "uth\030\010 \001(\0132\024.flyteidl.admin.AuthB\002\030\001\022+\n\ta" + - "uth_role\030\t \001(\0132\030.flyteidl.admin.AuthRole" + - "\"\217\002\n\021LaunchPlanClosure\022.\n\005state\030\001 \001(\0162\037." + - "flyteidl.admin.LaunchPlanState\0224\n\017expect" + - "ed_inputs\030\002 \001(\0132\033.flyteidl.core.Paramete" + - "rMap\0224\n\020expected_outputs\030\003 \001(\0132\032.flyteid" + - "l.core.VariableMap\022.\n\ncreated_at\030\004 \001(\0132\032" + - ".google.protobuf.Timestamp\022.\n\nupdated_at" + - "\030\005 \001(\0132\032.google.protobuf.Timestamp\"u\n\022La" + - "unchPlanMetadata\022*\n\010schedule\030\001 \001(\0132\030.fly" + - "teidl.admin.Schedule\0223\n\rnotifications\030\002 " + - "\003(\0132\034.flyteidl.admin.Notification\"p\n\027Lau" + - "nchPlanUpdateRequest\022%\n\002id\030\001 \001(\0132\031.flyte" + - "idl.core.Identifier\022.\n\005state\030\002 \001(\0162\037.fly" + - "teidl.admin.LaunchPlanState\"\032\n\030LaunchPla" + - "nUpdateResponse\"L\n\027ActiveLaunchPlanReque" + - "st\0221\n\002id\030\001 \001(\0132%.flyteidl.admin.NamedEnt" + - "ityIdentifier\"\203\001\n\033ActiveLaunchPlanListRe" + - "quest\022\017\n\007project\030\001 \001(\t\022\016\n\006domain\030\002 \001(\t\022\r" + - "\n\005limit\030\003 \001(\r\022\r\n\005token\030\004 \001(\t\022%\n\007sort_by\030" + - "\005 \001(\0132\024.flyteidl.admin.Sort*+\n\017LaunchPla" + - "nState\022\014\n\010INACTIVE\020\000\022\n\n\006ACTIVE\020\001B3Z1gith" + - "ub.com/lyft/flyteidl/gen/pb-go/flyteidl/" + - "adminb\006proto3" + "eidl.admin\032\035flyteidl/core/execution.prot" + + "o\032\034flyteidl/core/literals.proto\032\036flyteid" + + "l/core/identifier.proto\032\035flyteidl/core/i" + + "nterface.proto\032\035flyteidl/admin/schedule." + + "proto\032\033flyteidl/admin/common.proto\032\037goog" + + "le/protobuf/timestamp.proto\"n\n\027LaunchPla" + + "nCreateRequest\022%\n\002id\030\001 \001(\0132\031.flyteidl.co" + + "re.Identifier\022,\n\004spec\030\002 \001(\0132\036.flyteidl.a" + + "dmin.LaunchPlanSpec\"\032\n\030LaunchPlanCreateR" + + "esponse\"\225\001\n\nLaunchPlan\022%\n\002id\030\001 \001(\0132\031.fly" + + "teidl.core.Identifier\022,\n\004spec\030\002 \001(\0132\036.fl" + + "yteidl.admin.LaunchPlanSpec\0222\n\007closure\030\003" + + " \001(\0132!.flyteidl.admin.LaunchPlanClosure\"" + + "Q\n\016LaunchPlanList\0220\n\014launch_plans\030\001 \003(\0132" + + "\032.flyteidl.admin.LaunchPlan\022\r\n\005token\030\002 \001" + + "(\t\"T\n\004Auth\022\034\n\022assumable_iam_role\030\001 \001(\tH\000" + + "\022$\n\032kubernetes_service_account\030\002 \001(\tH\000B\010" + + "\n\006method\"\341\003\n\016LaunchPlanSpec\022.\n\013workflow_" + + "id\030\001 \001(\0132\031.flyteidl.core.Identifier\022;\n\017e" + + "ntity_metadata\030\002 \001(\0132\".flyteidl.admin.La" + + "unchPlanMetadata\0223\n\016default_inputs\030\003 \001(\013" + + "2\033.flyteidl.core.ParameterMap\022/\n\014fixed_i" + + "nputs\030\004 \001(\0132\031.flyteidl.core.LiteralMap\022\020" + + "\n\004role\030\005 \001(\tB\002\030\001\022&\n\006labels\030\006 \001(\0132\026.flyte" + + "idl.admin.Labels\0220\n\013annotations\030\007 \001(\0132\033." + + "flyteidl.admin.Annotations\022&\n\004auth\030\010 \001(\013" + + "2\024.flyteidl.admin.AuthB\002\030\001\022+\n\tauth_role\030" + + "\t \001(\0132\030.flyteidl.admin.AuthRole\022;\n\022quali" + + "ty_of_service\030\020 \001(\0132\037.flyteidl.core.Qual" + + "ityOfService\"\217\002\n\021LaunchPlanClosure\022.\n\005st" + + "ate\030\001 \001(\0162\037.flyteidl.admin.LaunchPlanSta" + + "te\0224\n\017expected_inputs\030\002 \001(\0132\033.flyteidl.c" + + "ore.ParameterMap\0224\n\020expected_outputs\030\003 \001" + + "(\0132\032.flyteidl.core.VariableMap\022.\n\ncreate" + + "d_at\030\004 \001(\0132\032.google.protobuf.Timestamp\022." + + "\n\nupdated_at\030\005 \001(\0132\032.google.protobuf.Tim" + + "estamp\"u\n\022LaunchPlanMetadata\022*\n\010schedule" + + "\030\001 \001(\0132\030.flyteidl.admin.Schedule\0223\n\rnoti" + + "fications\030\002 \003(\0132\034.flyteidl.admin.Notific" + + "ation\"p\n\027LaunchPlanUpdateRequest\022%\n\002id\030\001" + + " \001(\0132\031.flyteidl.core.Identifier\022.\n\005state" + + "\030\002 \001(\0162\037.flyteidl.admin.LaunchPlanState\"" + + "\032\n\030LaunchPlanUpdateResponse\"L\n\027ActiveLau" + + "nchPlanRequest\0221\n\002id\030\001 \001(\0132%.flyteidl.ad" + + "min.NamedEntityIdentifier\"\203\001\n\033ActiveLaun" + + "chPlanListRequest\022\017\n\007project\030\001 \001(\t\022\016\n\006do" + + "main\030\002 \001(\t\022\r\n\005limit\030\003 \001(\r\022\r\n\005token\030\004 \001(\t" + + "\022%\n\007sort_by\030\005 \001(\0132\024.flyteidl.admin.Sort*" + + "+\n\017LaunchPlanState\022\014\n\010INACTIVE\020\000\022\n\n\006ACTI" + + "VE\020\001B3Z1github.com/lyft/flyteidl/gen/pb-" + + "go/flyteidl/adminb\006proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -12840,6 +13096,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( com.google.protobuf.Descriptors.FileDescriptor .internalBuildGeneratedFileFrom(descriptorData, new com.google.protobuf.Descriptors.FileDescriptor[] { + flyteidl.core.Execution.getDescriptor(), flyteidl.core.Literals.getDescriptor(), flyteidl.core.IdentifierOuterClass.getDescriptor(), flyteidl.core.Interface.getDescriptor(), @@ -12882,7 +13139,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_admin_LaunchPlanSpec_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_LaunchPlanSpec_descriptor, - new java.lang.String[] { "WorkflowId", "EntityMetadata", "DefaultInputs", "FixedInputs", "Role", "Labels", "Annotations", "Auth", "AuthRole", }); + new java.lang.String[] { "WorkflowId", "EntityMetadata", "DefaultInputs", "FixedInputs", "Role", "Labels", "Annotations", "Auth", "AuthRole", "QualityOfService", }); internal_static_flyteidl_admin_LaunchPlanClosure_descriptor = getDescriptor().getMessageTypes().get(6); internal_static_flyteidl_admin_LaunchPlanClosure_fieldAccessorTable = new @@ -12919,6 +13176,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_ActiveLaunchPlanListRequest_descriptor, new java.lang.String[] { "Project", "Domain", "Limit", "Token", "SortBy", }); + flyteidl.core.Execution.getDescriptor(); flyteidl.core.Literals.getDescriptor(); flyteidl.core.IdentifierOuterClass.getDescriptor(); flyteidl.core.Interface.getDescriptor(); diff --git a/flyteidl/gen/pb-java/flyteidl/admin/MatchableResourceOuterClass.java b/flyteidl/gen/pb-java/flyteidl/admin/MatchableResourceOuterClass.java index c35162de892..80d6676fabb 100644 --- a/flyteidl/gen/pb-java/flyteidl/admin/MatchableResourceOuterClass.java +++ b/flyteidl/gen/pb-java/flyteidl/admin/MatchableResourceOuterClass.java @@ -56,6 +56,14 @@ public enum MatchableResource * EXECUTION_CLUSTER_LABEL = 3; */ EXECUTION_CLUSTER_LABEL(3), + /** + *
+     * Configures default quality of service when undefined in an execution spec.
+     * 
+ * + * QUALITY_OF_SERVICE_SPECIFICATION = 4; + */ + QUALITY_OF_SERVICE_SPECIFICATION(4), UNRECOGNIZED(-1), ; @@ -91,6 +99,14 @@ public enum MatchableResource * EXECUTION_CLUSTER_LABEL = 3; */ public static final int EXECUTION_CLUSTER_LABEL_VALUE = 3; + /** + *
+     * Configures default quality of service when undefined in an execution spec.
+     * 
+ * + * QUALITY_OF_SERVICE_SPECIFICATION = 4; + */ + public static final int QUALITY_OF_SERVICE_SPECIFICATION_VALUE = 4; public final int getNumber() { @@ -115,6 +131,7 @@ public static MatchableResource forNumber(int value) { case 1: return CLUSTER_RESOURCE; case 2: return EXECUTION_QUEUE; case 3: return EXECUTION_CLUSTER_LABEL; + case 4: return QUALITY_OF_SERVICE_SPECIFICATION; default: return null; } } @@ -4056,6 +4073,19 @@ public interface MatchingAttributesOrBuilder extends */ flyteidl.admin.MatchableResourceOuterClass.ExecutionClusterLabelOrBuilder getExecutionClusterLabelOrBuilder(); + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + boolean hasQualityOfService(); + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + flyteidl.core.Execution.QualityOfService getQualityOfService(); + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder(); + public flyteidl.admin.MatchableResourceOuterClass.MatchingAttributes.TargetCase getTargetCase(); } /** @@ -4157,6 +4187,20 @@ private MatchingAttributes( targetCase_ = 4; break; } + case 42: { + flyteidl.core.Execution.QualityOfService.Builder subBuilder = null; + if (targetCase_ == 5) { + subBuilder = ((flyteidl.core.Execution.QualityOfService) target_).toBuilder(); + } + target_ = + input.readMessage(flyteidl.core.Execution.QualityOfService.parser(), extensionRegistry); + if (subBuilder != null) { + subBuilder.mergeFrom((flyteidl.core.Execution.QualityOfService) target_); + target_ = subBuilder.buildPartial(); + } + targetCase_ = 5; + break; + } default: { if (!parseUnknownField( input, unknownFields, extensionRegistry, tag)) { @@ -4197,6 +4241,7 @@ public enum TargetCase CLUSTER_RESOURCE_ATTRIBUTES(2), EXECUTION_QUEUE_ATTRIBUTES(3), EXECUTION_CLUSTER_LABEL(4), + QUALITY_OF_SERVICE(5), TARGET_NOT_SET(0); private final int value; private TargetCase(int value) { @@ -4216,6 +4261,7 @@ public static TargetCase forNumber(int value) { case 2: return CLUSTER_RESOURCE_ATTRIBUTES; case 3: return EXECUTION_QUEUE_ATTRIBUTES; case 4: return EXECUTION_CLUSTER_LABEL; + case 5: return QUALITY_OF_SERVICE; case 0: return TARGET_NOT_SET; default: return null; } @@ -4335,6 +4381,32 @@ public flyteidl.admin.MatchableResourceOuterClass.ExecutionClusterLabelOrBuilder return flyteidl.admin.MatchableResourceOuterClass.ExecutionClusterLabel.getDefaultInstance(); } + public static final int QUALITY_OF_SERVICE_FIELD_NUMBER = 5; + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public boolean hasQualityOfService() { + return targetCase_ == 5; + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public flyteidl.core.Execution.QualityOfService getQualityOfService() { + if (targetCase_ == 5) { + return (flyteidl.core.Execution.QualityOfService) target_; + } + return flyteidl.core.Execution.QualityOfService.getDefaultInstance(); + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder() { + if (targetCase_ == 5) { + return (flyteidl.core.Execution.QualityOfService) target_; + } + return flyteidl.core.Execution.QualityOfService.getDefaultInstance(); + } + private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { @@ -4361,6 +4433,9 @@ public void writeTo(com.google.protobuf.CodedOutputStream output) if (targetCase_ == 4) { output.writeMessage(4, (flyteidl.admin.MatchableResourceOuterClass.ExecutionClusterLabel) target_); } + if (targetCase_ == 5) { + output.writeMessage(5, (flyteidl.core.Execution.QualityOfService) target_); + } unknownFields.writeTo(output); } @@ -4386,6 +4461,10 @@ public int getSerializedSize() { size += com.google.protobuf.CodedOutputStream .computeMessageSize(4, (flyteidl.admin.MatchableResourceOuterClass.ExecutionClusterLabel) target_); } + if (targetCase_ == 5) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(5, (flyteidl.core.Execution.QualityOfService) target_); + } size += unknownFields.getSerializedSize(); memoizedSize = size; return size; @@ -4419,6 +4498,10 @@ public boolean equals(final java.lang.Object obj) { if (!getExecutionClusterLabel() .equals(other.getExecutionClusterLabel())) return false; break; + case 5: + if (!getQualityOfService() + .equals(other.getQualityOfService())) return false; + break; case 0: default: } @@ -4450,6 +4533,10 @@ public int hashCode() { hash = (37 * hash) + EXECUTION_CLUSTER_LABEL_FIELD_NUMBER; hash = (53 * hash) + getExecutionClusterLabel().hashCode(); break; + case 5: + hash = (37 * hash) + QUALITY_OF_SERVICE_FIELD_NUMBER; + hash = (53 * hash) + getQualityOfService().hashCode(); + break; case 0: default: } @@ -4646,6 +4733,13 @@ public flyteidl.admin.MatchableResourceOuterClass.MatchingAttributes buildPartia result.target_ = executionClusterLabelBuilder_.build(); } } + if (targetCase_ == 5) { + if (qualityOfServiceBuilder_ == null) { + result.target_ = target_; + } else { + result.target_ = qualityOfServiceBuilder_.build(); + } + } result.targetCase_ = targetCase_; onBuilt(); return result; @@ -4712,6 +4806,10 @@ public Builder mergeFrom(flyteidl.admin.MatchableResourceOuterClass.MatchingAttr mergeExecutionClusterLabel(other.getExecutionClusterLabel()); break; } + case QUALITY_OF_SERVICE: { + mergeQualityOfService(other.getQualityOfService()); + break; + } case TARGET_NOT_SET: { break; } @@ -5303,6 +5401,142 @@ public flyteidl.admin.MatchableResourceOuterClass.ExecutionClusterLabelOrBuilder onChanged();; return executionClusterLabelBuilder_; } + + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder> qualityOfServiceBuilder_; + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public boolean hasQualityOfService() { + return targetCase_ == 5; + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public flyteidl.core.Execution.QualityOfService getQualityOfService() { + if (qualityOfServiceBuilder_ == null) { + if (targetCase_ == 5) { + return (flyteidl.core.Execution.QualityOfService) target_; + } + return flyteidl.core.Execution.QualityOfService.getDefaultInstance(); + } else { + if (targetCase_ == 5) { + return qualityOfServiceBuilder_.getMessage(); + } + return flyteidl.core.Execution.QualityOfService.getDefaultInstance(); + } + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public Builder setQualityOfService(flyteidl.core.Execution.QualityOfService value) { + if (qualityOfServiceBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + target_ = value; + onChanged(); + } else { + qualityOfServiceBuilder_.setMessage(value); + } + targetCase_ = 5; + return this; + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public Builder setQualityOfService( + flyteidl.core.Execution.QualityOfService.Builder builderForValue) { + if (qualityOfServiceBuilder_ == null) { + target_ = builderForValue.build(); + onChanged(); + } else { + qualityOfServiceBuilder_.setMessage(builderForValue.build()); + } + targetCase_ = 5; + return this; + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public Builder mergeQualityOfService(flyteidl.core.Execution.QualityOfService value) { + if (qualityOfServiceBuilder_ == null) { + if (targetCase_ == 5 && + target_ != flyteidl.core.Execution.QualityOfService.getDefaultInstance()) { + target_ = flyteidl.core.Execution.QualityOfService.newBuilder((flyteidl.core.Execution.QualityOfService) target_) + .mergeFrom(value).buildPartial(); + } else { + target_ = value; + } + onChanged(); + } else { + if (targetCase_ == 5) { + qualityOfServiceBuilder_.mergeFrom(value); + } + qualityOfServiceBuilder_.setMessage(value); + } + targetCase_ = 5; + return this; + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public Builder clearQualityOfService() { + if (qualityOfServiceBuilder_ == null) { + if (targetCase_ == 5) { + targetCase_ = 0; + target_ = null; + onChanged(); + } + } else { + if (targetCase_ == 5) { + targetCase_ = 0; + target_ = null; + } + qualityOfServiceBuilder_.clear(); + } + return this; + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public flyteidl.core.Execution.QualityOfService.Builder getQualityOfServiceBuilder() { + return getQualityOfServiceFieldBuilder().getBuilder(); + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + public flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder() { + if ((targetCase_ == 5) && (qualityOfServiceBuilder_ != null)) { + return qualityOfServiceBuilder_.getMessageOrBuilder(); + } else { + if (targetCase_ == 5) { + return (flyteidl.core.Execution.QualityOfService) target_; + } + return flyteidl.core.Execution.QualityOfService.getDefaultInstance(); + } + } + /** + * .flyteidl.core.QualityOfService quality_of_service = 5; + */ + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder> + getQualityOfServiceFieldBuilder() { + if (qualityOfServiceBuilder_ == null) { + if (!(targetCase_ == 5)) { + target_ = flyteidl.core.Execution.QualityOfService.getDefaultInstance(); + } + qualityOfServiceBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder>( + (flyteidl.core.Execution.QualityOfService) target_, + getParentForChildren(), + isClean()); + target_ = null; + } + targetCase_ = 5; + onChanged();; + return qualityOfServiceBuilder_; + } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { @@ -7883,40 +8117,44 @@ public flyteidl.admin.MatchableResourceOuterClass.ListMatchableAttributesRespons static { java.lang.String[] descriptorData = { "\n\'flyteidl/admin/matchable_resource.prot" + - "o\022\016flyteidl.admin\"M\n\020TaskResourceSpec\022\013\n" + - "\003cpu\030\001 \001(\t\022\013\n\003gpu\030\002 \001(\t\022\016\n\006memory\030\003 \001(\t\022" + - "\017\n\007storage\030\004 \001(\t\"~\n\026TaskResourceAttribut" + - "es\0222\n\010defaults\030\001 \001(\0132 .flyteidl.admin.Ta" + - "skResourceSpec\0220\n\006limits\030\002 \001(\0132 .flyteid" + - "l.admin.TaskResourceSpec\"\235\001\n\031ClusterReso" + - "urceAttributes\022M\n\nattributes\030\001 \003(\01329.fly" + - "teidl.admin.ClusterResourceAttributes.At" + - "tributesEntry\0321\n\017AttributesEntry\022\013\n\003key\030" + - "\001 \001(\t\022\r\n\005value\030\002 \001(\t:\0028\001\"(\n\030ExecutionQue" + - "ueAttributes\022\014\n\004tags\030\001 \003(\t\"&\n\025ExecutionC" + - "lusterLabel\022\r\n\005value\030\001 \001(\t\"\326\002\n\022MatchingA" + - "ttributes\022J\n\030task_resource_attributes\030\001 " + - "\001(\0132&.flyteidl.admin.TaskResourceAttribu" + - "tesH\000\022P\n\033cluster_resource_attributes\030\002 \001" + - "(\0132).flyteidl.admin.ClusterResourceAttri" + - "butesH\000\022N\n\032execution_queue_attributes\030\003 " + - "\001(\0132(.flyteidl.admin.ExecutionQueueAttri" + - "butesH\000\022H\n\027execution_cluster_label\030\004 \001(\013" + - "2%.flyteidl.admin.ExecutionClusterLabelH" + - "\000B\010\n\006target\"\242\001\n MatchableAttributesConfi" + - "guration\0226\n\nattributes\030\001 \001(\0132\".flyteidl." + - "admin.MatchingAttributes\022\016\n\006domain\030\002 \001(\t" + - "\022\017\n\007project\030\003 \001(\t\022\020\n\010workflow\030\004 \001(\t\022\023\n\013l" + - "aunch_plan\030\005 \001(\t\"Z\n\036ListMatchableAttribu" + - "tesRequest\0228\n\rresource_type\030\001 \001(\0162!.flyt" + - "eidl.admin.MatchableResource\"k\n\037ListMatc" + - "hableAttributesResponse\022H\n\016configuration" + - "s\030\001 \003(\01320.flyteidl.admin.MatchableAttrib" + - "utesConfiguration*n\n\021MatchableResource\022\021" + - "\n\rTASK_RESOURCE\020\000\022\024\n\020CLUSTER_RESOURCE\020\001\022" + - "\023\n\017EXECUTION_QUEUE\020\002\022\033\n\027EXECUTION_CLUSTE" + - "R_LABEL\020\003B3Z1github.com/lyft/flyteidl/ge" + - "n/pb-go/flyteidl/adminb\006proto3" + "o\022\016flyteidl.admin\032\033flyteidl/admin/common" + + ".proto\032\035flyteidl/core/execution.proto\"M\n" + + "\020TaskResourceSpec\022\013\n\003cpu\030\001 \001(\t\022\013\n\003gpu\030\002 " + + "\001(\t\022\016\n\006memory\030\003 \001(\t\022\017\n\007storage\030\004 \001(\t\"~\n\026" + + "TaskResourceAttributes\0222\n\010defaults\030\001 \001(\013" + + "2 .flyteidl.admin.TaskResourceSpec\0220\n\006li" + + "mits\030\002 \001(\0132 .flyteidl.admin.TaskResource" + + "Spec\"\235\001\n\031ClusterResourceAttributes\022M\n\nat" + + "tributes\030\001 \003(\01329.flyteidl.admin.ClusterR" + + "esourceAttributes.AttributesEntry\0321\n\017Att" + + "ributesEntry\022\013\n\003key\030\001 \001(\t\022\r\n\005value\030\002 \001(\t" + + ":\0028\001\"(\n\030ExecutionQueueAttributes\022\014\n\004tags" + + "\030\001 \003(\t\"&\n\025ExecutionClusterLabel\022\r\n\005value" + + "\030\001 \001(\t\"\225\003\n\022MatchingAttributes\022J\n\030task_re" + + "source_attributes\030\001 \001(\0132&.flyteidl.admin" + + ".TaskResourceAttributesH\000\022P\n\033cluster_res" + + "ource_attributes\030\002 \001(\0132).flyteidl.admin." + + "ClusterResourceAttributesH\000\022N\n\032execution" + + "_queue_attributes\030\003 \001(\0132(.flyteidl.admin" + + ".ExecutionQueueAttributesH\000\022H\n\027execution" + + "_cluster_label\030\004 \001(\0132%.flyteidl.admin.Ex" + + "ecutionClusterLabelH\000\022=\n\022quality_of_serv" + + "ice\030\005 \001(\0132\037.flyteidl.core.QualityOfServi" + + "ceH\000B\010\n\006target\"\242\001\n MatchableAttributesCo" + + "nfiguration\0226\n\nattributes\030\001 \001(\0132\".flytei" + + "dl.admin.MatchingAttributes\022\016\n\006domain\030\002 " + + "\001(\t\022\017\n\007project\030\003 \001(\t\022\020\n\010workflow\030\004 \001(\t\022\023" + + "\n\013launch_plan\030\005 \001(\t\"Z\n\036ListMatchableAttr" + + "ibutesRequest\0228\n\rresource_type\030\001 \001(\0162!.f" + + "lyteidl.admin.MatchableResource\"k\n\037ListM" + + "atchableAttributesResponse\022H\n\016configurat" + + "ions\030\001 \003(\01320.flyteidl.admin.MatchableAtt" + + "ributesConfiguration*\224\001\n\021MatchableResour" + + "ce\022\021\n\rTASK_RESOURCE\020\000\022\024\n\020CLUSTER_RESOURC" + + "E\020\001\022\023\n\017EXECUTION_QUEUE\020\002\022\033\n\027EXECUTION_CL" + + "USTER_LABEL\020\003\022$\n QUALITY_OF_SERVICE_SPEC" + + "IFICATION\020\004B3Z1github.com/lyft/flyteidl/" + + "gen/pb-go/flyteidl/adminb\006proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -7929,6 +8167,8 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( com.google.protobuf.Descriptors.FileDescriptor .internalBuildGeneratedFileFrom(descriptorData, new com.google.protobuf.Descriptors.FileDescriptor[] { + flyteidl.admin.Common.getDescriptor(), + flyteidl.core.Execution.getDescriptor(), }, assigner); internal_static_flyteidl_admin_TaskResourceSpec_descriptor = getDescriptor().getMessageTypes().get(0); @@ -7971,7 +8211,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_admin_MatchingAttributes_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_MatchingAttributes_descriptor, - new java.lang.String[] { "TaskResourceAttributes", "ClusterResourceAttributes", "ExecutionQueueAttributes", "ExecutionClusterLabel", "Target", }); + new java.lang.String[] { "TaskResourceAttributes", "ClusterResourceAttributes", "ExecutionQueueAttributes", "ExecutionClusterLabel", "QualityOfService", "Target", }); internal_static_flyteidl_admin_MatchableAttributesConfiguration_descriptor = getDescriptor().getMessageTypes().get(6); internal_static_flyteidl_admin_MatchableAttributesConfiguration_fieldAccessorTable = new @@ -7990,6 +8230,8 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_ListMatchableAttributesResponse_descriptor, new java.lang.String[] { "Configurations", }); + flyteidl.admin.Common.getDescriptor(); + flyteidl.core.Execution.getDescriptor(); } // @@protoc_insertion_point(outer_class_scope) diff --git a/flyteidl/gen/pb-java/flyteidl/core/Execution.java b/flyteidl/gen/pb-java/flyteidl/core/Execution.java index b11a0648172..35c7a3c95fe 100644 --- a/flyteidl/gen/pb-java/flyteidl/core/Execution.java +++ b/flyteidl/gen/pb-java/flyteidl/core/Execution.java @@ -4007,6 +4007,1625 @@ public flyteidl.core.Execution.TaskLog getDefaultInstanceForType() { } + public interface QualityOfServiceSpecOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.core.QualityOfServiceSpec) + com.google.protobuf.MessageOrBuilder { + + /** + *
+     * Indicates how much queueing delay an execution can tolerate.
+     * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + boolean hasQueueingBudget(); + /** + *
+     * Indicates how much queueing delay an execution can tolerate.
+     * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + com.google.protobuf.Duration getQueueingBudget(); + /** + *
+     * Indicates how much queueing delay an execution can tolerate.
+     * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + com.google.protobuf.DurationOrBuilder getQueueingBudgetOrBuilder(); + } + /** + *
+   * Represents customized execution run-time attributes.
+   * 
+ * + * Protobuf type {@code flyteidl.core.QualityOfServiceSpec} + */ + public static final class QualityOfServiceSpec extends + com.google.protobuf.GeneratedMessageV3 implements + // @@protoc_insertion_point(message_implements:flyteidl.core.QualityOfServiceSpec) + QualityOfServiceSpecOrBuilder { + private static final long serialVersionUID = 0L; + // Use QualityOfServiceSpec.newBuilder() to construct. + private QualityOfServiceSpec(com.google.protobuf.GeneratedMessageV3.Builder builder) { + super(builder); + } + private QualityOfServiceSpec() { + } + + @java.lang.Override + public final com.google.protobuf.UnknownFieldSet + getUnknownFields() { + return this.unknownFields; + } + private QualityOfServiceSpec( + 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: { + com.google.protobuf.Duration.Builder subBuilder = null; + if (queueingBudget_ != null) { + subBuilder = queueingBudget_.toBuilder(); + } + queueingBudget_ = input.readMessage(com.google.protobuf.Duration.parser(), extensionRegistry); + if (subBuilder != null) { + subBuilder.mergeFrom(queueingBudget_); + queueingBudget_ = 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.core.Execution.internal_static_flyteidl_core_QualityOfServiceSpec_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.core.Execution.internal_static_flyteidl_core_QualityOfServiceSpec_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.core.Execution.QualityOfServiceSpec.class, flyteidl.core.Execution.QualityOfServiceSpec.Builder.class); + } + + public static final int QUEUEING_BUDGET_FIELD_NUMBER = 1; + private com.google.protobuf.Duration queueingBudget_; + /** + *
+     * Indicates how much queueing delay an execution can tolerate.
+     * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public boolean hasQueueingBudget() { + return queueingBudget_ != null; + } + /** + *
+     * Indicates how much queueing delay an execution can tolerate.
+     * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public com.google.protobuf.Duration getQueueingBudget() { + return queueingBudget_ == null ? com.google.protobuf.Duration.getDefaultInstance() : queueingBudget_; + } + /** + *
+     * Indicates how much queueing delay an execution can tolerate.
+     * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public com.google.protobuf.DurationOrBuilder getQueueingBudgetOrBuilder() { + return getQueueingBudget(); + } + + 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 (queueingBudget_ != null) { + output.writeMessage(1, getQueueingBudget()); + } + unknownFields.writeTo(output); + } + + @java.lang.Override + public int getSerializedSize() { + int size = memoizedSize; + if (size != -1) return size; + + size = 0; + if (queueingBudget_ != null) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(1, getQueueingBudget()); + } + 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.core.Execution.QualityOfServiceSpec)) { + return super.equals(obj); + } + flyteidl.core.Execution.QualityOfServiceSpec other = (flyteidl.core.Execution.QualityOfServiceSpec) obj; + + if (hasQueueingBudget() != other.hasQueueingBudget()) return false; + if (hasQueueingBudget()) { + if (!getQueueingBudget() + .equals(other.getQueueingBudget())) 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 (hasQueueingBudget()) { + hash = (37 * hash) + QUEUEING_BUDGET_FIELD_NUMBER; + hash = (53 * hash) + getQueueingBudget().hashCode(); + } + hash = (29 * hash) + unknownFields.hashCode(); + memoizedHashCode = hash; + return hash; + } + + public static flyteidl.core.Execution.QualityOfServiceSpec parseFrom( + java.nio.ByteBuffer data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.core.Execution.QualityOfServiceSpec parseFrom( + java.nio.ByteBuffer data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.core.Execution.QualityOfServiceSpec parseFrom( + com.google.protobuf.ByteString data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.core.Execution.QualityOfServiceSpec parseFrom( + com.google.protobuf.ByteString data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.core.Execution.QualityOfServiceSpec parseFrom(byte[] data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.core.Execution.QualityOfServiceSpec parseFrom( + byte[] data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.core.Execution.QualityOfServiceSpec parseFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.core.Execution.QualityOfServiceSpec 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.core.Execution.QualityOfServiceSpec parseDelimitedFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input); + } + public static flyteidl.core.Execution.QualityOfServiceSpec 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.core.Execution.QualityOfServiceSpec parseFrom( + com.google.protobuf.CodedInputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.core.Execution.QualityOfServiceSpec 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.core.Execution.QualityOfServiceSpec 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; + } + /** + *
+     * Represents customized execution run-time attributes.
+     * 
+ * + * Protobuf type {@code flyteidl.core.QualityOfServiceSpec} + */ + public static final class Builder extends + com.google.protobuf.GeneratedMessageV3.Builder implements + // @@protoc_insertion_point(builder_implements:flyteidl.core.QualityOfServiceSpec) + flyteidl.core.Execution.QualityOfServiceSpecOrBuilder { + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.core.Execution.internal_static_flyteidl_core_QualityOfServiceSpec_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.core.Execution.internal_static_flyteidl_core_QualityOfServiceSpec_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.core.Execution.QualityOfServiceSpec.class, flyteidl.core.Execution.QualityOfServiceSpec.Builder.class); + } + + // Construct using flyteidl.core.Execution.QualityOfServiceSpec.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 (queueingBudgetBuilder_ == null) { + queueingBudget_ = null; + } else { + queueingBudget_ = null; + queueingBudgetBuilder_ = null; + } + return this; + } + + @java.lang.Override + public com.google.protobuf.Descriptors.Descriptor + getDescriptorForType() { + return flyteidl.core.Execution.internal_static_flyteidl_core_QualityOfServiceSpec_descriptor; + } + + @java.lang.Override + public flyteidl.core.Execution.QualityOfServiceSpec getDefaultInstanceForType() { + return flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance(); + } + + @java.lang.Override + public flyteidl.core.Execution.QualityOfServiceSpec build() { + flyteidl.core.Execution.QualityOfServiceSpec result = buildPartial(); + if (!result.isInitialized()) { + throw newUninitializedMessageException(result); + } + return result; + } + + @java.lang.Override + public flyteidl.core.Execution.QualityOfServiceSpec buildPartial() { + flyteidl.core.Execution.QualityOfServiceSpec result = new flyteidl.core.Execution.QualityOfServiceSpec(this); + if (queueingBudgetBuilder_ == null) { + result.queueingBudget_ = queueingBudget_; + } else { + result.queueingBudget_ = queueingBudgetBuilder_.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.core.Execution.QualityOfServiceSpec) { + return mergeFrom((flyteidl.core.Execution.QualityOfServiceSpec)other); + } else { + super.mergeFrom(other); + return this; + } + } + + public Builder mergeFrom(flyteidl.core.Execution.QualityOfServiceSpec other) { + if (other == flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance()) return this; + if (other.hasQueueingBudget()) { + mergeQueueingBudget(other.getQueueingBudget()); + } + 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.core.Execution.QualityOfServiceSpec parsedMessage = null; + try { + parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + parsedMessage = (flyteidl.core.Execution.QualityOfServiceSpec) e.getUnfinishedMessage(); + throw e.unwrapIOException(); + } finally { + if (parsedMessage != null) { + mergeFrom(parsedMessage); + } + } + return this; + } + + private com.google.protobuf.Duration queueingBudget_; + private com.google.protobuf.SingleFieldBuilderV3< + com.google.protobuf.Duration, com.google.protobuf.Duration.Builder, com.google.protobuf.DurationOrBuilder> queueingBudgetBuilder_; + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public boolean hasQueueingBudget() { + return queueingBudgetBuilder_ != null || queueingBudget_ != null; + } + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public com.google.protobuf.Duration getQueueingBudget() { + if (queueingBudgetBuilder_ == null) { + return queueingBudget_ == null ? com.google.protobuf.Duration.getDefaultInstance() : queueingBudget_; + } else { + return queueingBudgetBuilder_.getMessage(); + } + } + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public Builder setQueueingBudget(com.google.protobuf.Duration value) { + if (queueingBudgetBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + queueingBudget_ = value; + onChanged(); + } else { + queueingBudgetBuilder_.setMessage(value); + } + + return this; + } + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public Builder setQueueingBudget( + com.google.protobuf.Duration.Builder builderForValue) { + if (queueingBudgetBuilder_ == null) { + queueingBudget_ = builderForValue.build(); + onChanged(); + } else { + queueingBudgetBuilder_.setMessage(builderForValue.build()); + } + + return this; + } + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public Builder mergeQueueingBudget(com.google.protobuf.Duration value) { + if (queueingBudgetBuilder_ == null) { + if (queueingBudget_ != null) { + queueingBudget_ = + com.google.protobuf.Duration.newBuilder(queueingBudget_).mergeFrom(value).buildPartial(); + } else { + queueingBudget_ = value; + } + onChanged(); + } else { + queueingBudgetBuilder_.mergeFrom(value); + } + + return this; + } + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public Builder clearQueueingBudget() { + if (queueingBudgetBuilder_ == null) { + queueingBudget_ = null; + onChanged(); + } else { + queueingBudget_ = null; + queueingBudgetBuilder_ = null; + } + + return this; + } + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public com.google.protobuf.Duration.Builder getQueueingBudgetBuilder() { + + onChanged(); + return getQueueingBudgetFieldBuilder().getBuilder(); + } + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + public com.google.protobuf.DurationOrBuilder getQueueingBudgetOrBuilder() { + if (queueingBudgetBuilder_ != null) { + return queueingBudgetBuilder_.getMessageOrBuilder(); + } else { + return queueingBudget_ == null ? + com.google.protobuf.Duration.getDefaultInstance() : queueingBudget_; + } + } + /** + *
+       * Indicates how much queueing delay an execution can tolerate.
+       * 
+ * + * .google.protobuf.Duration queueing_budget = 1; + */ + private com.google.protobuf.SingleFieldBuilderV3< + com.google.protobuf.Duration, com.google.protobuf.Duration.Builder, com.google.protobuf.DurationOrBuilder> + getQueueingBudgetFieldBuilder() { + if (queueingBudgetBuilder_ == null) { + queueingBudgetBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + com.google.protobuf.Duration, com.google.protobuf.Duration.Builder, com.google.protobuf.DurationOrBuilder>( + getQueueingBudget(), + getParentForChildren(), + isClean()); + queueingBudget_ = null; + } + return queueingBudgetBuilder_; + } + @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.core.QualityOfServiceSpec) + } + + // @@protoc_insertion_point(class_scope:flyteidl.core.QualityOfServiceSpec) + private static final flyteidl.core.Execution.QualityOfServiceSpec DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.core.Execution.QualityOfServiceSpec(); + } + + public static flyteidl.core.Execution.QualityOfServiceSpec getDefaultInstance() { + return DEFAULT_INSTANCE; + } + + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { + @java.lang.Override + public QualityOfServiceSpec parsePartialFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return new QualityOfServiceSpec(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.core.Execution.QualityOfServiceSpec getDefaultInstanceForType() { + return DEFAULT_INSTANCE; + } + + } + + public interface QualityOfServiceOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.core.QualityOfService) + com.google.protobuf.MessageOrBuilder { + + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + int getTierValue(); + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + flyteidl.core.Execution.QualityOfService.Tier getTier(); + + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + boolean hasSpec(); + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + flyteidl.core.Execution.QualityOfServiceSpec getSpec(); + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + flyteidl.core.Execution.QualityOfServiceSpecOrBuilder getSpecOrBuilder(); + + public flyteidl.core.Execution.QualityOfService.DesignationCase getDesignationCase(); + } + /** + *
+   * Indicates the priority of an execution.
+   * 
+ * + * Protobuf type {@code flyteidl.core.QualityOfService} + */ + public static final class QualityOfService extends + com.google.protobuf.GeneratedMessageV3 implements + // @@protoc_insertion_point(message_implements:flyteidl.core.QualityOfService) + QualityOfServiceOrBuilder { + private static final long serialVersionUID = 0L; + // Use QualityOfService.newBuilder() to construct. + private QualityOfService(com.google.protobuf.GeneratedMessageV3.Builder builder) { + super(builder); + } + private QualityOfService() { + } + + @java.lang.Override + public final com.google.protobuf.UnknownFieldSet + getUnknownFields() { + return this.unknownFields; + } + private QualityOfService( + 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 8: { + int rawValue = input.readEnum(); + designationCase_ = 1; + designation_ = rawValue; + break; + } + case 18: { + flyteidl.core.Execution.QualityOfServiceSpec.Builder subBuilder = null; + if (designationCase_ == 2) { + subBuilder = ((flyteidl.core.Execution.QualityOfServiceSpec) designation_).toBuilder(); + } + designation_ = + input.readMessage(flyteidl.core.Execution.QualityOfServiceSpec.parser(), extensionRegistry); + if (subBuilder != null) { + subBuilder.mergeFrom((flyteidl.core.Execution.QualityOfServiceSpec) designation_); + designation_ = subBuilder.buildPartial(); + } + designationCase_ = 2; + 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.core.Execution.internal_static_flyteidl_core_QualityOfService_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.core.Execution.internal_static_flyteidl_core_QualityOfService_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.core.Execution.QualityOfService.class, flyteidl.core.Execution.QualityOfService.Builder.class); + } + + /** + * Protobuf enum {@code flyteidl.core.QualityOfService.Tier} + */ + public enum Tier + implements com.google.protobuf.ProtocolMessageEnum { + /** + *
+       * Default: no quality of service specified.
+       * 
+ * + * UNDEFINED = 0; + */ + UNDEFINED(0), + /** + * HIGH = 1; + */ + HIGH(1), + /** + * MEDIUM = 2; + */ + MEDIUM(2), + /** + * LOW = 3; + */ + LOW(3), + UNRECOGNIZED(-1), + ; + + /** + *
+       * Default: no quality of service specified.
+       * 
+ * + * UNDEFINED = 0; + */ + public static final int UNDEFINED_VALUE = 0; + /** + * HIGH = 1; + */ + public static final int HIGH_VALUE = 1; + /** + * MEDIUM = 2; + */ + public static final int MEDIUM_VALUE = 2; + /** + * LOW = 3; + */ + public static final int LOW_VALUE = 3; + + + public final int getNumber() { + if (this == UNRECOGNIZED) { + throw new java.lang.IllegalArgumentException( + "Can't get the number of an unknown enum value."); + } + return value; + } + + /** + * @deprecated Use {@link #forNumber(int)} instead. + */ + @java.lang.Deprecated + public static Tier valueOf(int value) { + return forNumber(value); + } + + public static Tier forNumber(int value) { + switch (value) { + case 0: return UNDEFINED; + case 1: return HIGH; + case 2: return MEDIUM; + case 3: return LOW; + default: return null; + } + } + + public static com.google.protobuf.Internal.EnumLiteMap + internalGetValueMap() { + return internalValueMap; + } + private static final com.google.protobuf.Internal.EnumLiteMap< + Tier> internalValueMap = + new com.google.protobuf.Internal.EnumLiteMap() { + public Tier findValueByNumber(int number) { + return Tier.forNumber(number); + } + }; + + public final com.google.protobuf.Descriptors.EnumValueDescriptor + getValueDescriptor() { + return getDescriptor().getValues().get(ordinal()); + } + public final com.google.protobuf.Descriptors.EnumDescriptor + getDescriptorForType() { + return getDescriptor(); + } + public static final com.google.protobuf.Descriptors.EnumDescriptor + getDescriptor() { + return flyteidl.core.Execution.QualityOfService.getDescriptor().getEnumTypes().get(0); + } + + private static final Tier[] VALUES = values(); + + public static Tier valueOf( + com.google.protobuf.Descriptors.EnumValueDescriptor desc) { + if (desc.getType() != getDescriptor()) { + throw new java.lang.IllegalArgumentException( + "EnumValueDescriptor is not for this type."); + } + if (desc.getIndex() == -1) { + return UNRECOGNIZED; + } + return VALUES[desc.getIndex()]; + } + + private final int value; + + private Tier(int value) { + this.value = value; + } + + // @@protoc_insertion_point(enum_scope:flyteidl.core.QualityOfService.Tier) + } + + private int designationCase_ = 0; + private java.lang.Object designation_; + public enum DesignationCase + implements com.google.protobuf.Internal.EnumLite { + TIER(1), + SPEC(2), + DESIGNATION_NOT_SET(0); + private final int value; + private DesignationCase(int value) { + this.value = value; + } + /** + * @deprecated Use {@link #forNumber(int)} instead. + */ + @java.lang.Deprecated + public static DesignationCase valueOf(int value) { + return forNumber(value); + } + + public static DesignationCase forNumber(int value) { + switch (value) { + case 1: return TIER; + case 2: return SPEC; + case 0: return DESIGNATION_NOT_SET; + default: return null; + } + } + public int getNumber() { + return this.value; + } + }; + + public DesignationCase + getDesignationCase() { + return DesignationCase.forNumber( + designationCase_); + } + + public static final int TIER_FIELD_NUMBER = 1; + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + public int getTierValue() { + if (designationCase_ == 1) { + return (java.lang.Integer) designation_; + } + return 0; + } + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + public flyteidl.core.Execution.QualityOfService.Tier getTier() { + if (designationCase_ == 1) { + @SuppressWarnings("deprecation") + flyteidl.core.Execution.QualityOfService.Tier result = flyteidl.core.Execution.QualityOfService.Tier.valueOf( + (java.lang.Integer) designation_); + return result == null ? flyteidl.core.Execution.QualityOfService.Tier.UNRECOGNIZED : result; + } + return flyteidl.core.Execution.QualityOfService.Tier.UNDEFINED; + } + + public static final int SPEC_FIELD_NUMBER = 2; + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public boolean hasSpec() { + return designationCase_ == 2; + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public flyteidl.core.Execution.QualityOfServiceSpec getSpec() { + if (designationCase_ == 2) { + return (flyteidl.core.Execution.QualityOfServiceSpec) designation_; + } + return flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance(); + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public flyteidl.core.Execution.QualityOfServiceSpecOrBuilder getSpecOrBuilder() { + if (designationCase_ == 2) { + return (flyteidl.core.Execution.QualityOfServiceSpec) designation_; + } + return flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance(); + } + + 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 (designationCase_ == 1) { + output.writeEnum(1, ((java.lang.Integer) designation_)); + } + if (designationCase_ == 2) { + output.writeMessage(2, (flyteidl.core.Execution.QualityOfServiceSpec) designation_); + } + unknownFields.writeTo(output); + } + + @java.lang.Override + public int getSerializedSize() { + int size = memoizedSize; + if (size != -1) return size; + + size = 0; + if (designationCase_ == 1) { + size += com.google.protobuf.CodedOutputStream + .computeEnumSize(1, ((java.lang.Integer) designation_)); + } + if (designationCase_ == 2) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(2, (flyteidl.core.Execution.QualityOfServiceSpec) designation_); + } + 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.core.Execution.QualityOfService)) { + return super.equals(obj); + } + flyteidl.core.Execution.QualityOfService other = (flyteidl.core.Execution.QualityOfService) obj; + + if (!getDesignationCase().equals(other.getDesignationCase())) return false; + switch (designationCase_) { + case 1: + if (getTierValue() + != other.getTierValue()) return false; + break; + case 2: + if (!getSpec() + .equals(other.getSpec())) return false; + break; + case 0: + default: + } + 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(); + switch (designationCase_) { + case 1: + hash = (37 * hash) + TIER_FIELD_NUMBER; + hash = (53 * hash) + getTierValue(); + break; + case 2: + hash = (37 * hash) + SPEC_FIELD_NUMBER; + hash = (53 * hash) + getSpec().hashCode(); + break; + case 0: + default: + } + hash = (29 * hash) + unknownFields.hashCode(); + memoizedHashCode = hash; + return hash; + } + + public static flyteidl.core.Execution.QualityOfService parseFrom( + java.nio.ByteBuffer data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.core.Execution.QualityOfService parseFrom( + java.nio.ByteBuffer data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.core.Execution.QualityOfService parseFrom( + com.google.protobuf.ByteString data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.core.Execution.QualityOfService parseFrom( + com.google.protobuf.ByteString data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.core.Execution.QualityOfService parseFrom(byte[] data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.core.Execution.QualityOfService parseFrom( + byte[] data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.core.Execution.QualityOfService parseFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.core.Execution.QualityOfService 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.core.Execution.QualityOfService parseDelimitedFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input); + } + public static flyteidl.core.Execution.QualityOfService 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.core.Execution.QualityOfService parseFrom( + com.google.protobuf.CodedInputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.core.Execution.QualityOfService 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.core.Execution.QualityOfService 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; + } + /** + *
+     * Indicates the priority of an execution.
+     * 
+ * + * Protobuf type {@code flyteidl.core.QualityOfService} + */ + public static final class Builder extends + com.google.protobuf.GeneratedMessageV3.Builder implements + // @@protoc_insertion_point(builder_implements:flyteidl.core.QualityOfService) + flyteidl.core.Execution.QualityOfServiceOrBuilder { + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.core.Execution.internal_static_flyteidl_core_QualityOfService_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.core.Execution.internal_static_flyteidl_core_QualityOfService_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.core.Execution.QualityOfService.class, flyteidl.core.Execution.QualityOfService.Builder.class); + } + + // Construct using flyteidl.core.Execution.QualityOfService.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(); + designationCase_ = 0; + designation_ = null; + return this; + } + + @java.lang.Override + public com.google.protobuf.Descriptors.Descriptor + getDescriptorForType() { + return flyteidl.core.Execution.internal_static_flyteidl_core_QualityOfService_descriptor; + } + + @java.lang.Override + public flyteidl.core.Execution.QualityOfService getDefaultInstanceForType() { + return flyteidl.core.Execution.QualityOfService.getDefaultInstance(); + } + + @java.lang.Override + public flyteidl.core.Execution.QualityOfService build() { + flyteidl.core.Execution.QualityOfService result = buildPartial(); + if (!result.isInitialized()) { + throw newUninitializedMessageException(result); + } + return result; + } + + @java.lang.Override + public flyteidl.core.Execution.QualityOfService buildPartial() { + flyteidl.core.Execution.QualityOfService result = new flyteidl.core.Execution.QualityOfService(this); + if (designationCase_ == 1) { + result.designation_ = designation_; + } + if (designationCase_ == 2) { + if (specBuilder_ == null) { + result.designation_ = designation_; + } else { + result.designation_ = specBuilder_.build(); + } + } + result.designationCase_ = designationCase_; + 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.core.Execution.QualityOfService) { + return mergeFrom((flyteidl.core.Execution.QualityOfService)other); + } else { + super.mergeFrom(other); + return this; + } + } + + public Builder mergeFrom(flyteidl.core.Execution.QualityOfService other) { + if (other == flyteidl.core.Execution.QualityOfService.getDefaultInstance()) return this; + switch (other.getDesignationCase()) { + case TIER: { + setTierValue(other.getTierValue()); + break; + } + case SPEC: { + mergeSpec(other.getSpec()); + break; + } + case DESIGNATION_NOT_SET: { + break; + } + } + 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.core.Execution.QualityOfService parsedMessage = null; + try { + parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + parsedMessage = (flyteidl.core.Execution.QualityOfService) e.getUnfinishedMessage(); + throw e.unwrapIOException(); + } finally { + if (parsedMessage != null) { + mergeFrom(parsedMessage); + } + } + return this; + } + private int designationCase_ = 0; + private java.lang.Object designation_; + public DesignationCase + getDesignationCase() { + return DesignationCase.forNumber( + designationCase_); + } + + public Builder clearDesignation() { + designationCase_ = 0; + designation_ = null; + onChanged(); + return this; + } + + + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + public int getTierValue() { + if (designationCase_ == 1) { + return ((java.lang.Integer) designation_).intValue(); + } + return 0; + } + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + public Builder setTierValue(int value) { + designationCase_ = 1; + designation_ = value; + onChanged(); + return this; + } + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + public flyteidl.core.Execution.QualityOfService.Tier getTier() { + if (designationCase_ == 1) { + @SuppressWarnings("deprecation") + flyteidl.core.Execution.QualityOfService.Tier result = flyteidl.core.Execution.QualityOfService.Tier.valueOf( + (java.lang.Integer) designation_); + return result == null ? flyteidl.core.Execution.QualityOfService.Tier.UNRECOGNIZED : result; + } + return flyteidl.core.Execution.QualityOfService.Tier.UNDEFINED; + } + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + public Builder setTier(flyteidl.core.Execution.QualityOfService.Tier value) { + if (value == null) { + throw new NullPointerException(); + } + designationCase_ = 1; + designation_ = value.getNumber(); + onChanged(); + return this; + } + /** + * .flyteidl.core.QualityOfService.Tier tier = 1; + */ + public Builder clearTier() { + if (designationCase_ == 1) { + designationCase_ = 0; + designation_ = null; + onChanged(); + } + return this; + } + + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfServiceSpec, flyteidl.core.Execution.QualityOfServiceSpec.Builder, flyteidl.core.Execution.QualityOfServiceSpecOrBuilder> specBuilder_; + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public boolean hasSpec() { + return designationCase_ == 2; + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public flyteidl.core.Execution.QualityOfServiceSpec getSpec() { + if (specBuilder_ == null) { + if (designationCase_ == 2) { + return (flyteidl.core.Execution.QualityOfServiceSpec) designation_; + } + return flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance(); + } else { + if (designationCase_ == 2) { + return specBuilder_.getMessage(); + } + return flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance(); + } + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public Builder setSpec(flyteidl.core.Execution.QualityOfServiceSpec value) { + if (specBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + designation_ = value; + onChanged(); + } else { + specBuilder_.setMessage(value); + } + designationCase_ = 2; + return this; + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public Builder setSpec( + flyteidl.core.Execution.QualityOfServiceSpec.Builder builderForValue) { + if (specBuilder_ == null) { + designation_ = builderForValue.build(); + onChanged(); + } else { + specBuilder_.setMessage(builderForValue.build()); + } + designationCase_ = 2; + return this; + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public Builder mergeSpec(flyteidl.core.Execution.QualityOfServiceSpec value) { + if (specBuilder_ == null) { + if (designationCase_ == 2 && + designation_ != flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance()) { + designation_ = flyteidl.core.Execution.QualityOfServiceSpec.newBuilder((flyteidl.core.Execution.QualityOfServiceSpec) designation_) + .mergeFrom(value).buildPartial(); + } else { + designation_ = value; + } + onChanged(); + } else { + if (designationCase_ == 2) { + specBuilder_.mergeFrom(value); + } + specBuilder_.setMessage(value); + } + designationCase_ = 2; + return this; + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public Builder clearSpec() { + if (specBuilder_ == null) { + if (designationCase_ == 2) { + designationCase_ = 0; + designation_ = null; + onChanged(); + } + } else { + if (designationCase_ == 2) { + designationCase_ = 0; + designation_ = null; + } + specBuilder_.clear(); + } + return this; + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public flyteidl.core.Execution.QualityOfServiceSpec.Builder getSpecBuilder() { + return getSpecFieldBuilder().getBuilder(); + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + public flyteidl.core.Execution.QualityOfServiceSpecOrBuilder getSpecOrBuilder() { + if ((designationCase_ == 2) && (specBuilder_ != null)) { + return specBuilder_.getMessageOrBuilder(); + } else { + if (designationCase_ == 2) { + return (flyteidl.core.Execution.QualityOfServiceSpec) designation_; + } + return flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance(); + } + } + /** + * .flyteidl.core.QualityOfServiceSpec spec = 2; + */ + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfServiceSpec, flyteidl.core.Execution.QualityOfServiceSpec.Builder, flyteidl.core.Execution.QualityOfServiceSpecOrBuilder> + getSpecFieldBuilder() { + if (specBuilder_ == null) { + if (!(designationCase_ == 2)) { + designation_ = flyteidl.core.Execution.QualityOfServiceSpec.getDefaultInstance(); + } + specBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfServiceSpec, flyteidl.core.Execution.QualityOfServiceSpec.Builder, flyteidl.core.Execution.QualityOfServiceSpecOrBuilder>( + (flyteidl.core.Execution.QualityOfServiceSpec) designation_, + getParentForChildren(), + isClean()); + designation_ = null; + } + designationCase_ = 2; + onChanged();; + return specBuilder_; + } + @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.core.QualityOfService) + } + + // @@protoc_insertion_point(class_scope:flyteidl.core.QualityOfService) + private static final flyteidl.core.Execution.QualityOfService DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.core.Execution.QualityOfService(); + } + + public static flyteidl.core.Execution.QualityOfService getDefaultInstance() { + return DEFAULT_INSTANCE; + } + + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { + @java.lang.Override + public QualityOfService parsePartialFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return new QualityOfService(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.core.Execution.QualityOfService getDefaultInstanceForType() { + return DEFAULT_INSTANCE; + } + + } + private static final com.google.protobuf.Descriptors.Descriptor internal_static_flyteidl_core_WorkflowExecution_descriptor; private static final @@ -4032,6 +5651,16 @@ public flyteidl.core.Execution.TaskLog getDefaultInstanceForType() { private static final com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internal_static_flyteidl_core_TaskLog_fieldAccessorTable; + private static final com.google.protobuf.Descriptors.Descriptor + internal_static_flyteidl_core_QualityOfServiceSpec_descriptor; + private static final + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internal_static_flyteidl_core_QualityOfServiceSpec_fieldAccessorTable; + private static final com.google.protobuf.Descriptors.Descriptor + internal_static_flyteidl_core_QualityOfService_descriptor; + private static final + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internal_static_flyteidl_core_QualityOfService_fieldAccessorTable; public static com.google.protobuf.Descriptors.FileDescriptor getDescriptor() { @@ -4063,8 +5692,15 @@ public flyteidl.core.Execution.TaskLog getDefaultInstanceForType() { "ormat\030\003 \001(\0162$.flyteidl.core.TaskLog.Mess" + "ageFormat\022&\n\003ttl\030\004 \001(\0132\031.google.protobuf" + ".Duration\"/\n\rMessageFormat\022\013\n\007UNKNOWN\020\000\022" + - "\007\n\003CSV\020\001\022\010\n\004JSON\020\002B2Z0github.com/lyft/fl" + - "yteidl/gen/pb-go/flyteidl/coreb\006proto3" + "\007\n\003CSV\020\001\022\010\n\004JSON\020\002\"J\n\024QualityOfServiceSp" + + "ec\0222\n\017queueing_budget\030\001 \001(\0132\031.google.pro" + + "tobuf.Duration\"\302\001\n\020QualityOfService\0224\n\004t" + + "ier\030\001 \001(\0162$.flyteidl.core.QualityOfServi" + + "ce.TierH\000\0223\n\004spec\030\002 \001(\0132#.flyteidl.core." + + "QualityOfServiceSpecH\000\"4\n\004Tier\022\r\n\tUNDEFI" + + "NED\020\000\022\010\n\004HIGH\020\001\022\n\n\006MEDIUM\020\002\022\007\n\003LOW\020\003B\r\n\013" + + "designationB2Z0github.com/lyft/flyteidl/" + + "gen/pb-go/flyteidl/coreb\006proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -4109,6 +5745,18 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_core_TaskLog_descriptor, new java.lang.String[] { "Uri", "Name", "MessageFormat", "Ttl", }); + internal_static_flyteidl_core_QualityOfServiceSpec_descriptor = + getDescriptor().getMessageTypes().get(5); + internal_static_flyteidl_core_QualityOfServiceSpec_fieldAccessorTable = new + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( + internal_static_flyteidl_core_QualityOfServiceSpec_descriptor, + new java.lang.String[] { "QueueingBudget", }); + internal_static_flyteidl_core_QualityOfService_descriptor = + getDescriptor().getMessageTypes().get(6); + internal_static_flyteidl_core_QualityOfService_fieldAccessorTable = new + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( + internal_static_flyteidl_core_QualityOfService_descriptor, + new java.lang.String[] { "Tier", "Spec", "Designation", }); com.google.protobuf.DurationProto.getDescriptor(); } diff --git a/flyteidl/gen/pb-java/flyteidl/core/Workflow.java b/flyteidl/gen/pb-java/flyteidl/core/Workflow.java index b1632be342f..e0eed4bcd37 100644 --- a/flyteidl/gen/pb-java/flyteidl/core/Workflow.java +++ b/flyteidl/gen/pb-java/flyteidl/core/Workflow.java @@ -10201,28 +10201,28 @@ public interface WorkflowMetadataOrBuilder extends /** *
-     * Total wait time a workflow can be delayed by queueing.
+     * Indicates the runtime priority of workflow executions. 
      * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - boolean hasQueuingBudget(); + boolean hasQualityOfService(); /** *
-     * Total wait time a workflow can be delayed by queueing.
+     * Indicates the runtime priority of workflow executions. 
      * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - com.google.protobuf.Duration getQueuingBudget(); + flyteidl.core.Execution.QualityOfService getQualityOfService(); /** *
-     * Total wait time a workflow can be delayed by queueing.
+     * Indicates the runtime priority of workflow executions. 
      * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - com.google.protobuf.DurationOrBuilder getQueuingBudgetOrBuilder(); + flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder(); /** *
@@ -10286,14 +10286,14 @@ private WorkflowMetadata(
               done = true;
               break;
             case 10: {
-              com.google.protobuf.Duration.Builder subBuilder = null;
-              if (queuingBudget_ != null) {
-                subBuilder = queuingBudget_.toBuilder();
+              flyteidl.core.Execution.QualityOfService.Builder subBuilder = null;
+              if (qualityOfService_ != null) {
+                subBuilder = qualityOfService_.toBuilder();
               }
-              queuingBudget_ = input.readMessage(com.google.protobuf.Duration.parser(), extensionRegistry);
+              qualityOfService_ = input.readMessage(flyteidl.core.Execution.QualityOfService.parser(), extensionRegistry);
               if (subBuilder != null) {
-                subBuilder.mergeFrom(queuingBudget_);
-                queuingBudget_ = subBuilder.buildPartial();
+                subBuilder.mergeFrom(qualityOfService_);
+                qualityOfService_ = subBuilder.buildPartial();
               }
 
               break;
@@ -10464,37 +10464,37 @@ private OnFailurePolicy(int value) {
       // @@protoc_insertion_point(enum_scope:flyteidl.core.WorkflowMetadata.OnFailurePolicy)
     }
 
-    public static final int QUEUING_BUDGET_FIELD_NUMBER = 1;
-    private com.google.protobuf.Duration queuingBudget_;
+    public static final int QUALITY_OF_SERVICE_FIELD_NUMBER = 1;
+    private flyteidl.core.Execution.QualityOfService qualityOfService_;
     /**
      * 
-     * Total wait time a workflow can be delayed by queueing.
+     * Indicates the runtime priority of workflow executions. 
      * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public boolean hasQueuingBudget() { - return queuingBudget_ != null; + public boolean hasQualityOfService() { + return qualityOfService_ != null; } /** *
-     * Total wait time a workflow can be delayed by queueing.
+     * Indicates the runtime priority of workflow executions. 
      * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public com.google.protobuf.Duration getQueuingBudget() { - return queuingBudget_ == null ? com.google.protobuf.Duration.getDefaultInstance() : queuingBudget_; + public flyteidl.core.Execution.QualityOfService getQualityOfService() { + return qualityOfService_ == null ? flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; } /** *
-     * Total wait time a workflow can be delayed by queueing.
+     * Indicates the runtime priority of workflow executions. 
      * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public com.google.protobuf.DurationOrBuilder getQueuingBudgetOrBuilder() { - return getQueuingBudget(); + public flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder() { + return getQualityOfService(); } public static final int ON_FAILURE_FIELD_NUMBER = 2; @@ -10536,8 +10536,8 @@ public final boolean isInitialized() { @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { - if (queuingBudget_ != null) { - output.writeMessage(1, getQueuingBudget()); + if (qualityOfService_ != null) { + output.writeMessage(1, getQualityOfService()); } if (onFailure_ != flyteidl.core.Workflow.WorkflowMetadata.OnFailurePolicy.FAIL_IMMEDIATELY.getNumber()) { output.writeEnum(2, onFailure_); @@ -10551,9 +10551,9 @@ public int getSerializedSize() { if (size != -1) return size; size = 0; - if (queuingBudget_ != null) { + if (qualityOfService_ != null) { size += com.google.protobuf.CodedOutputStream - .computeMessageSize(1, getQueuingBudget()); + .computeMessageSize(1, getQualityOfService()); } if (onFailure_ != flyteidl.core.Workflow.WorkflowMetadata.OnFailurePolicy.FAIL_IMMEDIATELY.getNumber()) { size += com.google.protobuf.CodedOutputStream @@ -10574,10 +10574,10 @@ public boolean equals(final java.lang.Object obj) { } flyteidl.core.Workflow.WorkflowMetadata other = (flyteidl.core.Workflow.WorkflowMetadata) obj; - if (hasQueuingBudget() != other.hasQueuingBudget()) return false; - if (hasQueuingBudget()) { - if (!getQueuingBudget() - .equals(other.getQueuingBudget())) return false; + if (hasQualityOfService() != other.hasQualityOfService()) return false; + if (hasQualityOfService()) { + if (!getQualityOfService() + .equals(other.getQualityOfService())) return false; } if (onFailure_ != other.onFailure_) return false; if (!unknownFields.equals(other.unknownFields)) return false; @@ -10591,9 +10591,9 @@ public int hashCode() { } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); - if (hasQueuingBudget()) { - hash = (37 * hash) + QUEUING_BUDGET_FIELD_NUMBER; - hash = (53 * hash) + getQueuingBudget().hashCode(); + if (hasQualityOfService()) { + hash = (37 * hash) + QUALITY_OF_SERVICE_FIELD_NUMBER; + hash = (53 * hash) + getQualityOfService().hashCode(); } hash = (37 * hash) + ON_FAILURE_FIELD_NUMBER; hash = (53 * hash) + onFailure_; @@ -10734,11 +10734,11 @@ private void maybeForceBuilderInitialization() { @java.lang.Override public Builder clear() { super.clear(); - if (queuingBudgetBuilder_ == null) { - queuingBudget_ = null; + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = null; } else { - queuingBudget_ = null; - queuingBudgetBuilder_ = null; + qualityOfService_ = null; + qualityOfServiceBuilder_ = null; } onFailure_ = 0; @@ -10768,10 +10768,10 @@ public flyteidl.core.Workflow.WorkflowMetadata build() { @java.lang.Override public flyteidl.core.Workflow.WorkflowMetadata buildPartial() { flyteidl.core.Workflow.WorkflowMetadata result = new flyteidl.core.Workflow.WorkflowMetadata(this); - if (queuingBudgetBuilder_ == null) { - result.queuingBudget_ = queuingBudget_; + if (qualityOfServiceBuilder_ == null) { + result.qualityOfService_ = qualityOfService_; } else { - result.queuingBudget_ = queuingBudgetBuilder_.build(); + result.qualityOfService_ = qualityOfServiceBuilder_.build(); } result.onFailure_ = onFailure_; onBuilt(); @@ -10822,8 +10822,8 @@ public Builder mergeFrom(com.google.protobuf.Message other) { public Builder mergeFrom(flyteidl.core.Workflow.WorkflowMetadata other) { if (other == flyteidl.core.Workflow.WorkflowMetadata.getDefaultInstance()) return this; - if (other.hasQueuingBudget()) { - mergeQueuingBudget(other.getQueuingBudget()); + if (other.hasQualityOfService()) { + mergeQualityOfService(other.getQualityOfService()); } if (other.onFailure_ != 0) { setOnFailureValue(other.getOnFailureValue()); @@ -10857,157 +10857,157 @@ public Builder mergeFrom( return this; } - private com.google.protobuf.Duration queuingBudget_; + private flyteidl.core.Execution.QualityOfService qualityOfService_; private com.google.protobuf.SingleFieldBuilderV3< - com.google.protobuf.Duration, com.google.protobuf.Duration.Builder, com.google.protobuf.DurationOrBuilder> queuingBudgetBuilder_; + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder> qualityOfServiceBuilder_; /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public boolean hasQueuingBudget() { - return queuingBudgetBuilder_ != null || queuingBudget_ != null; + public boolean hasQualityOfService() { + return qualityOfServiceBuilder_ != null || qualityOfService_ != null; } /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public com.google.protobuf.Duration getQueuingBudget() { - if (queuingBudgetBuilder_ == null) { - return queuingBudget_ == null ? com.google.protobuf.Duration.getDefaultInstance() : queuingBudget_; + public flyteidl.core.Execution.QualityOfService getQualityOfService() { + if (qualityOfServiceBuilder_ == null) { + return qualityOfService_ == null ? flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; } else { - return queuingBudgetBuilder_.getMessage(); + return qualityOfServiceBuilder_.getMessage(); } } /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public Builder setQueuingBudget(com.google.protobuf.Duration value) { - if (queuingBudgetBuilder_ == null) { + public Builder setQualityOfService(flyteidl.core.Execution.QualityOfService value) { + if (qualityOfServiceBuilder_ == null) { if (value == null) { throw new NullPointerException(); } - queuingBudget_ = value; + qualityOfService_ = value; onChanged(); } else { - queuingBudgetBuilder_.setMessage(value); + qualityOfServiceBuilder_.setMessage(value); } return this; } /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public Builder setQueuingBudget( - com.google.protobuf.Duration.Builder builderForValue) { - if (queuingBudgetBuilder_ == null) { - queuingBudget_ = builderForValue.build(); + public Builder setQualityOfService( + flyteidl.core.Execution.QualityOfService.Builder builderForValue) { + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = builderForValue.build(); onChanged(); } else { - queuingBudgetBuilder_.setMessage(builderForValue.build()); + qualityOfServiceBuilder_.setMessage(builderForValue.build()); } return this; } /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public Builder mergeQueuingBudget(com.google.protobuf.Duration value) { - if (queuingBudgetBuilder_ == null) { - if (queuingBudget_ != null) { - queuingBudget_ = - com.google.protobuf.Duration.newBuilder(queuingBudget_).mergeFrom(value).buildPartial(); + public Builder mergeQualityOfService(flyteidl.core.Execution.QualityOfService value) { + if (qualityOfServiceBuilder_ == null) { + if (qualityOfService_ != null) { + qualityOfService_ = + flyteidl.core.Execution.QualityOfService.newBuilder(qualityOfService_).mergeFrom(value).buildPartial(); } else { - queuingBudget_ = value; + qualityOfService_ = value; } onChanged(); } else { - queuingBudgetBuilder_.mergeFrom(value); + qualityOfServiceBuilder_.mergeFrom(value); } return this; } /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public Builder clearQueuingBudget() { - if (queuingBudgetBuilder_ == null) { - queuingBudget_ = null; + public Builder clearQualityOfService() { + if (qualityOfServiceBuilder_ == null) { + qualityOfService_ = null; onChanged(); } else { - queuingBudget_ = null; - queuingBudgetBuilder_ = null; + qualityOfService_ = null; + qualityOfServiceBuilder_ = null; } return this; } /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public com.google.protobuf.Duration.Builder getQueuingBudgetBuilder() { + public flyteidl.core.Execution.QualityOfService.Builder getQualityOfServiceBuilder() { onChanged(); - return getQueuingBudgetFieldBuilder().getBuilder(); + return getQualityOfServiceFieldBuilder().getBuilder(); } /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ - public com.google.protobuf.DurationOrBuilder getQueuingBudgetOrBuilder() { - if (queuingBudgetBuilder_ != null) { - return queuingBudgetBuilder_.getMessageOrBuilder(); + public flyteidl.core.Execution.QualityOfServiceOrBuilder getQualityOfServiceOrBuilder() { + if (qualityOfServiceBuilder_ != null) { + return qualityOfServiceBuilder_.getMessageOrBuilder(); } else { - return queuingBudget_ == null ? - com.google.protobuf.Duration.getDefaultInstance() : queuingBudget_; + return qualityOfService_ == null ? + flyteidl.core.Execution.QualityOfService.getDefaultInstance() : qualityOfService_; } } /** *
-       * Total wait time a workflow can be delayed by queueing.
+       * Indicates the runtime priority of workflow executions. 
        * 
* - * .google.protobuf.Duration queuing_budget = 1; + * .flyteidl.core.QualityOfService quality_of_service = 1; */ private com.google.protobuf.SingleFieldBuilderV3< - com.google.protobuf.Duration, com.google.protobuf.Duration.Builder, com.google.protobuf.DurationOrBuilder> - getQueuingBudgetFieldBuilder() { - if (queuingBudgetBuilder_ == null) { - queuingBudgetBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< - com.google.protobuf.Duration, com.google.protobuf.Duration.Builder, com.google.protobuf.DurationOrBuilder>( - getQueuingBudget(), + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder> + getQualityOfServiceFieldBuilder() { + if (qualityOfServiceBuilder_ == null) { + qualityOfServiceBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.core.Execution.QualityOfService, flyteidl.core.Execution.QualityOfService.Builder, flyteidl.core.Execution.QualityOfServiceOrBuilder>( + getQualityOfService(), getParentForChildren(), isClean()); - queuingBudget_ = null; + qualityOfService_ = null; } - return queuingBudgetBuilder_; + return qualityOfServiceBuilder_; } private int onFailure_ = 0; @@ -14558,56 +14558,57 @@ public flyteidl.core.Workflow.WorkflowTemplate getDefaultInstanceForType() { static { java.lang.String[] descriptorData = { "\n\034flyteidl/core/workflow.proto\022\rflyteidl" + - ".core\032\035flyteidl/core/condition.proto\032\036fl" + - "yteidl/core/identifier.proto\032\035flyteidl/c" + - "ore/interface.proto\032\034flyteidl/core/liter" + - "als.proto\032\031flyteidl/core/types.proto\032\036go" + - "ogle/protobuf/duration.proto\"f\n\007IfBlock\022" + - "3\n\tcondition\030\001 \001(\0132 .flyteidl.core.Boole" + - "anExpression\022&\n\tthen_node\030\002 \001(\0132\023.flytei" + - "dl.core.Node\"\266\001\n\013IfElseBlock\022$\n\004case\030\001 \001" + - "(\0132\026.flyteidl.core.IfBlock\022%\n\005other\030\002 \003(" + - "\0132\026.flyteidl.core.IfBlock\022(\n\telse_node\030\003" + - " \001(\0132\023.flyteidl.core.NodeH\000\022%\n\005error\030\004 \001" + - "(\0132\024.flyteidl.core.ErrorH\000B\t\n\007default\"9\n" + - "\nBranchNode\022+\n\007if_else\030\001 \001(\0132\032.flyteidl." + - "core.IfElseBlock\"J\n\010TaskNode\0221\n\014referenc" + - "e_id\030\001 \001(\0132\031.flyteidl.core.IdentifierH\000B" + - "\013\n\treference\"\207\001\n\014WorkflowNode\0223\n\016launchp" + - "lan_ref\030\001 \001(\0132\031.flyteidl.core.Identifier" + - "H\000\0225\n\020sub_workflow_ref\030\002 \001(\0132\031.flyteidl." + - "core.IdentifierH\000B\013\n\treference\"\247\001\n\014NodeM" + - "etadata\022\014\n\004name\030\001 \001(\t\022*\n\007timeout\030\004 \001(\0132\031" + - ".google.protobuf.Duration\022-\n\007retries\030\005 \001" + - "(\0132\034.flyteidl.core.RetryStrategy\022\027\n\rinte" + - "rruptible\030\006 \001(\010H\000B\025\n\023interruptible_value" + - "\"#\n\005Alias\022\013\n\003var\030\001 \001(\t\022\r\n\005alias\030\002 \001(\t\"\322\002" + - "\n\004Node\022\n\n\002id\030\001 \001(\t\022-\n\010metadata\030\002 \001(\0132\033.f" + - "lyteidl.core.NodeMetadata\022&\n\006inputs\030\003 \003(" + - "\0132\026.flyteidl.core.Binding\022\031\n\021upstream_no" + - "de_ids\030\004 \003(\t\022,\n\016output_aliases\030\005 \003(\0132\024.f" + - "lyteidl.core.Alias\022,\n\ttask_node\030\006 \001(\0132\027." + - "flyteidl.core.TaskNodeH\000\0224\n\rworkflow_nod" + - "e\030\007 \001(\0132\033.flyteidl.core.WorkflowNodeH\000\0220" + - "\n\013branch_node\030\010 \001(\0132\031.flyteidl.core.Bran" + - "chNodeH\000B\010\n\006target\"\335\001\n\020WorkflowMetadata\022" + - "1\n\016queuing_budget\030\001 \001(\0132\031.google.protobu" + - "f.Duration\022C\n\non_failure\030\002 \001(\0162/.flyteid" + - "l.core.WorkflowMetadata.OnFailurePolicy\"" + - "Q\n\017OnFailurePolicy\022\024\n\020FAIL_IMMEDIATELY\020\000" + - "\022(\n$FAIL_AFTER_EXECUTABLE_NODES_COMPLETE" + - "\020\001\"1\n\030WorkflowMetadataDefaults\022\025\n\rinterr" + - "uptible\030\001 \001(\010\"\332\002\n\020WorkflowTemplate\022%\n\002id" + - "\030\001 \001(\0132\031.flyteidl.core.Identifier\0221\n\010met" + - "adata\030\002 \001(\0132\037.flyteidl.core.WorkflowMeta" + - "data\0220\n\tinterface\030\003 \001(\0132\035.flyteidl.core." + - "TypedInterface\022\"\n\005nodes\030\004 \003(\0132\023.flyteidl" + - ".core.Node\022\'\n\007outputs\030\005 \003(\0132\026.flyteidl.c" + - "ore.Binding\022)\n\014failure_node\030\006 \001(\0132\023.flyt" + - "eidl.core.Node\022B\n\021metadata_defaults\030\007 \001(" + - "\0132\'.flyteidl.core.WorkflowMetadataDefaul" + - "tsB2Z0github.com/lyft/flyteidl/gen/pb-go" + - "/flyteidl/coreb\006proto3" + ".core\032\035flyteidl/core/condition.proto\032\035fl" + + "yteidl/core/execution.proto\032\036flyteidl/co" + + "re/identifier.proto\032\035flyteidl/core/inter" + + "face.proto\032\034flyteidl/core/literals.proto" + + "\032\031flyteidl/core/types.proto\032\036google/prot" + + "obuf/duration.proto\"f\n\007IfBlock\0223\n\tcondit" + + "ion\030\001 \001(\0132 .flyteidl.core.BooleanExpress" + + "ion\022&\n\tthen_node\030\002 \001(\0132\023.flyteidl.core.N" + + "ode\"\266\001\n\013IfElseBlock\022$\n\004case\030\001 \001(\0132\026.flyt" + + "eidl.core.IfBlock\022%\n\005other\030\002 \003(\0132\026.flyte" + + "idl.core.IfBlock\022(\n\telse_node\030\003 \001(\0132\023.fl" + + "yteidl.core.NodeH\000\022%\n\005error\030\004 \001(\0132\024.flyt" + + "eidl.core.ErrorH\000B\t\n\007default\"9\n\nBranchNo" + + "de\022+\n\007if_else\030\001 \001(\0132\032.flyteidl.core.IfEl" + + "seBlock\"J\n\010TaskNode\0221\n\014reference_id\030\001 \001(" + + "\0132\031.flyteidl.core.IdentifierH\000B\013\n\trefere" + + "nce\"\207\001\n\014WorkflowNode\0223\n\016launchplan_ref\030\001" + + " \001(\0132\031.flyteidl.core.IdentifierH\000\0225\n\020sub" + + "_workflow_ref\030\002 \001(\0132\031.flyteidl.core.Iden" + + "tifierH\000B\013\n\treference\"\247\001\n\014NodeMetadata\022\014" + + "\n\004name\030\001 \001(\t\022*\n\007timeout\030\004 \001(\0132\031.google.p" + + "rotobuf.Duration\022-\n\007retries\030\005 \001(\0132\034.flyt" + + "eidl.core.RetryStrategy\022\027\n\rinterruptible" + + "\030\006 \001(\010H\000B\025\n\023interruptible_value\"#\n\005Alias" + + "\022\013\n\003var\030\001 \001(\t\022\r\n\005alias\030\002 \001(\t\"\322\002\n\004Node\022\n\n" + + "\002id\030\001 \001(\t\022-\n\010metadata\030\002 \001(\0132\033.flyteidl.c" + + "ore.NodeMetadata\022&\n\006inputs\030\003 \003(\0132\026.flyte" + + "idl.core.Binding\022\031\n\021upstream_node_ids\030\004 " + + "\003(\t\022,\n\016output_aliases\030\005 \003(\0132\024.flyteidl.c" + + "ore.Alias\022,\n\ttask_node\030\006 \001(\0132\027.flyteidl." + + "core.TaskNodeH\000\0224\n\rworkflow_node\030\007 \001(\0132\033" + + ".flyteidl.core.WorkflowNodeH\000\0220\n\013branch_" + + "node\030\010 \001(\0132\031.flyteidl.core.BranchNodeH\000B" + + "\010\n\006target\"\347\001\n\020WorkflowMetadata\022;\n\022qualit" + + "y_of_service\030\001 \001(\0132\037.flyteidl.core.Quali" + + "tyOfService\022C\n\non_failure\030\002 \001(\0162/.flytei" + + "dl.core.WorkflowMetadata.OnFailurePolicy" + + "\"Q\n\017OnFailurePolicy\022\024\n\020FAIL_IMMEDIATELY\020" + + "\000\022(\n$FAIL_AFTER_EXECUTABLE_NODES_COMPLET" + + "E\020\001\"1\n\030WorkflowMetadataDefaults\022\025\n\rinter" + + "ruptible\030\001 \001(\010\"\332\002\n\020WorkflowTemplate\022%\n\002i" + + "d\030\001 \001(\0132\031.flyteidl.core.Identifier\0221\n\010me" + + "tadata\030\002 \001(\0132\037.flyteidl.core.WorkflowMet" + + "adata\0220\n\tinterface\030\003 \001(\0132\035.flyteidl.core" + + ".TypedInterface\022\"\n\005nodes\030\004 \003(\0132\023.flyteid" + + "l.core.Node\022\'\n\007outputs\030\005 \003(\0132\026.flyteidl." + + "core.Binding\022)\n\014failure_node\030\006 \001(\0132\023.fly" + + "teidl.core.Node\022B\n\021metadata_defaults\030\007 \001" + + "(\0132\'.flyteidl.core.WorkflowMetadataDefau" + + "ltsB2Z0github.com/lyft/flyteidl/gen/pb-g" + + "o/flyteidl/coreb\006proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -14621,6 +14622,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( .internalBuildGeneratedFileFrom(descriptorData, new com.google.protobuf.Descriptors.FileDescriptor[] { flyteidl.core.Condition.getDescriptor(), + flyteidl.core.Execution.getDescriptor(), flyteidl.core.IdentifierOuterClass.getDescriptor(), flyteidl.core.Interface.getDescriptor(), flyteidl.core.Literals.getDescriptor(), @@ -14680,7 +14682,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_core_WorkflowMetadata_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_core_WorkflowMetadata_descriptor, - new java.lang.String[] { "QueuingBudget", "OnFailure", }); + new java.lang.String[] { "QualityOfService", "OnFailure", }); internal_static_flyteidl_core_WorkflowMetadataDefaults_descriptor = getDescriptor().getMessageTypes().get(9); internal_static_flyteidl_core_WorkflowMetadataDefaults_fieldAccessorTable = new @@ -14694,6 +14696,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_core_WorkflowTemplate_descriptor, new java.lang.String[] { "Id", "Metadata", "Interface", "Nodes", "Outputs", "FailureNode", "MetadataDefaults", }); flyteidl.core.Condition.getDescriptor(); + flyteidl.core.Execution.getDescriptor(); flyteidl.core.IdentifierOuterClass.getDescriptor(); flyteidl.core.Interface.getDescriptor(); flyteidl.core.Literals.getDescriptor(); diff --git a/flyteidl/gen/pb-js/flyteidl.d.ts b/flyteidl/gen/pb-js/flyteidl.d.ts index 59a762ef168..0965b43e524 100644 --- a/flyteidl/gen/pb-js/flyteidl.d.ts +++ b/flyteidl/gen/pb-js/flyteidl.d.ts @@ -822,8 +822,8 @@ export namespace flyteidl { /** Properties of a WorkflowMetadata. */ interface IWorkflowMetadata { - /** WorkflowMetadata queuingBudget */ - queuingBudget?: (google.protobuf.IDuration|null); + /** WorkflowMetadata qualityOfService */ + qualityOfService?: (flyteidl.core.IQualityOfService|null); /** WorkflowMetadata onFailure */ onFailure?: (flyteidl.core.WorkflowMetadata.OnFailurePolicy|null); @@ -838,8 +838,8 @@ export namespace flyteidl { */ constructor(properties?: flyteidl.core.IWorkflowMetadata); - /** WorkflowMetadata queuingBudget. */ - public queuingBudget?: (google.protobuf.IDuration|null); + /** WorkflowMetadata qualityOfService. */ + public qualityOfService?: (flyteidl.core.IQualityOfService|null); /** WorkflowMetadata onFailure. */ public onFailure: flyteidl.core.WorkflowMetadata.OnFailurePolicy; @@ -2670,1799 +2670,1923 @@ export namespace flyteidl { public static verify(message: { [k: string]: any }): (string|null); } - /** ResourceType enum. */ - enum ResourceType { - UNSPECIFIED = 0, - TASK = 1, - WORKFLOW = 2, - LAUNCH_PLAN = 3 - } - - /** Properties of an Identifier. */ - interface IIdentifier { - - /** Identifier resourceType */ - resourceType?: (flyteidl.core.ResourceType|null); - - /** Identifier project */ - project?: (string|null); - - /** Identifier domain */ - domain?: (string|null); - - /** Identifier name */ - name?: (string|null); - - /** Identifier version */ - version?: (string|null); + /** Properties of a WorkflowExecution. */ + interface IWorkflowExecution { } - /** Represents an Identifier. */ - class Identifier implements IIdentifier { + /** Represents a WorkflowExecution. */ + class WorkflowExecution implements IWorkflowExecution { /** - * Constructs a new Identifier. + * Constructs a new WorkflowExecution. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IIdentifier); - - /** Identifier resourceType. */ - public resourceType: flyteidl.core.ResourceType; - - /** Identifier project. */ - public project: string; - - /** Identifier domain. */ - public domain: string; - - /** Identifier name. */ - public name: string; - - /** Identifier version. */ - public version: string; + constructor(properties?: flyteidl.core.IWorkflowExecution); /** - * Creates a new Identifier instance using the specified properties. + * Creates a new WorkflowExecution instance using the specified properties. * @param [properties] Properties to set - * @returns Identifier instance + * @returns WorkflowExecution instance */ - public static create(properties?: flyteidl.core.IIdentifier): flyteidl.core.Identifier; + public static create(properties?: flyteidl.core.IWorkflowExecution): flyteidl.core.WorkflowExecution; /** - * Encodes the specified Identifier message. Does not implicitly {@link flyteidl.core.Identifier.verify|verify} messages. - * @param message Identifier message or plain object to encode + * Encodes the specified WorkflowExecution message. Does not implicitly {@link flyteidl.core.WorkflowExecution.verify|verify} messages. + * @param message WorkflowExecution message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IIdentifier, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IWorkflowExecution, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes an Identifier message from the specified reader or buffer. + * Decodes a WorkflowExecution message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns Identifier + * @returns WorkflowExecution * @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.core.Identifier; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.WorkflowExecution; /** - * Verifies an Identifier message. + * Verifies a WorkflowExecution 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 WorkflowExecutionIdentifier. */ - interface IWorkflowExecutionIdentifier { - - /** WorkflowExecutionIdentifier project */ - project?: (string|null); + namespace WorkflowExecution { - /** WorkflowExecutionIdentifier domain */ - domain?: (string|null); + /** Phase enum. */ + enum Phase { + UNDEFINED = 0, + QUEUED = 1, + RUNNING = 2, + SUCCEEDING = 3, + SUCCEEDED = 4, + FAILING = 5, + FAILED = 6, + ABORTED = 7, + TIMED_OUT = 8 + } + } - /** WorkflowExecutionIdentifier name */ - name?: (string|null); + /** Properties of a NodeExecution. */ + interface INodeExecution { } - /** Represents a WorkflowExecutionIdentifier. */ - class WorkflowExecutionIdentifier implements IWorkflowExecutionIdentifier { + /** Represents a NodeExecution. */ + class NodeExecution implements INodeExecution { /** - * Constructs a new WorkflowExecutionIdentifier. + * Constructs a new NodeExecution. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IWorkflowExecutionIdentifier); - - /** WorkflowExecutionIdentifier project. */ - public project: string; - - /** WorkflowExecutionIdentifier domain. */ - public domain: string; - - /** WorkflowExecutionIdentifier name. */ - public name: string; + constructor(properties?: flyteidl.core.INodeExecution); /** - * Creates a new WorkflowExecutionIdentifier instance using the specified properties. + * Creates a new NodeExecution instance using the specified properties. * @param [properties] Properties to set - * @returns WorkflowExecutionIdentifier instance + * @returns NodeExecution instance */ - public static create(properties?: flyteidl.core.IWorkflowExecutionIdentifier): flyteidl.core.WorkflowExecutionIdentifier; + public static create(properties?: flyteidl.core.INodeExecution): flyteidl.core.NodeExecution; /** - * Encodes the specified WorkflowExecutionIdentifier message. Does not implicitly {@link flyteidl.core.WorkflowExecutionIdentifier.verify|verify} messages. - * @param message WorkflowExecutionIdentifier message or plain object to encode + * Encodes the specified NodeExecution message. Does not implicitly {@link flyteidl.core.NodeExecution.verify|verify} messages. + * @param message NodeExecution message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IWorkflowExecutionIdentifier, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.INodeExecution, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a WorkflowExecutionIdentifier message from the specified reader or buffer. + * Decodes a NodeExecution message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns WorkflowExecutionIdentifier + * @returns NodeExecution * @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.core.WorkflowExecutionIdentifier; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.NodeExecution; /** - * Verifies a WorkflowExecutionIdentifier message. + * Verifies a NodeExecution 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 NodeExecutionIdentifier. */ - interface INodeExecutionIdentifier { + namespace NodeExecution { - /** NodeExecutionIdentifier nodeId */ - nodeId?: (string|null); + /** Phase enum. */ + enum Phase { + UNDEFINED = 0, + QUEUED = 1, + RUNNING = 2, + SUCCEEDED = 3, + FAILING = 4, + FAILED = 5, + ABORTED = 6, + SKIPPED = 7, + TIMED_OUT = 8 + } + } - /** NodeExecutionIdentifier executionId */ - executionId?: (flyteidl.core.IWorkflowExecutionIdentifier|null); + /** Properties of a TaskExecution. */ + interface ITaskExecution { } - /** Represents a NodeExecutionIdentifier. */ - class NodeExecutionIdentifier implements INodeExecutionIdentifier { + /** Represents a TaskExecution. */ + class TaskExecution implements ITaskExecution { /** - * Constructs a new NodeExecutionIdentifier. + * Constructs a new TaskExecution. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.INodeExecutionIdentifier); - - /** NodeExecutionIdentifier nodeId. */ - public nodeId: string; - - /** NodeExecutionIdentifier executionId. */ - public executionId?: (flyteidl.core.IWorkflowExecutionIdentifier|null); + constructor(properties?: flyteidl.core.ITaskExecution); /** - * Creates a new NodeExecutionIdentifier instance using the specified properties. + * Creates a new TaskExecution instance using the specified properties. * @param [properties] Properties to set - * @returns NodeExecutionIdentifier instance + * @returns TaskExecution instance */ - public static create(properties?: flyteidl.core.INodeExecutionIdentifier): flyteidl.core.NodeExecutionIdentifier; + public static create(properties?: flyteidl.core.ITaskExecution): flyteidl.core.TaskExecution; /** - * Encodes the specified NodeExecutionIdentifier message. Does not implicitly {@link flyteidl.core.NodeExecutionIdentifier.verify|verify} messages. - * @param message NodeExecutionIdentifier message or plain object to encode + * Encodes the specified TaskExecution message. Does not implicitly {@link flyteidl.core.TaskExecution.verify|verify} messages. + * @param message TaskExecution message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.INodeExecutionIdentifier, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.ITaskExecution, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a NodeExecutionIdentifier message from the specified reader or buffer. + * Decodes a TaskExecution message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns NodeExecutionIdentifier + * @returns TaskExecution * @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.core.NodeExecutionIdentifier; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.TaskExecution; /** - * Verifies a NodeExecutionIdentifier message. + * Verifies a TaskExecution 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 TaskExecutionIdentifier. */ - interface ITaskExecutionIdentifier { + namespace TaskExecution { - /** TaskExecutionIdentifier taskId */ - taskId?: (flyteidl.core.IIdentifier|null); + /** Phase enum. */ + enum Phase { + UNDEFINED = 0, + QUEUED = 1, + RUNNING = 2, + SUCCEEDED = 3, + ABORTED = 4, + FAILED = 5, + INITIALIZING = 6, + WAITING_FOR_RESOURCES = 7 + } + } - /** TaskExecutionIdentifier nodeExecutionId */ - nodeExecutionId?: (flyteidl.core.INodeExecutionIdentifier|null); + /** Properties of an ExecutionError. */ + interface IExecutionError { - /** TaskExecutionIdentifier retryAttempt */ - retryAttempt?: (number|null); + /** ExecutionError code */ + code?: (string|null); + + /** ExecutionError message */ + message?: (string|null); + + /** ExecutionError errorUri */ + errorUri?: (string|null); + + /** ExecutionError kind */ + kind?: (flyteidl.core.ExecutionError.ErrorKind|null); } - /** Represents a TaskExecutionIdentifier. */ - class TaskExecutionIdentifier implements ITaskExecutionIdentifier { + /** Represents an ExecutionError. */ + class ExecutionError implements IExecutionError { /** - * Constructs a new TaskExecutionIdentifier. + * Constructs a new ExecutionError. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.ITaskExecutionIdentifier); + constructor(properties?: flyteidl.core.IExecutionError); - /** TaskExecutionIdentifier taskId. */ - public taskId?: (flyteidl.core.IIdentifier|null); + /** ExecutionError code. */ + public code: string; - /** TaskExecutionIdentifier nodeExecutionId. */ - public nodeExecutionId?: (flyteidl.core.INodeExecutionIdentifier|null); + /** ExecutionError message. */ + public message: string; - /** TaskExecutionIdentifier retryAttempt. */ - public retryAttempt: number; + /** ExecutionError errorUri. */ + public errorUri: string; + + /** ExecutionError kind. */ + public kind: flyteidl.core.ExecutionError.ErrorKind; /** - * Creates a new TaskExecutionIdentifier instance using the specified properties. + * Creates a new ExecutionError instance using the specified properties. * @param [properties] Properties to set - * @returns TaskExecutionIdentifier instance + * @returns ExecutionError instance */ - public static create(properties?: flyteidl.core.ITaskExecutionIdentifier): flyteidl.core.TaskExecutionIdentifier; + public static create(properties?: flyteidl.core.IExecutionError): flyteidl.core.ExecutionError; /** - * Encodes the specified TaskExecutionIdentifier message. Does not implicitly {@link flyteidl.core.TaskExecutionIdentifier.verify|verify} messages. - * @param message TaskExecutionIdentifier message or plain object to encode + * Encodes the specified ExecutionError message. Does not implicitly {@link flyteidl.core.ExecutionError.verify|verify} messages. + * @param message ExecutionError message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.ITaskExecutionIdentifier, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IExecutionError, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a TaskExecutionIdentifier message from the specified reader or buffer. + * Decodes an ExecutionError message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns TaskExecutionIdentifier + * @returns ExecutionError * @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.core.TaskExecutionIdentifier; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.ExecutionError; /** - * Verifies a TaskExecutionIdentifier message. + * Verifies an ExecutionError 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 Variable. */ - interface IVariable { + namespace ExecutionError { - /** Variable type */ - type?: (flyteidl.core.ILiteralType|null); + /** ErrorKind enum. */ + enum ErrorKind { + UNKNOWN = 0, + USER = 1, + SYSTEM = 2 + } + } - /** Variable description */ - description?: (string|null); + /** Properties of a TaskLog. */ + interface ITaskLog { + + /** TaskLog uri */ + uri?: (string|null); + + /** TaskLog name */ + name?: (string|null); + + /** TaskLog messageFormat */ + messageFormat?: (flyteidl.core.TaskLog.MessageFormat|null); + + /** TaskLog ttl */ + ttl?: (google.protobuf.IDuration|null); } - /** Represents a Variable. */ - class Variable implements IVariable { + /** Represents a TaskLog. */ + class TaskLog implements ITaskLog { /** - * Constructs a new Variable. + * Constructs a new TaskLog. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IVariable); + constructor(properties?: flyteidl.core.ITaskLog); - /** Variable type. */ - public type?: (flyteidl.core.ILiteralType|null); + /** TaskLog uri. */ + public uri: string; - /** Variable description. */ - public description: string; + /** TaskLog name. */ + public name: string; + + /** TaskLog messageFormat. */ + public messageFormat: flyteidl.core.TaskLog.MessageFormat; + + /** TaskLog ttl. */ + public ttl?: (google.protobuf.IDuration|null); /** - * Creates a new Variable instance using the specified properties. + * Creates a new TaskLog instance using the specified properties. * @param [properties] Properties to set - * @returns Variable instance + * @returns TaskLog instance */ - public static create(properties?: flyteidl.core.IVariable): flyteidl.core.Variable; + public static create(properties?: flyteidl.core.ITaskLog): flyteidl.core.TaskLog; /** - * Encodes the specified Variable message. Does not implicitly {@link flyteidl.core.Variable.verify|verify} messages. - * @param message Variable message or plain object to encode + * Encodes the specified TaskLog message. Does not implicitly {@link flyteidl.core.TaskLog.verify|verify} messages. + * @param message TaskLog message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IVariable, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.ITaskLog, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a Variable message from the specified reader or buffer. + * Decodes a TaskLog message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns Variable + * @returns TaskLog * @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.core.Variable; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.TaskLog; /** - * Verifies a Variable message. + * Verifies a TaskLog 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 VariableMap. */ - interface IVariableMap { + namespace TaskLog { - /** VariableMap variables */ - variables?: ({ [k: string]: flyteidl.core.IVariable }|null); + /** MessageFormat enum. */ + enum MessageFormat { + UNKNOWN = 0, + CSV = 1, + JSON = 2 + } } - /** Represents a VariableMap. */ - class VariableMap implements IVariableMap { + /** Properties of a QualityOfServiceSpec. */ + interface IQualityOfServiceSpec { + + /** QualityOfServiceSpec queueingBudget */ + queueingBudget?: (google.protobuf.IDuration|null); + } + + /** Represents a QualityOfServiceSpec. */ + class QualityOfServiceSpec implements IQualityOfServiceSpec { /** - * Constructs a new VariableMap. + * Constructs a new QualityOfServiceSpec. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IVariableMap); + constructor(properties?: flyteidl.core.IQualityOfServiceSpec); - /** VariableMap variables. */ - public variables: { [k: string]: flyteidl.core.IVariable }; + /** QualityOfServiceSpec queueingBudget. */ + public queueingBudget?: (google.protobuf.IDuration|null); /** - * Creates a new VariableMap instance using the specified properties. + * Creates a new QualityOfServiceSpec instance using the specified properties. * @param [properties] Properties to set - * @returns VariableMap instance + * @returns QualityOfServiceSpec instance */ - public static create(properties?: flyteidl.core.IVariableMap): flyteidl.core.VariableMap; + public static create(properties?: flyteidl.core.IQualityOfServiceSpec): flyteidl.core.QualityOfServiceSpec; /** - * Encodes the specified VariableMap message. Does not implicitly {@link flyteidl.core.VariableMap.verify|verify} messages. - * @param message VariableMap message or plain object to encode + * Encodes the specified QualityOfServiceSpec message. Does not implicitly {@link flyteidl.core.QualityOfServiceSpec.verify|verify} messages. + * @param message QualityOfServiceSpec message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IVariableMap, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IQualityOfServiceSpec, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a VariableMap message from the specified reader or buffer. + * Decodes a QualityOfServiceSpec message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns VariableMap + * @returns QualityOfServiceSpec * @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.core.VariableMap; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.QualityOfServiceSpec; /** - * Verifies a VariableMap message. + * Verifies a QualityOfServiceSpec 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 TypedInterface. */ - interface ITypedInterface { + /** Properties of a QualityOfService. */ + interface IQualityOfService { - /** TypedInterface inputs */ - inputs?: (flyteidl.core.IVariableMap|null); + /** QualityOfService tier */ + tier?: (flyteidl.core.QualityOfService.Tier|null); - /** TypedInterface outputs */ - outputs?: (flyteidl.core.IVariableMap|null); + /** QualityOfService spec */ + spec?: (flyteidl.core.IQualityOfServiceSpec|null); } - /** Represents a TypedInterface. */ - class TypedInterface implements ITypedInterface { + /** Represents a QualityOfService. */ + class QualityOfService implements IQualityOfService { /** - * Constructs a new TypedInterface. + * Constructs a new QualityOfService. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.ITypedInterface); + constructor(properties?: flyteidl.core.IQualityOfService); - /** TypedInterface inputs. */ - public inputs?: (flyteidl.core.IVariableMap|null); + /** QualityOfService tier. */ + public tier: flyteidl.core.QualityOfService.Tier; - /** TypedInterface outputs. */ - public outputs?: (flyteidl.core.IVariableMap|null); + /** QualityOfService spec. */ + public spec?: (flyteidl.core.IQualityOfServiceSpec|null); + + /** QualityOfService designation. */ + public designation?: ("tier"|"spec"); /** - * Creates a new TypedInterface instance using the specified properties. + * Creates a new QualityOfService instance using the specified properties. * @param [properties] Properties to set - * @returns TypedInterface instance + * @returns QualityOfService instance */ - public static create(properties?: flyteidl.core.ITypedInterface): flyteidl.core.TypedInterface; + public static create(properties?: flyteidl.core.IQualityOfService): flyteidl.core.QualityOfService; /** - * Encodes the specified TypedInterface message. Does not implicitly {@link flyteidl.core.TypedInterface.verify|verify} messages. - * @param message TypedInterface message or plain object to encode + * Encodes the specified QualityOfService message. Does not implicitly {@link flyteidl.core.QualityOfService.verify|verify} messages. + * @param message QualityOfService message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.ITypedInterface, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IQualityOfService, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a TypedInterface message from the specified reader or buffer. + * Decodes a QualityOfService message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns TypedInterface + * @returns QualityOfService * @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.core.TypedInterface; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.QualityOfService; /** - * Verifies a TypedInterface message. + * Verifies a QualityOfService 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 Parameter. */ - interface IParameter { + namespace QualityOfService { - /** Parameter var */ - "var"?: (flyteidl.core.IVariable|null); + /** Tier enum. */ + enum Tier { + UNDEFINED = 0, + HIGH = 1, + MEDIUM = 2, + LOW = 3 + } + } - /** Parameter default */ - "default"?: (flyteidl.core.ILiteral|null); + /** ResourceType enum. */ + enum ResourceType { + UNSPECIFIED = 0, + TASK = 1, + WORKFLOW = 2, + LAUNCH_PLAN = 3 + } - /** Parameter required */ - required?: (boolean|null); + /** Properties of an Identifier. */ + interface IIdentifier { + + /** Identifier resourceType */ + resourceType?: (flyteidl.core.ResourceType|null); + + /** Identifier project */ + project?: (string|null); + + /** Identifier domain */ + domain?: (string|null); + + /** Identifier name */ + name?: (string|null); + + /** Identifier version */ + version?: (string|null); } - /** Represents a Parameter. */ - class Parameter implements IParameter { + /** Represents an Identifier. */ + class Identifier implements IIdentifier { /** - * Constructs a new Parameter. + * Constructs a new Identifier. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IParameter); + constructor(properties?: flyteidl.core.IIdentifier); - /** Parameter var. */ - public var?: (flyteidl.core.IVariable|null); + /** Identifier resourceType. */ + public resourceType: flyteidl.core.ResourceType; - /** Parameter default. */ - public default?: (flyteidl.core.ILiteral|null); + /** Identifier project. */ + public project: string; - /** Parameter required. */ - public required: boolean; + /** Identifier domain. */ + public domain: string; - /** Parameter behavior. */ - public behavior?: ("default"|"required"); + /** Identifier name. */ + public name: string; + + /** Identifier version. */ + public version: string; /** - * Creates a new Parameter instance using the specified properties. + * Creates a new Identifier instance using the specified properties. * @param [properties] Properties to set - * @returns Parameter instance + * @returns Identifier instance */ - public static create(properties?: flyteidl.core.IParameter): flyteidl.core.Parameter; + public static create(properties?: flyteidl.core.IIdentifier): flyteidl.core.Identifier; /** - * Encodes the specified Parameter message. Does not implicitly {@link flyteidl.core.Parameter.verify|verify} messages. - * @param message Parameter message or plain object to encode + * Encodes the specified Identifier message. Does not implicitly {@link flyteidl.core.Identifier.verify|verify} messages. + * @param message Identifier message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IParameter, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IIdentifier, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a Parameter message from the specified reader or buffer. + * Decodes an Identifier message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns Parameter + * @returns Identifier * @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.core.Parameter; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.Identifier; /** - * Verifies a Parameter message. + * Verifies an Identifier 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 ParameterMap. */ - interface IParameterMap { + /** Properties of a WorkflowExecutionIdentifier. */ + interface IWorkflowExecutionIdentifier { - /** ParameterMap parameters */ - parameters?: ({ [k: string]: flyteidl.core.IParameter }|null); + /** WorkflowExecutionIdentifier project */ + project?: (string|null); + + /** WorkflowExecutionIdentifier domain */ + domain?: (string|null); + + /** WorkflowExecutionIdentifier name */ + name?: (string|null); } - /** Represents a ParameterMap. */ - class ParameterMap implements IParameterMap { + /** Represents a WorkflowExecutionIdentifier. */ + class WorkflowExecutionIdentifier implements IWorkflowExecutionIdentifier { /** - * Constructs a new ParameterMap. + * Constructs a new WorkflowExecutionIdentifier. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IParameterMap); + constructor(properties?: flyteidl.core.IWorkflowExecutionIdentifier); - /** ParameterMap parameters. */ - public parameters: { [k: string]: flyteidl.core.IParameter }; + /** WorkflowExecutionIdentifier project. */ + public project: string; + + /** WorkflowExecutionIdentifier domain. */ + public domain: string; + + /** WorkflowExecutionIdentifier name. */ + public name: string; /** - * Creates a new ParameterMap instance using the specified properties. + * Creates a new WorkflowExecutionIdentifier instance using the specified properties. * @param [properties] Properties to set - * @returns ParameterMap instance + * @returns WorkflowExecutionIdentifier instance */ - public static create(properties?: flyteidl.core.IParameterMap): flyteidl.core.ParameterMap; + public static create(properties?: flyteidl.core.IWorkflowExecutionIdentifier): flyteidl.core.WorkflowExecutionIdentifier; /** - * Encodes the specified ParameterMap message. Does not implicitly {@link flyteidl.core.ParameterMap.verify|verify} messages. - * @param message ParameterMap message or plain object to encode + * Encodes the specified WorkflowExecutionIdentifier message. Does not implicitly {@link flyteidl.core.WorkflowExecutionIdentifier.verify|verify} messages. + * @param message WorkflowExecutionIdentifier message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IParameterMap, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IWorkflowExecutionIdentifier, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a ParameterMap message from the specified reader or buffer. + * Decodes a WorkflowExecutionIdentifier message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns ParameterMap + * @returns WorkflowExecutionIdentifier * @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.core.ParameterMap; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.WorkflowExecutionIdentifier; /** - * Verifies a ParameterMap message. + * Verifies a WorkflowExecutionIdentifier 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 Resources. */ - interface IResources { + /** Properties of a NodeExecutionIdentifier. */ + interface INodeExecutionIdentifier { - /** Resources requests */ - requests?: (flyteidl.core.Resources.IResourceEntry[]|null); + /** NodeExecutionIdentifier nodeId */ + nodeId?: (string|null); - /** Resources limits */ - limits?: (flyteidl.core.Resources.IResourceEntry[]|null); + /** NodeExecutionIdentifier executionId */ + executionId?: (flyteidl.core.IWorkflowExecutionIdentifier|null); } - /** Represents a Resources. */ - class Resources implements IResources { + /** Represents a NodeExecutionIdentifier. */ + class NodeExecutionIdentifier implements INodeExecutionIdentifier { /** - * Constructs a new Resources. + * Constructs a new NodeExecutionIdentifier. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IResources); + constructor(properties?: flyteidl.core.INodeExecutionIdentifier); - /** Resources requests. */ - public requests: flyteidl.core.Resources.IResourceEntry[]; + /** NodeExecutionIdentifier nodeId. */ + public nodeId: string; - /** Resources limits. */ - public limits: flyteidl.core.Resources.IResourceEntry[]; + /** NodeExecutionIdentifier executionId. */ + public executionId?: (flyteidl.core.IWorkflowExecutionIdentifier|null); /** - * Creates a new Resources instance using the specified properties. + * Creates a new NodeExecutionIdentifier instance using the specified properties. * @param [properties] Properties to set - * @returns Resources instance + * @returns NodeExecutionIdentifier instance */ - public static create(properties?: flyteidl.core.IResources): flyteidl.core.Resources; + public static create(properties?: flyteidl.core.INodeExecutionIdentifier): flyteidl.core.NodeExecutionIdentifier; /** - * Encodes the specified Resources message. Does not implicitly {@link flyteidl.core.Resources.verify|verify} messages. - * @param message Resources message or plain object to encode + * Encodes the specified NodeExecutionIdentifier message. Does not implicitly {@link flyteidl.core.NodeExecutionIdentifier.verify|verify} messages. + * @param message NodeExecutionIdentifier message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IResources, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.INodeExecutionIdentifier, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a Resources message from the specified reader or buffer. + * Decodes a NodeExecutionIdentifier message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns Resources + * @returns NodeExecutionIdentifier * @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.core.Resources; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.NodeExecutionIdentifier; /** - * Verifies a Resources message. + * Verifies a NodeExecutionIdentifier 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); } - namespace Resources { + /** Properties of a TaskExecutionIdentifier. */ + interface ITaskExecutionIdentifier { - /** ResourceName enum. */ - enum ResourceName { - UNKNOWN = 0, - CPU = 1, - GPU = 2, - MEMORY = 3, - STORAGE = 4 - } + /** TaskExecutionIdentifier taskId */ + taskId?: (flyteidl.core.IIdentifier|null); - /** Properties of a ResourceEntry. */ - interface IResourceEntry { + /** TaskExecutionIdentifier nodeExecutionId */ + nodeExecutionId?: (flyteidl.core.INodeExecutionIdentifier|null); - /** ResourceEntry name */ - name?: (flyteidl.core.Resources.ResourceName|null); + /** TaskExecutionIdentifier retryAttempt */ + retryAttempt?: (number|null); + } - /** ResourceEntry value */ - value?: (string|null); - } + /** Represents a TaskExecutionIdentifier. */ + class TaskExecutionIdentifier implements ITaskExecutionIdentifier { - /** Represents a ResourceEntry. */ - class ResourceEntry implements IResourceEntry { + /** + * Constructs a new TaskExecutionIdentifier. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.core.ITaskExecutionIdentifier); - /** - * Constructs a new ResourceEntry. - * @param [properties] Properties to set - */ - constructor(properties?: flyteidl.core.Resources.IResourceEntry); + /** TaskExecutionIdentifier taskId. */ + public taskId?: (flyteidl.core.IIdentifier|null); - /** ResourceEntry name. */ - public name: flyteidl.core.Resources.ResourceName; + /** TaskExecutionIdentifier nodeExecutionId. */ + public nodeExecutionId?: (flyteidl.core.INodeExecutionIdentifier|null); - /** ResourceEntry value. */ - public value: string; + /** TaskExecutionIdentifier retryAttempt. */ + public retryAttempt: number; - /** - * Creates a new ResourceEntry instance using the specified properties. - * @param [properties] Properties to set - * @returns ResourceEntry instance - */ - public static create(properties?: flyteidl.core.Resources.IResourceEntry): flyteidl.core.Resources.ResourceEntry; + /** + * Creates a new TaskExecutionIdentifier instance using the specified properties. + * @param [properties] Properties to set + * @returns TaskExecutionIdentifier instance + */ + public static create(properties?: flyteidl.core.ITaskExecutionIdentifier): flyteidl.core.TaskExecutionIdentifier; - /** - * Encodes the specified ResourceEntry message. Does not implicitly {@link flyteidl.core.Resources.ResourceEntry.verify|verify} messages. - * @param message ResourceEntry message or plain object to encode - * @param [writer] Writer to encode to - * @returns Writer - */ - public static encode(message: flyteidl.core.Resources.IResourceEntry, writer?: $protobuf.Writer): $protobuf.Writer; + /** + * Encodes the specified TaskExecutionIdentifier message. Does not implicitly {@link flyteidl.core.TaskExecutionIdentifier.verify|verify} messages. + * @param message TaskExecutionIdentifier message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.core.ITaskExecutionIdentifier, writer?: $protobuf.Writer): $protobuf.Writer; - /** - * Decodes a ResourceEntry message from the specified reader or buffer. - * @param reader Reader or buffer to decode from - * @param [length] Message length if known beforehand - * @returns ResourceEntry - * @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.core.Resources.ResourceEntry; + /** + * Decodes a TaskExecutionIdentifier message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns TaskExecutionIdentifier + * @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.core.TaskExecutionIdentifier; - /** - * Verifies a ResourceEntry 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); - } + /** + * Verifies a TaskExecutionIdentifier 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 RuntimeMetadata. */ - interface IRuntimeMetadata { - - /** RuntimeMetadata type */ - type?: (flyteidl.core.RuntimeMetadata.RuntimeType|null); + /** Properties of a Variable. */ + interface IVariable { - /** RuntimeMetadata version */ - version?: (string|null); + /** Variable type */ + type?: (flyteidl.core.ILiteralType|null); - /** RuntimeMetadata flavor */ - flavor?: (string|null); + /** Variable description */ + description?: (string|null); } - /** Represents a RuntimeMetadata. */ - class RuntimeMetadata implements IRuntimeMetadata { + /** Represents a Variable. */ + class Variable implements IVariable { /** - * Constructs a new RuntimeMetadata. + * Constructs a new Variable. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IRuntimeMetadata); - - /** RuntimeMetadata type. */ - public type: flyteidl.core.RuntimeMetadata.RuntimeType; + constructor(properties?: flyteidl.core.IVariable); - /** RuntimeMetadata version. */ - public version: string; + /** Variable type. */ + public type?: (flyteidl.core.ILiteralType|null); - /** RuntimeMetadata flavor. */ - public flavor: string; + /** Variable description. */ + public description: string; /** - * Creates a new RuntimeMetadata instance using the specified properties. + * Creates a new Variable instance using the specified properties. * @param [properties] Properties to set - * @returns RuntimeMetadata instance + * @returns Variable instance */ - public static create(properties?: flyteidl.core.IRuntimeMetadata): flyteidl.core.RuntimeMetadata; + public static create(properties?: flyteidl.core.IVariable): flyteidl.core.Variable; /** - * Encodes the specified RuntimeMetadata message. Does not implicitly {@link flyteidl.core.RuntimeMetadata.verify|verify} messages. - * @param message RuntimeMetadata message or plain object to encode + * Encodes the specified Variable message. Does not implicitly {@link flyteidl.core.Variable.verify|verify} messages. + * @param message Variable message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IRuntimeMetadata, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IVariable, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a RuntimeMetadata message from the specified reader or buffer. + * Decodes a Variable message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns RuntimeMetadata + * @returns Variable * @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.core.RuntimeMetadata; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.Variable; /** - * Verifies a RuntimeMetadata message. + * Verifies a Variable 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); } - namespace RuntimeMetadata { + /** Properties of a VariableMap. */ + interface IVariableMap { - /** RuntimeType enum. */ - enum RuntimeType { - OTHER = 0, - FLYTE_SDK = 1 - } + /** VariableMap variables */ + variables?: ({ [k: string]: flyteidl.core.IVariable }|null); } - /** Properties of a TaskMetadata. */ - interface ITaskMetadata { - - /** TaskMetadata discoverable */ - discoverable?: (boolean|null); + /** Represents a VariableMap. */ + class VariableMap implements IVariableMap { - /** TaskMetadata runtime */ - runtime?: (flyteidl.core.IRuntimeMetadata|null); + /** + * Constructs a new VariableMap. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.core.IVariableMap); - /** TaskMetadata timeout */ - timeout?: (google.protobuf.IDuration|null); + /** VariableMap variables. */ + public variables: { [k: string]: flyteidl.core.IVariable }; - /** TaskMetadata retries */ - retries?: (flyteidl.core.IRetryStrategy|null); + /** + * Creates a new VariableMap instance using the specified properties. + * @param [properties] Properties to set + * @returns VariableMap instance + */ + public static create(properties?: flyteidl.core.IVariableMap): flyteidl.core.VariableMap; - /** TaskMetadata discoveryVersion */ - discoveryVersion?: (string|null); - - /** TaskMetadata deprecatedErrorMessage */ - deprecatedErrorMessage?: (string|null); - - /** TaskMetadata interruptible */ - interruptible?: (boolean|null); - } - - /** Represents a TaskMetadata. */ - class TaskMetadata implements ITaskMetadata { + /** + * Encodes the specified VariableMap message. Does not implicitly {@link flyteidl.core.VariableMap.verify|verify} messages. + * @param message VariableMap message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.core.IVariableMap, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Constructs a new TaskMetadata. - * @param [properties] Properties to set + * Decodes a VariableMap message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns VariableMap + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - constructor(properties?: flyteidl.core.ITaskMetadata); + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.VariableMap; - /** TaskMetadata discoverable. */ - public discoverable: boolean; + /** + * Verifies a VariableMap 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); + } - /** TaskMetadata runtime. */ - public runtime?: (flyteidl.core.IRuntimeMetadata|null); + /** Properties of a TypedInterface. */ + interface ITypedInterface { - /** TaskMetadata timeout. */ - public timeout?: (google.protobuf.IDuration|null); + /** TypedInterface inputs */ + inputs?: (flyteidl.core.IVariableMap|null); - /** TaskMetadata retries. */ - public retries?: (flyteidl.core.IRetryStrategy|null); + /** TypedInterface outputs */ + outputs?: (flyteidl.core.IVariableMap|null); + } - /** TaskMetadata discoveryVersion. */ - public discoveryVersion: string; + /** Represents a TypedInterface. */ + class TypedInterface implements ITypedInterface { - /** TaskMetadata deprecatedErrorMessage. */ - public deprecatedErrorMessage: string; + /** + * Constructs a new TypedInterface. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.core.ITypedInterface); - /** TaskMetadata interruptible. */ - public interruptible: boolean; + /** TypedInterface inputs. */ + public inputs?: (flyteidl.core.IVariableMap|null); - /** TaskMetadata interruptibleValue. */ - public interruptibleValue?: "interruptible"; + /** TypedInterface outputs. */ + public outputs?: (flyteidl.core.IVariableMap|null); /** - * Creates a new TaskMetadata instance using the specified properties. + * Creates a new TypedInterface instance using the specified properties. * @param [properties] Properties to set - * @returns TaskMetadata instance + * @returns TypedInterface instance */ - public static create(properties?: flyteidl.core.ITaskMetadata): flyteidl.core.TaskMetadata; + public static create(properties?: flyteidl.core.ITypedInterface): flyteidl.core.TypedInterface; /** - * Encodes the specified TaskMetadata message. Does not implicitly {@link flyteidl.core.TaskMetadata.verify|verify} messages. - * @param message TaskMetadata message or plain object to encode + * Encodes the specified TypedInterface message. Does not implicitly {@link flyteidl.core.TypedInterface.verify|verify} messages. + * @param message TypedInterface message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.ITaskMetadata, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.ITypedInterface, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a TaskMetadata message from the specified reader or buffer. + * Decodes a TypedInterface message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns TaskMetadata + * @returns TypedInterface * @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.core.TaskMetadata; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.TypedInterface; /** - * Verifies a TaskMetadata message. + * Verifies a TypedInterface 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 TaskTemplate. */ - interface ITaskTemplate { - - /** TaskTemplate id */ - id?: (flyteidl.core.IIdentifier|null); - - /** TaskTemplate type */ - type?: (string|null); - - /** TaskTemplate metadata */ - metadata?: (flyteidl.core.ITaskMetadata|null); + /** Properties of a Parameter. */ + interface IParameter { - /** TaskTemplate interface */ - "interface"?: (flyteidl.core.ITypedInterface|null); + /** Parameter var */ + "var"?: (flyteidl.core.IVariable|null); - /** TaskTemplate custom */ - custom?: (google.protobuf.IStruct|null); + /** Parameter default */ + "default"?: (flyteidl.core.ILiteral|null); - /** TaskTemplate container */ - container?: (flyteidl.core.IContainer|null); + /** Parameter required */ + required?: (boolean|null); } - /** Represents a TaskTemplate. */ - class TaskTemplate implements ITaskTemplate { + /** Represents a Parameter. */ + class Parameter implements IParameter { /** - * Constructs a new TaskTemplate. + * Constructs a new Parameter. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.ITaskTemplate); - - /** TaskTemplate id. */ - public id?: (flyteidl.core.IIdentifier|null); - - /** TaskTemplate type. */ - public type: string; - - /** TaskTemplate metadata. */ - public metadata?: (flyteidl.core.ITaskMetadata|null); + constructor(properties?: flyteidl.core.IParameter); - /** TaskTemplate interface. */ - public interface?: (flyteidl.core.ITypedInterface|null); + /** Parameter var. */ + public var?: (flyteidl.core.IVariable|null); - /** TaskTemplate custom. */ - public custom?: (google.protobuf.IStruct|null); + /** Parameter default. */ + public default?: (flyteidl.core.ILiteral|null); - /** TaskTemplate container. */ - public container?: (flyteidl.core.IContainer|null); + /** Parameter required. */ + public required: boolean; - /** TaskTemplate target. */ - public target?: "container"; + /** Parameter behavior. */ + public behavior?: ("default"|"required"); /** - * Creates a new TaskTemplate instance using the specified properties. + * Creates a new Parameter instance using the specified properties. * @param [properties] Properties to set - * @returns TaskTemplate instance + * @returns Parameter instance */ - public static create(properties?: flyteidl.core.ITaskTemplate): flyteidl.core.TaskTemplate; + public static create(properties?: flyteidl.core.IParameter): flyteidl.core.Parameter; /** - * Encodes the specified TaskTemplate message. Does not implicitly {@link flyteidl.core.TaskTemplate.verify|verify} messages. - * @param message TaskTemplate message or plain object to encode + * Encodes the specified Parameter message. Does not implicitly {@link flyteidl.core.Parameter.verify|verify} messages. + * @param message Parameter message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.ITaskTemplate, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IParameter, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a TaskTemplate message from the specified reader or buffer. + * Decodes a Parameter message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns TaskTemplate + * @returns Parameter * @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.core.TaskTemplate; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.Parameter; /** - * Verifies a TaskTemplate message. + * Verifies a Parameter 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 ContainerPort. */ - interface IContainerPort { + /** Properties of a ParameterMap. */ + interface IParameterMap { - /** ContainerPort containerPort */ - containerPort?: (number|null); + /** ParameterMap parameters */ + parameters?: ({ [k: string]: flyteidl.core.IParameter }|null); } - /** Represents a ContainerPort. */ - class ContainerPort implements IContainerPort { + /** Represents a ParameterMap. */ + class ParameterMap implements IParameterMap { /** - * Constructs a new ContainerPort. + * Constructs a new ParameterMap. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IContainerPort); + constructor(properties?: flyteidl.core.IParameterMap); - /** ContainerPort containerPort. */ - public containerPort: number; + /** ParameterMap parameters. */ + public parameters: { [k: string]: flyteidl.core.IParameter }; /** - * Creates a new ContainerPort instance using the specified properties. + * Creates a new ParameterMap instance using the specified properties. * @param [properties] Properties to set - * @returns ContainerPort instance + * @returns ParameterMap instance */ - public static create(properties?: flyteidl.core.IContainerPort): flyteidl.core.ContainerPort; + public static create(properties?: flyteidl.core.IParameterMap): flyteidl.core.ParameterMap; /** - * Encodes the specified ContainerPort message. Does not implicitly {@link flyteidl.core.ContainerPort.verify|verify} messages. - * @param message ContainerPort message or plain object to encode + * Encodes the specified ParameterMap message. Does not implicitly {@link flyteidl.core.ParameterMap.verify|verify} messages. + * @param message ParameterMap message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IContainerPort, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IParameterMap, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a ContainerPort message from the specified reader or buffer. + * Decodes a ParameterMap message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns ContainerPort + * @returns ParameterMap * @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.core.ContainerPort; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.ParameterMap; /** - * Verifies a ContainerPort message. + * Verifies a ParameterMap 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 Container. */ - interface IContainer { - - /** Container image */ - image?: (string|null); - - /** Container command */ - command?: (string[]|null); - - /** Container args */ - args?: (string[]|null); - - /** Container resources */ - resources?: (flyteidl.core.IResources|null); - - /** Container env */ - env?: (flyteidl.core.IKeyValuePair[]|null); - - /** Container config */ - config?: (flyteidl.core.IKeyValuePair[]|null); + /** Properties of a Resources. */ + interface IResources { - /** Container ports */ - ports?: (flyteidl.core.IContainerPort[]|null); + /** Resources requests */ + requests?: (flyteidl.core.Resources.IResourceEntry[]|null); - /** Container dataConfig */ - dataConfig?: (flyteidl.core.IDataLoadingConfig|null); + /** Resources limits */ + limits?: (flyteidl.core.Resources.IResourceEntry[]|null); } - /** Represents a Container. */ - class Container implements IContainer { + /** Represents a Resources. */ + class Resources implements IResources { /** - * Constructs a new Container. + * Constructs a new Resources. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IContainer); - - /** Container image. */ - public image: string; - - /** Container command. */ - public command: string[]; - - /** Container args. */ - public args: string[]; - - /** Container resources. */ - public resources?: (flyteidl.core.IResources|null); - - /** Container env. */ - public env: flyteidl.core.IKeyValuePair[]; - - /** Container config. */ - public config: flyteidl.core.IKeyValuePair[]; + constructor(properties?: flyteidl.core.IResources); - /** Container ports. */ - public ports: flyteidl.core.IContainerPort[]; + /** Resources requests. */ + public requests: flyteidl.core.Resources.IResourceEntry[]; - /** Container dataConfig. */ - public dataConfig?: (flyteidl.core.IDataLoadingConfig|null); + /** Resources limits. */ + public limits: flyteidl.core.Resources.IResourceEntry[]; /** - * Creates a new Container instance using the specified properties. + * Creates a new Resources instance using the specified properties. * @param [properties] Properties to set - * @returns Container instance + * @returns Resources instance */ - public static create(properties?: flyteidl.core.IContainer): flyteidl.core.Container; + public static create(properties?: flyteidl.core.IResources): flyteidl.core.Resources; /** - * Encodes the specified Container message. Does not implicitly {@link flyteidl.core.Container.verify|verify} messages. - * @param message Container message or plain object to encode + * Encodes the specified Resources message. Does not implicitly {@link flyteidl.core.Resources.verify|verify} messages. + * @param message Resources message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IContainer, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IResources, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a Container message from the specified reader or buffer. + * Decodes a Resources message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns Container + * @returns Resources * @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.core.Container; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.Resources; /** - * Verifies a Container message. + * Verifies a Resources 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 IOStrategy. */ - interface IIOStrategy { + namespace Resources { + + /** ResourceName enum. */ + enum ResourceName { + UNKNOWN = 0, + CPU = 1, + GPU = 2, + MEMORY = 3, + STORAGE = 4 + } + + /** Properties of a ResourceEntry. */ + interface IResourceEntry { + + /** ResourceEntry name */ + name?: (flyteidl.core.Resources.ResourceName|null); + + /** ResourceEntry value */ + value?: (string|null); + } + + /** Represents a ResourceEntry. */ + class ResourceEntry implements IResourceEntry { + + /** + * Constructs a new ResourceEntry. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.core.Resources.IResourceEntry); + + /** ResourceEntry name. */ + public name: flyteidl.core.Resources.ResourceName; + + /** ResourceEntry value. */ + public value: string; + + /** + * Creates a new ResourceEntry instance using the specified properties. + * @param [properties] Properties to set + * @returns ResourceEntry instance + */ + public static create(properties?: flyteidl.core.Resources.IResourceEntry): flyteidl.core.Resources.ResourceEntry; + + /** + * Encodes the specified ResourceEntry message. Does not implicitly {@link flyteidl.core.Resources.ResourceEntry.verify|verify} messages. + * @param message ResourceEntry message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.core.Resources.IResourceEntry, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ResourceEntry message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ResourceEntry + * @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.core.Resources.ResourceEntry; + + /** + * Verifies a ResourceEntry 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 RuntimeMetadata. */ + interface IRuntimeMetadata { - /** IOStrategy downloadMode */ - downloadMode?: (flyteidl.core.IOStrategy.DownloadMode|null); + /** RuntimeMetadata type */ + type?: (flyteidl.core.RuntimeMetadata.RuntimeType|null); - /** IOStrategy uploadMode */ - uploadMode?: (flyteidl.core.IOStrategy.UploadMode|null); + /** RuntimeMetadata version */ + version?: (string|null); + + /** RuntimeMetadata flavor */ + flavor?: (string|null); } - /** Represents a IOStrategy. */ - class IOStrategy implements IIOStrategy { + /** Represents a RuntimeMetadata. */ + class RuntimeMetadata implements IRuntimeMetadata { /** - * Constructs a new IOStrategy. + * Constructs a new RuntimeMetadata. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IIOStrategy); + constructor(properties?: flyteidl.core.IRuntimeMetadata); - /** IOStrategy downloadMode. */ - public downloadMode: flyteidl.core.IOStrategy.DownloadMode; + /** RuntimeMetadata type. */ + public type: flyteidl.core.RuntimeMetadata.RuntimeType; - /** IOStrategy uploadMode. */ - public uploadMode: flyteidl.core.IOStrategy.UploadMode; + /** RuntimeMetadata version. */ + public version: string; + + /** RuntimeMetadata flavor. */ + public flavor: string; /** - * Creates a new IOStrategy instance using the specified properties. + * Creates a new RuntimeMetadata instance using the specified properties. * @param [properties] Properties to set - * @returns IOStrategy instance + * @returns RuntimeMetadata instance */ - public static create(properties?: flyteidl.core.IIOStrategy): flyteidl.core.IOStrategy; + public static create(properties?: flyteidl.core.IRuntimeMetadata): flyteidl.core.RuntimeMetadata; /** - * Encodes the specified IOStrategy message. Does not implicitly {@link flyteidl.core.IOStrategy.verify|verify} messages. - * @param message IOStrategy message or plain object to encode + * Encodes the specified RuntimeMetadata message. Does not implicitly {@link flyteidl.core.RuntimeMetadata.verify|verify} messages. + * @param message RuntimeMetadata message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IIOStrategy, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IRuntimeMetadata, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a IOStrategy message from the specified reader or buffer. + * Decodes a RuntimeMetadata message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns IOStrategy + * @returns RuntimeMetadata * @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.core.IOStrategy; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.RuntimeMetadata; /** - * Verifies a IOStrategy message. + * Verifies a RuntimeMetadata 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); } - namespace IOStrategy { - - /** DownloadMode enum. */ - enum DownloadMode { - DOWNLOAD_EAGER = 0, - DOWNLOAD_STREAM = 1, - DO_NOT_DOWNLOAD = 2 - } + namespace RuntimeMetadata { - /** UploadMode enum. */ - enum UploadMode { - UPLOAD_ON_EXIT = 0, - UPLOAD_EAGER = 1, - DO_NOT_UPLOAD = 2 + /** RuntimeType enum. */ + enum RuntimeType { + OTHER = 0, + FLYTE_SDK = 1 } } - /** Properties of a DataLoadingConfig. */ - interface IDataLoadingConfig { + /** Properties of a TaskMetadata. */ + interface ITaskMetadata { - /** DataLoadingConfig enabled */ - enabled?: (boolean|null); + /** TaskMetadata discoverable */ + discoverable?: (boolean|null); - /** DataLoadingConfig inputPath */ - inputPath?: (string|null); + /** TaskMetadata runtime */ + runtime?: (flyteidl.core.IRuntimeMetadata|null); - /** DataLoadingConfig outputPath */ - outputPath?: (string|null); + /** TaskMetadata timeout */ + timeout?: (google.protobuf.IDuration|null); - /** DataLoadingConfig format */ - format?: (flyteidl.core.DataLoadingConfig.LiteralMapFormat|null); + /** TaskMetadata retries */ + retries?: (flyteidl.core.IRetryStrategy|null); - /** DataLoadingConfig ioStrategy */ - ioStrategy?: (flyteidl.core.IIOStrategy|null); + /** TaskMetadata discoveryVersion */ + discoveryVersion?: (string|null); + + /** TaskMetadata deprecatedErrorMessage */ + deprecatedErrorMessage?: (string|null); + + /** TaskMetadata interruptible */ + interruptible?: (boolean|null); } - /** Represents a DataLoadingConfig. */ - class DataLoadingConfig implements IDataLoadingConfig { + /** Represents a TaskMetadata. */ + class TaskMetadata implements ITaskMetadata { /** - * Constructs a new DataLoadingConfig. + * Constructs a new TaskMetadata. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IDataLoadingConfig); + constructor(properties?: flyteidl.core.ITaskMetadata); - /** DataLoadingConfig enabled. */ - public enabled: boolean; + /** TaskMetadata discoverable. */ + public discoverable: boolean; - /** DataLoadingConfig inputPath. */ - public inputPath: string; + /** TaskMetadata runtime. */ + public runtime?: (flyteidl.core.IRuntimeMetadata|null); - /** DataLoadingConfig outputPath. */ - public outputPath: string; + /** TaskMetadata timeout. */ + public timeout?: (google.protobuf.IDuration|null); - /** DataLoadingConfig format. */ - public format: flyteidl.core.DataLoadingConfig.LiteralMapFormat; + /** TaskMetadata retries. */ + public retries?: (flyteidl.core.IRetryStrategy|null); - /** DataLoadingConfig ioStrategy. */ - public ioStrategy?: (flyteidl.core.IIOStrategy|null); + /** TaskMetadata discoveryVersion. */ + public discoveryVersion: string; + + /** TaskMetadata deprecatedErrorMessage. */ + public deprecatedErrorMessage: string; + + /** TaskMetadata interruptible. */ + public interruptible: boolean; + + /** TaskMetadata interruptibleValue. */ + public interruptibleValue?: "interruptible"; /** - * Creates a new DataLoadingConfig instance using the specified properties. + * Creates a new TaskMetadata instance using the specified properties. * @param [properties] Properties to set - * @returns DataLoadingConfig instance + * @returns TaskMetadata instance */ - public static create(properties?: flyteidl.core.IDataLoadingConfig): flyteidl.core.DataLoadingConfig; + public static create(properties?: flyteidl.core.ITaskMetadata): flyteidl.core.TaskMetadata; /** - * Encodes the specified DataLoadingConfig message. Does not implicitly {@link flyteidl.core.DataLoadingConfig.verify|verify} messages. - * @param message DataLoadingConfig message or plain object to encode + * Encodes the specified TaskMetadata message. Does not implicitly {@link flyteidl.core.TaskMetadata.verify|verify} messages. + * @param message TaskMetadata message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IDataLoadingConfig, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.ITaskMetadata, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a DataLoadingConfig message from the specified reader or buffer. + * Decodes a TaskMetadata message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns DataLoadingConfig + * @returns TaskMetadata * @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.core.DataLoadingConfig; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.TaskMetadata; /** - * Verifies a DataLoadingConfig message. + * Verifies a TaskMetadata 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); } - namespace DataLoadingConfig { - - /** LiteralMapFormat enum. */ - enum LiteralMapFormat { - JSON = 0, - YAML = 1, - PROTO = 2 - } - } + /** Properties of a TaskTemplate. */ + interface ITaskTemplate { - /** Properties of a DynamicJobSpec. */ - interface IDynamicJobSpec { + /** TaskTemplate id */ + id?: (flyteidl.core.IIdentifier|null); - /** DynamicJobSpec nodes */ - nodes?: (flyteidl.core.INode[]|null); + /** TaskTemplate type */ + type?: (string|null); - /** DynamicJobSpec minSuccesses */ - minSuccesses?: (Long|null); + /** TaskTemplate metadata */ + metadata?: (flyteidl.core.ITaskMetadata|null); - /** DynamicJobSpec outputs */ - outputs?: (flyteidl.core.IBinding[]|null); + /** TaskTemplate interface */ + "interface"?: (flyteidl.core.ITypedInterface|null); - /** DynamicJobSpec tasks */ - tasks?: (flyteidl.core.ITaskTemplate[]|null); + /** TaskTemplate custom */ + custom?: (google.protobuf.IStruct|null); - /** DynamicJobSpec subworkflows */ - subworkflows?: (flyteidl.core.IWorkflowTemplate[]|null); + /** TaskTemplate container */ + container?: (flyteidl.core.IContainer|null); } - /** Represents a DynamicJobSpec. */ - class DynamicJobSpec implements IDynamicJobSpec { + /** Represents a TaskTemplate. */ + class TaskTemplate implements ITaskTemplate { /** - * Constructs a new DynamicJobSpec. + * Constructs a new TaskTemplate. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IDynamicJobSpec); + constructor(properties?: flyteidl.core.ITaskTemplate); - /** DynamicJobSpec nodes. */ - public nodes: flyteidl.core.INode[]; + /** TaskTemplate id. */ + public id?: (flyteidl.core.IIdentifier|null); - /** DynamicJobSpec minSuccesses. */ - public minSuccesses: Long; + /** TaskTemplate type. */ + public type: string; - /** DynamicJobSpec outputs. */ - public outputs: flyteidl.core.IBinding[]; + /** TaskTemplate metadata. */ + public metadata?: (flyteidl.core.ITaskMetadata|null); - /** DynamicJobSpec tasks. */ - public tasks: flyteidl.core.ITaskTemplate[]; + /** TaskTemplate interface. */ + public interface?: (flyteidl.core.ITypedInterface|null); - /** DynamicJobSpec subworkflows. */ - public subworkflows: flyteidl.core.IWorkflowTemplate[]; + /** TaskTemplate custom. */ + public custom?: (google.protobuf.IStruct|null); + + /** TaskTemplate container. */ + public container?: (flyteidl.core.IContainer|null); + + /** TaskTemplate target. */ + public target?: "container"; /** - * Creates a new DynamicJobSpec instance using the specified properties. + * Creates a new TaskTemplate instance using the specified properties. * @param [properties] Properties to set - * @returns DynamicJobSpec instance + * @returns TaskTemplate instance */ - public static create(properties?: flyteidl.core.IDynamicJobSpec): flyteidl.core.DynamicJobSpec; + public static create(properties?: flyteidl.core.ITaskTemplate): flyteidl.core.TaskTemplate; /** - * Encodes the specified DynamicJobSpec message. Does not implicitly {@link flyteidl.core.DynamicJobSpec.verify|verify} messages. - * @param message DynamicJobSpec message or plain object to encode + * Encodes the specified TaskTemplate message. Does not implicitly {@link flyteidl.core.TaskTemplate.verify|verify} messages. + * @param message TaskTemplate message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IDynamicJobSpec, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.ITaskTemplate, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a DynamicJobSpec message from the specified reader or buffer. + * Decodes a TaskTemplate message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns DynamicJobSpec + * @returns TaskTemplate * @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.core.DynamicJobSpec; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.TaskTemplate; /** - * Verifies a DynamicJobSpec message. + * Verifies a TaskTemplate 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 ContainerError. */ - interface IContainerError { - - /** ContainerError code */ - code?: (string|null); - - /** ContainerError message */ - message?: (string|null); - - /** ContainerError kind */ - kind?: (flyteidl.core.ContainerError.Kind|null); + /** Properties of a ContainerPort. */ + interface IContainerPort { - /** ContainerError origin */ - origin?: (flyteidl.core.ExecutionError.ErrorKind|null); + /** ContainerPort containerPort */ + containerPort?: (number|null); } - /** Represents a ContainerError. */ - class ContainerError implements IContainerError { + /** Represents a ContainerPort. */ + class ContainerPort implements IContainerPort { /** - * Constructs a new ContainerError. + * Constructs a new ContainerPort. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IContainerError); - - /** ContainerError code. */ - public code: string; - - /** ContainerError message. */ - public message: string; - - /** ContainerError kind. */ - public kind: flyteidl.core.ContainerError.Kind; + constructor(properties?: flyteidl.core.IContainerPort); - /** ContainerError origin. */ - public origin: flyteidl.core.ExecutionError.ErrorKind; + /** ContainerPort containerPort. */ + public containerPort: number; /** - * Creates a new ContainerError instance using the specified properties. + * Creates a new ContainerPort instance using the specified properties. * @param [properties] Properties to set - * @returns ContainerError instance + * @returns ContainerPort instance */ - public static create(properties?: flyteidl.core.IContainerError): flyteidl.core.ContainerError; + public static create(properties?: flyteidl.core.IContainerPort): flyteidl.core.ContainerPort; /** - * Encodes the specified ContainerError message. Does not implicitly {@link flyteidl.core.ContainerError.verify|verify} messages. - * @param message ContainerError message or plain object to encode + * Encodes the specified ContainerPort message. Does not implicitly {@link flyteidl.core.ContainerPort.verify|verify} messages. + * @param message ContainerPort message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IContainerError, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IContainerPort, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a ContainerError message from the specified reader or buffer. + * Decodes a ContainerPort message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns ContainerError + * @returns ContainerPort * @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.core.ContainerError; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.ContainerPort; /** - * Verifies a ContainerError message. + * Verifies a ContainerPort 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); } - namespace ContainerError { + /** Properties of a Container. */ + interface IContainer { - /** Kind enum. */ - enum Kind { - NON_RECOVERABLE = 0, - RECOVERABLE = 1 - } - } + /** Container image */ + image?: (string|null); - /** Properties of an ErrorDocument. */ - interface IErrorDocument { + /** Container command */ + command?: (string[]|null); - /** ErrorDocument error */ - error?: (flyteidl.core.IContainerError|null); + /** Container args */ + args?: (string[]|null); + + /** Container resources */ + resources?: (flyteidl.core.IResources|null); + + /** Container env */ + env?: (flyteidl.core.IKeyValuePair[]|null); + + /** Container config */ + config?: (flyteidl.core.IKeyValuePair[]|null); + + /** Container ports */ + ports?: (flyteidl.core.IContainerPort[]|null); + + /** Container dataConfig */ + dataConfig?: (flyteidl.core.IDataLoadingConfig|null); } - /** Represents an ErrorDocument. */ - class ErrorDocument implements IErrorDocument { + /** Represents a Container. */ + class Container implements IContainer { /** - * Constructs a new ErrorDocument. + * Constructs a new Container. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IErrorDocument); + constructor(properties?: flyteidl.core.IContainer); - /** ErrorDocument error. */ - public error?: (flyteidl.core.IContainerError|null); + /** Container image. */ + public image: string; + + /** Container command. */ + public command: string[]; + + /** Container args. */ + public args: string[]; + + /** Container resources. */ + public resources?: (flyteidl.core.IResources|null); + + /** Container env. */ + public env: flyteidl.core.IKeyValuePair[]; + + /** Container config. */ + public config: flyteidl.core.IKeyValuePair[]; + + /** Container ports. */ + public ports: flyteidl.core.IContainerPort[]; + + /** Container dataConfig. */ + public dataConfig?: (flyteidl.core.IDataLoadingConfig|null); /** - * Creates a new ErrorDocument instance using the specified properties. + * Creates a new Container instance using the specified properties. * @param [properties] Properties to set - * @returns ErrorDocument instance + * @returns Container instance */ - public static create(properties?: flyteidl.core.IErrorDocument): flyteidl.core.ErrorDocument; + public static create(properties?: flyteidl.core.IContainer): flyteidl.core.Container; /** - * Encodes the specified ErrorDocument message. Does not implicitly {@link flyteidl.core.ErrorDocument.verify|verify} messages. - * @param message ErrorDocument message or plain object to encode + * Encodes the specified Container message. Does not implicitly {@link flyteidl.core.Container.verify|verify} messages. + * @param message Container message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IErrorDocument, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IContainer, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes an ErrorDocument message from the specified reader or buffer. + * Decodes a Container message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns ErrorDocument + * @returns Container * @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.core.ErrorDocument; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.Container; /** - * Verifies an ErrorDocument message. + * Verifies a Container 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 WorkflowExecution. */ - interface IWorkflowExecution { + /** Properties of a IOStrategy. */ + interface IIOStrategy { + + /** IOStrategy downloadMode */ + downloadMode?: (flyteidl.core.IOStrategy.DownloadMode|null); + + /** IOStrategy uploadMode */ + uploadMode?: (flyteidl.core.IOStrategy.UploadMode|null); } - /** Represents a WorkflowExecution. */ - class WorkflowExecution implements IWorkflowExecution { + /** Represents a IOStrategy. */ + class IOStrategy implements IIOStrategy { /** - * Constructs a new WorkflowExecution. + * Constructs a new IOStrategy. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IWorkflowExecution); + constructor(properties?: flyteidl.core.IIOStrategy); + + /** IOStrategy downloadMode. */ + public downloadMode: flyteidl.core.IOStrategy.DownloadMode; + + /** IOStrategy uploadMode. */ + public uploadMode: flyteidl.core.IOStrategy.UploadMode; /** - * Creates a new WorkflowExecution instance using the specified properties. + * Creates a new IOStrategy instance using the specified properties. * @param [properties] Properties to set - * @returns WorkflowExecution instance + * @returns IOStrategy instance */ - public static create(properties?: flyteidl.core.IWorkflowExecution): flyteidl.core.WorkflowExecution; + public static create(properties?: flyteidl.core.IIOStrategy): flyteidl.core.IOStrategy; /** - * Encodes the specified WorkflowExecution message. Does not implicitly {@link flyteidl.core.WorkflowExecution.verify|verify} messages. - * @param message WorkflowExecution message or plain object to encode + * Encodes the specified IOStrategy message. Does not implicitly {@link flyteidl.core.IOStrategy.verify|verify} messages. + * @param message IOStrategy message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IWorkflowExecution, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IIOStrategy, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a WorkflowExecution message from the specified reader or buffer. + * Decodes a IOStrategy message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns WorkflowExecution + * @returns IOStrategy * @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.core.WorkflowExecution; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.IOStrategy; /** - * Verifies a WorkflowExecution message. + * Verifies a IOStrategy 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); } - namespace WorkflowExecution { + namespace IOStrategy { - /** Phase enum. */ - enum Phase { - UNDEFINED = 0, - QUEUED = 1, - RUNNING = 2, - SUCCEEDING = 3, - SUCCEEDED = 4, - FAILING = 5, - FAILED = 6, - ABORTED = 7, - TIMED_OUT = 8 + /** DownloadMode enum. */ + enum DownloadMode { + DOWNLOAD_EAGER = 0, + DOWNLOAD_STREAM = 1, + DO_NOT_DOWNLOAD = 2 + } + + /** UploadMode enum. */ + enum UploadMode { + UPLOAD_ON_EXIT = 0, + UPLOAD_EAGER = 1, + DO_NOT_UPLOAD = 2 } } - /** Properties of a NodeExecution. */ - interface INodeExecution { + /** Properties of a DataLoadingConfig. */ + interface IDataLoadingConfig { + + /** DataLoadingConfig enabled */ + enabled?: (boolean|null); + + /** DataLoadingConfig inputPath */ + inputPath?: (string|null); + + /** DataLoadingConfig outputPath */ + outputPath?: (string|null); + + /** DataLoadingConfig format */ + format?: (flyteidl.core.DataLoadingConfig.LiteralMapFormat|null); + + /** DataLoadingConfig ioStrategy */ + ioStrategy?: (flyteidl.core.IIOStrategy|null); } - /** Represents a NodeExecution. */ - class NodeExecution implements INodeExecution { + /** Represents a DataLoadingConfig. */ + class DataLoadingConfig implements IDataLoadingConfig { /** - * Constructs a new NodeExecution. + * Constructs a new DataLoadingConfig. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.INodeExecution); + constructor(properties?: flyteidl.core.IDataLoadingConfig); + + /** DataLoadingConfig enabled. */ + public enabled: boolean; + + /** DataLoadingConfig inputPath. */ + public inputPath: string; + + /** DataLoadingConfig outputPath. */ + public outputPath: string; + + /** DataLoadingConfig format. */ + public format: flyteidl.core.DataLoadingConfig.LiteralMapFormat; + + /** DataLoadingConfig ioStrategy. */ + public ioStrategy?: (flyteidl.core.IIOStrategy|null); /** - * Creates a new NodeExecution instance using the specified properties. + * Creates a new DataLoadingConfig instance using the specified properties. * @param [properties] Properties to set - * @returns NodeExecution instance + * @returns DataLoadingConfig instance */ - public static create(properties?: flyteidl.core.INodeExecution): flyteidl.core.NodeExecution; + public static create(properties?: flyteidl.core.IDataLoadingConfig): flyteidl.core.DataLoadingConfig; /** - * Encodes the specified NodeExecution message. Does not implicitly {@link flyteidl.core.NodeExecution.verify|verify} messages. - * @param message NodeExecution message or plain object to encode + * Encodes the specified DataLoadingConfig message. Does not implicitly {@link flyteidl.core.DataLoadingConfig.verify|verify} messages. + * @param message DataLoadingConfig message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.INodeExecution, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IDataLoadingConfig, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a NodeExecution message from the specified reader or buffer. + * Decodes a DataLoadingConfig message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns NodeExecution + * @returns DataLoadingConfig * @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.core.NodeExecution; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.DataLoadingConfig; /** - * Verifies a NodeExecution message. + * Verifies a DataLoadingConfig 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); } - namespace NodeExecution { + namespace DataLoadingConfig { - /** Phase enum. */ - enum Phase { - UNDEFINED = 0, - QUEUED = 1, - RUNNING = 2, - SUCCEEDED = 3, - FAILING = 4, - FAILED = 5, - ABORTED = 6, - SKIPPED = 7, - TIMED_OUT = 8 + /** LiteralMapFormat enum. */ + enum LiteralMapFormat { + JSON = 0, + YAML = 1, + PROTO = 2 } } - /** Properties of a TaskExecution. */ - interface ITaskExecution { + /** Properties of a DynamicJobSpec. */ + interface IDynamicJobSpec { + + /** DynamicJobSpec nodes */ + nodes?: (flyteidl.core.INode[]|null); + + /** DynamicJobSpec minSuccesses */ + minSuccesses?: (Long|null); + + /** DynamicJobSpec outputs */ + outputs?: (flyteidl.core.IBinding[]|null); + + /** DynamicJobSpec tasks */ + tasks?: (flyteidl.core.ITaskTemplate[]|null); + + /** DynamicJobSpec subworkflows */ + subworkflows?: (flyteidl.core.IWorkflowTemplate[]|null); } - /** Represents a TaskExecution. */ - class TaskExecution implements ITaskExecution { + /** Represents a DynamicJobSpec. */ + class DynamicJobSpec implements IDynamicJobSpec { /** - * Constructs a new TaskExecution. + * Constructs a new DynamicJobSpec. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.ITaskExecution); + constructor(properties?: flyteidl.core.IDynamicJobSpec); + + /** DynamicJobSpec nodes. */ + public nodes: flyteidl.core.INode[]; + + /** DynamicJobSpec minSuccesses. */ + public minSuccesses: Long; + + /** DynamicJobSpec outputs. */ + public outputs: flyteidl.core.IBinding[]; + + /** DynamicJobSpec tasks. */ + public tasks: flyteidl.core.ITaskTemplate[]; + + /** DynamicJobSpec subworkflows. */ + public subworkflows: flyteidl.core.IWorkflowTemplate[]; /** - * Creates a new TaskExecution instance using the specified properties. + * Creates a new DynamicJobSpec instance using the specified properties. * @param [properties] Properties to set - * @returns TaskExecution instance + * @returns DynamicJobSpec instance */ - public static create(properties?: flyteidl.core.ITaskExecution): flyteidl.core.TaskExecution; + public static create(properties?: flyteidl.core.IDynamicJobSpec): flyteidl.core.DynamicJobSpec; /** - * Encodes the specified TaskExecution message. Does not implicitly {@link flyteidl.core.TaskExecution.verify|verify} messages. - * @param message TaskExecution message or plain object to encode + * Encodes the specified DynamicJobSpec message. Does not implicitly {@link flyteidl.core.DynamicJobSpec.verify|verify} messages. + * @param message DynamicJobSpec message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.ITaskExecution, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IDynamicJobSpec, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a TaskExecution message from the specified reader or buffer. + * Decodes a DynamicJobSpec message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns TaskExecution + * @returns DynamicJobSpec * @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.core.TaskExecution; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.DynamicJobSpec; /** - * Verifies a TaskExecution message. + * Verifies a DynamicJobSpec 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); } - namespace TaskExecution { - - /** Phase enum. */ - enum Phase { - UNDEFINED = 0, - QUEUED = 1, - RUNNING = 2, - SUCCEEDED = 3, - ABORTED = 4, - FAILED = 5, - INITIALIZING = 6, - WAITING_FOR_RESOURCES = 7 - } - } - - /** Properties of an ExecutionError. */ - interface IExecutionError { + /** Properties of a ContainerError. */ + interface IContainerError { - /** ExecutionError code */ + /** ContainerError code */ code?: (string|null); - /** ExecutionError message */ + /** ContainerError message */ message?: (string|null); - /** ExecutionError errorUri */ - errorUri?: (string|null); + /** ContainerError kind */ + kind?: (flyteidl.core.ContainerError.Kind|null); - /** ExecutionError kind */ - kind?: (flyteidl.core.ExecutionError.ErrorKind|null); + /** ContainerError origin */ + origin?: (flyteidl.core.ExecutionError.ErrorKind|null); } - /** Represents an ExecutionError. */ - class ExecutionError implements IExecutionError { + /** Represents a ContainerError. */ + class ContainerError implements IContainerError { /** - * Constructs a new ExecutionError. + * Constructs a new ContainerError. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.IExecutionError); + constructor(properties?: flyteidl.core.IContainerError); - /** ExecutionError code. */ + /** ContainerError code. */ public code: string; - /** ExecutionError message. */ + /** ContainerError message. */ public message: string; - /** ExecutionError errorUri. */ - public errorUri: string; + /** ContainerError kind. */ + public kind: flyteidl.core.ContainerError.Kind; - /** ExecutionError kind. */ - public kind: flyteidl.core.ExecutionError.ErrorKind; + /** ContainerError origin. */ + public origin: flyteidl.core.ExecutionError.ErrorKind; /** - * Creates a new ExecutionError instance using the specified properties. + * Creates a new ContainerError instance using the specified properties. * @param [properties] Properties to set - * @returns ExecutionError instance + * @returns ContainerError instance */ - public static create(properties?: flyteidl.core.IExecutionError): flyteidl.core.ExecutionError; + public static create(properties?: flyteidl.core.IContainerError): flyteidl.core.ContainerError; /** - * Encodes the specified ExecutionError message. Does not implicitly {@link flyteidl.core.ExecutionError.verify|verify} messages. - * @param message ExecutionError message or plain object to encode + * Encodes the specified ContainerError message. Does not implicitly {@link flyteidl.core.ContainerError.verify|verify} messages. + * @param message ContainerError message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.IExecutionError, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IContainerError, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes an ExecutionError message from the specified reader or buffer. + * Decodes a ContainerError message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns ExecutionError + * @returns ContainerError * @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.core.ExecutionError; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.ContainerError; /** - * Verifies an ExecutionError message. + * Verifies a ContainerError 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); } - namespace ExecutionError { + namespace ContainerError { - /** ErrorKind enum. */ - enum ErrorKind { - UNKNOWN = 0, - USER = 1, - SYSTEM = 2 + /** Kind enum. */ + enum Kind { + NON_RECOVERABLE = 0, + RECOVERABLE = 1 } } - /** Properties of a TaskLog. */ - interface ITaskLog { - - /** TaskLog uri */ - uri?: (string|null); - - /** TaskLog name */ - name?: (string|null); - - /** TaskLog messageFormat */ - messageFormat?: (flyteidl.core.TaskLog.MessageFormat|null); + /** Properties of an ErrorDocument. */ + interface IErrorDocument { - /** TaskLog ttl */ - ttl?: (google.protobuf.IDuration|null); + /** ErrorDocument error */ + error?: (flyteidl.core.IContainerError|null); } - /** Represents a TaskLog. */ - class TaskLog implements ITaskLog { + /** Represents an ErrorDocument. */ + class ErrorDocument implements IErrorDocument { /** - * Constructs a new TaskLog. + * Constructs a new ErrorDocument. * @param [properties] Properties to set */ - constructor(properties?: flyteidl.core.ITaskLog); - - /** TaskLog uri. */ - public uri: string; - - /** TaskLog name. */ - public name: string; - - /** TaskLog messageFormat. */ - public messageFormat: flyteidl.core.TaskLog.MessageFormat; + constructor(properties?: flyteidl.core.IErrorDocument); - /** TaskLog ttl. */ - public ttl?: (google.protobuf.IDuration|null); + /** ErrorDocument error. */ + public error?: (flyteidl.core.IContainerError|null); /** - * Creates a new TaskLog instance using the specified properties. + * Creates a new ErrorDocument instance using the specified properties. * @param [properties] Properties to set - * @returns TaskLog instance + * @returns ErrorDocument instance */ - public static create(properties?: flyteidl.core.ITaskLog): flyteidl.core.TaskLog; + public static create(properties?: flyteidl.core.IErrorDocument): flyteidl.core.ErrorDocument; /** - * Encodes the specified TaskLog message. Does not implicitly {@link flyteidl.core.TaskLog.verify|verify} messages. - * @param message TaskLog message or plain object to encode + * Encodes the specified ErrorDocument message. Does not implicitly {@link flyteidl.core.ErrorDocument.verify|verify} messages. + * @param message ErrorDocument message or plain object to encode * @param [writer] Writer to encode to * @returns Writer */ - public static encode(message: flyteidl.core.ITaskLog, writer?: $protobuf.Writer): $protobuf.Writer; + public static encode(message: flyteidl.core.IErrorDocument, writer?: $protobuf.Writer): $protobuf.Writer; /** - * Decodes a TaskLog message from the specified reader or buffer. + * Decodes an ErrorDocument message from the specified reader or buffer. * @param reader Reader or buffer to decode from * @param [length] Message length if known beforehand - * @returns TaskLog + * @returns ErrorDocument * @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.core.TaskLog; + public static decode(reader: ($protobuf.Reader|Uint8Array), length?: number): flyteidl.core.ErrorDocument; /** - * Verifies a TaskLog message. + * Verifies an ErrorDocument 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); } - namespace TaskLog { - - /** MessageFormat enum. */ - enum MessageFormat { - UNKNOWN = 0, - CSV = 1, - JSON = 2 - } - } - /** Properties of a WorkflowClosure. */ interface IWorkflowClosure { @@ -7488,6 +7612,9 @@ export namespace flyteidl { /** ExecutionSpec authRole */ authRole?: (flyteidl.admin.IAuthRole|null); + + /** ExecutionSpec qualityOfService */ + qualityOfService?: (flyteidl.core.IQualityOfService|null); } /** Represents an ExecutionSpec. */ @@ -7523,6 +7650,9 @@ export namespace flyteidl { /** ExecutionSpec authRole. */ public authRole?: (flyteidl.admin.IAuthRole|null); + /** ExecutionSpec qualityOfService. */ + public qualityOfService?: (flyteidl.core.IQualityOfService|null); + /** ExecutionSpec notificationOverrides. */ public notificationOverrides?: ("notifications"|"disableAll"); @@ -8095,6 +8225,9 @@ export namespace flyteidl { /** LaunchPlanSpec authRole */ authRole?: (flyteidl.admin.IAuthRole|null); + + /** LaunchPlanSpec qualityOfService */ + qualityOfService?: (flyteidl.core.IQualityOfService|null); } /** Represents a LaunchPlanSpec. */ @@ -8133,6 +8266,9 @@ export namespace flyteidl { /** LaunchPlanSpec authRole. */ public authRole?: (flyteidl.admin.IAuthRole|null); + /** LaunchPlanSpec qualityOfService. */ + public qualityOfService?: (flyteidl.core.IQualityOfService|null); + /** * Creates a new LaunchPlanSpec instance using the specified properties. * @param [properties] Properties to set @@ -8669,7 +8805,8 @@ export namespace flyteidl { TASK_RESOURCE = 0, CLUSTER_RESOURCE = 1, EXECUTION_QUEUE = 2, - EXECUTION_CLUSTER_LABEL = 3 + EXECUTION_CLUSTER_LABEL = 3, + QUALITY_OF_SERVICE_SPECIFICATION = 4 } /** Properties of a TaskResourceSpec. */ @@ -8970,6 +9107,9 @@ export namespace flyteidl { /** MatchingAttributes executionClusterLabel */ executionClusterLabel?: (flyteidl.admin.IExecutionClusterLabel|null); + + /** MatchingAttributes qualityOfService */ + qualityOfService?: (flyteidl.core.IQualityOfService|null); } /** Represents a MatchingAttributes. */ @@ -8993,8 +9133,11 @@ export namespace flyteidl { /** MatchingAttributes executionClusterLabel. */ public executionClusterLabel?: (flyteidl.admin.IExecutionClusterLabel|null); + /** MatchingAttributes qualityOfService. */ + public qualityOfService?: (flyteidl.core.IQualityOfService|null); + /** MatchingAttributes target. */ - public target?: ("taskResourceAttributes"|"clusterResourceAttributes"|"executionQueueAttributes"|"executionClusterLabel"); + public target?: ("taskResourceAttributes"|"clusterResourceAttributes"|"executionQueueAttributes"|"executionClusterLabel"|"qualityOfService"); /** * Creates a new MatchingAttributes instance using the specified properties. diff --git a/flyteidl/gen/pb-js/flyteidl.js b/flyteidl/gen/pb-js/flyteidl.js index 2e8e399b233..8647ede7059 100644 --- a/flyteidl/gen/pb-js/flyteidl.js +++ b/flyteidl/gen/pb-js/flyteidl.js @@ -2046,7 +2046,7 @@ export const flyteidl = $root.flyteidl = (() => { * Properties of a WorkflowMetadata. * @memberof flyteidl.core * @interface IWorkflowMetadata - * @property {google.protobuf.IDuration|null} [queuingBudget] WorkflowMetadata queuingBudget + * @property {flyteidl.core.IQualityOfService|null} [qualityOfService] WorkflowMetadata qualityOfService * @property {flyteidl.core.WorkflowMetadata.OnFailurePolicy|null} [onFailure] WorkflowMetadata onFailure */ @@ -2066,12 +2066,12 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * WorkflowMetadata queuingBudget. - * @member {google.protobuf.IDuration|null|undefined} queuingBudget + * WorkflowMetadata qualityOfService. + * @member {flyteidl.core.IQualityOfService|null|undefined} qualityOfService * @memberof flyteidl.core.WorkflowMetadata * @instance */ - WorkflowMetadata.prototype.queuingBudget = null; + WorkflowMetadata.prototype.qualityOfService = null; /** * WorkflowMetadata onFailure. @@ -2105,8 +2105,8 @@ export const flyteidl = $root.flyteidl = (() => { WorkflowMetadata.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.queuingBudget != null && message.hasOwnProperty("queuingBudget")) - $root.google.protobuf.Duration.encode(message.queuingBudget, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.qualityOfService != null && message.hasOwnProperty("qualityOfService")) + $root.flyteidl.core.QualityOfService.encode(message.qualityOfService, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); if (message.onFailure != null && message.hasOwnProperty("onFailure")) writer.uint32(/* id 2, wireType 0 =*/16).int32(message.onFailure); return writer; @@ -2131,7 +2131,7 @@ export const flyteidl = $root.flyteidl = (() => { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.queuingBudget = $root.google.protobuf.Duration.decode(reader, reader.uint32()); + message.qualityOfService = $root.flyteidl.core.QualityOfService.decode(reader, reader.uint32()); break; case 2: message.onFailure = reader.int32(); @@ -2155,10 +2155,10 @@ export const flyteidl = $root.flyteidl = (() => { WorkflowMetadata.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.queuingBudget != null && message.hasOwnProperty("queuingBudget")) { - let error = $root.google.protobuf.Duration.verify(message.queuingBudget); + if (message.qualityOfService != null && message.hasOwnProperty("qualityOfService")) { + let error = $root.flyteidl.core.QualityOfService.verify(message.qualityOfService); if (error) - return "queuingBudget." + error; + return "qualityOfService." + error; } if (message.onFailure != null && message.hasOwnProperty("onFailure")) switch (message.onFailure) { @@ -6494,46 +6494,23 @@ export const flyteidl = $root.flyteidl = (() => { return Error; })(); - /** - * ResourceType enum. - * @name flyteidl.core.ResourceType - * @enum {string} - * @property {number} UNSPECIFIED=0 UNSPECIFIED value - * @property {number} TASK=1 TASK value - * @property {number} WORKFLOW=2 WORKFLOW value - * @property {number} LAUNCH_PLAN=3 LAUNCH_PLAN value - */ - core.ResourceType = (function() { - const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "UNSPECIFIED"] = 0; - values[valuesById[1] = "TASK"] = 1; - values[valuesById[2] = "WORKFLOW"] = 2; - values[valuesById[3] = "LAUNCH_PLAN"] = 3; - return values; - })(); - - core.Identifier = (function() { + core.WorkflowExecution = (function() { /** - * Properties of an Identifier. + * Properties of a WorkflowExecution. * @memberof flyteidl.core - * @interface IIdentifier - * @property {flyteidl.core.ResourceType|null} [resourceType] Identifier resourceType - * @property {string|null} [project] Identifier project - * @property {string|null} [domain] Identifier domain - * @property {string|null} [name] Identifier name - * @property {string|null} [version] Identifier version + * @interface IWorkflowExecution */ /** - * Constructs a new Identifier. + * Constructs a new WorkflowExecution. * @memberof flyteidl.core - * @classdesc Represents an Identifier. - * @implements IIdentifier + * @classdesc Represents a WorkflowExecution. + * @implements IWorkflowExecution * @constructor - * @param {flyteidl.core.IIdentifier=} [properties] Properties to set + * @param {flyteidl.core.IWorkflowExecution=} [properties] Properties to set */ - function Identifier(properties) { + function WorkflowExecution(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -6541,115 +6518,50 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * Identifier resourceType. - * @member {flyteidl.core.ResourceType} resourceType - * @memberof flyteidl.core.Identifier - * @instance - */ - Identifier.prototype.resourceType = 0; - - /** - * Identifier project. - * @member {string} project - * @memberof flyteidl.core.Identifier - * @instance - */ - Identifier.prototype.project = ""; - - /** - * Identifier domain. - * @member {string} domain - * @memberof flyteidl.core.Identifier - * @instance - */ - Identifier.prototype.domain = ""; - - /** - * Identifier name. - * @member {string} name - * @memberof flyteidl.core.Identifier - * @instance - */ - Identifier.prototype.name = ""; - - /** - * Identifier version. - * @member {string} version - * @memberof flyteidl.core.Identifier - * @instance - */ - Identifier.prototype.version = ""; - - /** - * Creates a new Identifier instance using the specified properties. + * Creates a new WorkflowExecution instance using the specified properties. * @function create - * @memberof flyteidl.core.Identifier + * @memberof flyteidl.core.WorkflowExecution * @static - * @param {flyteidl.core.IIdentifier=} [properties] Properties to set - * @returns {flyteidl.core.Identifier} Identifier instance + * @param {flyteidl.core.IWorkflowExecution=} [properties] Properties to set + * @returns {flyteidl.core.WorkflowExecution} WorkflowExecution instance */ - Identifier.create = function create(properties) { - return new Identifier(properties); + WorkflowExecution.create = function create(properties) { + return new WorkflowExecution(properties); }; /** - * Encodes the specified Identifier message. Does not implicitly {@link flyteidl.core.Identifier.verify|verify} messages. + * Encodes the specified WorkflowExecution message. Does not implicitly {@link flyteidl.core.WorkflowExecution.verify|verify} messages. * @function encode - * @memberof flyteidl.core.Identifier + * @memberof flyteidl.core.WorkflowExecution * @static - * @param {flyteidl.core.IIdentifier} message Identifier message or plain object to encode + * @param {flyteidl.core.IWorkflowExecution} message WorkflowExecution message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - Identifier.encode = function encode(message, writer) { + WorkflowExecution.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.resourceType != null && message.hasOwnProperty("resourceType")) - writer.uint32(/* id 1, wireType 0 =*/8).int32(message.resourceType); - if (message.project != null && message.hasOwnProperty("project")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.project); - if (message.domain != null && message.hasOwnProperty("domain")) - writer.uint32(/* id 3, wireType 2 =*/26).string(message.domain); - if (message.name != null && message.hasOwnProperty("name")) - writer.uint32(/* id 4, wireType 2 =*/34).string(message.name); - if (message.version != null && message.hasOwnProperty("version")) - writer.uint32(/* id 5, wireType 2 =*/42).string(message.version); return writer; }; /** - * Decodes an Identifier message from the specified reader or buffer. + * Decodes a WorkflowExecution message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.Identifier + * @memberof flyteidl.core.WorkflowExecution * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.Identifier} Identifier + * @returns {flyteidl.core.WorkflowExecution} WorkflowExecution * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - Identifier.decode = function decode(reader, length) { + WorkflowExecution.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.core.Identifier(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.WorkflowExecution(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { - case 1: - message.resourceType = reader.int32(); - break; - case 2: - message.project = reader.string(); - break; - case 3: - message.domain = reader.string(); - break; - case 4: - message.name = reader.string(); - break; - case 5: - message.version = reader.string(); - break; default: reader.skipType(tag & 7); break; @@ -6659,64 +6571,67 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies an Identifier message. + * Verifies a WorkflowExecution message. * @function verify - * @memberof flyteidl.core.Identifier + * @memberof flyteidl.core.WorkflowExecution * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - Identifier.verify = function verify(message) { + WorkflowExecution.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.resourceType != null && message.hasOwnProperty("resourceType")) - switch (message.resourceType) { - default: - return "resourceType: enum value expected"; - case 0: - case 1: - case 2: - case 3: - break; - } - if (message.project != null && message.hasOwnProperty("project")) - if (!$util.isString(message.project)) - return "project: string expected"; - if (message.domain != null && message.hasOwnProperty("domain")) - if (!$util.isString(message.domain)) - return "domain: string expected"; - if (message.name != null && message.hasOwnProperty("name")) - if (!$util.isString(message.name)) - return "name: string expected"; - if (message.version != null && message.hasOwnProperty("version")) - if (!$util.isString(message.version)) - return "version: string expected"; return null; }; - return Identifier; + /** + * Phase enum. + * @name flyteidl.core.WorkflowExecution.Phase + * @enum {string} + * @property {number} UNDEFINED=0 UNDEFINED value + * @property {number} QUEUED=1 QUEUED value + * @property {number} RUNNING=2 RUNNING value + * @property {number} SUCCEEDING=3 SUCCEEDING value + * @property {number} SUCCEEDED=4 SUCCEEDED value + * @property {number} FAILING=5 FAILING value + * @property {number} FAILED=6 FAILED value + * @property {number} ABORTED=7 ABORTED value + * @property {number} TIMED_OUT=8 TIMED_OUT value + */ + WorkflowExecution.Phase = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNDEFINED"] = 0; + values[valuesById[1] = "QUEUED"] = 1; + values[valuesById[2] = "RUNNING"] = 2; + values[valuesById[3] = "SUCCEEDING"] = 3; + values[valuesById[4] = "SUCCEEDED"] = 4; + values[valuesById[5] = "FAILING"] = 5; + values[valuesById[6] = "FAILED"] = 6; + values[valuesById[7] = "ABORTED"] = 7; + values[valuesById[8] = "TIMED_OUT"] = 8; + return values; + })(); + + return WorkflowExecution; })(); - core.WorkflowExecutionIdentifier = (function() { + core.NodeExecution = (function() { /** - * Properties of a WorkflowExecutionIdentifier. + * Properties of a NodeExecution. * @memberof flyteidl.core - * @interface IWorkflowExecutionIdentifier - * @property {string|null} [project] WorkflowExecutionIdentifier project - * @property {string|null} [domain] WorkflowExecutionIdentifier domain - * @property {string|null} [name] WorkflowExecutionIdentifier name + * @interface INodeExecution */ /** - * Constructs a new WorkflowExecutionIdentifier. + * Constructs a new NodeExecution. * @memberof flyteidl.core - * @classdesc Represents a WorkflowExecutionIdentifier. - * @implements IWorkflowExecutionIdentifier + * @classdesc Represents a NodeExecution. + * @implements INodeExecution * @constructor - * @param {flyteidl.core.IWorkflowExecutionIdentifier=} [properties] Properties to set + * @param {flyteidl.core.INodeExecution=} [properties] Properties to set */ - function WorkflowExecutionIdentifier(properties) { + function NodeExecution(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -6724,89 +6639,50 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * WorkflowExecutionIdentifier project. - * @member {string} project - * @memberof flyteidl.core.WorkflowExecutionIdentifier - * @instance - */ - WorkflowExecutionIdentifier.prototype.project = ""; - - /** - * WorkflowExecutionIdentifier domain. - * @member {string} domain - * @memberof flyteidl.core.WorkflowExecutionIdentifier - * @instance - */ - WorkflowExecutionIdentifier.prototype.domain = ""; - - /** - * WorkflowExecutionIdentifier name. - * @member {string} name - * @memberof flyteidl.core.WorkflowExecutionIdentifier - * @instance - */ - WorkflowExecutionIdentifier.prototype.name = ""; - - /** - * Creates a new WorkflowExecutionIdentifier instance using the specified properties. + * Creates a new NodeExecution instance using the specified properties. * @function create - * @memberof flyteidl.core.WorkflowExecutionIdentifier + * @memberof flyteidl.core.NodeExecution * @static - * @param {flyteidl.core.IWorkflowExecutionIdentifier=} [properties] Properties to set - * @returns {flyteidl.core.WorkflowExecutionIdentifier} WorkflowExecutionIdentifier instance + * @param {flyteidl.core.INodeExecution=} [properties] Properties to set + * @returns {flyteidl.core.NodeExecution} NodeExecution instance */ - WorkflowExecutionIdentifier.create = function create(properties) { - return new WorkflowExecutionIdentifier(properties); + NodeExecution.create = function create(properties) { + return new NodeExecution(properties); }; /** - * Encodes the specified WorkflowExecutionIdentifier message. Does not implicitly {@link flyteidl.core.WorkflowExecutionIdentifier.verify|verify} messages. + * Encodes the specified NodeExecution message. Does not implicitly {@link flyteidl.core.NodeExecution.verify|verify} messages. * @function encode - * @memberof flyteidl.core.WorkflowExecutionIdentifier + * @memberof flyteidl.core.NodeExecution * @static - * @param {flyteidl.core.IWorkflowExecutionIdentifier} message WorkflowExecutionIdentifier message or plain object to encode + * @param {flyteidl.core.INodeExecution} message NodeExecution message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - WorkflowExecutionIdentifier.encode = function encode(message, writer) { + NodeExecution.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.project != null && message.hasOwnProperty("project")) - writer.uint32(/* id 1, wireType 2 =*/10).string(message.project); - if (message.domain != null && message.hasOwnProperty("domain")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.domain); - if (message.name != null && message.hasOwnProperty("name")) - writer.uint32(/* id 4, wireType 2 =*/34).string(message.name); return writer; }; /** - * Decodes a WorkflowExecutionIdentifier message from the specified reader or buffer. + * Decodes a NodeExecution message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.WorkflowExecutionIdentifier + * @memberof flyteidl.core.NodeExecution * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.WorkflowExecutionIdentifier} WorkflowExecutionIdentifier + * @returns {flyteidl.core.NodeExecution} NodeExecution * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - WorkflowExecutionIdentifier.decode = function decode(reader, length) { + NodeExecution.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.core.WorkflowExecutionIdentifier(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.NodeExecution(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { - case 1: - message.project = reader.string(); - break; - case 2: - message.domain = reader.string(); - break; - case 4: - message.name = reader.string(); - break; default: reader.skipType(tag & 7); break; @@ -6816,50 +6692,67 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a WorkflowExecutionIdentifier message. + * Verifies a NodeExecution message. * @function verify - * @memberof flyteidl.core.WorkflowExecutionIdentifier + * @memberof flyteidl.core.NodeExecution * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - WorkflowExecutionIdentifier.verify = function verify(message) { + NodeExecution.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.project != null && message.hasOwnProperty("project")) - if (!$util.isString(message.project)) - return "project: string expected"; - if (message.domain != null && message.hasOwnProperty("domain")) - if (!$util.isString(message.domain)) - return "domain: string expected"; - if (message.name != null && message.hasOwnProperty("name")) - if (!$util.isString(message.name)) - return "name: string expected"; return null; }; - return WorkflowExecutionIdentifier; + /** + * Phase enum. + * @name flyteidl.core.NodeExecution.Phase + * @enum {string} + * @property {number} UNDEFINED=0 UNDEFINED value + * @property {number} QUEUED=1 QUEUED value + * @property {number} RUNNING=2 RUNNING value + * @property {number} SUCCEEDED=3 SUCCEEDED value + * @property {number} FAILING=4 FAILING value + * @property {number} FAILED=5 FAILED value + * @property {number} ABORTED=6 ABORTED value + * @property {number} SKIPPED=7 SKIPPED value + * @property {number} TIMED_OUT=8 TIMED_OUT value + */ + NodeExecution.Phase = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNDEFINED"] = 0; + values[valuesById[1] = "QUEUED"] = 1; + values[valuesById[2] = "RUNNING"] = 2; + values[valuesById[3] = "SUCCEEDED"] = 3; + values[valuesById[4] = "FAILING"] = 4; + values[valuesById[5] = "FAILED"] = 5; + values[valuesById[6] = "ABORTED"] = 6; + values[valuesById[7] = "SKIPPED"] = 7; + values[valuesById[8] = "TIMED_OUT"] = 8; + return values; + })(); + + return NodeExecution; })(); - core.NodeExecutionIdentifier = (function() { + core.TaskExecution = (function() { /** - * Properties of a NodeExecutionIdentifier. + * Properties of a TaskExecution. * @memberof flyteidl.core - * @interface INodeExecutionIdentifier - * @property {string|null} [nodeId] NodeExecutionIdentifier nodeId - * @property {flyteidl.core.IWorkflowExecutionIdentifier|null} [executionId] NodeExecutionIdentifier executionId + * @interface ITaskExecution */ /** - * Constructs a new NodeExecutionIdentifier. + * Constructs a new TaskExecution. * @memberof flyteidl.core - * @classdesc Represents a NodeExecutionIdentifier. - * @implements INodeExecutionIdentifier + * @classdesc Represents a TaskExecution. + * @implements ITaskExecution * @constructor - * @param {flyteidl.core.INodeExecutionIdentifier=} [properties] Properties to set + * @param {flyteidl.core.ITaskExecution=} [properties] Properties to set */ - function NodeExecutionIdentifier(properties) { + function TaskExecution(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -6867,76 +6760,50 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * NodeExecutionIdentifier nodeId. - * @member {string} nodeId - * @memberof flyteidl.core.NodeExecutionIdentifier - * @instance - */ - NodeExecutionIdentifier.prototype.nodeId = ""; - - /** - * NodeExecutionIdentifier executionId. - * @member {flyteidl.core.IWorkflowExecutionIdentifier|null|undefined} executionId - * @memberof flyteidl.core.NodeExecutionIdentifier - * @instance - */ - NodeExecutionIdentifier.prototype.executionId = null; - - /** - * Creates a new NodeExecutionIdentifier instance using the specified properties. + * Creates a new TaskExecution instance using the specified properties. * @function create - * @memberof flyteidl.core.NodeExecutionIdentifier + * @memberof flyteidl.core.TaskExecution * @static - * @param {flyteidl.core.INodeExecutionIdentifier=} [properties] Properties to set - * @returns {flyteidl.core.NodeExecutionIdentifier} NodeExecutionIdentifier instance + * @param {flyteidl.core.ITaskExecution=} [properties] Properties to set + * @returns {flyteidl.core.TaskExecution} TaskExecution instance */ - NodeExecutionIdentifier.create = function create(properties) { - return new NodeExecutionIdentifier(properties); + TaskExecution.create = function create(properties) { + return new TaskExecution(properties); }; /** - * Encodes the specified NodeExecutionIdentifier message. Does not implicitly {@link flyteidl.core.NodeExecutionIdentifier.verify|verify} messages. + * Encodes the specified TaskExecution message. Does not implicitly {@link flyteidl.core.TaskExecution.verify|verify} messages. * @function encode - * @memberof flyteidl.core.NodeExecutionIdentifier + * @memberof flyteidl.core.TaskExecution * @static - * @param {flyteidl.core.INodeExecutionIdentifier} message NodeExecutionIdentifier message or plain object to encode + * @param {flyteidl.core.ITaskExecution} message TaskExecution message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - NodeExecutionIdentifier.encode = function encode(message, writer) { + TaskExecution.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); - if (message.executionId != null && message.hasOwnProperty("executionId")) - $root.flyteidl.core.WorkflowExecutionIdentifier.encode(message.executionId, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); return writer; }; /** - * Decodes a NodeExecutionIdentifier message from the specified reader or buffer. + * Decodes a TaskExecution message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.NodeExecutionIdentifier + * @memberof flyteidl.core.TaskExecution * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.NodeExecutionIdentifier} NodeExecutionIdentifier + * @returns {flyteidl.core.TaskExecution} TaskExecution * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - NodeExecutionIdentifier.decode = function decode(reader, length) { + TaskExecution.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.core.NodeExecutionIdentifier(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.TaskExecution(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { - case 1: - message.nodeId = reader.string(); - break; - case 2: - message.executionId = $root.flyteidl.core.WorkflowExecutionIdentifier.decode(reader, reader.uint32()); - break; default: reader.skipType(tag & 7); break; @@ -6946,50 +6813,69 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a NodeExecutionIdentifier message. + * Verifies a TaskExecution message. * @function verify - * @memberof flyteidl.core.NodeExecutionIdentifier + * @memberof flyteidl.core.TaskExecution * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - NodeExecutionIdentifier.verify = function verify(message) { + TaskExecution.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"; - if (message.executionId != null && message.hasOwnProperty("executionId")) { - let error = $root.flyteidl.core.WorkflowExecutionIdentifier.verify(message.executionId); - if (error) - return "executionId." + error; - } return null; }; - return NodeExecutionIdentifier; + /** + * Phase enum. + * @name flyteidl.core.TaskExecution.Phase + * @enum {string} + * @property {number} UNDEFINED=0 UNDEFINED value + * @property {number} QUEUED=1 QUEUED value + * @property {number} RUNNING=2 RUNNING value + * @property {number} SUCCEEDED=3 SUCCEEDED value + * @property {number} ABORTED=4 ABORTED value + * @property {number} FAILED=5 FAILED value + * @property {number} INITIALIZING=6 INITIALIZING value + * @property {number} WAITING_FOR_RESOURCES=7 WAITING_FOR_RESOURCES value + */ + TaskExecution.Phase = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNDEFINED"] = 0; + values[valuesById[1] = "QUEUED"] = 1; + values[valuesById[2] = "RUNNING"] = 2; + values[valuesById[3] = "SUCCEEDED"] = 3; + values[valuesById[4] = "ABORTED"] = 4; + values[valuesById[5] = "FAILED"] = 5; + values[valuesById[6] = "INITIALIZING"] = 6; + values[valuesById[7] = "WAITING_FOR_RESOURCES"] = 7; + return values; + })(); + + return TaskExecution; })(); - core.TaskExecutionIdentifier = (function() { + core.ExecutionError = (function() { /** - * Properties of a TaskExecutionIdentifier. + * Properties of an ExecutionError. * @memberof flyteidl.core - * @interface ITaskExecutionIdentifier - * @property {flyteidl.core.IIdentifier|null} [taskId] TaskExecutionIdentifier taskId - * @property {flyteidl.core.INodeExecutionIdentifier|null} [nodeExecutionId] TaskExecutionIdentifier nodeExecutionId - * @property {number|null} [retryAttempt] TaskExecutionIdentifier retryAttempt + * @interface IExecutionError + * @property {string|null} [code] ExecutionError code + * @property {string|null} [message] ExecutionError message + * @property {string|null} [errorUri] ExecutionError errorUri + * @property {flyteidl.core.ExecutionError.ErrorKind|null} [kind] ExecutionError kind */ /** - * Constructs a new TaskExecutionIdentifier. + * Constructs a new ExecutionError. * @memberof flyteidl.core - * @classdesc Represents a TaskExecutionIdentifier. - * @implements ITaskExecutionIdentifier + * @classdesc Represents an ExecutionError. + * @implements IExecutionError * @constructor - * @param {flyteidl.core.ITaskExecutionIdentifier=} [properties] Properties to set + * @param {flyteidl.core.IExecutionError=} [properties] Properties to set */ - function TaskExecutionIdentifier(properties) { + function ExecutionError(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -6997,88 +6883,101 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * TaskExecutionIdentifier taskId. - * @member {flyteidl.core.IIdentifier|null|undefined} taskId - * @memberof flyteidl.core.TaskExecutionIdentifier + * ExecutionError code. + * @member {string} code + * @memberof flyteidl.core.ExecutionError * @instance */ - TaskExecutionIdentifier.prototype.taskId = null; + ExecutionError.prototype.code = ""; /** - * TaskExecutionIdentifier nodeExecutionId. - * @member {flyteidl.core.INodeExecutionIdentifier|null|undefined} nodeExecutionId - * @memberof flyteidl.core.TaskExecutionIdentifier + * ExecutionError message. + * @member {string} message + * @memberof flyteidl.core.ExecutionError * @instance */ - TaskExecutionIdentifier.prototype.nodeExecutionId = null; + ExecutionError.prototype.message = ""; /** - * TaskExecutionIdentifier retryAttempt. - * @member {number} retryAttempt - * @memberof flyteidl.core.TaskExecutionIdentifier + * ExecutionError errorUri. + * @member {string} errorUri + * @memberof flyteidl.core.ExecutionError * @instance */ - TaskExecutionIdentifier.prototype.retryAttempt = 0; + ExecutionError.prototype.errorUri = ""; /** - * Creates a new TaskExecutionIdentifier instance using the specified properties. + * ExecutionError kind. + * @member {flyteidl.core.ExecutionError.ErrorKind} kind + * @memberof flyteidl.core.ExecutionError + * @instance + */ + ExecutionError.prototype.kind = 0; + + /** + * Creates a new ExecutionError instance using the specified properties. * @function create - * @memberof flyteidl.core.TaskExecutionIdentifier + * @memberof flyteidl.core.ExecutionError * @static - * @param {flyteidl.core.ITaskExecutionIdentifier=} [properties] Properties to set - * @returns {flyteidl.core.TaskExecutionIdentifier} TaskExecutionIdentifier instance + * @param {flyteidl.core.IExecutionError=} [properties] Properties to set + * @returns {flyteidl.core.ExecutionError} ExecutionError instance */ - TaskExecutionIdentifier.create = function create(properties) { - return new TaskExecutionIdentifier(properties); + ExecutionError.create = function create(properties) { + return new ExecutionError(properties); }; /** - * Encodes the specified TaskExecutionIdentifier message. Does not implicitly {@link flyteidl.core.TaskExecutionIdentifier.verify|verify} messages. + * Encodes the specified ExecutionError message. Does not implicitly {@link flyteidl.core.ExecutionError.verify|verify} messages. * @function encode - * @memberof flyteidl.core.TaskExecutionIdentifier + * @memberof flyteidl.core.ExecutionError * @static - * @param {flyteidl.core.ITaskExecutionIdentifier} message TaskExecutionIdentifier message or plain object to encode + * @param {flyteidl.core.IExecutionError} message ExecutionError message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - TaskExecutionIdentifier.encode = function encode(message, writer) { + ExecutionError.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.taskId != null && message.hasOwnProperty("taskId")) - $root.flyteidl.core.Identifier.encode(message.taskId, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); - if (message.nodeExecutionId != null && message.hasOwnProperty("nodeExecutionId")) - $root.flyteidl.core.NodeExecutionIdentifier.encode(message.nodeExecutionId, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); - if (message.retryAttempt != null && message.hasOwnProperty("retryAttempt")) - writer.uint32(/* id 3, wireType 0 =*/24).uint32(message.retryAttempt); + if (message.code != null && message.hasOwnProperty("code")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.code); + if (message.message != null && message.hasOwnProperty("message")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.message); + if (message.errorUri != null && message.hasOwnProperty("errorUri")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.errorUri); + if (message.kind != null && message.hasOwnProperty("kind")) + writer.uint32(/* id 4, wireType 0 =*/32).int32(message.kind); return writer; }; /** - * Decodes a TaskExecutionIdentifier message from the specified reader or buffer. + * Decodes an ExecutionError message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.TaskExecutionIdentifier + * @memberof flyteidl.core.ExecutionError * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.TaskExecutionIdentifier} TaskExecutionIdentifier + * @returns {flyteidl.core.ExecutionError} ExecutionError * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - TaskExecutionIdentifier.decode = function decode(reader, length) { + ExecutionError.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.core.TaskExecutionIdentifier(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.ExecutionError(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.taskId = $root.flyteidl.core.Identifier.decode(reader, reader.uint32()); + message.code = reader.string(); break; case 2: - message.nodeExecutionId = $root.flyteidl.core.NodeExecutionIdentifier.decode(reader, reader.uint32()); + message.message = reader.string(); break; case 3: - message.retryAttempt = reader.uint32(); + message.errorUri = reader.string(); + break; + case 4: + message.kind = reader.int32(); break; default: reader.skipType(tag & 7); @@ -7089,54 +6988,77 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a TaskExecutionIdentifier message. + * Verifies an ExecutionError message. * @function verify - * @memberof flyteidl.core.TaskExecutionIdentifier + * @memberof flyteidl.core.ExecutionError * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - TaskExecutionIdentifier.verify = function verify(message) { + ExecutionError.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.taskId != null && message.hasOwnProperty("taskId")) { - let error = $root.flyteidl.core.Identifier.verify(message.taskId); - if (error) - return "taskId." + error; - } - if (message.nodeExecutionId != null && message.hasOwnProperty("nodeExecutionId")) { - let error = $root.flyteidl.core.NodeExecutionIdentifier.verify(message.nodeExecutionId); - if (error) - return "nodeExecutionId." + error; - } - if (message.retryAttempt != null && message.hasOwnProperty("retryAttempt")) - if (!$util.isInteger(message.retryAttempt)) - return "retryAttempt: integer expected"; + if (message.code != null && message.hasOwnProperty("code")) + if (!$util.isString(message.code)) + return "code: string expected"; + if (message.message != null && message.hasOwnProperty("message")) + if (!$util.isString(message.message)) + return "message: string expected"; + if (message.errorUri != null && message.hasOwnProperty("errorUri")) + if (!$util.isString(message.errorUri)) + return "errorUri: string expected"; + if (message.kind != null && message.hasOwnProperty("kind")) + switch (message.kind) { + default: + return "kind: enum value expected"; + case 0: + case 1: + case 2: + break; + } return null; }; - return TaskExecutionIdentifier; + /** + * ErrorKind enum. + * @name flyteidl.core.ExecutionError.ErrorKind + * @enum {string} + * @property {number} UNKNOWN=0 UNKNOWN value + * @property {number} USER=1 USER value + * @property {number} SYSTEM=2 SYSTEM value + */ + ExecutionError.ErrorKind = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNKNOWN"] = 0; + values[valuesById[1] = "USER"] = 1; + values[valuesById[2] = "SYSTEM"] = 2; + return values; + })(); + + return ExecutionError; })(); - core.Variable = (function() { + core.TaskLog = (function() { /** - * Properties of a Variable. + * Properties of a TaskLog. * @memberof flyteidl.core - * @interface IVariable - * @property {flyteidl.core.ILiteralType|null} [type] Variable type - * @property {string|null} [description] Variable description + * @interface ITaskLog + * @property {string|null} [uri] TaskLog uri + * @property {string|null} [name] TaskLog name + * @property {flyteidl.core.TaskLog.MessageFormat|null} [messageFormat] TaskLog messageFormat + * @property {google.protobuf.IDuration|null} [ttl] TaskLog ttl */ /** - * Constructs a new Variable. + * Constructs a new TaskLog. * @memberof flyteidl.core - * @classdesc Represents a Variable. - * @implements IVariable + * @classdesc Represents a TaskLog. + * @implements ITaskLog * @constructor - * @param {flyteidl.core.IVariable=} [properties] Properties to set + * @param {flyteidl.core.ITaskLog=} [properties] Properties to set */ - function Variable(properties) { + function TaskLog(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -7144,75 +7066,101 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * Variable type. - * @member {flyteidl.core.ILiteralType|null|undefined} type - * @memberof flyteidl.core.Variable + * TaskLog uri. + * @member {string} uri + * @memberof flyteidl.core.TaskLog * @instance */ - Variable.prototype.type = null; + TaskLog.prototype.uri = ""; /** - * Variable description. - * @member {string} description - * @memberof flyteidl.core.Variable + * TaskLog name. + * @member {string} name + * @memberof flyteidl.core.TaskLog * @instance */ - Variable.prototype.description = ""; + TaskLog.prototype.name = ""; /** - * Creates a new Variable instance using the specified properties. + * TaskLog messageFormat. + * @member {flyteidl.core.TaskLog.MessageFormat} messageFormat + * @memberof flyteidl.core.TaskLog + * @instance + */ + TaskLog.prototype.messageFormat = 0; + + /** + * TaskLog ttl. + * @member {google.protobuf.IDuration|null|undefined} ttl + * @memberof flyteidl.core.TaskLog + * @instance + */ + TaskLog.prototype.ttl = null; + + /** + * Creates a new TaskLog instance using the specified properties. * @function create - * @memberof flyteidl.core.Variable + * @memberof flyteidl.core.TaskLog * @static - * @param {flyteidl.core.IVariable=} [properties] Properties to set - * @returns {flyteidl.core.Variable} Variable instance + * @param {flyteidl.core.ITaskLog=} [properties] Properties to set + * @returns {flyteidl.core.TaskLog} TaskLog instance */ - Variable.create = function create(properties) { - return new Variable(properties); + TaskLog.create = function create(properties) { + return new TaskLog(properties); }; /** - * Encodes the specified Variable message. Does not implicitly {@link flyteidl.core.Variable.verify|verify} messages. + * Encodes the specified TaskLog message. Does not implicitly {@link flyteidl.core.TaskLog.verify|verify} messages. * @function encode - * @memberof flyteidl.core.Variable + * @memberof flyteidl.core.TaskLog * @static - * @param {flyteidl.core.IVariable} message Variable message or plain object to encode + * @param {flyteidl.core.ITaskLog} message TaskLog message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - Variable.encode = function encode(message, writer) { + TaskLog.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.type != null && message.hasOwnProperty("type")) - $root.flyteidl.core.LiteralType.encode(message.type, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); - if (message.description != null && message.hasOwnProperty("description")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.description); + if (message.uri != null && message.hasOwnProperty("uri")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.uri); + if (message.name != null && message.hasOwnProperty("name")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.name); + if (message.messageFormat != null && message.hasOwnProperty("messageFormat")) + writer.uint32(/* id 3, wireType 0 =*/24).int32(message.messageFormat); + if (message.ttl != null && message.hasOwnProperty("ttl")) + $root.google.protobuf.Duration.encode(message.ttl, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); return writer; }; /** - * Decodes a Variable message from the specified reader or buffer. + * Decodes a TaskLog message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.Variable + * @memberof flyteidl.core.TaskLog * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.Variable} Variable + * @returns {flyteidl.core.TaskLog} TaskLog * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - Variable.decode = function decode(reader, length) { + TaskLog.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.core.Variable(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.TaskLog(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.type = $root.flyteidl.core.LiteralType.decode(reader, reader.uint32()); + message.uri = reader.string(); break; case 2: - message.description = reader.string(); + message.name = reader.string(); + break; + case 3: + message.messageFormat = reader.int32(); + break; + case 4: + message.ttl = $root.google.protobuf.Duration.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -7223,49 +7171,76 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a Variable message. + * Verifies a TaskLog message. * @function verify - * @memberof flyteidl.core.Variable + * @memberof flyteidl.core.TaskLog * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - Variable.verify = function verify(message) { + TaskLog.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.type != null && message.hasOwnProperty("type")) { - let error = $root.flyteidl.core.LiteralType.verify(message.type); + if (message.uri != null && message.hasOwnProperty("uri")) + if (!$util.isString(message.uri)) + return "uri: string expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.messageFormat != null && message.hasOwnProperty("messageFormat")) + switch (message.messageFormat) { + default: + return "messageFormat: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.ttl != null && message.hasOwnProperty("ttl")) { + let error = $root.google.protobuf.Duration.verify(message.ttl); if (error) - return "type." + error; + return "ttl." + error; } - if (message.description != null && message.hasOwnProperty("description")) - if (!$util.isString(message.description)) - return "description: string expected"; return null; }; - return Variable; + /** + * MessageFormat enum. + * @name flyteidl.core.TaskLog.MessageFormat + * @enum {string} + * @property {number} UNKNOWN=0 UNKNOWN value + * @property {number} CSV=1 CSV value + * @property {number} JSON=2 JSON value + */ + TaskLog.MessageFormat = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNKNOWN"] = 0; + values[valuesById[1] = "CSV"] = 1; + values[valuesById[2] = "JSON"] = 2; + return values; + })(); + + return TaskLog; })(); - core.VariableMap = (function() { + core.QualityOfServiceSpec = (function() { /** - * Properties of a VariableMap. + * Properties of a QualityOfServiceSpec. * @memberof flyteidl.core - * @interface IVariableMap - * @property {Object.|null} [variables] VariableMap variables + * @interface IQualityOfServiceSpec + * @property {google.protobuf.IDuration|null} [queueingBudget] QualityOfServiceSpec queueingBudget */ /** - * Constructs a new VariableMap. + * Constructs a new QualityOfServiceSpec. * @memberof flyteidl.core - * @classdesc Represents a VariableMap. - * @implements IVariableMap + * @classdesc Represents a QualityOfServiceSpec. + * @implements IQualityOfServiceSpec * @constructor - * @param {flyteidl.core.IVariableMap=} [properties] Properties to set + * @param {flyteidl.core.IQualityOfServiceSpec=} [properties] Properties to set */ - function VariableMap(properties) { - this.variables = {}; + function QualityOfServiceSpec(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -7273,70 +7248,62 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * VariableMap variables. - * @member {Object.} variables - * @memberof flyteidl.core.VariableMap + * QualityOfServiceSpec queueingBudget. + * @member {google.protobuf.IDuration|null|undefined} queueingBudget + * @memberof flyteidl.core.QualityOfServiceSpec * @instance */ - VariableMap.prototype.variables = $util.emptyObject; + QualityOfServiceSpec.prototype.queueingBudget = null; /** - * Creates a new VariableMap instance using the specified properties. + * Creates a new QualityOfServiceSpec instance using the specified properties. * @function create - * @memberof flyteidl.core.VariableMap + * @memberof flyteidl.core.QualityOfServiceSpec * @static - * @param {flyteidl.core.IVariableMap=} [properties] Properties to set - * @returns {flyteidl.core.VariableMap} VariableMap instance + * @param {flyteidl.core.IQualityOfServiceSpec=} [properties] Properties to set + * @returns {flyteidl.core.QualityOfServiceSpec} QualityOfServiceSpec instance */ - VariableMap.create = function create(properties) { - return new VariableMap(properties); + QualityOfServiceSpec.create = function create(properties) { + return new QualityOfServiceSpec(properties); }; /** - * Encodes the specified VariableMap message. Does not implicitly {@link flyteidl.core.VariableMap.verify|verify} messages. + * Encodes the specified QualityOfServiceSpec message. Does not implicitly {@link flyteidl.core.QualityOfServiceSpec.verify|verify} messages. * @function encode - * @memberof flyteidl.core.VariableMap + * @memberof flyteidl.core.QualityOfServiceSpec * @static - * @param {flyteidl.core.IVariableMap} message VariableMap message or plain object to encode + * @param {flyteidl.core.IQualityOfServiceSpec} message QualityOfServiceSpec message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - VariableMap.encode = function encode(message, writer) { + QualityOfServiceSpec.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.variables != null && message.hasOwnProperty("variables")) - for (let keys = Object.keys(message.variables), i = 0; i < keys.length; ++i) { - writer.uint32(/* id 1, wireType 2 =*/10).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]); - $root.flyteidl.core.Variable.encode(message.variables[keys[i]], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim().ldelim(); - } + if (message.queueingBudget != null && message.hasOwnProperty("queueingBudget")) + $root.google.protobuf.Duration.encode(message.queueingBudget, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); return writer; }; /** - * Decodes a VariableMap message from the specified reader or buffer. + * Decodes a QualityOfServiceSpec message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.VariableMap + * @memberof flyteidl.core.QualityOfServiceSpec * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.VariableMap} VariableMap + * @returns {flyteidl.core.QualityOfServiceSpec} QualityOfServiceSpec * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - VariableMap.decode = function decode(reader, length) { + QualityOfServiceSpec.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.core.VariableMap(), key; + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.QualityOfServiceSpec(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - reader.skip().pos++; - if (message.variables === $util.emptyObject) - message.variables = {}; - key = reader.string(); - reader.pos++; - message.variables[key] = $root.flyteidl.core.Variable.decode(reader, reader.uint32()); + message.queueingBudget = $root.google.protobuf.Duration.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -7347,51 +7314,46 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a VariableMap message. + * Verifies a QualityOfServiceSpec message. * @function verify - * @memberof flyteidl.core.VariableMap + * @memberof flyteidl.core.QualityOfServiceSpec * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - VariableMap.verify = function verify(message) { + QualityOfServiceSpec.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.variables != null && message.hasOwnProperty("variables")) { - if (!$util.isObject(message.variables)) - return "variables: object expected"; - let key = Object.keys(message.variables); - for (let i = 0; i < key.length; ++i) { - let error = $root.flyteidl.core.Variable.verify(message.variables[key[i]]); - if (error) - return "variables." + error; - } + if (message.queueingBudget != null && message.hasOwnProperty("queueingBudget")) { + let error = $root.google.protobuf.Duration.verify(message.queueingBudget); + if (error) + return "queueingBudget." + error; } return null; }; - return VariableMap; + return QualityOfServiceSpec; })(); - core.TypedInterface = (function() { + core.QualityOfService = (function() { /** - * Properties of a TypedInterface. + * Properties of a QualityOfService. * @memberof flyteidl.core - * @interface ITypedInterface - * @property {flyteidl.core.IVariableMap|null} [inputs] TypedInterface inputs - * @property {flyteidl.core.IVariableMap|null} [outputs] TypedInterface outputs + * @interface IQualityOfService + * @property {flyteidl.core.QualityOfService.Tier|null} [tier] QualityOfService tier + * @property {flyteidl.core.IQualityOfServiceSpec|null} [spec] QualityOfService spec */ /** - * Constructs a new TypedInterface. + * Constructs a new QualityOfService. * @memberof flyteidl.core - * @classdesc Represents a TypedInterface. - * @implements ITypedInterface + * @classdesc Represents a QualityOfService. + * @implements IQualityOfService * @constructor - * @param {flyteidl.core.ITypedInterface=} [properties] Properties to set + * @param {flyteidl.core.IQualityOfService=} [properties] Properties to set */ - function TypedInterface(properties) { + function QualityOfService(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -7399,75 +7361,89 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * TypedInterface inputs. - * @member {flyteidl.core.IVariableMap|null|undefined} inputs - * @memberof flyteidl.core.TypedInterface + * QualityOfService tier. + * @member {flyteidl.core.QualityOfService.Tier} tier + * @memberof flyteidl.core.QualityOfService * @instance */ - TypedInterface.prototype.inputs = null; + QualityOfService.prototype.tier = 0; /** - * TypedInterface outputs. - * @member {flyteidl.core.IVariableMap|null|undefined} outputs - * @memberof flyteidl.core.TypedInterface + * QualityOfService spec. + * @member {flyteidl.core.IQualityOfServiceSpec|null|undefined} spec + * @memberof flyteidl.core.QualityOfService * @instance */ - TypedInterface.prototype.outputs = null; + QualityOfService.prototype.spec = null; + + // OneOf field names bound to virtual getters and setters + let $oneOfFields; /** - * Creates a new TypedInterface instance using the specified properties. + * QualityOfService designation. + * @member {"tier"|"spec"|undefined} designation + * @memberof flyteidl.core.QualityOfService + * @instance + */ + Object.defineProperty(QualityOfService.prototype, "designation", { + get: $util.oneOfGetter($oneOfFields = ["tier", "spec"]), + set: $util.oneOfSetter($oneOfFields) + }); + + /** + * Creates a new QualityOfService instance using the specified properties. * @function create - * @memberof flyteidl.core.TypedInterface + * @memberof flyteidl.core.QualityOfService * @static - * @param {flyteidl.core.ITypedInterface=} [properties] Properties to set - * @returns {flyteidl.core.TypedInterface} TypedInterface instance + * @param {flyteidl.core.IQualityOfService=} [properties] Properties to set + * @returns {flyteidl.core.QualityOfService} QualityOfService instance */ - TypedInterface.create = function create(properties) { - return new TypedInterface(properties); + QualityOfService.create = function create(properties) { + return new QualityOfService(properties); }; /** - * Encodes the specified TypedInterface message. Does not implicitly {@link flyteidl.core.TypedInterface.verify|verify} messages. + * Encodes the specified QualityOfService message. Does not implicitly {@link flyteidl.core.QualityOfService.verify|verify} messages. * @function encode - * @memberof flyteidl.core.TypedInterface + * @memberof flyteidl.core.QualityOfService * @static - * @param {flyteidl.core.ITypedInterface} message TypedInterface message or plain object to encode + * @param {flyteidl.core.IQualityOfService} message QualityOfService message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - TypedInterface.encode = function encode(message, writer) { + QualityOfService.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.inputs != null && message.hasOwnProperty("inputs")) - $root.flyteidl.core.VariableMap.encode(message.inputs, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); - if (message.outputs != null && message.hasOwnProperty("outputs")) - $root.flyteidl.core.VariableMap.encode(message.outputs, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.tier != null && message.hasOwnProperty("tier")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.tier); + if (message.spec != null && message.hasOwnProperty("spec")) + $root.flyteidl.core.QualityOfServiceSpec.encode(message.spec, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); return writer; }; /** - * Decodes a TypedInterface message from the specified reader or buffer. + * Decodes a QualityOfService message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.TypedInterface + * @memberof flyteidl.core.QualityOfService * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.TypedInterface} TypedInterface + * @returns {flyteidl.core.QualityOfService} QualityOfService * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - TypedInterface.decode = function decode(reader, length) { + QualityOfService.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.core.TypedInterface(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.QualityOfService(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.inputs = $root.flyteidl.core.VariableMap.decode(reader, reader.uint32()); + message.tier = reader.int32(); break; case 2: - message.outputs = $root.flyteidl.core.VariableMap.decode(reader, reader.uint32()); + message.spec = $root.flyteidl.core.QualityOfServiceSpec.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -7478,52 +7454,103 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a TypedInterface message. + * Verifies a QualityOfService message. * @function verify - * @memberof flyteidl.core.TypedInterface + * @memberof flyteidl.core.QualityOfService * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - TypedInterface.verify = function verify(message) { + QualityOfService.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.inputs != null && message.hasOwnProperty("inputs")) { - let error = $root.flyteidl.core.VariableMap.verify(message.inputs); - if (error) - return "inputs." + error; + let properties = {}; + if (message.tier != null && message.hasOwnProperty("tier")) { + properties.designation = 1; + switch (message.tier) { + default: + return "tier: enum value expected"; + case 0: + case 1: + case 2: + case 3: + break; + } } - if (message.outputs != null && message.hasOwnProperty("outputs")) { - let error = $root.flyteidl.core.VariableMap.verify(message.outputs); - if (error) - return "outputs." + error; + if (message.spec != null && message.hasOwnProperty("spec")) { + if (properties.designation === 1) + return "designation: multiple values"; + properties.designation = 1; + { + let error = $root.flyteidl.core.QualityOfServiceSpec.verify(message.spec); + if (error) + return "spec." + error; + } } return null; }; - return TypedInterface; + /** + * Tier enum. + * @name flyteidl.core.QualityOfService.Tier + * @enum {string} + * @property {number} UNDEFINED=0 UNDEFINED value + * @property {number} HIGH=1 HIGH value + * @property {number} MEDIUM=2 MEDIUM value + * @property {number} LOW=3 LOW value + */ + QualityOfService.Tier = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNDEFINED"] = 0; + values[valuesById[1] = "HIGH"] = 1; + values[valuesById[2] = "MEDIUM"] = 2; + values[valuesById[3] = "LOW"] = 3; + return values; + })(); + + return QualityOfService; })(); - core.Parameter = (function() { + /** + * ResourceType enum. + * @name flyteidl.core.ResourceType + * @enum {string} + * @property {number} UNSPECIFIED=0 UNSPECIFIED value + * @property {number} TASK=1 TASK value + * @property {number} WORKFLOW=2 WORKFLOW value + * @property {number} LAUNCH_PLAN=3 LAUNCH_PLAN value + */ + core.ResourceType = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNSPECIFIED"] = 0; + values[valuesById[1] = "TASK"] = 1; + values[valuesById[2] = "WORKFLOW"] = 2; + values[valuesById[3] = "LAUNCH_PLAN"] = 3; + return values; + })(); + + core.Identifier = (function() { /** - * Properties of a Parameter. + * Properties of an Identifier. * @memberof flyteidl.core - * @interface IParameter - * @property {flyteidl.core.IVariable|null} ["var"] Parameter var - * @property {flyteidl.core.ILiteral|null} ["default"] Parameter default - * @property {boolean|null} [required] Parameter required + * @interface IIdentifier + * @property {flyteidl.core.ResourceType|null} [resourceType] Identifier resourceType + * @property {string|null} [project] Identifier project + * @property {string|null} [domain] Identifier domain + * @property {string|null} [name] Identifier name + * @property {string|null} [version] Identifier version */ /** - * Constructs a new Parameter. + * Constructs a new Identifier. * @memberof flyteidl.core - * @classdesc Represents a Parameter. - * @implements IParameter + * @classdesc Represents an Identifier. + * @implements IIdentifier * @constructor - * @param {flyteidl.core.IParameter=} [properties] Properties to set + * @param {flyteidl.core.IIdentifier=} [properties] Properties to set */ - function Parameter(properties) { + function Identifier(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -7531,102 +7558,114 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * Parameter var. - * @member {flyteidl.core.IVariable|null|undefined} var - * @memberof flyteidl.core.Parameter + * Identifier resourceType. + * @member {flyteidl.core.ResourceType} resourceType + * @memberof flyteidl.core.Identifier * @instance */ - Parameter.prototype["var"] = null; + Identifier.prototype.resourceType = 0; /** - * Parameter default. - * @member {flyteidl.core.ILiteral|null|undefined} default - * @memberof flyteidl.core.Parameter + * Identifier project. + * @member {string} project + * @memberof flyteidl.core.Identifier * @instance */ - Parameter.prototype["default"] = null; + Identifier.prototype.project = ""; /** - * Parameter required. - * @member {boolean} required - * @memberof flyteidl.core.Parameter + * Identifier domain. + * @member {string} domain + * @memberof flyteidl.core.Identifier * @instance */ - Parameter.prototype.required = false; + Identifier.prototype.domain = ""; - // OneOf field names bound to virtual getters and setters - let $oneOfFields; + /** + * Identifier name. + * @member {string} name + * @memberof flyteidl.core.Identifier + * @instance + */ + Identifier.prototype.name = ""; /** - * Parameter behavior. - * @member {"default"|"required"|undefined} behavior - * @memberof flyteidl.core.Parameter + * Identifier version. + * @member {string} version + * @memberof flyteidl.core.Identifier * @instance */ - Object.defineProperty(Parameter.prototype, "behavior", { - get: $util.oneOfGetter($oneOfFields = ["default", "required"]), - set: $util.oneOfSetter($oneOfFields) - }); + Identifier.prototype.version = ""; /** - * Creates a new Parameter instance using the specified properties. + * Creates a new Identifier instance using the specified properties. * @function create - * @memberof flyteidl.core.Parameter + * @memberof flyteidl.core.Identifier * @static - * @param {flyteidl.core.IParameter=} [properties] Properties to set - * @returns {flyteidl.core.Parameter} Parameter instance + * @param {flyteidl.core.IIdentifier=} [properties] Properties to set + * @returns {flyteidl.core.Identifier} Identifier instance */ - Parameter.create = function create(properties) { - return new Parameter(properties); + Identifier.create = function create(properties) { + return new Identifier(properties); }; /** - * Encodes the specified Parameter message. Does not implicitly {@link flyteidl.core.Parameter.verify|verify} messages. + * Encodes the specified Identifier message. Does not implicitly {@link flyteidl.core.Identifier.verify|verify} messages. * @function encode - * @memberof flyteidl.core.Parameter + * @memberof flyteidl.core.Identifier * @static - * @param {flyteidl.core.IParameter} message Parameter message or plain object to encode + * @param {flyteidl.core.IIdentifier} message Identifier message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - Parameter.encode = function encode(message, writer) { + Identifier.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message["var"] != null && message.hasOwnProperty("var")) - $root.flyteidl.core.Variable.encode(message["var"], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); - if (message["default"] != null && message.hasOwnProperty("default")) - $root.flyteidl.core.Literal.encode(message["default"], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); - if (message.required != null && message.hasOwnProperty("required")) - writer.uint32(/* id 3, wireType 0 =*/24).bool(message.required); + if (message.resourceType != null && message.hasOwnProperty("resourceType")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.resourceType); + if (message.project != null && message.hasOwnProperty("project")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.project); + if (message.domain != null && message.hasOwnProperty("domain")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.domain); + if (message.name != null && message.hasOwnProperty("name")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.name); + if (message.version != null && message.hasOwnProperty("version")) + writer.uint32(/* id 5, wireType 2 =*/42).string(message.version); return writer; }; /** - * Decodes a Parameter message from the specified reader or buffer. + * Decodes an Identifier message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.Parameter + * @memberof flyteidl.core.Identifier * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.Parameter} Parameter + * @returns {flyteidl.core.Identifier} Identifier * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - Parameter.decode = function decode(reader, length) { + Identifier.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.core.Parameter(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.Identifier(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message["var"] = $root.flyteidl.core.Variable.decode(reader, reader.uint32()); + message.resourceType = reader.int32(); break; case 2: - message["default"] = $root.flyteidl.core.Literal.decode(reader, reader.uint32()); + message.project = reader.string(); break; case 3: - message.required = reader.bool(); + message.domain = reader.string(); + break; + case 4: + message.name = reader.string(); + break; + case 5: + message.version = reader.string(); break; default: reader.skipType(tag & 7); @@ -7637,62 +7676,64 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a Parameter message. + * Verifies an Identifier message. * @function verify - * @memberof flyteidl.core.Parameter + * @memberof flyteidl.core.Identifier * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - Parameter.verify = function verify(message) { + Identifier.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - let properties = {}; - if (message["var"] != null && message.hasOwnProperty("var")) { - let error = $root.flyteidl.core.Variable.verify(message["var"]); - if (error) - return "var." + error; - } - if (message["default"] != null && message.hasOwnProperty("default")) { - properties.behavior = 1; - { - let error = $root.flyteidl.core.Literal.verify(message["default"]); - if (error) - return "default." + error; + if (message.resourceType != null && message.hasOwnProperty("resourceType")) + switch (message.resourceType) { + default: + return "resourceType: enum value expected"; + case 0: + case 1: + case 2: + case 3: + break; } - } - if (message.required != null && message.hasOwnProperty("required")) { - if (properties.behavior === 1) - return "behavior: multiple values"; - properties.behavior = 1; - if (typeof message.required !== "boolean") - return "required: boolean expected"; - } + if (message.project != null && message.hasOwnProperty("project")) + if (!$util.isString(message.project)) + return "project: string expected"; + if (message.domain != null && message.hasOwnProperty("domain")) + if (!$util.isString(message.domain)) + return "domain: string expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.version != null && message.hasOwnProperty("version")) + if (!$util.isString(message.version)) + return "version: string expected"; return null; }; - return Parameter; + return Identifier; })(); - core.ParameterMap = (function() { + core.WorkflowExecutionIdentifier = (function() { /** - * Properties of a ParameterMap. + * Properties of a WorkflowExecutionIdentifier. * @memberof flyteidl.core - * @interface IParameterMap - * @property {Object.|null} [parameters] ParameterMap parameters + * @interface IWorkflowExecutionIdentifier + * @property {string|null} [project] WorkflowExecutionIdentifier project + * @property {string|null} [domain] WorkflowExecutionIdentifier domain + * @property {string|null} [name] WorkflowExecutionIdentifier name */ /** - * Constructs a new ParameterMap. + * Constructs a new WorkflowExecutionIdentifier. * @memberof flyteidl.core - * @classdesc Represents a ParameterMap. - * @implements IParameterMap + * @classdesc Represents a WorkflowExecutionIdentifier. + * @implements IWorkflowExecutionIdentifier * @constructor - * @param {flyteidl.core.IParameterMap=} [properties] Properties to set + * @param {flyteidl.core.IWorkflowExecutionIdentifier=} [properties] Properties to set */ - function ParameterMap(properties) { - this.parameters = {}; + function WorkflowExecutionIdentifier(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -7700,70 +7741,88 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * ParameterMap parameters. - * @member {Object.} parameters - * @memberof flyteidl.core.ParameterMap + * WorkflowExecutionIdentifier project. + * @member {string} project + * @memberof flyteidl.core.WorkflowExecutionIdentifier * @instance */ - ParameterMap.prototype.parameters = $util.emptyObject; + WorkflowExecutionIdentifier.prototype.project = ""; /** - * Creates a new ParameterMap instance using the specified properties. + * WorkflowExecutionIdentifier domain. + * @member {string} domain + * @memberof flyteidl.core.WorkflowExecutionIdentifier + * @instance + */ + WorkflowExecutionIdentifier.prototype.domain = ""; + + /** + * WorkflowExecutionIdentifier name. + * @member {string} name + * @memberof flyteidl.core.WorkflowExecutionIdentifier + * @instance + */ + WorkflowExecutionIdentifier.prototype.name = ""; + + /** + * Creates a new WorkflowExecutionIdentifier instance using the specified properties. * @function create - * @memberof flyteidl.core.ParameterMap + * @memberof flyteidl.core.WorkflowExecutionIdentifier * @static - * @param {flyteidl.core.IParameterMap=} [properties] Properties to set - * @returns {flyteidl.core.ParameterMap} ParameterMap instance + * @param {flyteidl.core.IWorkflowExecutionIdentifier=} [properties] Properties to set + * @returns {flyteidl.core.WorkflowExecutionIdentifier} WorkflowExecutionIdentifier instance */ - ParameterMap.create = function create(properties) { - return new ParameterMap(properties); + WorkflowExecutionIdentifier.create = function create(properties) { + return new WorkflowExecutionIdentifier(properties); }; /** - * Encodes the specified ParameterMap message. Does not implicitly {@link flyteidl.core.ParameterMap.verify|verify} messages. + * Encodes the specified WorkflowExecutionIdentifier message. Does not implicitly {@link flyteidl.core.WorkflowExecutionIdentifier.verify|verify} messages. * @function encode - * @memberof flyteidl.core.ParameterMap + * @memberof flyteidl.core.WorkflowExecutionIdentifier * @static - * @param {flyteidl.core.IParameterMap} message ParameterMap message or plain object to encode + * @param {flyteidl.core.IWorkflowExecutionIdentifier} message WorkflowExecutionIdentifier message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - ParameterMap.encode = function encode(message, writer) { + WorkflowExecutionIdentifier.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.parameters != null && message.hasOwnProperty("parameters")) - for (let keys = Object.keys(message.parameters), i = 0; i < keys.length; ++i) { - writer.uint32(/* id 1, wireType 2 =*/10).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]); - $root.flyteidl.core.Parameter.encode(message.parameters[keys[i]], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim().ldelim(); - } + if (message.project != null && message.hasOwnProperty("project")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.project); + if (message.domain != null && message.hasOwnProperty("domain")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.domain); + if (message.name != null && message.hasOwnProperty("name")) + writer.uint32(/* id 4, wireType 2 =*/34).string(message.name); return writer; }; /** - * Decodes a ParameterMap message from the specified reader or buffer. + * Decodes a WorkflowExecutionIdentifier message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.ParameterMap + * @memberof flyteidl.core.WorkflowExecutionIdentifier * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.ParameterMap} ParameterMap + * @returns {flyteidl.core.WorkflowExecutionIdentifier} WorkflowExecutionIdentifier * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - ParameterMap.decode = function decode(reader, length) { + WorkflowExecutionIdentifier.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.core.ParameterMap(), key; + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.WorkflowExecutionIdentifier(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - reader.skip().pos++; - if (message.parameters === $util.emptyObject) - message.parameters = {}; - key = reader.string(); - reader.pos++; - message.parameters[key] = $root.flyteidl.core.Parameter.decode(reader, reader.uint32()); + message.project = reader.string(); + break; + case 2: + message.domain = reader.string(); + break; + case 4: + message.name = reader.string(); break; default: reader.skipType(tag & 7); @@ -7774,53 +7833,50 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a ParameterMap message. + * Verifies a WorkflowExecutionIdentifier message. * @function verify - * @memberof flyteidl.core.ParameterMap + * @memberof flyteidl.core.WorkflowExecutionIdentifier * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - ParameterMap.verify = function verify(message) { + WorkflowExecutionIdentifier.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.parameters != null && message.hasOwnProperty("parameters")) { - if (!$util.isObject(message.parameters)) - return "parameters: object expected"; - let key = Object.keys(message.parameters); - for (let i = 0; i < key.length; ++i) { - let error = $root.flyteidl.core.Parameter.verify(message.parameters[key[i]]); - if (error) - return "parameters." + error; - } - } + if (message.project != null && message.hasOwnProperty("project")) + if (!$util.isString(message.project)) + return "project: string expected"; + if (message.domain != null && message.hasOwnProperty("domain")) + if (!$util.isString(message.domain)) + return "domain: string expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; return null; }; - return ParameterMap; + return WorkflowExecutionIdentifier; })(); - core.Resources = (function() { + core.NodeExecutionIdentifier = (function() { /** - * Properties of a Resources. + * Properties of a NodeExecutionIdentifier. * @memberof flyteidl.core - * @interface IResources - * @property {Array.|null} [requests] Resources requests - * @property {Array.|null} [limits] Resources limits + * @interface INodeExecutionIdentifier + * @property {string|null} [nodeId] NodeExecutionIdentifier nodeId + * @property {flyteidl.core.IWorkflowExecutionIdentifier|null} [executionId] NodeExecutionIdentifier executionId */ /** - * Constructs a new Resources. + * Constructs a new NodeExecutionIdentifier. * @memberof flyteidl.core - * @classdesc Represents a Resources. - * @implements IResources + * @classdesc Represents a NodeExecutionIdentifier. + * @implements INodeExecutionIdentifier * @constructor - * @param {flyteidl.core.IResources=} [properties] Properties to set + * @param {flyteidl.core.INodeExecutionIdentifier=} [properties] Properties to set */ - function Resources(properties) { - this.requests = []; - this.limits = []; + function NodeExecutionIdentifier(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -7828,81 +7884,75 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * Resources requests. - * @member {Array.} requests - * @memberof flyteidl.core.Resources + * NodeExecutionIdentifier nodeId. + * @member {string} nodeId + * @memberof flyteidl.core.NodeExecutionIdentifier * @instance */ - Resources.prototype.requests = $util.emptyArray; + NodeExecutionIdentifier.prototype.nodeId = ""; /** - * Resources limits. - * @member {Array.} limits - * @memberof flyteidl.core.Resources + * NodeExecutionIdentifier executionId. + * @member {flyteidl.core.IWorkflowExecutionIdentifier|null|undefined} executionId + * @memberof flyteidl.core.NodeExecutionIdentifier * @instance */ - Resources.prototype.limits = $util.emptyArray; + NodeExecutionIdentifier.prototype.executionId = null; /** - * Creates a new Resources instance using the specified properties. + * Creates a new NodeExecutionIdentifier instance using the specified properties. * @function create - * @memberof flyteidl.core.Resources + * @memberof flyteidl.core.NodeExecutionIdentifier * @static - * @param {flyteidl.core.IResources=} [properties] Properties to set - * @returns {flyteidl.core.Resources} Resources instance + * @param {flyteidl.core.INodeExecutionIdentifier=} [properties] Properties to set + * @returns {flyteidl.core.NodeExecutionIdentifier} NodeExecutionIdentifier instance */ - Resources.create = function create(properties) { - return new Resources(properties); + NodeExecutionIdentifier.create = function create(properties) { + return new NodeExecutionIdentifier(properties); }; /** - * Encodes the specified Resources message. Does not implicitly {@link flyteidl.core.Resources.verify|verify} messages. + * Encodes the specified NodeExecutionIdentifier message. Does not implicitly {@link flyteidl.core.NodeExecutionIdentifier.verify|verify} messages. * @function encode - * @memberof flyteidl.core.Resources + * @memberof flyteidl.core.NodeExecutionIdentifier * @static - * @param {flyteidl.core.IResources} message Resources message or plain object to encode + * @param {flyteidl.core.INodeExecutionIdentifier} message NodeExecutionIdentifier message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - Resources.encode = function encode(message, writer) { + NodeExecutionIdentifier.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.requests != null && message.requests.length) - for (let i = 0; i < message.requests.length; ++i) - $root.flyteidl.core.Resources.ResourceEntry.encode(message.requests[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); - if (message.limits != null && message.limits.length) - for (let i = 0; i < message.limits.length; ++i) - $root.flyteidl.core.Resources.ResourceEntry.encode(message.limits[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); - return writer; - }; - + if (message.nodeId != null && message.hasOwnProperty("nodeId")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.nodeId); + if (message.executionId != null && message.hasOwnProperty("executionId")) + $root.flyteidl.core.WorkflowExecutionIdentifier.encode(message.executionId, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + return writer; + }; + /** - * Decodes a Resources message from the specified reader or buffer. + * Decodes a NodeExecutionIdentifier message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.Resources + * @memberof flyteidl.core.NodeExecutionIdentifier * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.Resources} Resources + * @returns {flyteidl.core.NodeExecutionIdentifier} NodeExecutionIdentifier * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - Resources.decode = function decode(reader, length) { + NodeExecutionIdentifier.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.core.Resources(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.NodeExecutionIdentifier(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - if (!(message.requests && message.requests.length)) - message.requests = []; - message.requests.push($root.flyteidl.core.Resources.ResourceEntry.decode(reader, reader.uint32())); + message.nodeId = reader.string(); break; case 2: - if (!(message.limits && message.limits.length)) - message.limits = []; - message.limits.push($root.flyteidl.core.Resources.ResourceEntry.decode(reader, reader.uint32())); + message.executionId = $root.flyteidl.core.WorkflowExecutionIdentifier.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -7913,215 +7963,197 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a Resources message. + * Verifies a NodeExecutionIdentifier message. * @function verify - * @memberof flyteidl.core.Resources + * @memberof flyteidl.core.NodeExecutionIdentifier * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - Resources.verify = function verify(message) { + NodeExecutionIdentifier.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.requests != null && message.hasOwnProperty("requests")) { - if (!Array.isArray(message.requests)) - return "requests: array expected"; - for (let i = 0; i < message.requests.length; ++i) { - let error = $root.flyteidl.core.Resources.ResourceEntry.verify(message.requests[i]); - if (error) - return "requests." + error; - } - } - if (message.limits != null && message.hasOwnProperty("limits")) { - if (!Array.isArray(message.limits)) - return "limits: array expected"; - for (let i = 0; i < message.limits.length; ++i) { - let error = $root.flyteidl.core.Resources.ResourceEntry.verify(message.limits[i]); - if (error) - return "limits." + error; - } + if (message.nodeId != null && message.hasOwnProperty("nodeId")) + if (!$util.isString(message.nodeId)) + return "nodeId: string expected"; + if (message.executionId != null && message.hasOwnProperty("executionId")) { + let error = $root.flyteidl.core.WorkflowExecutionIdentifier.verify(message.executionId); + if (error) + return "executionId." + error; } return null; }; + return NodeExecutionIdentifier; + })(); + + core.TaskExecutionIdentifier = (function() { + /** - * ResourceName enum. - * @name flyteidl.core.Resources.ResourceName - * @enum {string} - * @property {number} UNKNOWN=0 UNKNOWN value - * @property {number} CPU=1 CPU value - * @property {number} GPU=2 GPU value - * @property {number} MEMORY=3 MEMORY value - * @property {number} STORAGE=4 STORAGE value + * Properties of a TaskExecutionIdentifier. + * @memberof flyteidl.core + * @interface ITaskExecutionIdentifier + * @property {flyteidl.core.IIdentifier|null} [taskId] TaskExecutionIdentifier taskId + * @property {flyteidl.core.INodeExecutionIdentifier|null} [nodeExecutionId] TaskExecutionIdentifier nodeExecutionId + * @property {number|null} [retryAttempt] TaskExecutionIdentifier retryAttempt */ - Resources.ResourceName = (function() { - const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "UNKNOWN"] = 0; - values[valuesById[1] = "CPU"] = 1; - values[valuesById[2] = "GPU"] = 2; - values[valuesById[3] = "MEMORY"] = 3; - values[valuesById[4] = "STORAGE"] = 4; - return values; - })(); - - Resources.ResourceEntry = (function() { - /** - * Properties of a ResourceEntry. - * @memberof flyteidl.core.Resources - * @interface IResourceEntry - * @property {flyteidl.core.Resources.ResourceName|null} [name] ResourceEntry name - * @property {string|null} [value] ResourceEntry value - */ + /** + * Constructs a new TaskExecutionIdentifier. + * @memberof flyteidl.core + * @classdesc Represents a TaskExecutionIdentifier. + * @implements ITaskExecutionIdentifier + * @constructor + * @param {flyteidl.core.ITaskExecutionIdentifier=} [properties] Properties to set + */ + function TaskExecutionIdentifier(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]]; + } - /** - * Constructs a new ResourceEntry. - * @memberof flyteidl.core.Resources - * @classdesc Represents a ResourceEntry. - * @implements IResourceEntry - * @constructor - * @param {flyteidl.core.Resources.IResourceEntry=} [properties] Properties to set - */ - function ResourceEntry(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]]; - } + /** + * TaskExecutionIdentifier taskId. + * @member {flyteidl.core.IIdentifier|null|undefined} taskId + * @memberof flyteidl.core.TaskExecutionIdentifier + * @instance + */ + TaskExecutionIdentifier.prototype.taskId = null; - /** - * ResourceEntry name. - * @member {flyteidl.core.Resources.ResourceName} name - * @memberof flyteidl.core.Resources.ResourceEntry - * @instance - */ - ResourceEntry.prototype.name = 0; + /** + * TaskExecutionIdentifier nodeExecutionId. + * @member {flyteidl.core.INodeExecutionIdentifier|null|undefined} nodeExecutionId + * @memberof flyteidl.core.TaskExecutionIdentifier + * @instance + */ + TaskExecutionIdentifier.prototype.nodeExecutionId = null; - /** - * ResourceEntry value. - * @member {string} value - * @memberof flyteidl.core.Resources.ResourceEntry - * @instance - */ - ResourceEntry.prototype.value = ""; + /** + * TaskExecutionIdentifier retryAttempt. + * @member {number} retryAttempt + * @memberof flyteidl.core.TaskExecutionIdentifier + * @instance + */ + TaskExecutionIdentifier.prototype.retryAttempt = 0; - /** - * Creates a new ResourceEntry instance using the specified properties. - * @function create - * @memberof flyteidl.core.Resources.ResourceEntry - * @static - * @param {flyteidl.core.Resources.IResourceEntry=} [properties] Properties to set - * @returns {flyteidl.core.Resources.ResourceEntry} ResourceEntry instance - */ - ResourceEntry.create = function create(properties) { - return new ResourceEntry(properties); - }; + /** + * Creates a new TaskExecutionIdentifier instance using the specified properties. + * @function create + * @memberof flyteidl.core.TaskExecutionIdentifier + * @static + * @param {flyteidl.core.ITaskExecutionIdentifier=} [properties] Properties to set + * @returns {flyteidl.core.TaskExecutionIdentifier} TaskExecutionIdentifier instance + */ + TaskExecutionIdentifier.create = function create(properties) { + return new TaskExecutionIdentifier(properties); + }; - /** - * Encodes the specified ResourceEntry message. Does not implicitly {@link flyteidl.core.Resources.ResourceEntry.verify|verify} messages. - * @function encode - * @memberof flyteidl.core.Resources.ResourceEntry - * @static - * @param {flyteidl.core.Resources.IResourceEntry} message ResourceEntry message or plain object to encode - * @param {$protobuf.Writer} [writer] Writer to encode to - * @returns {$protobuf.Writer} Writer - */ - ResourceEntry.encode = function encode(message, writer) { - if (!writer) - writer = $Writer.create(); - if (message.name != null && message.hasOwnProperty("name")) - writer.uint32(/* id 1, wireType 0 =*/8).int32(message.name); - if (message.value != null && message.hasOwnProperty("value")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.value); - return writer; - }; + /** + * Encodes the specified TaskExecutionIdentifier message. Does not implicitly {@link flyteidl.core.TaskExecutionIdentifier.verify|verify} messages. + * @function encode + * @memberof flyteidl.core.TaskExecutionIdentifier + * @static + * @param {flyteidl.core.ITaskExecutionIdentifier} message TaskExecutionIdentifier message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + TaskExecutionIdentifier.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.taskId != null && message.hasOwnProperty("taskId")) + $root.flyteidl.core.Identifier.encode(message.taskId, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.nodeExecutionId != null && message.hasOwnProperty("nodeExecutionId")) + $root.flyteidl.core.NodeExecutionIdentifier.encode(message.nodeExecutionId, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.retryAttempt != null && message.hasOwnProperty("retryAttempt")) + writer.uint32(/* id 3, wireType 0 =*/24).uint32(message.retryAttempt); + return writer; + }; - /** - * Decodes a ResourceEntry message from the specified reader or buffer. - * @function decode - * @memberof flyteidl.core.Resources.ResourceEntry - * @static - * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from - * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.Resources.ResourceEntry} ResourceEntry - * @throws {Error} If the payload is not a reader or valid buffer - * @throws {$protobuf.util.ProtocolError} If required fields are missing - */ - ResourceEntry.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.core.Resources.ResourceEntry(); - while (reader.pos < end) { - let tag = reader.uint32(); - switch (tag >>> 3) { - case 1: - message.name = reader.int32(); - break; - case 2: - message.value = reader.string(); - break; - default: - reader.skipType(tag & 7); - break; - } + /** + * Decodes a TaskExecutionIdentifier message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.core.TaskExecutionIdentifier + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.core.TaskExecutionIdentifier} TaskExecutionIdentifier + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + TaskExecutionIdentifier.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.core.TaskExecutionIdentifier(); + while (reader.pos < end) { + let tag = reader.uint32(); + switch (tag >>> 3) { + case 1: + message.taskId = $root.flyteidl.core.Identifier.decode(reader, reader.uint32()); + break; + case 2: + message.nodeExecutionId = $root.flyteidl.core.NodeExecutionIdentifier.decode(reader, reader.uint32()); + break; + case 3: + message.retryAttempt = reader.uint32(); + break; + default: + reader.skipType(tag & 7); + break; } - return message; - }; - - /** - * Verifies a ResourceEntry message. - * @function verify - * @memberof flyteidl.core.Resources.ResourceEntry - * @static - * @param {Object.} message Plain object to verify - * @returns {string|null} `null` if valid, otherwise the reason why it is not - */ - ResourceEntry.verify = function verify(message) { - if (typeof message !== "object" || message === null) - return "object expected"; - if (message.name != null && message.hasOwnProperty("name")) - switch (message.name) { - default: - return "name: enum value expected"; - case 0: - case 1: - case 2: - case 3: - case 4: - break; - } - if (message.value != null && message.hasOwnProperty("value")) - if (!$util.isString(message.value)) - return "value: string expected"; - return null; - }; + } + return message; + }; - return ResourceEntry; - })(); + /** + * Verifies a TaskExecutionIdentifier message. + * @function verify + * @memberof flyteidl.core.TaskExecutionIdentifier + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + TaskExecutionIdentifier.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.taskId != null && message.hasOwnProperty("taskId")) { + let error = $root.flyteidl.core.Identifier.verify(message.taskId); + if (error) + return "taskId." + error; + } + if (message.nodeExecutionId != null && message.hasOwnProperty("nodeExecutionId")) { + let error = $root.flyteidl.core.NodeExecutionIdentifier.verify(message.nodeExecutionId); + if (error) + return "nodeExecutionId." + error; + } + if (message.retryAttempt != null && message.hasOwnProperty("retryAttempt")) + if (!$util.isInteger(message.retryAttempt)) + return "retryAttempt: integer expected"; + return null; + }; - return Resources; + return TaskExecutionIdentifier; })(); - core.RuntimeMetadata = (function() { + core.Variable = (function() { /** - * Properties of a RuntimeMetadata. + * Properties of a Variable. * @memberof flyteidl.core - * @interface IRuntimeMetadata - * @property {flyteidl.core.RuntimeMetadata.RuntimeType|null} [type] RuntimeMetadata type - * @property {string|null} [version] RuntimeMetadata version - * @property {string|null} [flavor] RuntimeMetadata flavor + * @interface IVariable + * @property {flyteidl.core.ILiteralType|null} [type] Variable type + * @property {string|null} [description] Variable description */ /** - * Constructs a new RuntimeMetadata. + * Constructs a new Variable. * @memberof flyteidl.core - * @classdesc Represents a RuntimeMetadata. - * @implements IRuntimeMetadata + * @classdesc Represents a Variable. + * @implements IVariable * @constructor - * @param {flyteidl.core.IRuntimeMetadata=} [properties] Properties to set + * @param {flyteidl.core.IVariable=} [properties] Properties to set */ - function RuntimeMetadata(properties) { + function Variable(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -8129,88 +8161,75 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * RuntimeMetadata type. - * @member {flyteidl.core.RuntimeMetadata.RuntimeType} type - * @memberof flyteidl.core.RuntimeMetadata - * @instance - */ - RuntimeMetadata.prototype.type = 0; - - /** - * RuntimeMetadata version. - * @member {string} version - * @memberof flyteidl.core.RuntimeMetadata + * Variable type. + * @member {flyteidl.core.ILiteralType|null|undefined} type + * @memberof flyteidl.core.Variable * @instance */ - RuntimeMetadata.prototype.version = ""; + Variable.prototype.type = null; /** - * RuntimeMetadata flavor. - * @member {string} flavor - * @memberof flyteidl.core.RuntimeMetadata + * Variable description. + * @member {string} description + * @memberof flyteidl.core.Variable * @instance */ - RuntimeMetadata.prototype.flavor = ""; + Variable.prototype.description = ""; /** - * Creates a new RuntimeMetadata instance using the specified properties. + * Creates a new Variable instance using the specified properties. * @function create - * @memberof flyteidl.core.RuntimeMetadata + * @memberof flyteidl.core.Variable * @static - * @param {flyteidl.core.IRuntimeMetadata=} [properties] Properties to set - * @returns {flyteidl.core.RuntimeMetadata} RuntimeMetadata instance + * @param {flyteidl.core.IVariable=} [properties] Properties to set + * @returns {flyteidl.core.Variable} Variable instance */ - RuntimeMetadata.create = function create(properties) { - return new RuntimeMetadata(properties); + Variable.create = function create(properties) { + return new Variable(properties); }; /** - * Encodes the specified RuntimeMetadata message. Does not implicitly {@link flyteidl.core.RuntimeMetadata.verify|verify} messages. + * Encodes the specified Variable message. Does not implicitly {@link flyteidl.core.Variable.verify|verify} messages. * @function encode - * @memberof flyteidl.core.RuntimeMetadata + * @memberof flyteidl.core.Variable * @static - * @param {flyteidl.core.IRuntimeMetadata} message RuntimeMetadata message or plain object to encode + * @param {flyteidl.core.IVariable} message Variable message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - RuntimeMetadata.encode = function encode(message, writer) { + Variable.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); if (message.type != null && message.hasOwnProperty("type")) - writer.uint32(/* id 1, wireType 0 =*/8).int32(message.type); - if (message.version != null && message.hasOwnProperty("version")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.version); - if (message.flavor != null && message.hasOwnProperty("flavor")) - writer.uint32(/* id 3, wireType 2 =*/26).string(message.flavor); + $root.flyteidl.core.LiteralType.encode(message.type, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.description != null && message.hasOwnProperty("description")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.description); return writer; }; /** - * Decodes a RuntimeMetadata message from the specified reader or buffer. + * Decodes a Variable message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.RuntimeMetadata + * @memberof flyteidl.core.Variable * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.RuntimeMetadata} RuntimeMetadata + * @returns {flyteidl.core.Variable} Variable * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - RuntimeMetadata.decode = function decode(reader, length) { + Variable.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.core.RuntimeMetadata(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.Variable(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.type = reader.int32(); + message.type = $root.flyteidl.core.LiteralType.decode(reader, reader.uint32()); break; case 2: - message.version = reader.string(); - break; - case 3: - message.flavor = reader.string(); + message.description = reader.string(); break; default: reader.skipType(tag & 7); @@ -8221,74 +8240,175 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a RuntimeMetadata message. + * Verifies a Variable message. * @function verify - * @memberof flyteidl.core.RuntimeMetadata + * @memberof flyteidl.core.Variable * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - RuntimeMetadata.verify = function verify(message) { + Variable.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.type != null && message.hasOwnProperty("type")) - switch (message.type) { - default: - return "type: enum value expected"; - case 0: + if (message.type != null && message.hasOwnProperty("type")) { + let error = $root.flyteidl.core.LiteralType.verify(message.type); + if (error) + return "type." + error; + } + if (message.description != null && message.hasOwnProperty("description")) + if (!$util.isString(message.description)) + return "description: string expected"; + return null; + }; + + return Variable; + })(); + + core.VariableMap = (function() { + + /** + * Properties of a VariableMap. + * @memberof flyteidl.core + * @interface IVariableMap + * @property {Object.|null} [variables] VariableMap variables + */ + + /** + * Constructs a new VariableMap. + * @memberof flyteidl.core + * @classdesc Represents a VariableMap. + * @implements IVariableMap + * @constructor + * @param {flyteidl.core.IVariableMap=} [properties] Properties to set + */ + function VariableMap(properties) { + this.variables = {}; + 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]]; + } + + /** + * VariableMap variables. + * @member {Object.} variables + * @memberof flyteidl.core.VariableMap + * @instance + */ + VariableMap.prototype.variables = $util.emptyObject; + + /** + * Creates a new VariableMap instance using the specified properties. + * @function create + * @memberof flyteidl.core.VariableMap + * @static + * @param {flyteidl.core.IVariableMap=} [properties] Properties to set + * @returns {flyteidl.core.VariableMap} VariableMap instance + */ + VariableMap.create = function create(properties) { + return new VariableMap(properties); + }; + + /** + * Encodes the specified VariableMap message. Does not implicitly {@link flyteidl.core.VariableMap.verify|verify} messages. + * @function encode + * @memberof flyteidl.core.VariableMap + * @static + * @param {flyteidl.core.IVariableMap} message VariableMap message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + VariableMap.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.variables != null && message.hasOwnProperty("variables")) + for (let keys = Object.keys(message.variables), i = 0; i < keys.length; ++i) { + writer.uint32(/* id 1, wireType 2 =*/10).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]); + $root.flyteidl.core.Variable.encode(message.variables[keys[i]], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim().ldelim(); + } + return writer; + }; + + /** + * Decodes a VariableMap message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.core.VariableMap + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.core.VariableMap} VariableMap + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + VariableMap.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.core.VariableMap(), key; + while (reader.pos < end) { + let tag = reader.uint32(); + switch (tag >>> 3) { case 1: + reader.skip().pos++; + if (message.variables === $util.emptyObject) + message.variables = {}; + key = reader.string(); + reader.pos++; + message.variables[key] = $root.flyteidl.core.Variable.decode(reader, reader.uint32()); + break; + default: + reader.skipType(tag & 7); break; } - if (message.version != null && message.hasOwnProperty("version")) - if (!$util.isString(message.version)) - return "version: string expected"; - if (message.flavor != null && message.hasOwnProperty("flavor")) - if (!$util.isString(message.flavor)) - return "flavor: string expected"; - return null; + } + return message; }; /** - * RuntimeType enum. - * @name flyteidl.core.RuntimeMetadata.RuntimeType - * @enum {string} - * @property {number} OTHER=0 OTHER value - * @property {number} FLYTE_SDK=1 FLYTE_SDK value + * Verifies a VariableMap message. + * @function verify + * @memberof flyteidl.core.VariableMap + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - RuntimeMetadata.RuntimeType = (function() { - const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "OTHER"] = 0; - values[valuesById[1] = "FLYTE_SDK"] = 1; - return values; - })(); + VariableMap.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.variables != null && message.hasOwnProperty("variables")) { + if (!$util.isObject(message.variables)) + return "variables: object expected"; + let key = Object.keys(message.variables); + for (let i = 0; i < key.length; ++i) { + let error = $root.flyteidl.core.Variable.verify(message.variables[key[i]]); + if (error) + return "variables." + error; + } + } + return null; + }; - return RuntimeMetadata; + return VariableMap; })(); - core.TaskMetadata = (function() { + core.TypedInterface = (function() { /** - * Properties of a TaskMetadata. + * Properties of a TypedInterface. * @memberof flyteidl.core - * @interface ITaskMetadata - * @property {boolean|null} [discoverable] TaskMetadata discoverable - * @property {flyteidl.core.IRuntimeMetadata|null} [runtime] TaskMetadata runtime - * @property {google.protobuf.IDuration|null} [timeout] TaskMetadata timeout - * @property {flyteidl.core.IRetryStrategy|null} [retries] TaskMetadata retries - * @property {string|null} [discoveryVersion] TaskMetadata discoveryVersion - * @property {string|null} [deprecatedErrorMessage] TaskMetadata deprecatedErrorMessage - * @property {boolean|null} [interruptible] TaskMetadata interruptible + * @interface ITypedInterface + * @property {flyteidl.core.IVariableMap|null} [inputs] TypedInterface inputs + * @property {flyteidl.core.IVariableMap|null} [outputs] TypedInterface outputs */ /** - * Constructs a new TaskMetadata. + * Constructs a new TypedInterface. * @memberof flyteidl.core - * @classdesc Represents a TaskMetadata. - * @implements ITaskMetadata + * @classdesc Represents a TypedInterface. + * @implements ITypedInterface * @constructor - * @param {flyteidl.core.ITaskMetadata=} [properties] Properties to set + * @param {flyteidl.core.ITypedInterface=} [properties] Properties to set */ - function TaskMetadata(properties) { + function TypedInterface(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -8296,154 +8416,75 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * TaskMetadata discoverable. - * @member {boolean} discoverable - * @memberof flyteidl.core.TaskMetadata - * @instance - */ - TaskMetadata.prototype.discoverable = false; - - /** - * TaskMetadata runtime. - * @member {flyteidl.core.IRuntimeMetadata|null|undefined} runtime - * @memberof flyteidl.core.TaskMetadata - * @instance - */ - TaskMetadata.prototype.runtime = null; - - /** - * TaskMetadata timeout. - * @member {google.protobuf.IDuration|null|undefined} timeout - * @memberof flyteidl.core.TaskMetadata - * @instance - */ - TaskMetadata.prototype.timeout = null; - - /** - * TaskMetadata retries. - * @member {flyteidl.core.IRetryStrategy|null|undefined} retries - * @memberof flyteidl.core.TaskMetadata - * @instance - */ - TaskMetadata.prototype.retries = null; - - /** - * TaskMetadata discoveryVersion. - * @member {string} discoveryVersion - * @memberof flyteidl.core.TaskMetadata - * @instance - */ - TaskMetadata.prototype.discoveryVersion = ""; - - /** - * TaskMetadata deprecatedErrorMessage. - * @member {string} deprecatedErrorMessage - * @memberof flyteidl.core.TaskMetadata - * @instance - */ - TaskMetadata.prototype.deprecatedErrorMessage = ""; - - /** - * TaskMetadata interruptible. - * @member {boolean} interruptible - * @memberof flyteidl.core.TaskMetadata + * TypedInterface inputs. + * @member {flyteidl.core.IVariableMap|null|undefined} inputs + * @memberof flyteidl.core.TypedInterface * @instance */ - TaskMetadata.prototype.interruptible = false; - - // OneOf field names bound to virtual getters and setters - let $oneOfFields; + TypedInterface.prototype.inputs = null; /** - * TaskMetadata interruptibleValue. - * @member {"interruptible"|undefined} interruptibleValue - * @memberof flyteidl.core.TaskMetadata + * TypedInterface outputs. + * @member {flyteidl.core.IVariableMap|null|undefined} outputs + * @memberof flyteidl.core.TypedInterface * @instance */ - Object.defineProperty(TaskMetadata.prototype, "interruptibleValue", { - get: $util.oneOfGetter($oneOfFields = ["interruptible"]), - set: $util.oneOfSetter($oneOfFields) - }); + TypedInterface.prototype.outputs = null; /** - * Creates a new TaskMetadata instance using the specified properties. + * Creates a new TypedInterface instance using the specified properties. * @function create - * @memberof flyteidl.core.TaskMetadata + * @memberof flyteidl.core.TypedInterface * @static - * @param {flyteidl.core.ITaskMetadata=} [properties] Properties to set - * @returns {flyteidl.core.TaskMetadata} TaskMetadata instance + * @param {flyteidl.core.ITypedInterface=} [properties] Properties to set + * @returns {flyteidl.core.TypedInterface} TypedInterface instance */ - TaskMetadata.create = function create(properties) { - return new TaskMetadata(properties); + TypedInterface.create = function create(properties) { + return new TypedInterface(properties); }; /** - * Encodes the specified TaskMetadata message. Does not implicitly {@link flyteidl.core.TaskMetadata.verify|verify} messages. + * Encodes the specified TypedInterface message. Does not implicitly {@link flyteidl.core.TypedInterface.verify|verify} messages. * @function encode - * @memberof flyteidl.core.TaskMetadata + * @memberof flyteidl.core.TypedInterface * @static - * @param {flyteidl.core.ITaskMetadata} message TaskMetadata message or plain object to encode + * @param {flyteidl.core.ITypedInterface} message TypedInterface message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - TaskMetadata.encode = function encode(message, writer) { + TypedInterface.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.discoverable != null && message.hasOwnProperty("discoverable")) - writer.uint32(/* id 1, wireType 0 =*/8).bool(message.discoverable); - if (message.runtime != null && message.hasOwnProperty("runtime")) - $root.flyteidl.core.RuntimeMetadata.encode(message.runtime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); - if (message.timeout != null && message.hasOwnProperty("timeout")) - $root.google.protobuf.Duration.encode(message.timeout, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); - if (message.retries != null && message.hasOwnProperty("retries")) - $root.flyteidl.core.RetryStrategy.encode(message.retries, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); - if (message.discoveryVersion != null && message.hasOwnProperty("discoveryVersion")) - writer.uint32(/* id 6, wireType 2 =*/50).string(message.discoveryVersion); - if (message.deprecatedErrorMessage != null && message.hasOwnProperty("deprecatedErrorMessage")) - writer.uint32(/* id 7, wireType 2 =*/58).string(message.deprecatedErrorMessage); - if (message.interruptible != null && message.hasOwnProperty("interruptible")) - writer.uint32(/* id 8, wireType 0 =*/64).bool(message.interruptible); + if (message.inputs != null && message.hasOwnProperty("inputs")) + $root.flyteidl.core.VariableMap.encode(message.inputs, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.outputs != null && message.hasOwnProperty("outputs")) + $root.flyteidl.core.VariableMap.encode(message.outputs, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); return writer; }; /** - * Decodes a TaskMetadata message from the specified reader or buffer. + * Decodes a TypedInterface message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.TaskMetadata + * @memberof flyteidl.core.TypedInterface * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.TaskMetadata} TaskMetadata + * @returns {flyteidl.core.TypedInterface} TypedInterface * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - TaskMetadata.decode = function decode(reader, length) { + TypedInterface.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.core.TaskMetadata(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.TypedInterface(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.discoverable = reader.bool(); + message.inputs = $root.flyteidl.core.VariableMap.decode(reader, reader.uint32()); break; case 2: - message.runtime = $root.flyteidl.core.RuntimeMetadata.decode(reader, reader.uint32()); - break; - case 4: - message.timeout = $root.google.protobuf.Duration.decode(reader, reader.uint32()); - break; - case 5: - message.retries = $root.flyteidl.core.RetryStrategy.decode(reader, reader.uint32()); - break; - case 6: - message.discoveryVersion = reader.string(); - break; - case 7: - message.deprecatedErrorMessage = reader.string(); - break; - case 8: - message.interruptible = reader.bool(); + message.outputs = $root.flyteidl.core.VariableMap.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -8454,217 +8495,155 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a TaskMetadata message. + * Verifies a TypedInterface message. * @function verify - * @memberof flyteidl.core.TaskMetadata + * @memberof flyteidl.core.TypedInterface * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - TaskMetadata.verify = function verify(message) { + TypedInterface.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - let properties = {}; - if (message.discoverable != null && message.hasOwnProperty("discoverable")) - if (typeof message.discoverable !== "boolean") - return "discoverable: boolean expected"; - if (message.runtime != null && message.hasOwnProperty("runtime")) { - let error = $root.flyteidl.core.RuntimeMetadata.verify(message.runtime); - if (error) - return "runtime." + error; - } - if (message.timeout != null && message.hasOwnProperty("timeout")) { - let error = $root.google.protobuf.Duration.verify(message.timeout); + if (message.inputs != null && message.hasOwnProperty("inputs")) { + let error = $root.flyteidl.core.VariableMap.verify(message.inputs); if (error) - return "timeout." + error; + return "inputs." + error; } - if (message.retries != null && message.hasOwnProperty("retries")) { - let error = $root.flyteidl.core.RetryStrategy.verify(message.retries); + if (message.outputs != null && message.hasOwnProperty("outputs")) { + let error = $root.flyteidl.core.VariableMap.verify(message.outputs); if (error) - return "retries." + error; - } - if (message.discoveryVersion != null && message.hasOwnProperty("discoveryVersion")) - if (!$util.isString(message.discoveryVersion)) - return "discoveryVersion: string expected"; - if (message.deprecatedErrorMessage != null && message.hasOwnProperty("deprecatedErrorMessage")) - if (!$util.isString(message.deprecatedErrorMessage)) - return "deprecatedErrorMessage: string expected"; - if (message.interruptible != null && message.hasOwnProperty("interruptible")) { - properties.interruptibleValue = 1; - if (typeof message.interruptible !== "boolean") - return "interruptible: boolean expected"; + return "outputs." + error; } return null; }; - return TaskMetadata; + return TypedInterface; })(); - core.TaskTemplate = (function() { - - /** - * Properties of a TaskTemplate. - * @memberof flyteidl.core - * @interface ITaskTemplate - * @property {flyteidl.core.IIdentifier|null} [id] TaskTemplate id - * @property {string|null} [type] TaskTemplate type - * @property {flyteidl.core.ITaskMetadata|null} [metadata] TaskTemplate metadata - * @property {flyteidl.core.ITypedInterface|null} ["interface"] TaskTemplate interface - * @property {google.protobuf.IStruct|null} [custom] TaskTemplate custom - * @property {flyteidl.core.IContainer|null} [container] TaskTemplate container - */ + core.Parameter = (function() { /** - * Constructs a new TaskTemplate. + * Properties of a Parameter. * @memberof flyteidl.core - * @classdesc Represents a TaskTemplate. - * @implements ITaskTemplate - * @constructor - * @param {flyteidl.core.ITaskTemplate=} [properties] Properties to set - */ - function TaskTemplate(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]]; - } - - /** - * TaskTemplate id. - * @member {flyteidl.core.IIdentifier|null|undefined} id - * @memberof flyteidl.core.TaskTemplate - * @instance - */ - TaskTemplate.prototype.id = null; - - /** - * TaskTemplate type. - * @member {string} type - * @memberof flyteidl.core.TaskTemplate - * @instance + * @interface IParameter + * @property {flyteidl.core.IVariable|null} ["var"] Parameter var + * @property {flyteidl.core.ILiteral|null} ["default"] Parameter default + * @property {boolean|null} [required] Parameter required */ - TaskTemplate.prototype.type = ""; /** - * TaskTemplate metadata. - * @member {flyteidl.core.ITaskMetadata|null|undefined} metadata - * @memberof flyteidl.core.TaskTemplate - * @instance + * Constructs a new Parameter. + * @memberof flyteidl.core + * @classdesc Represents a Parameter. + * @implements IParameter + * @constructor + * @param {flyteidl.core.IParameter=} [properties] Properties to set */ - TaskTemplate.prototype.metadata = null; + function Parameter(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]]; + } /** - * TaskTemplate interface. - * @member {flyteidl.core.ITypedInterface|null|undefined} interface - * @memberof flyteidl.core.TaskTemplate + * Parameter var. + * @member {flyteidl.core.IVariable|null|undefined} var + * @memberof flyteidl.core.Parameter * @instance */ - TaskTemplate.prototype["interface"] = null; + Parameter.prototype["var"] = null; /** - * TaskTemplate custom. - * @member {google.protobuf.IStruct|null|undefined} custom - * @memberof flyteidl.core.TaskTemplate + * Parameter default. + * @member {flyteidl.core.ILiteral|null|undefined} default + * @memberof flyteidl.core.Parameter * @instance */ - TaskTemplate.prototype.custom = null; + Parameter.prototype["default"] = null; /** - * TaskTemplate container. - * @member {flyteidl.core.IContainer|null|undefined} container - * @memberof flyteidl.core.TaskTemplate + * Parameter required. + * @member {boolean} required + * @memberof flyteidl.core.Parameter * @instance */ - TaskTemplate.prototype.container = null; + Parameter.prototype.required = false; // OneOf field names bound to virtual getters and setters let $oneOfFields; /** - * TaskTemplate target. - * @member {"container"|undefined} target - * @memberof flyteidl.core.TaskTemplate + * Parameter behavior. + * @member {"default"|"required"|undefined} behavior + * @memberof flyteidl.core.Parameter * @instance */ - Object.defineProperty(TaskTemplate.prototype, "target", { - get: $util.oneOfGetter($oneOfFields = ["container"]), + Object.defineProperty(Parameter.prototype, "behavior", { + get: $util.oneOfGetter($oneOfFields = ["default", "required"]), set: $util.oneOfSetter($oneOfFields) }); /** - * Creates a new TaskTemplate instance using the specified properties. + * Creates a new Parameter instance using the specified properties. * @function create - * @memberof flyteidl.core.TaskTemplate + * @memberof flyteidl.core.Parameter * @static - * @param {flyteidl.core.ITaskTemplate=} [properties] Properties to set - * @returns {flyteidl.core.TaskTemplate} TaskTemplate instance + * @param {flyteidl.core.IParameter=} [properties] Properties to set + * @returns {flyteidl.core.Parameter} Parameter instance */ - TaskTemplate.create = function create(properties) { - return new TaskTemplate(properties); + Parameter.create = function create(properties) { + return new Parameter(properties); }; /** - * Encodes the specified TaskTemplate message. Does not implicitly {@link flyteidl.core.TaskTemplate.verify|verify} messages. + * Encodes the specified Parameter message. Does not implicitly {@link flyteidl.core.Parameter.verify|verify} messages. * @function encode - * @memberof flyteidl.core.TaskTemplate + * @memberof flyteidl.core.Parameter * @static - * @param {flyteidl.core.ITaskTemplate} message TaskTemplate message or plain object to encode + * @param {flyteidl.core.IParameter} message Parameter message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - TaskTemplate.encode = function encode(message, writer) { + Parameter.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.id != null && message.hasOwnProperty("id")) - $root.flyteidl.core.Identifier.encode(message.id, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); - if (message.type != null && message.hasOwnProperty("type")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.type); - if (message.metadata != null && message.hasOwnProperty("metadata")) - $root.flyteidl.core.TaskMetadata.encode(message.metadata, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); - if (message["interface"] != null && message.hasOwnProperty("interface")) - $root.flyteidl.core.TypedInterface.encode(message["interface"], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); - if (message.custom != null && message.hasOwnProperty("custom")) - $root.google.protobuf.Struct.encode(message.custom, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); - if (message.container != null && message.hasOwnProperty("container")) - $root.flyteidl.core.Container.encode(message.container, writer.uint32(/* id 6, wireType 2 =*/50).fork()).ldelim(); + if (message["var"] != null && message.hasOwnProperty("var")) + $root.flyteidl.core.Variable.encode(message["var"], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message["default"] != null && message.hasOwnProperty("default")) + $root.flyteidl.core.Literal.encode(message["default"], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.required != null && message.hasOwnProperty("required")) + writer.uint32(/* id 3, wireType 0 =*/24).bool(message.required); return writer; }; /** - * Decodes a TaskTemplate message from the specified reader or buffer. + * Decodes a Parameter message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.TaskTemplate + * @memberof flyteidl.core.Parameter * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.TaskTemplate} TaskTemplate + * @returns {flyteidl.core.Parameter} Parameter * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - TaskTemplate.decode = function decode(reader, length) { + Parameter.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.core.TaskTemplate(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.Parameter(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.id = $root.flyteidl.core.Identifier.decode(reader, reader.uint32()); + message["var"] = $root.flyteidl.core.Variable.decode(reader, reader.uint32()); break; case 2: - message.type = reader.string(); + message["default"] = $root.flyteidl.core.Literal.decode(reader, reader.uint32()); break; case 3: - message.metadata = $root.flyteidl.core.TaskMetadata.decode(reader, reader.uint32()); - break; - case 4: - message["interface"] = $root.flyteidl.core.TypedInterface.decode(reader, reader.uint32()); - break; - case 5: - message.custom = $root.google.protobuf.Struct.decode(reader, reader.uint32()); - break; - case 6: - message.container = $root.flyteidl.core.Container.decode(reader, reader.uint32()); + message.required = reader.bool(); break; default: reader.skipType(tag & 7); @@ -8675,72 +8654,62 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a TaskTemplate message. + * Verifies a Parameter message. * @function verify - * @memberof flyteidl.core.TaskTemplate + * @memberof flyteidl.core.Parameter * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - TaskTemplate.verify = function verify(message) { + Parameter.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; let properties = {}; - if (message.id != null && message.hasOwnProperty("id")) { - let error = $root.flyteidl.core.Identifier.verify(message.id); - if (error) - return "id." + error; - } - if (message.type != null && message.hasOwnProperty("type")) - if (!$util.isString(message.type)) - return "type: string expected"; - if (message.metadata != null && message.hasOwnProperty("metadata")) { - let error = $root.flyteidl.core.TaskMetadata.verify(message.metadata); - if (error) - return "metadata." + error; - } - if (message["interface"] != null && message.hasOwnProperty("interface")) { - let error = $root.flyteidl.core.TypedInterface.verify(message["interface"]); - if (error) - return "interface." + error; - } - if (message.custom != null && message.hasOwnProperty("custom")) { - let error = $root.google.protobuf.Struct.verify(message.custom); + if (message["var"] != null && message.hasOwnProperty("var")) { + let error = $root.flyteidl.core.Variable.verify(message["var"]); if (error) - return "custom." + error; + return "var." + error; } - if (message.container != null && message.hasOwnProperty("container")) { - properties.target = 1; + if (message["default"] != null && message.hasOwnProperty("default")) { + properties.behavior = 1; { - let error = $root.flyteidl.core.Container.verify(message.container); + let error = $root.flyteidl.core.Literal.verify(message["default"]); if (error) - return "container." + error; + return "default." + error; } } + if (message.required != null && message.hasOwnProperty("required")) { + if (properties.behavior === 1) + return "behavior: multiple values"; + properties.behavior = 1; + if (typeof message.required !== "boolean") + return "required: boolean expected"; + } return null; }; - return TaskTemplate; + return Parameter; })(); - core.ContainerPort = (function() { + core.ParameterMap = (function() { /** - * Properties of a ContainerPort. + * Properties of a ParameterMap. * @memberof flyteidl.core - * @interface IContainerPort - * @property {number|null} [containerPort] ContainerPort containerPort + * @interface IParameterMap + * @property {Object.|null} [parameters] ParameterMap parameters */ /** - * Constructs a new ContainerPort. + * Constructs a new ParameterMap. * @memberof flyteidl.core - * @classdesc Represents a ContainerPort. - * @implements IContainerPort + * @classdesc Represents a ParameterMap. + * @implements IParameterMap * @constructor - * @param {flyteidl.core.IContainerPort=} [properties] Properties to set + * @param {flyteidl.core.IParameterMap=} [properties] Properties to set */ - function ContainerPort(properties) { + function ParameterMap(properties) { + this.parameters = {}; if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -8748,62 +8717,70 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * ContainerPort containerPort. - * @member {number} containerPort - * @memberof flyteidl.core.ContainerPort + * ParameterMap parameters. + * @member {Object.} parameters + * @memberof flyteidl.core.ParameterMap * @instance */ - ContainerPort.prototype.containerPort = 0; + ParameterMap.prototype.parameters = $util.emptyObject; /** - * Creates a new ContainerPort instance using the specified properties. + * Creates a new ParameterMap instance using the specified properties. * @function create - * @memberof flyteidl.core.ContainerPort + * @memberof flyteidl.core.ParameterMap * @static - * @param {flyteidl.core.IContainerPort=} [properties] Properties to set - * @returns {flyteidl.core.ContainerPort} ContainerPort instance + * @param {flyteidl.core.IParameterMap=} [properties] Properties to set + * @returns {flyteidl.core.ParameterMap} ParameterMap instance */ - ContainerPort.create = function create(properties) { - return new ContainerPort(properties); + ParameterMap.create = function create(properties) { + return new ParameterMap(properties); }; /** - * Encodes the specified ContainerPort message. Does not implicitly {@link flyteidl.core.ContainerPort.verify|verify} messages. + * Encodes the specified ParameterMap message. Does not implicitly {@link flyteidl.core.ParameterMap.verify|verify} messages. * @function encode - * @memberof flyteidl.core.ContainerPort + * @memberof flyteidl.core.ParameterMap * @static - * @param {flyteidl.core.IContainerPort} message ContainerPort message or plain object to encode + * @param {flyteidl.core.IParameterMap} message ParameterMap message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - ContainerPort.encode = function encode(message, writer) { + ParameterMap.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.containerPort != null && message.hasOwnProperty("containerPort")) - writer.uint32(/* id 1, wireType 0 =*/8).uint32(message.containerPort); + if (message.parameters != null && message.hasOwnProperty("parameters")) + for (let keys = Object.keys(message.parameters), i = 0; i < keys.length; ++i) { + writer.uint32(/* id 1, wireType 2 =*/10).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]); + $root.flyteidl.core.Parameter.encode(message.parameters[keys[i]], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim().ldelim(); + } return writer; }; /** - * Decodes a ContainerPort message from the specified reader or buffer. + * Decodes a ParameterMap message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.ContainerPort + * @memberof flyteidl.core.ParameterMap * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.ContainerPort} ContainerPort + * @returns {flyteidl.core.ParameterMap} ParameterMap * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - ContainerPort.decode = function decode(reader, length) { + ParameterMap.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.core.ContainerPort(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.ParameterMap(), key; while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.containerPort = reader.uint32(); + reader.skip().pos++; + if (message.parameters === $util.emptyObject) + message.parameters = {}; + key = reader.string(); + reader.pos++; + message.parameters[key] = $root.flyteidl.core.Parameter.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -8814,55 +8791,53 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a ContainerPort message. + * Verifies a ParameterMap message. * @function verify - * @memberof flyteidl.core.ContainerPort + * @memberof flyteidl.core.ParameterMap * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - ContainerPort.verify = function verify(message) { + ParameterMap.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.containerPort != null && message.hasOwnProperty("containerPort")) - if (!$util.isInteger(message.containerPort)) - return "containerPort: integer expected"; + if (message.parameters != null && message.hasOwnProperty("parameters")) { + if (!$util.isObject(message.parameters)) + return "parameters: object expected"; + let key = Object.keys(message.parameters); + for (let i = 0; i < key.length; ++i) { + let error = $root.flyteidl.core.Parameter.verify(message.parameters[key[i]]); + if (error) + return "parameters." + error; + } + } return null; }; - return ContainerPort; + return ParameterMap; })(); - core.Container = (function() { + core.Resources = (function() { /** - * Properties of a Container. + * Properties of a Resources. * @memberof flyteidl.core - * @interface IContainer - * @property {string|null} [image] Container image - * @property {Array.|null} [command] Container command - * @property {Array.|null} [args] Container args - * @property {flyteidl.core.IResources|null} [resources] Container resources - * @property {Array.|null} [env] Container env - * @property {Array.|null} [config] Container config - * @property {Array.|null} [ports] Container ports - * @property {flyteidl.core.IDataLoadingConfig|null} [dataConfig] Container dataConfig + * @interface IResources + * @property {Array.|null} [requests] Resources requests + * @property {Array.|null} [limits] Resources limits */ /** - * Constructs a new Container. + * Constructs a new Resources. * @memberof flyteidl.core - * @classdesc Represents a Container. - * @implements IContainer + * @classdesc Represents a Resources. + * @implements IResources * @constructor - * @param {flyteidl.core.IContainer=} [properties] Properties to set + * @param {flyteidl.core.IResources=} [properties] Properties to set */ - function Container(properties) { - this.command = []; - this.args = []; - this.env = []; - this.config = []; - this.ports = []; + function Resources(properties) { + this.requests = []; + this.limits = []; if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -8870,168 +8845,81 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * Container image. - * @member {string} image - * @memberof flyteidl.core.Container - * @instance - */ - Container.prototype.image = ""; - - /** - * Container command. - * @member {Array.} command - * @memberof flyteidl.core.Container - * @instance - */ - Container.prototype.command = $util.emptyArray; - - /** - * Container args. - * @member {Array.} args - * @memberof flyteidl.core.Container - * @instance - */ - Container.prototype.args = $util.emptyArray; - - /** - * Container resources. - * @member {flyteidl.core.IResources|null|undefined} resources - * @memberof flyteidl.core.Container - * @instance - */ - Container.prototype.resources = null; - - /** - * Container env. - * @member {Array.} env - * @memberof flyteidl.core.Container - * @instance - */ - Container.prototype.env = $util.emptyArray; - - /** - * Container config. - * @member {Array.} config - * @memberof flyteidl.core.Container - * @instance - */ - Container.prototype.config = $util.emptyArray; - - /** - * Container ports. - * @member {Array.} ports - * @memberof flyteidl.core.Container + * Resources requests. + * @member {Array.} requests + * @memberof flyteidl.core.Resources * @instance */ - Container.prototype.ports = $util.emptyArray; + Resources.prototype.requests = $util.emptyArray; /** - * Container dataConfig. - * @member {flyteidl.core.IDataLoadingConfig|null|undefined} dataConfig - * @memberof flyteidl.core.Container + * Resources limits. + * @member {Array.} limits + * @memberof flyteidl.core.Resources * @instance */ - Container.prototype.dataConfig = null; + Resources.prototype.limits = $util.emptyArray; /** - * Creates a new Container instance using the specified properties. + * Creates a new Resources instance using the specified properties. * @function create - * @memberof flyteidl.core.Container + * @memberof flyteidl.core.Resources * @static - * @param {flyteidl.core.IContainer=} [properties] Properties to set - * @returns {flyteidl.core.Container} Container instance + * @param {flyteidl.core.IResources=} [properties] Properties to set + * @returns {flyteidl.core.Resources} Resources instance */ - Container.create = function create(properties) { - return new Container(properties); + Resources.create = function create(properties) { + return new Resources(properties); }; /** - * Encodes the specified Container message. Does not implicitly {@link flyteidl.core.Container.verify|verify} messages. + * Encodes the specified Resources message. Does not implicitly {@link flyteidl.core.Resources.verify|verify} messages. * @function encode - * @memberof flyteidl.core.Container + * @memberof flyteidl.core.Resources * @static - * @param {flyteidl.core.IContainer} message Container message or plain object to encode + * @param {flyteidl.core.IResources} message Resources message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - Container.encode = function encode(message, writer) { + Resources.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.image != null && message.hasOwnProperty("image")) - writer.uint32(/* id 1, wireType 2 =*/10).string(message.image); - if (message.command != null && message.command.length) - for (let i = 0; i < message.command.length; ++i) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.command[i]); - if (message.args != null && message.args.length) - for (let i = 0; i < message.args.length; ++i) - writer.uint32(/* id 3, wireType 2 =*/26).string(message.args[i]); - if (message.resources != null && message.hasOwnProperty("resources")) - $root.flyteidl.core.Resources.encode(message.resources, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); - if (message.env != null && message.env.length) - for (let i = 0; i < message.env.length; ++i) - $root.flyteidl.core.KeyValuePair.encode(message.env[i], writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); - if (message.config != null && message.config.length) - for (let i = 0; i < message.config.length; ++i) - $root.flyteidl.core.KeyValuePair.encode(message.config[i], writer.uint32(/* id 6, wireType 2 =*/50).fork()).ldelim(); - if (message.ports != null && message.ports.length) - for (let i = 0; i < message.ports.length; ++i) - $root.flyteidl.core.ContainerPort.encode(message.ports[i], writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim(); - if (message.dataConfig != null && message.hasOwnProperty("dataConfig")) - $root.flyteidl.core.DataLoadingConfig.encode(message.dataConfig, writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim(); + if (message.requests != null && message.requests.length) + for (let i = 0; i < message.requests.length; ++i) + $root.flyteidl.core.Resources.ResourceEntry.encode(message.requests[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.limits != null && message.limits.length) + for (let i = 0; i < message.limits.length; ++i) + $root.flyteidl.core.Resources.ResourceEntry.encode(message.limits[i], writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); return writer; }; /** - * Decodes a Container message from the specified reader or buffer. + * Decodes a Resources message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.Container + * @memberof flyteidl.core.Resources * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.Container} Container + * @returns {flyteidl.core.Resources} Resources * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - Container.decode = function decode(reader, length) { + Resources.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.core.Container(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.Resources(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.image = reader.string(); + if (!(message.requests && message.requests.length)) + message.requests = []; + message.requests.push($root.flyteidl.core.Resources.ResourceEntry.decode(reader, reader.uint32())); break; case 2: - if (!(message.command && message.command.length)) - message.command = []; - message.command.push(reader.string()); - break; - case 3: - if (!(message.args && message.args.length)) - message.args = []; - message.args.push(reader.string()); - break; - case 4: - message.resources = $root.flyteidl.core.Resources.decode(reader, reader.uint32()); - break; - case 5: - if (!(message.env && message.env.length)) - message.env = []; - message.env.push($root.flyteidl.core.KeyValuePair.decode(reader, reader.uint32())); - break; - case 6: - if (!(message.config && message.config.length)) - message.config = []; - message.config.push($root.flyteidl.core.KeyValuePair.decode(reader, reader.uint32())); - break; - case 7: - if (!(message.ports && message.ports.length)) - message.ports = []; - message.ports.push($root.flyteidl.core.ContainerPort.decode(reader, reader.uint32())); - break; - case 9: - message.dataConfig = $root.flyteidl.core.DataLoadingConfig.decode(reader, reader.uint32()); + if (!(message.limits && message.limits.length)) + message.limits = []; + message.limits.push($root.flyteidl.core.Resources.ResourceEntry.decode(reader, reader.uint32())); break; default: reader.skipType(tag & 7); @@ -9042,95 +8930,215 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a Container message. + * Verifies a Resources message. * @function verify - * @memberof flyteidl.core.Container + * @memberof flyteidl.core.Resources * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - Container.verify = function verify(message) { + Resources.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.image != null && message.hasOwnProperty("image")) - if (!$util.isString(message.image)) - return "image: string expected"; - if (message.command != null && message.hasOwnProperty("command")) { - if (!Array.isArray(message.command)) - return "command: array expected"; - for (let i = 0; i < message.command.length; ++i) - if (!$util.isString(message.command[i])) - return "command: string[] expected"; - } - if (message.args != null && message.hasOwnProperty("args")) { - if (!Array.isArray(message.args)) - return "args: array expected"; - for (let i = 0; i < message.args.length; ++i) - if (!$util.isString(message.args[i])) - return "args: string[] expected"; - } - if (message.resources != null && message.hasOwnProperty("resources")) { - let error = $root.flyteidl.core.Resources.verify(message.resources); - if (error) - return "resources." + error; - } - if (message.env != null && message.hasOwnProperty("env")) { - if (!Array.isArray(message.env)) - return "env: array expected"; - for (let i = 0; i < message.env.length; ++i) { - let error = $root.flyteidl.core.KeyValuePair.verify(message.env[i]); - if (error) - return "env." + error; - } - } - if (message.config != null && message.hasOwnProperty("config")) { - if (!Array.isArray(message.config)) - return "config: array expected"; - for (let i = 0; i < message.config.length; ++i) { - let error = $root.flyteidl.core.KeyValuePair.verify(message.config[i]); + if (message.requests != null && message.hasOwnProperty("requests")) { + if (!Array.isArray(message.requests)) + return "requests: array expected"; + for (let i = 0; i < message.requests.length; ++i) { + let error = $root.flyteidl.core.Resources.ResourceEntry.verify(message.requests[i]); if (error) - return "config." + error; + return "requests." + error; } } - if (message.ports != null && message.hasOwnProperty("ports")) { - if (!Array.isArray(message.ports)) - return "ports: array expected"; - for (let i = 0; i < message.ports.length; ++i) { - let error = $root.flyteidl.core.ContainerPort.verify(message.ports[i]); + if (message.limits != null && message.hasOwnProperty("limits")) { + if (!Array.isArray(message.limits)) + return "limits: array expected"; + for (let i = 0; i < message.limits.length; ++i) { + let error = $root.flyteidl.core.Resources.ResourceEntry.verify(message.limits[i]); if (error) - return "ports." + error; - } - } - if (message.dataConfig != null && message.hasOwnProperty("dataConfig")) { - let error = $root.flyteidl.core.DataLoadingConfig.verify(message.dataConfig); - if (error) - return "dataConfig." + error; + return "limits." + error; + } } return null; }; - return Container; + /** + * ResourceName enum. + * @name flyteidl.core.Resources.ResourceName + * @enum {string} + * @property {number} UNKNOWN=0 UNKNOWN value + * @property {number} CPU=1 CPU value + * @property {number} GPU=2 GPU value + * @property {number} MEMORY=3 MEMORY value + * @property {number} STORAGE=4 STORAGE value + */ + Resources.ResourceName = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UNKNOWN"] = 0; + values[valuesById[1] = "CPU"] = 1; + values[valuesById[2] = "GPU"] = 2; + values[valuesById[3] = "MEMORY"] = 3; + values[valuesById[4] = "STORAGE"] = 4; + return values; + })(); + + Resources.ResourceEntry = (function() { + + /** + * Properties of a ResourceEntry. + * @memberof flyteidl.core.Resources + * @interface IResourceEntry + * @property {flyteidl.core.Resources.ResourceName|null} [name] ResourceEntry name + * @property {string|null} [value] ResourceEntry value + */ + + /** + * Constructs a new ResourceEntry. + * @memberof flyteidl.core.Resources + * @classdesc Represents a ResourceEntry. + * @implements IResourceEntry + * @constructor + * @param {flyteidl.core.Resources.IResourceEntry=} [properties] Properties to set + */ + function ResourceEntry(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]]; + } + + /** + * ResourceEntry name. + * @member {flyteidl.core.Resources.ResourceName} name + * @memberof flyteidl.core.Resources.ResourceEntry + * @instance + */ + ResourceEntry.prototype.name = 0; + + /** + * ResourceEntry value. + * @member {string} value + * @memberof flyteidl.core.Resources.ResourceEntry + * @instance + */ + ResourceEntry.prototype.value = ""; + + /** + * Creates a new ResourceEntry instance using the specified properties. + * @function create + * @memberof flyteidl.core.Resources.ResourceEntry + * @static + * @param {flyteidl.core.Resources.IResourceEntry=} [properties] Properties to set + * @returns {flyteidl.core.Resources.ResourceEntry} ResourceEntry instance + */ + ResourceEntry.create = function create(properties) { + return new ResourceEntry(properties); + }; + + /** + * Encodes the specified ResourceEntry message. Does not implicitly {@link flyteidl.core.Resources.ResourceEntry.verify|verify} messages. + * @function encode + * @memberof flyteidl.core.Resources.ResourceEntry + * @static + * @param {flyteidl.core.Resources.IResourceEntry} message ResourceEntry message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ResourceEntry.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && message.hasOwnProperty("name")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.name); + if (message.value != null && message.hasOwnProperty("value")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.value); + return writer; + }; + + /** + * Decodes a ResourceEntry message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.core.Resources.ResourceEntry + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.core.Resources.ResourceEntry} ResourceEntry + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ResourceEntry.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.core.Resources.ResourceEntry(); + while (reader.pos < end) { + let tag = reader.uint32(); + switch (tag >>> 3) { + case 1: + message.name = reader.int32(); + break; + case 2: + message.value = reader.string(); + break; + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Verifies a ResourceEntry message. + * @function verify + * @memberof flyteidl.core.Resources.ResourceEntry + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ResourceEntry.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + switch (message.name) { + default: + return "name: enum value expected"; + case 0: + case 1: + case 2: + case 3: + case 4: + break; + } + if (message.value != null && message.hasOwnProperty("value")) + if (!$util.isString(message.value)) + return "value: string expected"; + return null; + }; + + return ResourceEntry; + })(); + + return Resources; })(); - core.IOStrategy = (function() { + core.RuntimeMetadata = (function() { /** - * Properties of a IOStrategy. + * Properties of a RuntimeMetadata. * @memberof flyteidl.core - * @interface IIOStrategy - * @property {flyteidl.core.IOStrategy.DownloadMode|null} [downloadMode] IOStrategy downloadMode - * @property {flyteidl.core.IOStrategy.UploadMode|null} [uploadMode] IOStrategy uploadMode + * @interface IRuntimeMetadata + * @property {flyteidl.core.RuntimeMetadata.RuntimeType|null} [type] RuntimeMetadata type + * @property {string|null} [version] RuntimeMetadata version + * @property {string|null} [flavor] RuntimeMetadata flavor */ /** - * Constructs a new IOStrategy. + * Constructs a new RuntimeMetadata. * @memberof flyteidl.core - * @classdesc Represents a IOStrategy. - * @implements IIOStrategy + * @classdesc Represents a RuntimeMetadata. + * @implements IRuntimeMetadata * @constructor - * @param {flyteidl.core.IIOStrategy=} [properties] Properties to set + * @param {flyteidl.core.IRuntimeMetadata=} [properties] Properties to set */ - function IOStrategy(properties) { + function RuntimeMetadata(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -9138,75 +9146,88 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * IOStrategy downloadMode. - * @member {flyteidl.core.IOStrategy.DownloadMode} downloadMode - * @memberof flyteidl.core.IOStrategy + * RuntimeMetadata type. + * @member {flyteidl.core.RuntimeMetadata.RuntimeType} type + * @memberof flyteidl.core.RuntimeMetadata * @instance */ - IOStrategy.prototype.downloadMode = 0; + RuntimeMetadata.prototype.type = 0; /** - * IOStrategy uploadMode. - * @member {flyteidl.core.IOStrategy.UploadMode} uploadMode - * @memberof flyteidl.core.IOStrategy + * RuntimeMetadata version. + * @member {string} version + * @memberof flyteidl.core.RuntimeMetadata * @instance */ - IOStrategy.prototype.uploadMode = 0; + RuntimeMetadata.prototype.version = ""; /** - * Creates a new IOStrategy instance using the specified properties. + * RuntimeMetadata flavor. + * @member {string} flavor + * @memberof flyteidl.core.RuntimeMetadata + * @instance + */ + RuntimeMetadata.prototype.flavor = ""; + + /** + * Creates a new RuntimeMetadata instance using the specified properties. * @function create - * @memberof flyteidl.core.IOStrategy + * @memberof flyteidl.core.RuntimeMetadata * @static - * @param {flyteidl.core.IIOStrategy=} [properties] Properties to set - * @returns {flyteidl.core.IOStrategy} IOStrategy instance + * @param {flyteidl.core.IRuntimeMetadata=} [properties] Properties to set + * @returns {flyteidl.core.RuntimeMetadata} RuntimeMetadata instance */ - IOStrategy.create = function create(properties) { - return new IOStrategy(properties); + RuntimeMetadata.create = function create(properties) { + return new RuntimeMetadata(properties); }; /** - * Encodes the specified IOStrategy message. Does not implicitly {@link flyteidl.core.IOStrategy.verify|verify} messages. + * Encodes the specified RuntimeMetadata message. Does not implicitly {@link flyteidl.core.RuntimeMetadata.verify|verify} messages. * @function encode - * @memberof flyteidl.core.IOStrategy + * @memberof flyteidl.core.RuntimeMetadata * @static - * @param {flyteidl.core.IIOStrategy} message IOStrategy message or plain object to encode + * @param {flyteidl.core.IRuntimeMetadata} message RuntimeMetadata message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - IOStrategy.encode = function encode(message, writer) { + RuntimeMetadata.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.downloadMode != null && message.hasOwnProperty("downloadMode")) - writer.uint32(/* id 1, wireType 0 =*/8).int32(message.downloadMode); - if (message.uploadMode != null && message.hasOwnProperty("uploadMode")) - writer.uint32(/* id 2, wireType 0 =*/16).int32(message.uploadMode); + if (message.type != null && message.hasOwnProperty("type")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.type); + if (message.version != null && message.hasOwnProperty("version")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.version); + if (message.flavor != null && message.hasOwnProperty("flavor")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.flavor); return writer; }; /** - * Decodes a IOStrategy message from the specified reader or buffer. + * Decodes a RuntimeMetadata message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.IOStrategy + * @memberof flyteidl.core.RuntimeMetadata * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.IOStrategy} IOStrategy + * @returns {flyteidl.core.RuntimeMetadata} RuntimeMetadata * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - IOStrategy.decode = function decode(reader, length) { + RuntimeMetadata.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.core.IOStrategy(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.RuntimeMetadata(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.downloadMode = reader.int32(); + message.type = reader.int32(); break; case 2: - message.uploadMode = reader.int32(); + message.version = reader.string(); + break; + case 3: + message.flavor = reader.string(); break; default: reader.skipType(tag & 7); @@ -9217,94 +9238,74 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a IOStrategy message. + * Verifies a RuntimeMetadata message. * @function verify - * @memberof flyteidl.core.IOStrategy + * @memberof flyteidl.core.RuntimeMetadata * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - IOStrategy.verify = function verify(message) { + RuntimeMetadata.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.downloadMode != null && message.hasOwnProperty("downloadMode")) - switch (message.downloadMode) { - default: - return "downloadMode: enum value expected"; - case 0: - case 1: - case 2: - break; - } - if (message.uploadMode != null && message.hasOwnProperty("uploadMode")) - switch (message.uploadMode) { + if (message.type != null && message.hasOwnProperty("type")) + switch (message.type) { default: - return "uploadMode: enum value expected"; + return "type: enum value expected"; case 0: case 1: - case 2: break; } + if (message.version != null && message.hasOwnProperty("version")) + if (!$util.isString(message.version)) + return "version: string expected"; + if (message.flavor != null && message.hasOwnProperty("flavor")) + if (!$util.isString(message.flavor)) + return "flavor: string expected"; return null; }; /** - * DownloadMode enum. - * @name flyteidl.core.IOStrategy.DownloadMode - * @enum {string} - * @property {number} DOWNLOAD_EAGER=0 DOWNLOAD_EAGER value - * @property {number} DOWNLOAD_STREAM=1 DOWNLOAD_STREAM value - * @property {number} DO_NOT_DOWNLOAD=2 DO_NOT_DOWNLOAD value - */ - IOStrategy.DownloadMode = (function() { - const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "DOWNLOAD_EAGER"] = 0; - values[valuesById[1] = "DOWNLOAD_STREAM"] = 1; - values[valuesById[2] = "DO_NOT_DOWNLOAD"] = 2; - return values; - })(); - - /** - * UploadMode enum. - * @name flyteidl.core.IOStrategy.UploadMode + * RuntimeType enum. + * @name flyteidl.core.RuntimeMetadata.RuntimeType * @enum {string} - * @property {number} UPLOAD_ON_EXIT=0 UPLOAD_ON_EXIT value - * @property {number} UPLOAD_EAGER=1 UPLOAD_EAGER value - * @property {number} DO_NOT_UPLOAD=2 DO_NOT_UPLOAD value + * @property {number} OTHER=0 OTHER value + * @property {number} FLYTE_SDK=1 FLYTE_SDK value */ - IOStrategy.UploadMode = (function() { + RuntimeMetadata.RuntimeType = (function() { const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "UPLOAD_ON_EXIT"] = 0; - values[valuesById[1] = "UPLOAD_EAGER"] = 1; - values[valuesById[2] = "DO_NOT_UPLOAD"] = 2; + values[valuesById[0] = "OTHER"] = 0; + values[valuesById[1] = "FLYTE_SDK"] = 1; return values; })(); - return IOStrategy; + return RuntimeMetadata; })(); - core.DataLoadingConfig = (function() { + core.TaskMetadata = (function() { /** - * Properties of a DataLoadingConfig. + * Properties of a TaskMetadata. * @memberof flyteidl.core - * @interface IDataLoadingConfig - * @property {boolean|null} [enabled] DataLoadingConfig enabled - * @property {string|null} [inputPath] DataLoadingConfig inputPath - * @property {string|null} [outputPath] DataLoadingConfig outputPath - * @property {flyteidl.core.DataLoadingConfig.LiteralMapFormat|null} [format] DataLoadingConfig format - * @property {flyteidl.core.IIOStrategy|null} [ioStrategy] DataLoadingConfig ioStrategy + * @interface ITaskMetadata + * @property {boolean|null} [discoverable] TaskMetadata discoverable + * @property {flyteidl.core.IRuntimeMetadata|null} [runtime] TaskMetadata runtime + * @property {google.protobuf.IDuration|null} [timeout] TaskMetadata timeout + * @property {flyteidl.core.IRetryStrategy|null} [retries] TaskMetadata retries + * @property {string|null} [discoveryVersion] TaskMetadata discoveryVersion + * @property {string|null} [deprecatedErrorMessage] TaskMetadata deprecatedErrorMessage + * @property {boolean|null} [interruptible] TaskMetadata interruptible */ /** - * Constructs a new DataLoadingConfig. + * Constructs a new TaskMetadata. * @memberof flyteidl.core - * @classdesc Represents a DataLoadingConfig. - * @implements IDataLoadingConfig + * @classdesc Represents a TaskMetadata. + * @implements ITaskMetadata * @constructor - * @param {flyteidl.core.IDataLoadingConfig=} [properties] Properties to set + * @param {flyteidl.core.ITaskMetadata=} [properties] Properties to set */ - function DataLoadingConfig(properties) { + function TaskMetadata(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -9312,114 +9313,154 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * DataLoadingConfig enabled. - * @member {boolean} enabled - * @memberof flyteidl.core.DataLoadingConfig + * TaskMetadata discoverable. + * @member {boolean} discoverable + * @memberof flyteidl.core.TaskMetadata * @instance */ - DataLoadingConfig.prototype.enabled = false; + TaskMetadata.prototype.discoverable = false; /** - * DataLoadingConfig inputPath. - * @member {string} inputPath - * @memberof flyteidl.core.DataLoadingConfig + * TaskMetadata runtime. + * @member {flyteidl.core.IRuntimeMetadata|null|undefined} runtime + * @memberof flyteidl.core.TaskMetadata * @instance */ - DataLoadingConfig.prototype.inputPath = ""; + TaskMetadata.prototype.runtime = null; /** - * DataLoadingConfig outputPath. - * @member {string} outputPath - * @memberof flyteidl.core.DataLoadingConfig + * TaskMetadata timeout. + * @member {google.protobuf.IDuration|null|undefined} timeout + * @memberof flyteidl.core.TaskMetadata * @instance */ - DataLoadingConfig.prototype.outputPath = ""; + TaskMetadata.prototype.timeout = null; /** - * DataLoadingConfig format. - * @member {flyteidl.core.DataLoadingConfig.LiteralMapFormat} format - * @memberof flyteidl.core.DataLoadingConfig + * TaskMetadata retries. + * @member {flyteidl.core.IRetryStrategy|null|undefined} retries + * @memberof flyteidl.core.TaskMetadata * @instance */ - DataLoadingConfig.prototype.format = 0; + TaskMetadata.prototype.retries = null; /** - * DataLoadingConfig ioStrategy. - * @member {flyteidl.core.IIOStrategy|null|undefined} ioStrategy - * @memberof flyteidl.core.DataLoadingConfig + * TaskMetadata discoveryVersion. + * @member {string} discoveryVersion + * @memberof flyteidl.core.TaskMetadata * @instance */ - DataLoadingConfig.prototype.ioStrategy = null; + TaskMetadata.prototype.discoveryVersion = ""; /** - * Creates a new DataLoadingConfig instance using the specified properties. + * TaskMetadata deprecatedErrorMessage. + * @member {string} deprecatedErrorMessage + * @memberof flyteidl.core.TaskMetadata + * @instance + */ + TaskMetadata.prototype.deprecatedErrorMessage = ""; + + /** + * TaskMetadata interruptible. + * @member {boolean} interruptible + * @memberof flyteidl.core.TaskMetadata + * @instance + */ + TaskMetadata.prototype.interruptible = false; + + // OneOf field names bound to virtual getters and setters + let $oneOfFields; + + /** + * TaskMetadata interruptibleValue. + * @member {"interruptible"|undefined} interruptibleValue + * @memberof flyteidl.core.TaskMetadata + * @instance + */ + Object.defineProperty(TaskMetadata.prototype, "interruptibleValue", { + get: $util.oneOfGetter($oneOfFields = ["interruptible"]), + set: $util.oneOfSetter($oneOfFields) + }); + + /** + * Creates a new TaskMetadata instance using the specified properties. * @function create - * @memberof flyteidl.core.DataLoadingConfig + * @memberof flyteidl.core.TaskMetadata * @static - * @param {flyteidl.core.IDataLoadingConfig=} [properties] Properties to set - * @returns {flyteidl.core.DataLoadingConfig} DataLoadingConfig instance + * @param {flyteidl.core.ITaskMetadata=} [properties] Properties to set + * @returns {flyteidl.core.TaskMetadata} TaskMetadata instance */ - DataLoadingConfig.create = function create(properties) { - return new DataLoadingConfig(properties); + TaskMetadata.create = function create(properties) { + return new TaskMetadata(properties); }; /** - * Encodes the specified DataLoadingConfig message. Does not implicitly {@link flyteidl.core.DataLoadingConfig.verify|verify} messages. + * Encodes the specified TaskMetadata message. Does not implicitly {@link flyteidl.core.TaskMetadata.verify|verify} messages. * @function encode - * @memberof flyteidl.core.DataLoadingConfig + * @memberof flyteidl.core.TaskMetadata * @static - * @param {flyteidl.core.IDataLoadingConfig} message DataLoadingConfig message or plain object to encode + * @param {flyteidl.core.ITaskMetadata} message TaskMetadata message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - DataLoadingConfig.encode = function encode(message, writer) { + TaskMetadata.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.enabled != null && message.hasOwnProperty("enabled")) - writer.uint32(/* id 1, wireType 0 =*/8).bool(message.enabled); - if (message.inputPath != null && message.hasOwnProperty("inputPath")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.inputPath); - if (message.outputPath != null && message.hasOwnProperty("outputPath")) - writer.uint32(/* id 3, wireType 2 =*/26).string(message.outputPath); - if (message.format != null && message.hasOwnProperty("format")) - writer.uint32(/* id 4, wireType 0 =*/32).int32(message.format); - if (message.ioStrategy != null && message.hasOwnProperty("ioStrategy")) - $root.flyteidl.core.IOStrategy.encode(message.ioStrategy, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + if (message.discoverable != null && message.hasOwnProperty("discoverable")) + writer.uint32(/* id 1, wireType 0 =*/8).bool(message.discoverable); + if (message.runtime != null && message.hasOwnProperty("runtime")) + $root.flyteidl.core.RuntimeMetadata.encode(message.runtime, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); + if (message.timeout != null && message.hasOwnProperty("timeout")) + $root.google.protobuf.Duration.encode(message.timeout, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.retries != null && message.hasOwnProperty("retries")) + $root.flyteidl.core.RetryStrategy.encode(message.retries, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + if (message.discoveryVersion != null && message.hasOwnProperty("discoveryVersion")) + writer.uint32(/* id 6, wireType 2 =*/50).string(message.discoveryVersion); + if (message.deprecatedErrorMessage != null && message.hasOwnProperty("deprecatedErrorMessage")) + writer.uint32(/* id 7, wireType 2 =*/58).string(message.deprecatedErrorMessage); + if (message.interruptible != null && message.hasOwnProperty("interruptible")) + writer.uint32(/* id 8, wireType 0 =*/64).bool(message.interruptible); return writer; }; /** - * Decodes a DataLoadingConfig message from the specified reader or buffer. + * Decodes a TaskMetadata message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.DataLoadingConfig + * @memberof flyteidl.core.TaskMetadata * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.DataLoadingConfig} DataLoadingConfig + * @returns {flyteidl.core.TaskMetadata} TaskMetadata * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - DataLoadingConfig.decode = function decode(reader, length) { + TaskMetadata.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.core.DataLoadingConfig(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.TaskMetadata(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.enabled = reader.bool(); + message.discoverable = reader.bool(); break; case 2: - message.inputPath = reader.string(); - break; - case 3: - message.outputPath = reader.string(); + message.runtime = $root.flyteidl.core.RuntimeMetadata.decode(reader, reader.uint32()); break; case 4: - message.format = reader.int32(); + message.timeout = $root.google.protobuf.Duration.decode(reader, reader.uint32()); break; case 5: - message.ioStrategy = $root.flyteidl.core.IOStrategy.decode(reader, reader.uint32()); + message.retries = $root.flyteidl.core.RetryStrategy.decode(reader, reader.uint32()); + break; + case 6: + message.discoveryVersion = reader.string(); + break; + case 7: + message.deprecatedErrorMessage = reader.string(); + break; + case 8: + message.interruptible = reader.bool(); break; default: reader.skipType(tag & 7); @@ -9430,87 +9471,75 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a DataLoadingConfig message. + * Verifies a TaskMetadata message. * @function verify - * @memberof flyteidl.core.DataLoadingConfig + * @memberof flyteidl.core.TaskMetadata * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - DataLoadingConfig.verify = function verify(message) { - if (typeof message !== "object" || message === null) - return "object expected"; - if (message.enabled != null && message.hasOwnProperty("enabled")) - if (typeof message.enabled !== "boolean") - return "enabled: boolean expected"; - if (message.inputPath != null && message.hasOwnProperty("inputPath")) - if (!$util.isString(message.inputPath)) - return "inputPath: string expected"; - if (message.outputPath != null && message.hasOwnProperty("outputPath")) - if (!$util.isString(message.outputPath)) - return "outputPath: string expected"; - if (message.format != null && message.hasOwnProperty("format")) - switch (message.format) { - default: - return "format: enum value expected"; - case 0: - case 1: - case 2: - break; - } - if (message.ioStrategy != null && message.hasOwnProperty("ioStrategy")) { - let error = $root.flyteidl.core.IOStrategy.verify(message.ioStrategy); + TaskMetadata.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + let properties = {}; + if (message.discoverable != null && message.hasOwnProperty("discoverable")) + if (typeof message.discoverable !== "boolean") + return "discoverable: boolean expected"; + if (message.runtime != null && message.hasOwnProperty("runtime")) { + let error = $root.flyteidl.core.RuntimeMetadata.verify(message.runtime); if (error) - return "ioStrategy." + error; + return "runtime." + error; + } + if (message.timeout != null && message.hasOwnProperty("timeout")) { + let error = $root.google.protobuf.Duration.verify(message.timeout); + if (error) + return "timeout." + error; + } + if (message.retries != null && message.hasOwnProperty("retries")) { + let error = $root.flyteidl.core.RetryStrategy.verify(message.retries); + if (error) + return "retries." + error; + } + if (message.discoveryVersion != null && message.hasOwnProperty("discoveryVersion")) + if (!$util.isString(message.discoveryVersion)) + return "discoveryVersion: string expected"; + if (message.deprecatedErrorMessage != null && message.hasOwnProperty("deprecatedErrorMessage")) + if (!$util.isString(message.deprecatedErrorMessage)) + return "deprecatedErrorMessage: string expected"; + if (message.interruptible != null && message.hasOwnProperty("interruptible")) { + properties.interruptibleValue = 1; + if (typeof message.interruptible !== "boolean") + return "interruptible: boolean expected"; } return null; }; - /** - * LiteralMapFormat enum. - * @name flyteidl.core.DataLoadingConfig.LiteralMapFormat - * @enum {string} - * @property {number} JSON=0 JSON value - * @property {number} YAML=1 YAML value - * @property {number} PROTO=2 PROTO value - */ - DataLoadingConfig.LiteralMapFormat = (function() { - const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "JSON"] = 0; - values[valuesById[1] = "YAML"] = 1; - values[valuesById[2] = "PROTO"] = 2; - return values; - })(); - - return DataLoadingConfig; + return TaskMetadata; })(); - core.DynamicJobSpec = (function() { + core.TaskTemplate = (function() { /** - * Properties of a DynamicJobSpec. + * Properties of a TaskTemplate. * @memberof flyteidl.core - * @interface IDynamicJobSpec - * @property {Array.|null} [nodes] DynamicJobSpec nodes - * @property {Long|null} [minSuccesses] DynamicJobSpec minSuccesses - * @property {Array.|null} [outputs] DynamicJobSpec outputs - * @property {Array.|null} [tasks] DynamicJobSpec tasks - * @property {Array.|null} [subworkflows] DynamicJobSpec subworkflows + * @interface ITaskTemplate + * @property {flyteidl.core.IIdentifier|null} [id] TaskTemplate id + * @property {string|null} [type] TaskTemplate type + * @property {flyteidl.core.ITaskMetadata|null} [metadata] TaskTemplate metadata + * @property {flyteidl.core.ITypedInterface|null} ["interface"] TaskTemplate interface + * @property {google.protobuf.IStruct|null} [custom] TaskTemplate custom + * @property {flyteidl.core.IContainer|null} [container] TaskTemplate container */ /** - * Constructs a new DynamicJobSpec. + * Constructs a new TaskTemplate. * @memberof flyteidl.core - * @classdesc Represents a DynamicJobSpec. - * @implements IDynamicJobSpec + * @classdesc Represents a TaskTemplate. + * @implements ITaskTemplate * @constructor - * @param {flyteidl.core.IDynamicJobSpec=} [properties] Properties to set + * @param {flyteidl.core.ITaskTemplate=} [properties] Properties to set */ - function DynamicJobSpec(properties) { - this.nodes = []; - this.outputs = []; - this.tasks = []; - this.subworkflows = []; + function TaskTemplate(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -9518,126 +9547,141 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * DynamicJobSpec nodes. - * @member {Array.} nodes - * @memberof flyteidl.core.DynamicJobSpec + * TaskTemplate id. + * @member {flyteidl.core.IIdentifier|null|undefined} id + * @memberof flyteidl.core.TaskTemplate * @instance */ - DynamicJobSpec.prototype.nodes = $util.emptyArray; + TaskTemplate.prototype.id = null; /** - * DynamicJobSpec minSuccesses. - * @member {Long} minSuccesses - * @memberof flyteidl.core.DynamicJobSpec + * TaskTemplate type. + * @member {string} type + * @memberof flyteidl.core.TaskTemplate * @instance */ - DynamicJobSpec.prototype.minSuccesses = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + TaskTemplate.prototype.type = ""; /** - * DynamicJobSpec outputs. - * @member {Array.} outputs - * @memberof flyteidl.core.DynamicJobSpec + * TaskTemplate metadata. + * @member {flyteidl.core.ITaskMetadata|null|undefined} metadata + * @memberof flyteidl.core.TaskTemplate * @instance */ - DynamicJobSpec.prototype.outputs = $util.emptyArray; + TaskTemplate.prototype.metadata = null; /** - * DynamicJobSpec tasks. - * @member {Array.} tasks - * @memberof flyteidl.core.DynamicJobSpec + * TaskTemplate interface. + * @member {flyteidl.core.ITypedInterface|null|undefined} interface + * @memberof flyteidl.core.TaskTemplate * @instance */ - DynamicJobSpec.prototype.tasks = $util.emptyArray; + TaskTemplate.prototype["interface"] = null; /** - * DynamicJobSpec subworkflows. - * @member {Array.} subworkflows - * @memberof flyteidl.core.DynamicJobSpec + * TaskTemplate custom. + * @member {google.protobuf.IStruct|null|undefined} custom + * @memberof flyteidl.core.TaskTemplate * @instance */ - DynamicJobSpec.prototype.subworkflows = $util.emptyArray; + TaskTemplate.prototype.custom = null; /** - * Creates a new DynamicJobSpec instance using the specified properties. + * TaskTemplate container. + * @member {flyteidl.core.IContainer|null|undefined} container + * @memberof flyteidl.core.TaskTemplate + * @instance + */ + TaskTemplate.prototype.container = null; + + // OneOf field names bound to virtual getters and setters + let $oneOfFields; + + /** + * TaskTemplate target. + * @member {"container"|undefined} target + * @memberof flyteidl.core.TaskTemplate + * @instance + */ + Object.defineProperty(TaskTemplate.prototype, "target", { + get: $util.oneOfGetter($oneOfFields = ["container"]), + set: $util.oneOfSetter($oneOfFields) + }); + + /** + * Creates a new TaskTemplate instance using the specified properties. * @function create - * @memberof flyteidl.core.DynamicJobSpec + * @memberof flyteidl.core.TaskTemplate * @static - * @param {flyteidl.core.IDynamicJobSpec=} [properties] Properties to set - * @returns {flyteidl.core.DynamicJobSpec} DynamicJobSpec instance + * @param {flyteidl.core.ITaskTemplate=} [properties] Properties to set + * @returns {flyteidl.core.TaskTemplate} TaskTemplate instance */ - DynamicJobSpec.create = function create(properties) { - return new DynamicJobSpec(properties); + TaskTemplate.create = function create(properties) { + return new TaskTemplate(properties); }; /** - * Encodes the specified DynamicJobSpec message. Does not implicitly {@link flyteidl.core.DynamicJobSpec.verify|verify} messages. + * Encodes the specified TaskTemplate message. Does not implicitly {@link flyteidl.core.TaskTemplate.verify|verify} messages. * @function encode - * @memberof flyteidl.core.DynamicJobSpec + * @memberof flyteidl.core.TaskTemplate * @static - * @param {flyteidl.core.IDynamicJobSpec} message DynamicJobSpec message or plain object to encode + * @param {flyteidl.core.ITaskTemplate} message TaskTemplate message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - DynamicJobSpec.encode = function encode(message, writer) { + TaskTemplate.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.nodes != null && message.nodes.length) - for (let i = 0; i < message.nodes.length; ++i) - $root.flyteidl.core.Node.encode(message.nodes[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); - if (message.minSuccesses != null && message.hasOwnProperty("minSuccesses")) - writer.uint32(/* id 2, wireType 0 =*/16).int64(message.minSuccesses); - if (message.outputs != null && message.outputs.length) - for (let i = 0; i < message.outputs.length; ++i) - $root.flyteidl.core.Binding.encode(message.outputs[i], writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); - if (message.tasks != null && message.tasks.length) - for (let i = 0; i < message.tasks.length; ++i) - $root.flyteidl.core.TaskTemplate.encode(message.tasks[i], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); - if (message.subworkflows != null && message.subworkflows.length) - for (let i = 0; i < message.subworkflows.length; ++i) - $root.flyteidl.core.WorkflowTemplate.encode(message.subworkflows[i], writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + if (message.id != null && message.hasOwnProperty("id")) + $root.flyteidl.core.Identifier.encode(message.id, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.type != null && message.hasOwnProperty("type")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.type); + if (message.metadata != null && message.hasOwnProperty("metadata")) + $root.flyteidl.core.TaskMetadata.encode(message.metadata, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message["interface"] != null && message.hasOwnProperty("interface")) + $root.flyteidl.core.TypedInterface.encode(message["interface"], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.custom != null && message.hasOwnProperty("custom")) + $root.google.protobuf.Struct.encode(message.custom, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + if (message.container != null && message.hasOwnProperty("container")) + $root.flyteidl.core.Container.encode(message.container, writer.uint32(/* id 6, wireType 2 =*/50).fork()).ldelim(); return writer; }; /** - * Decodes a DynamicJobSpec message from the specified reader or buffer. + * Decodes a TaskTemplate message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.DynamicJobSpec + * @memberof flyteidl.core.TaskTemplate * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.DynamicJobSpec} DynamicJobSpec + * @returns {flyteidl.core.TaskTemplate} TaskTemplate * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - DynamicJobSpec.decode = function decode(reader, length) { + TaskTemplate.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.core.DynamicJobSpec(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.TaskTemplate(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - if (!(message.nodes && message.nodes.length)) - message.nodes = []; - message.nodes.push($root.flyteidl.core.Node.decode(reader, reader.uint32())); + message.id = $root.flyteidl.core.Identifier.decode(reader, reader.uint32()); break; case 2: - message.minSuccesses = reader.int64(); + message.type = reader.string(); break; case 3: - if (!(message.outputs && message.outputs.length)) - message.outputs = []; - message.outputs.push($root.flyteidl.core.Binding.decode(reader, reader.uint32())); + message.metadata = $root.flyteidl.core.TaskMetadata.decode(reader, reader.uint32()); break; case 4: - if (!(message.tasks && message.tasks.length)) - message.tasks = []; - message.tasks.push($root.flyteidl.core.TaskTemplate.decode(reader, reader.uint32())); + message["interface"] = $root.flyteidl.core.TypedInterface.decode(reader, reader.uint32()); break; case 5: - if (!(message.subworkflows && message.subworkflows.length)) - message.subworkflows = []; - message.subworkflows.push($root.flyteidl.core.WorkflowTemplate.decode(reader, reader.uint32())); + message.custom = $root.google.protobuf.Struct.decode(reader, reader.uint32()); + break; + case 6: + message.container = $root.flyteidl.core.Container.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -9648,82 +9692,72 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a DynamicJobSpec message. + * Verifies a TaskTemplate message. * @function verify - * @memberof flyteidl.core.DynamicJobSpec + * @memberof flyteidl.core.TaskTemplate * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - DynamicJobSpec.verify = function verify(message) { + TaskTemplate.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.nodes != null && message.hasOwnProperty("nodes")) { - if (!Array.isArray(message.nodes)) - return "nodes: array expected"; - for (let i = 0; i < message.nodes.length; ++i) { - let error = $root.flyteidl.core.Node.verify(message.nodes[i]); - if (error) - return "nodes." + error; - } + let properties = {}; + if (message.id != null && message.hasOwnProperty("id")) { + let error = $root.flyteidl.core.Identifier.verify(message.id); + if (error) + return "id." + error; } - if (message.minSuccesses != null && message.hasOwnProperty("minSuccesses")) - if (!$util.isInteger(message.minSuccesses) && !(message.minSuccesses && $util.isInteger(message.minSuccesses.low) && $util.isInteger(message.minSuccesses.high))) - return "minSuccesses: integer|Long expected"; - if (message.outputs != null && message.hasOwnProperty("outputs")) { - if (!Array.isArray(message.outputs)) - return "outputs: array expected"; - for (let i = 0; i < message.outputs.length; ++i) { - let error = $root.flyteidl.core.Binding.verify(message.outputs[i]); - if (error) - return "outputs." + error; - } + if (message.type != null && message.hasOwnProperty("type")) + if (!$util.isString(message.type)) + return "type: string expected"; + if (message.metadata != null && message.hasOwnProperty("metadata")) { + let error = $root.flyteidl.core.TaskMetadata.verify(message.metadata); + if (error) + return "metadata." + error; } - if (message.tasks != null && message.hasOwnProperty("tasks")) { - if (!Array.isArray(message.tasks)) - return "tasks: array expected"; - for (let i = 0; i < message.tasks.length; ++i) { - let error = $root.flyteidl.core.TaskTemplate.verify(message.tasks[i]); - if (error) - return "tasks." + error; - } + if (message["interface"] != null && message.hasOwnProperty("interface")) { + let error = $root.flyteidl.core.TypedInterface.verify(message["interface"]); + if (error) + return "interface." + error; } - if (message.subworkflows != null && message.hasOwnProperty("subworkflows")) { - if (!Array.isArray(message.subworkflows)) - return "subworkflows: array expected"; - for (let i = 0; i < message.subworkflows.length; ++i) { - let error = $root.flyteidl.core.WorkflowTemplate.verify(message.subworkflows[i]); + if (message.custom != null && message.hasOwnProperty("custom")) { + let error = $root.google.protobuf.Struct.verify(message.custom); + if (error) + return "custom." + error; + } + if (message.container != null && message.hasOwnProperty("container")) { + properties.target = 1; + { + let error = $root.flyteidl.core.Container.verify(message.container); if (error) - return "subworkflows." + error; + return "container." + error; } } return null; }; - return DynamicJobSpec; + return TaskTemplate; })(); - core.ContainerError = (function() { + core.ContainerPort = (function() { /** - * Properties of a ContainerError. + * Properties of a ContainerPort. * @memberof flyteidl.core - * @interface IContainerError - * @property {string|null} [code] ContainerError code - * @property {string|null} [message] ContainerError message - * @property {flyteidl.core.ContainerError.Kind|null} [kind] ContainerError kind - * @property {flyteidl.core.ExecutionError.ErrorKind|null} [origin] ContainerError origin + * @interface IContainerPort + * @property {number|null} [containerPort] ContainerPort containerPort */ /** - * Constructs a new ContainerError. + * Constructs a new ContainerPort. * @memberof flyteidl.core - * @classdesc Represents a ContainerError. - * @implements IContainerError + * @classdesc Represents a ContainerPort. + * @implements IContainerPort * @constructor - * @param {flyteidl.core.IContainerError=} [properties] Properties to set + * @param {flyteidl.core.IContainerPort=} [properties] Properties to set */ - function ContainerError(properties) { + function ContainerPort(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -9731,101 +9765,62 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * ContainerError code. - * @member {string} code - * @memberof flyteidl.core.ContainerError - * @instance - */ - ContainerError.prototype.code = ""; - - /** - * ContainerError message. - * @member {string} message - * @memberof flyteidl.core.ContainerError - * @instance - */ - ContainerError.prototype.message = ""; - - /** - * ContainerError kind. - * @member {flyteidl.core.ContainerError.Kind} kind - * @memberof flyteidl.core.ContainerError - * @instance - */ - ContainerError.prototype.kind = 0; - - /** - * ContainerError origin. - * @member {flyteidl.core.ExecutionError.ErrorKind} origin - * @memberof flyteidl.core.ContainerError + * ContainerPort containerPort. + * @member {number} containerPort + * @memberof flyteidl.core.ContainerPort * @instance */ - ContainerError.prototype.origin = 0; + ContainerPort.prototype.containerPort = 0; /** - * Creates a new ContainerError instance using the specified properties. + * Creates a new ContainerPort instance using the specified properties. * @function create - * @memberof flyteidl.core.ContainerError + * @memberof flyteidl.core.ContainerPort * @static - * @param {flyteidl.core.IContainerError=} [properties] Properties to set - * @returns {flyteidl.core.ContainerError} ContainerError instance + * @param {flyteidl.core.IContainerPort=} [properties] Properties to set + * @returns {flyteidl.core.ContainerPort} ContainerPort instance */ - ContainerError.create = function create(properties) { - return new ContainerError(properties); + ContainerPort.create = function create(properties) { + return new ContainerPort(properties); }; /** - * Encodes the specified ContainerError message. Does not implicitly {@link flyteidl.core.ContainerError.verify|verify} messages. + * Encodes the specified ContainerPort message. Does not implicitly {@link flyteidl.core.ContainerPort.verify|verify} messages. * @function encode - * @memberof flyteidl.core.ContainerError + * @memberof flyteidl.core.ContainerPort * @static - * @param {flyteidl.core.IContainerError} message ContainerError message or plain object to encode + * @param {flyteidl.core.IContainerPort} message ContainerPort message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - ContainerError.encode = function encode(message, writer) { + ContainerPort.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.code != null && message.hasOwnProperty("code")) - writer.uint32(/* id 1, wireType 2 =*/10).string(message.code); - if (message.message != null && message.hasOwnProperty("message")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.message); - if (message.kind != null && message.hasOwnProperty("kind")) - writer.uint32(/* id 3, wireType 0 =*/24).int32(message.kind); - if (message.origin != null && message.hasOwnProperty("origin")) - writer.uint32(/* id 4, wireType 0 =*/32).int32(message.origin); + if (message.containerPort != null && message.hasOwnProperty("containerPort")) + writer.uint32(/* id 1, wireType 0 =*/8).uint32(message.containerPort); return writer; }; /** - * Decodes a ContainerError message from the specified reader or buffer. + * Decodes a ContainerPort message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.ContainerError + * @memberof flyteidl.core.ContainerPort * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.ContainerError} ContainerError + * @returns {flyteidl.core.ContainerPort} ContainerPort * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - ContainerError.decode = function decode(reader, length) { + ContainerPort.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.core.ContainerError(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.ContainerPort(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.code = reader.string(); - break; - case 2: - message.message = reader.string(); - break; - case 3: - message.kind = reader.int32(); - break; - case 4: - message.origin = reader.int32(); + message.containerPort = reader.uint32(); break; default: reader.skipType(tag & 7); @@ -9836,140 +9831,224 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a ContainerError message. + * Verifies a ContainerPort message. * @function verify - * @memberof flyteidl.core.ContainerError + * @memberof flyteidl.core.ContainerPort * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - ContainerError.verify = function verify(message) { + ContainerPort.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.code != null && message.hasOwnProperty("code")) - if (!$util.isString(message.code)) - return "code: string expected"; - if (message.message != null && message.hasOwnProperty("message")) - if (!$util.isString(message.message)) - return "message: string expected"; - if (message.kind != null && message.hasOwnProperty("kind")) - switch (message.kind) { - default: - return "kind: enum value expected"; - case 0: - case 1: - break; - } - if (message.origin != null && message.hasOwnProperty("origin")) - switch (message.origin) { - default: - return "origin: enum value expected"; - case 0: - case 1: - case 2: - break; - } + if (message.containerPort != null && message.hasOwnProperty("containerPort")) + if (!$util.isInteger(message.containerPort)) + return "containerPort: integer expected"; return null; }; + return ContainerPort; + })(); + + core.Container = (function() { + /** - * Kind enum. - * @name flyteidl.core.ContainerError.Kind - * @enum {string} - * @property {number} NON_RECOVERABLE=0 NON_RECOVERABLE value - * @property {number} RECOVERABLE=1 RECOVERABLE value + * Properties of a Container. + * @memberof flyteidl.core + * @interface IContainer + * @property {string|null} [image] Container image + * @property {Array.|null} [command] Container command + * @property {Array.|null} [args] Container args + * @property {flyteidl.core.IResources|null} [resources] Container resources + * @property {Array.|null} [env] Container env + * @property {Array.|null} [config] Container config + * @property {Array.|null} [ports] Container ports + * @property {flyteidl.core.IDataLoadingConfig|null} [dataConfig] Container dataConfig */ - ContainerError.Kind = (function() { - const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "NON_RECOVERABLE"] = 0; - values[valuesById[1] = "RECOVERABLE"] = 1; - return values; - })(); - return ContainerError; - })(); + /** + * Constructs a new Container. + * @memberof flyteidl.core + * @classdesc Represents a Container. + * @implements IContainer + * @constructor + * @param {flyteidl.core.IContainer=} [properties] Properties to set + */ + function Container(properties) { + this.command = []; + this.args = []; + this.env = []; + this.config = []; + this.ports = []; + 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]]; + } - core.ErrorDocument = (function() { + /** + * Container image. + * @member {string} image + * @memberof flyteidl.core.Container + * @instance + */ + Container.prototype.image = ""; /** - * Properties of an ErrorDocument. - * @memberof flyteidl.core - * @interface IErrorDocument - * @property {flyteidl.core.IContainerError|null} [error] ErrorDocument error + * Container command. + * @member {Array.} command + * @memberof flyteidl.core.Container + * @instance + */ + Container.prototype.command = $util.emptyArray; + + /** + * Container args. + * @member {Array.} args + * @memberof flyteidl.core.Container + * @instance + */ + Container.prototype.args = $util.emptyArray; + + /** + * Container resources. + * @member {flyteidl.core.IResources|null|undefined} resources + * @memberof flyteidl.core.Container + * @instance + */ + Container.prototype.resources = null; + + /** + * Container env. + * @member {Array.} env + * @memberof flyteidl.core.Container + * @instance + */ + Container.prototype.env = $util.emptyArray; + + /** + * Container config. + * @member {Array.} config + * @memberof flyteidl.core.Container + * @instance */ + Container.prototype.config = $util.emptyArray; /** - * Constructs a new ErrorDocument. - * @memberof flyteidl.core - * @classdesc Represents an ErrorDocument. - * @implements IErrorDocument - * @constructor - * @param {flyteidl.core.IErrorDocument=} [properties] Properties to set + * Container ports. + * @member {Array.} ports + * @memberof flyteidl.core.Container + * @instance */ - function ErrorDocument(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]]; - } + Container.prototype.ports = $util.emptyArray; /** - * ErrorDocument error. - * @member {flyteidl.core.IContainerError|null|undefined} error - * @memberof flyteidl.core.ErrorDocument + * Container dataConfig. + * @member {flyteidl.core.IDataLoadingConfig|null|undefined} dataConfig + * @memberof flyteidl.core.Container * @instance */ - ErrorDocument.prototype.error = null; + Container.prototype.dataConfig = null; /** - * Creates a new ErrorDocument instance using the specified properties. + * Creates a new Container instance using the specified properties. * @function create - * @memberof flyteidl.core.ErrorDocument + * @memberof flyteidl.core.Container * @static - * @param {flyteidl.core.IErrorDocument=} [properties] Properties to set - * @returns {flyteidl.core.ErrorDocument} ErrorDocument instance + * @param {flyteidl.core.IContainer=} [properties] Properties to set + * @returns {flyteidl.core.Container} Container instance */ - ErrorDocument.create = function create(properties) { - return new ErrorDocument(properties); + Container.create = function create(properties) { + return new Container(properties); }; /** - * Encodes the specified ErrorDocument message. Does not implicitly {@link flyteidl.core.ErrorDocument.verify|verify} messages. + * Encodes the specified Container message. Does not implicitly {@link flyteidl.core.Container.verify|verify} messages. * @function encode - * @memberof flyteidl.core.ErrorDocument + * @memberof flyteidl.core.Container * @static - * @param {flyteidl.core.IErrorDocument} message ErrorDocument message or plain object to encode + * @param {flyteidl.core.IContainer} message Container message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - ErrorDocument.encode = function encode(message, writer) { + Container.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.error != null && message.hasOwnProperty("error")) - $root.flyteidl.core.ContainerError.encode(message.error, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.image != null && message.hasOwnProperty("image")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.image); + if (message.command != null && message.command.length) + for (let i = 0; i < message.command.length; ++i) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.command[i]); + if (message.args != null && message.args.length) + for (let i = 0; i < message.args.length; ++i) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.args[i]); + if (message.resources != null && message.hasOwnProperty("resources")) + $root.flyteidl.core.Resources.encode(message.resources, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.env != null && message.env.length) + for (let i = 0; i < message.env.length; ++i) + $root.flyteidl.core.KeyValuePair.encode(message.env[i], writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); + if (message.config != null && message.config.length) + for (let i = 0; i < message.config.length; ++i) + $root.flyteidl.core.KeyValuePair.encode(message.config[i], writer.uint32(/* id 6, wireType 2 =*/50).fork()).ldelim(); + if (message.ports != null && message.ports.length) + for (let i = 0; i < message.ports.length; ++i) + $root.flyteidl.core.ContainerPort.encode(message.ports[i], writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim(); + if (message.dataConfig != null && message.hasOwnProperty("dataConfig")) + $root.flyteidl.core.DataLoadingConfig.encode(message.dataConfig, writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim(); return writer; }; /** - * Decodes an ErrorDocument message from the specified reader or buffer. + * Decodes a Container message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.ErrorDocument + * @memberof flyteidl.core.Container * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.ErrorDocument} ErrorDocument + * @returns {flyteidl.core.Container} Container * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - ErrorDocument.decode = function decode(reader, length) { + Container.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.core.ErrorDocument(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.Container(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.error = $root.flyteidl.core.ContainerError.decode(reader, reader.uint32()); + message.image = reader.string(); + break; + case 2: + if (!(message.command && message.command.length)) + message.command = []; + message.command.push(reader.string()); + break; + case 3: + if (!(message.args && message.args.length)) + message.args = []; + message.args.push(reader.string()); + break; + case 4: + message.resources = $root.flyteidl.core.Resources.decode(reader, reader.uint32()); + break; + case 5: + if (!(message.env && message.env.length)) + message.env = []; + message.env.push($root.flyteidl.core.KeyValuePair.decode(reader, reader.uint32())); + break; + case 6: + if (!(message.config && message.config.length)) + message.config = []; + message.config.push($root.flyteidl.core.KeyValuePair.decode(reader, reader.uint32())); + break; + case 7: + if (!(message.ports && message.ports.length)) + message.ports = []; + message.ports.push($root.flyteidl.core.ContainerPort.decode(reader, reader.uint32())); + break; + case 9: + message.dataConfig = $root.flyteidl.core.DataLoadingConfig.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -9980,44 +10059,95 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies an ErrorDocument message. + * Verifies a Container message. * @function verify - * @memberof flyteidl.core.ErrorDocument + * @memberof flyteidl.core.Container * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - ErrorDocument.verify = function verify(message) { + Container.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.error != null && message.hasOwnProperty("error")) { - let error = $root.flyteidl.core.ContainerError.verify(message.error); + if (message.image != null && message.hasOwnProperty("image")) + if (!$util.isString(message.image)) + return "image: string expected"; + if (message.command != null && message.hasOwnProperty("command")) { + if (!Array.isArray(message.command)) + return "command: array expected"; + for (let i = 0; i < message.command.length; ++i) + if (!$util.isString(message.command[i])) + return "command: string[] expected"; + } + if (message.args != null && message.hasOwnProperty("args")) { + if (!Array.isArray(message.args)) + return "args: array expected"; + for (let i = 0; i < message.args.length; ++i) + if (!$util.isString(message.args[i])) + return "args: string[] expected"; + } + if (message.resources != null && message.hasOwnProperty("resources")) { + let error = $root.flyteidl.core.Resources.verify(message.resources); if (error) - return "error." + error; + return "resources." + error; + } + if (message.env != null && message.hasOwnProperty("env")) { + if (!Array.isArray(message.env)) + return "env: array expected"; + for (let i = 0; i < message.env.length; ++i) { + let error = $root.flyteidl.core.KeyValuePair.verify(message.env[i]); + if (error) + return "env." + error; + } + } + if (message.config != null && message.hasOwnProperty("config")) { + if (!Array.isArray(message.config)) + return "config: array expected"; + for (let i = 0; i < message.config.length; ++i) { + let error = $root.flyteidl.core.KeyValuePair.verify(message.config[i]); + if (error) + return "config." + error; + } + } + if (message.ports != null && message.hasOwnProperty("ports")) { + if (!Array.isArray(message.ports)) + return "ports: array expected"; + for (let i = 0; i < message.ports.length; ++i) { + let error = $root.flyteidl.core.ContainerPort.verify(message.ports[i]); + if (error) + return "ports." + error; + } + } + if (message.dataConfig != null && message.hasOwnProperty("dataConfig")) { + let error = $root.flyteidl.core.DataLoadingConfig.verify(message.dataConfig); + if (error) + return "dataConfig." + error; } return null; }; - return ErrorDocument; + return Container; })(); - core.WorkflowExecution = (function() { + core.IOStrategy = (function() { /** - * Properties of a WorkflowExecution. + * Properties of a IOStrategy. * @memberof flyteidl.core - * @interface IWorkflowExecution + * @interface IIOStrategy + * @property {flyteidl.core.IOStrategy.DownloadMode|null} [downloadMode] IOStrategy downloadMode + * @property {flyteidl.core.IOStrategy.UploadMode|null} [uploadMode] IOStrategy uploadMode */ /** - * Constructs a new WorkflowExecution. + * Constructs a new IOStrategy. * @memberof flyteidl.core - * @classdesc Represents a WorkflowExecution. - * @implements IWorkflowExecution + * @classdesc Represents a IOStrategy. + * @implements IIOStrategy * @constructor - * @param {flyteidl.core.IWorkflowExecution=} [properties] Properties to set + * @param {flyteidl.core.IIOStrategy=} [properties] Properties to set */ - function WorkflowExecution(properties) { + function IOStrategy(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -10025,50 +10155,76 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * Creates a new WorkflowExecution instance using the specified properties. + * IOStrategy downloadMode. + * @member {flyteidl.core.IOStrategy.DownloadMode} downloadMode + * @memberof flyteidl.core.IOStrategy + * @instance + */ + IOStrategy.prototype.downloadMode = 0; + + /** + * IOStrategy uploadMode. + * @member {flyteidl.core.IOStrategy.UploadMode} uploadMode + * @memberof flyteidl.core.IOStrategy + * @instance + */ + IOStrategy.prototype.uploadMode = 0; + + /** + * Creates a new IOStrategy instance using the specified properties. * @function create - * @memberof flyteidl.core.WorkflowExecution + * @memberof flyteidl.core.IOStrategy * @static - * @param {flyteidl.core.IWorkflowExecution=} [properties] Properties to set - * @returns {flyteidl.core.WorkflowExecution} WorkflowExecution instance + * @param {flyteidl.core.IIOStrategy=} [properties] Properties to set + * @returns {flyteidl.core.IOStrategy} IOStrategy instance */ - WorkflowExecution.create = function create(properties) { - return new WorkflowExecution(properties); + IOStrategy.create = function create(properties) { + return new IOStrategy(properties); }; /** - * Encodes the specified WorkflowExecution message. Does not implicitly {@link flyteidl.core.WorkflowExecution.verify|verify} messages. + * Encodes the specified IOStrategy message. Does not implicitly {@link flyteidl.core.IOStrategy.verify|verify} messages. * @function encode - * @memberof flyteidl.core.WorkflowExecution + * @memberof flyteidl.core.IOStrategy * @static - * @param {flyteidl.core.IWorkflowExecution} message WorkflowExecution message or plain object to encode + * @param {flyteidl.core.IIOStrategy} message IOStrategy message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - WorkflowExecution.encode = function encode(message, writer) { + IOStrategy.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); + if (message.downloadMode != null && message.hasOwnProperty("downloadMode")) + writer.uint32(/* id 1, wireType 0 =*/8).int32(message.downloadMode); + if (message.uploadMode != null && message.hasOwnProperty("uploadMode")) + writer.uint32(/* id 2, wireType 0 =*/16).int32(message.uploadMode); return writer; }; /** - * Decodes a WorkflowExecution message from the specified reader or buffer. + * Decodes a IOStrategy message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.WorkflowExecution + * @memberof flyteidl.core.IOStrategy * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.WorkflowExecution} WorkflowExecution + * @returns {flyteidl.core.IOStrategy} IOStrategy * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - WorkflowExecution.decode = function decode(reader, length) { + IOStrategy.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.core.WorkflowExecution(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.IOStrategy(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { + case 1: + message.downloadMode = reader.int32(); + break; + case 2: + message.uploadMode = reader.int32(); + break; default: reader.skipType(tag & 7); break; @@ -10078,67 +10234,94 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a WorkflowExecution message. + * Verifies a IOStrategy message. * @function verify - * @memberof flyteidl.core.WorkflowExecution + * @memberof flyteidl.core.IOStrategy * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - WorkflowExecution.verify = function verify(message) { + IOStrategy.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; + if (message.downloadMode != null && message.hasOwnProperty("downloadMode")) + switch (message.downloadMode) { + default: + return "downloadMode: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.uploadMode != null && message.hasOwnProperty("uploadMode")) + switch (message.uploadMode) { + default: + return "uploadMode: enum value expected"; + case 0: + case 1: + case 2: + break; + } return null; }; /** - * Phase enum. - * @name flyteidl.core.WorkflowExecution.Phase + * DownloadMode enum. + * @name flyteidl.core.IOStrategy.DownloadMode * @enum {string} - * @property {number} UNDEFINED=0 UNDEFINED value - * @property {number} QUEUED=1 QUEUED value - * @property {number} RUNNING=2 RUNNING value - * @property {number} SUCCEEDING=3 SUCCEEDING value - * @property {number} SUCCEEDED=4 SUCCEEDED value - * @property {number} FAILING=5 FAILING value - * @property {number} FAILED=6 FAILED value - * @property {number} ABORTED=7 ABORTED value - * @property {number} TIMED_OUT=8 TIMED_OUT value + * @property {number} DOWNLOAD_EAGER=0 DOWNLOAD_EAGER value + * @property {number} DOWNLOAD_STREAM=1 DOWNLOAD_STREAM value + * @property {number} DO_NOT_DOWNLOAD=2 DO_NOT_DOWNLOAD value */ - WorkflowExecution.Phase = (function() { + IOStrategy.DownloadMode = (function() { const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "UNDEFINED"] = 0; - values[valuesById[1] = "QUEUED"] = 1; - values[valuesById[2] = "RUNNING"] = 2; - values[valuesById[3] = "SUCCEEDING"] = 3; - values[valuesById[4] = "SUCCEEDED"] = 4; - values[valuesById[5] = "FAILING"] = 5; - values[valuesById[6] = "FAILED"] = 6; - values[valuesById[7] = "ABORTED"] = 7; - values[valuesById[8] = "TIMED_OUT"] = 8; + values[valuesById[0] = "DOWNLOAD_EAGER"] = 0; + values[valuesById[1] = "DOWNLOAD_STREAM"] = 1; + values[valuesById[2] = "DO_NOT_DOWNLOAD"] = 2; return values; })(); - return WorkflowExecution; + /** + * UploadMode enum. + * @name flyteidl.core.IOStrategy.UploadMode + * @enum {string} + * @property {number} UPLOAD_ON_EXIT=0 UPLOAD_ON_EXIT value + * @property {number} UPLOAD_EAGER=1 UPLOAD_EAGER value + * @property {number} DO_NOT_UPLOAD=2 DO_NOT_UPLOAD value + */ + IOStrategy.UploadMode = (function() { + const valuesById = {}, values = Object.create(valuesById); + values[valuesById[0] = "UPLOAD_ON_EXIT"] = 0; + values[valuesById[1] = "UPLOAD_EAGER"] = 1; + values[valuesById[2] = "DO_NOT_UPLOAD"] = 2; + return values; + })(); + + return IOStrategy; })(); - core.NodeExecution = (function() { + core.DataLoadingConfig = (function() { /** - * Properties of a NodeExecution. + * Properties of a DataLoadingConfig. * @memberof flyteidl.core - * @interface INodeExecution + * @interface IDataLoadingConfig + * @property {boolean|null} [enabled] DataLoadingConfig enabled + * @property {string|null} [inputPath] DataLoadingConfig inputPath + * @property {string|null} [outputPath] DataLoadingConfig outputPath + * @property {flyteidl.core.DataLoadingConfig.LiteralMapFormat|null} [format] DataLoadingConfig format + * @property {flyteidl.core.IIOStrategy|null} [ioStrategy] DataLoadingConfig ioStrategy */ /** - * Constructs a new NodeExecution. + * Constructs a new DataLoadingConfig. * @memberof flyteidl.core - * @classdesc Represents a NodeExecution. - * @implements INodeExecution + * @classdesc Represents a DataLoadingConfig. + * @implements IDataLoadingConfig * @constructor - * @param {flyteidl.core.INodeExecution=} [properties] Properties to set + * @param {flyteidl.core.IDataLoadingConfig=} [properties] Properties to set */ - function NodeExecution(properties) { + function DataLoadingConfig(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -10146,50 +10329,115 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * Creates a new NodeExecution instance using the specified properties. + * DataLoadingConfig enabled. + * @member {boolean} enabled + * @memberof flyteidl.core.DataLoadingConfig + * @instance + */ + DataLoadingConfig.prototype.enabled = false; + + /** + * DataLoadingConfig inputPath. + * @member {string} inputPath + * @memberof flyteidl.core.DataLoadingConfig + * @instance + */ + DataLoadingConfig.prototype.inputPath = ""; + + /** + * DataLoadingConfig outputPath. + * @member {string} outputPath + * @memberof flyteidl.core.DataLoadingConfig + * @instance + */ + DataLoadingConfig.prototype.outputPath = ""; + + /** + * DataLoadingConfig format. + * @member {flyteidl.core.DataLoadingConfig.LiteralMapFormat} format + * @memberof flyteidl.core.DataLoadingConfig + * @instance + */ + DataLoadingConfig.prototype.format = 0; + + /** + * DataLoadingConfig ioStrategy. + * @member {flyteidl.core.IIOStrategy|null|undefined} ioStrategy + * @memberof flyteidl.core.DataLoadingConfig + * @instance + */ + DataLoadingConfig.prototype.ioStrategy = null; + + /** + * Creates a new DataLoadingConfig instance using the specified properties. * @function create - * @memberof flyteidl.core.NodeExecution + * @memberof flyteidl.core.DataLoadingConfig * @static - * @param {flyteidl.core.INodeExecution=} [properties] Properties to set - * @returns {flyteidl.core.NodeExecution} NodeExecution instance + * @param {flyteidl.core.IDataLoadingConfig=} [properties] Properties to set + * @returns {flyteidl.core.DataLoadingConfig} DataLoadingConfig instance */ - NodeExecution.create = function create(properties) { - return new NodeExecution(properties); + DataLoadingConfig.create = function create(properties) { + return new DataLoadingConfig(properties); }; /** - * Encodes the specified NodeExecution message. Does not implicitly {@link flyteidl.core.NodeExecution.verify|verify} messages. + * Encodes the specified DataLoadingConfig message. Does not implicitly {@link flyteidl.core.DataLoadingConfig.verify|verify} messages. * @function encode - * @memberof flyteidl.core.NodeExecution + * @memberof flyteidl.core.DataLoadingConfig * @static - * @param {flyteidl.core.INodeExecution} message NodeExecution message or plain object to encode + * @param {flyteidl.core.IDataLoadingConfig} message DataLoadingConfig message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - NodeExecution.encode = function encode(message, writer) { + DataLoadingConfig.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); + if (message.enabled != null && message.hasOwnProperty("enabled")) + writer.uint32(/* id 1, wireType 0 =*/8).bool(message.enabled); + if (message.inputPath != null && message.hasOwnProperty("inputPath")) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.inputPath); + if (message.outputPath != null && message.hasOwnProperty("outputPath")) + writer.uint32(/* id 3, wireType 2 =*/26).string(message.outputPath); + if (message.format != null && message.hasOwnProperty("format")) + writer.uint32(/* id 4, wireType 0 =*/32).int32(message.format); + if (message.ioStrategy != null && message.hasOwnProperty("ioStrategy")) + $root.flyteidl.core.IOStrategy.encode(message.ioStrategy, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); return writer; }; /** - * Decodes a NodeExecution message from the specified reader or buffer. + * Decodes a DataLoadingConfig message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.NodeExecution + * @memberof flyteidl.core.DataLoadingConfig * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.NodeExecution} NodeExecution + * @returns {flyteidl.core.DataLoadingConfig} DataLoadingConfig * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - NodeExecution.decode = function decode(reader, length) { + DataLoadingConfig.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.core.NodeExecution(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.DataLoadingConfig(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { + case 1: + message.enabled = reader.bool(); + break; + case 2: + message.inputPath = reader.string(); + break; + case 3: + message.outputPath = reader.string(); + break; + case 4: + message.format = reader.int32(); + break; + case 5: + message.ioStrategy = $root.flyteidl.core.IOStrategy.decode(reader, reader.uint32()); + break; default: reader.skipType(tag & 7); break; @@ -10199,67 +10447,87 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a NodeExecution message. + * Verifies a DataLoadingConfig message. * @function verify - * @memberof flyteidl.core.NodeExecution + * @memberof flyteidl.core.DataLoadingConfig * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - NodeExecution.verify = function verify(message) { + DataLoadingConfig.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; + if (message.enabled != null && message.hasOwnProperty("enabled")) + if (typeof message.enabled !== "boolean") + return "enabled: boolean expected"; + if (message.inputPath != null && message.hasOwnProperty("inputPath")) + if (!$util.isString(message.inputPath)) + return "inputPath: string expected"; + if (message.outputPath != null && message.hasOwnProperty("outputPath")) + if (!$util.isString(message.outputPath)) + return "outputPath: string expected"; + if (message.format != null && message.hasOwnProperty("format")) + switch (message.format) { + default: + return "format: enum value expected"; + case 0: + case 1: + case 2: + break; + } + if (message.ioStrategy != null && message.hasOwnProperty("ioStrategy")) { + let error = $root.flyteidl.core.IOStrategy.verify(message.ioStrategy); + if (error) + return "ioStrategy." + error; + } return null; }; /** - * Phase enum. - * @name flyteidl.core.NodeExecution.Phase + * LiteralMapFormat enum. + * @name flyteidl.core.DataLoadingConfig.LiteralMapFormat * @enum {string} - * @property {number} UNDEFINED=0 UNDEFINED value - * @property {number} QUEUED=1 QUEUED value - * @property {number} RUNNING=2 RUNNING value - * @property {number} SUCCEEDED=3 SUCCEEDED value - * @property {number} FAILING=4 FAILING value - * @property {number} FAILED=5 FAILED value - * @property {number} ABORTED=6 ABORTED value - * @property {number} SKIPPED=7 SKIPPED value - * @property {number} TIMED_OUT=8 TIMED_OUT value + * @property {number} JSON=0 JSON value + * @property {number} YAML=1 YAML value + * @property {number} PROTO=2 PROTO value */ - NodeExecution.Phase = (function() { + DataLoadingConfig.LiteralMapFormat = (function() { const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "UNDEFINED"] = 0; - values[valuesById[1] = "QUEUED"] = 1; - values[valuesById[2] = "RUNNING"] = 2; - values[valuesById[3] = "SUCCEEDED"] = 3; - values[valuesById[4] = "FAILING"] = 4; - values[valuesById[5] = "FAILED"] = 5; - values[valuesById[6] = "ABORTED"] = 6; - values[valuesById[7] = "SKIPPED"] = 7; - values[valuesById[8] = "TIMED_OUT"] = 8; + values[valuesById[0] = "JSON"] = 0; + values[valuesById[1] = "YAML"] = 1; + values[valuesById[2] = "PROTO"] = 2; return values; })(); - return NodeExecution; + return DataLoadingConfig; })(); - core.TaskExecution = (function() { + core.DynamicJobSpec = (function() { /** - * Properties of a TaskExecution. + * Properties of a DynamicJobSpec. * @memberof flyteidl.core - * @interface ITaskExecution + * @interface IDynamicJobSpec + * @property {Array.|null} [nodes] DynamicJobSpec nodes + * @property {Long|null} [minSuccesses] DynamicJobSpec minSuccesses + * @property {Array.|null} [outputs] DynamicJobSpec outputs + * @property {Array.|null} [tasks] DynamicJobSpec tasks + * @property {Array.|null} [subworkflows] DynamicJobSpec subworkflows */ /** - * Constructs a new TaskExecution. + * Constructs a new DynamicJobSpec. * @memberof flyteidl.core - * @classdesc Represents a TaskExecution. - * @implements ITaskExecution + * @classdesc Represents a DynamicJobSpec. + * @implements IDynamicJobSpec * @constructor - * @param {flyteidl.core.ITaskExecution=} [properties] Properties to set + * @param {flyteidl.core.IDynamicJobSpec=} [properties] Properties to set */ - function TaskExecution(properties) { + function DynamicJobSpec(properties) { + this.nodes = []; + this.outputs = []; + this.tasks = []; + this.subworkflows = []; if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -10267,50 +10535,127 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * Creates a new TaskExecution instance using the specified properties. + * DynamicJobSpec nodes. + * @member {Array.} nodes + * @memberof flyteidl.core.DynamicJobSpec + * @instance + */ + DynamicJobSpec.prototype.nodes = $util.emptyArray; + + /** + * DynamicJobSpec minSuccesses. + * @member {Long} minSuccesses + * @memberof flyteidl.core.DynamicJobSpec + * @instance + */ + DynamicJobSpec.prototype.minSuccesses = $util.Long ? $util.Long.fromBits(0,0,false) : 0; + + /** + * DynamicJobSpec outputs. + * @member {Array.} outputs + * @memberof flyteidl.core.DynamicJobSpec + * @instance + */ + DynamicJobSpec.prototype.outputs = $util.emptyArray; + + /** + * DynamicJobSpec tasks. + * @member {Array.} tasks + * @memberof flyteidl.core.DynamicJobSpec + * @instance + */ + DynamicJobSpec.prototype.tasks = $util.emptyArray; + + /** + * DynamicJobSpec subworkflows. + * @member {Array.} subworkflows + * @memberof flyteidl.core.DynamicJobSpec + * @instance + */ + DynamicJobSpec.prototype.subworkflows = $util.emptyArray; + + /** + * Creates a new DynamicJobSpec instance using the specified properties. * @function create - * @memberof flyteidl.core.TaskExecution + * @memberof flyteidl.core.DynamicJobSpec * @static - * @param {flyteidl.core.ITaskExecution=} [properties] Properties to set - * @returns {flyteidl.core.TaskExecution} TaskExecution instance + * @param {flyteidl.core.IDynamicJobSpec=} [properties] Properties to set + * @returns {flyteidl.core.DynamicJobSpec} DynamicJobSpec instance */ - TaskExecution.create = function create(properties) { - return new TaskExecution(properties); + DynamicJobSpec.create = function create(properties) { + return new DynamicJobSpec(properties); }; /** - * Encodes the specified TaskExecution message. Does not implicitly {@link flyteidl.core.TaskExecution.verify|verify} messages. + * Encodes the specified DynamicJobSpec message. Does not implicitly {@link flyteidl.core.DynamicJobSpec.verify|verify} messages. * @function encode - * @memberof flyteidl.core.TaskExecution + * @memberof flyteidl.core.DynamicJobSpec * @static - * @param {flyteidl.core.ITaskExecution} message TaskExecution message or plain object to encode + * @param {flyteidl.core.IDynamicJobSpec} message DynamicJobSpec message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - TaskExecution.encode = function encode(message, writer) { + DynamicJobSpec.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); + if (message.nodes != null && message.nodes.length) + for (let i = 0; i < message.nodes.length; ++i) + $root.flyteidl.core.Node.encode(message.nodes[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + if (message.minSuccesses != null && message.hasOwnProperty("minSuccesses")) + writer.uint32(/* id 2, wireType 0 =*/16).int64(message.minSuccesses); + if (message.outputs != null && message.outputs.length) + for (let i = 0; i < message.outputs.length; ++i) + $root.flyteidl.core.Binding.encode(message.outputs[i], writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); + if (message.tasks != null && message.tasks.length) + for (let i = 0; i < message.tasks.length; ++i) + $root.flyteidl.core.TaskTemplate.encode(message.tasks[i], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.subworkflows != null && message.subworkflows.length) + for (let i = 0; i < message.subworkflows.length; ++i) + $root.flyteidl.core.WorkflowTemplate.encode(message.subworkflows[i], writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); return writer; }; /** - * Decodes a TaskExecution message from the specified reader or buffer. + * Decodes a DynamicJobSpec message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.TaskExecution + * @memberof flyteidl.core.DynamicJobSpec * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.TaskExecution} TaskExecution + * @returns {flyteidl.core.DynamicJobSpec} DynamicJobSpec * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - TaskExecution.decode = function decode(reader, length) { + DynamicJobSpec.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.core.TaskExecution(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.DynamicJobSpec(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { + case 1: + if (!(message.nodes && message.nodes.length)) + message.nodes = []; + message.nodes.push($root.flyteidl.core.Node.decode(reader, reader.uint32())); + break; + case 2: + message.minSuccesses = reader.int64(); + break; + case 3: + if (!(message.outputs && message.outputs.length)) + message.outputs = []; + message.outputs.push($root.flyteidl.core.Binding.decode(reader, reader.uint32())); + break; + case 4: + if (!(message.tasks && message.tasks.length)) + message.tasks = []; + message.tasks.push($root.flyteidl.core.TaskTemplate.decode(reader, reader.uint32())); + break; + case 5: + if (!(message.subworkflows && message.subworkflows.length)) + message.subworkflows = []; + message.subworkflows.push($root.flyteidl.core.WorkflowTemplate.decode(reader, reader.uint32())); + break; default: reader.skipType(tag & 7); break; @@ -10320,69 +10665,82 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a TaskExecution message. + * Verifies a DynamicJobSpec message. * @function verify - * @memberof flyteidl.core.TaskExecution + * @memberof flyteidl.core.DynamicJobSpec * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - TaskExecution.verify = function verify(message) { + DynamicJobSpec.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; + if (message.nodes != null && message.hasOwnProperty("nodes")) { + if (!Array.isArray(message.nodes)) + return "nodes: array expected"; + for (let i = 0; i < message.nodes.length; ++i) { + let error = $root.flyteidl.core.Node.verify(message.nodes[i]); + if (error) + return "nodes." + error; + } + } + if (message.minSuccesses != null && message.hasOwnProperty("minSuccesses")) + if (!$util.isInteger(message.minSuccesses) && !(message.minSuccesses && $util.isInteger(message.minSuccesses.low) && $util.isInteger(message.minSuccesses.high))) + return "minSuccesses: integer|Long expected"; + if (message.outputs != null && message.hasOwnProperty("outputs")) { + if (!Array.isArray(message.outputs)) + return "outputs: array expected"; + for (let i = 0; i < message.outputs.length; ++i) { + let error = $root.flyteidl.core.Binding.verify(message.outputs[i]); + if (error) + return "outputs." + error; + } + } + if (message.tasks != null && message.hasOwnProperty("tasks")) { + if (!Array.isArray(message.tasks)) + return "tasks: array expected"; + for (let i = 0; i < message.tasks.length; ++i) { + let error = $root.flyteidl.core.TaskTemplate.verify(message.tasks[i]); + if (error) + return "tasks." + error; + } + } + if (message.subworkflows != null && message.hasOwnProperty("subworkflows")) { + if (!Array.isArray(message.subworkflows)) + return "subworkflows: array expected"; + for (let i = 0; i < message.subworkflows.length; ++i) { + let error = $root.flyteidl.core.WorkflowTemplate.verify(message.subworkflows[i]); + if (error) + return "subworkflows." + error; + } + } return null; }; - /** - * Phase enum. - * @name flyteidl.core.TaskExecution.Phase - * @enum {string} - * @property {number} UNDEFINED=0 UNDEFINED value - * @property {number} QUEUED=1 QUEUED value - * @property {number} RUNNING=2 RUNNING value - * @property {number} SUCCEEDED=3 SUCCEEDED value - * @property {number} ABORTED=4 ABORTED value - * @property {number} FAILED=5 FAILED value - * @property {number} INITIALIZING=6 INITIALIZING value - * @property {number} WAITING_FOR_RESOURCES=7 WAITING_FOR_RESOURCES value - */ - TaskExecution.Phase = (function() { - const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "UNDEFINED"] = 0; - values[valuesById[1] = "QUEUED"] = 1; - values[valuesById[2] = "RUNNING"] = 2; - values[valuesById[3] = "SUCCEEDED"] = 3; - values[valuesById[4] = "ABORTED"] = 4; - values[valuesById[5] = "FAILED"] = 5; - values[valuesById[6] = "INITIALIZING"] = 6; - values[valuesById[7] = "WAITING_FOR_RESOURCES"] = 7; - return values; - })(); - - return TaskExecution; + return DynamicJobSpec; })(); - core.ExecutionError = (function() { + core.ContainerError = (function() { /** - * Properties of an ExecutionError. + * Properties of a ContainerError. * @memberof flyteidl.core - * @interface IExecutionError - * @property {string|null} [code] ExecutionError code - * @property {string|null} [message] ExecutionError message - * @property {string|null} [errorUri] ExecutionError errorUri - * @property {flyteidl.core.ExecutionError.ErrorKind|null} [kind] ExecutionError kind + * @interface IContainerError + * @property {string|null} [code] ContainerError code + * @property {string|null} [message] ContainerError message + * @property {flyteidl.core.ContainerError.Kind|null} [kind] ContainerError kind + * @property {flyteidl.core.ExecutionError.ErrorKind|null} [origin] ContainerError origin */ /** - * Constructs a new ExecutionError. + * Constructs a new ContainerError. * @memberof flyteidl.core - * @classdesc Represents an ExecutionError. - * @implements IExecutionError + * @classdesc Represents a ContainerError. + * @implements IContainerError * @constructor - * @param {flyteidl.core.IExecutionError=} [properties] Properties to set + * @param {flyteidl.core.IContainerError=} [properties] Properties to set */ - function ExecutionError(properties) { + function ContainerError(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -10390,87 +10748,87 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * ExecutionError code. + * ContainerError code. * @member {string} code - * @memberof flyteidl.core.ExecutionError + * @memberof flyteidl.core.ContainerError * @instance */ - ExecutionError.prototype.code = ""; + ContainerError.prototype.code = ""; /** - * ExecutionError message. + * ContainerError message. * @member {string} message - * @memberof flyteidl.core.ExecutionError + * @memberof flyteidl.core.ContainerError * @instance */ - ExecutionError.prototype.message = ""; + ContainerError.prototype.message = ""; /** - * ExecutionError errorUri. - * @member {string} errorUri - * @memberof flyteidl.core.ExecutionError + * ContainerError kind. + * @member {flyteidl.core.ContainerError.Kind} kind + * @memberof flyteidl.core.ContainerError * @instance */ - ExecutionError.prototype.errorUri = ""; + ContainerError.prototype.kind = 0; /** - * ExecutionError kind. - * @member {flyteidl.core.ExecutionError.ErrorKind} kind - * @memberof flyteidl.core.ExecutionError + * ContainerError origin. + * @member {flyteidl.core.ExecutionError.ErrorKind} origin + * @memberof flyteidl.core.ContainerError * @instance */ - ExecutionError.prototype.kind = 0; + ContainerError.prototype.origin = 0; /** - * Creates a new ExecutionError instance using the specified properties. + * Creates a new ContainerError instance using the specified properties. * @function create - * @memberof flyteidl.core.ExecutionError - * @static - * @param {flyteidl.core.IExecutionError=} [properties] Properties to set - * @returns {flyteidl.core.ExecutionError} ExecutionError instance + * @memberof flyteidl.core.ContainerError + * @static + * @param {flyteidl.core.IContainerError=} [properties] Properties to set + * @returns {flyteidl.core.ContainerError} ContainerError instance */ - ExecutionError.create = function create(properties) { - return new ExecutionError(properties); + ContainerError.create = function create(properties) { + return new ContainerError(properties); }; /** - * Encodes the specified ExecutionError message. Does not implicitly {@link flyteidl.core.ExecutionError.verify|verify} messages. + * Encodes the specified ContainerError message. Does not implicitly {@link flyteidl.core.ContainerError.verify|verify} messages. * @function encode - * @memberof flyteidl.core.ExecutionError + * @memberof flyteidl.core.ContainerError * @static - * @param {flyteidl.core.IExecutionError} message ExecutionError message or plain object to encode + * @param {flyteidl.core.IContainerError} message ContainerError message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - ExecutionError.encode = function encode(message, writer) { + ContainerError.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); if (message.code != null && message.hasOwnProperty("code")) writer.uint32(/* id 1, wireType 2 =*/10).string(message.code); if (message.message != null && message.hasOwnProperty("message")) writer.uint32(/* id 2, wireType 2 =*/18).string(message.message); - if (message.errorUri != null && message.hasOwnProperty("errorUri")) - writer.uint32(/* id 3, wireType 2 =*/26).string(message.errorUri); if (message.kind != null && message.hasOwnProperty("kind")) - writer.uint32(/* id 4, wireType 0 =*/32).int32(message.kind); + writer.uint32(/* id 3, wireType 0 =*/24).int32(message.kind); + if (message.origin != null && message.hasOwnProperty("origin")) + writer.uint32(/* id 4, wireType 0 =*/32).int32(message.origin); return writer; }; /** - * Decodes an ExecutionError message from the specified reader or buffer. + * Decodes a ContainerError message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.ExecutionError + * @memberof flyteidl.core.ContainerError * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.ExecutionError} ExecutionError + * @returns {flyteidl.core.ContainerError} ContainerError * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - ExecutionError.decode = function decode(reader, length) { + ContainerError.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.core.ExecutionError(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.ContainerError(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { @@ -10481,10 +10839,10 @@ export const flyteidl = $root.flyteidl = (() => { message.message = reader.string(); break; case 3: - message.errorUri = reader.string(); + message.kind = reader.int32(); break; case 4: - message.kind = reader.int32(); + message.origin = reader.int32(); break; default: reader.skipType(tag & 7); @@ -10495,14 +10853,14 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies an ExecutionError message. + * Verifies a ContainerError message. * @function verify - * @memberof flyteidl.core.ExecutionError + * @memberof flyteidl.core.ContainerError * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - ExecutionError.verify = function verify(message) { + ContainerError.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; if (message.code != null && message.hasOwnProperty("code")) @@ -10511,14 +10869,19 @@ export const flyteidl = $root.flyteidl = (() => { if (message.message != null && message.hasOwnProperty("message")) if (!$util.isString(message.message)) return "message: string expected"; - if (message.errorUri != null && message.hasOwnProperty("errorUri")) - if (!$util.isString(message.errorUri)) - return "errorUri: string expected"; if (message.kind != null && message.hasOwnProperty("kind")) switch (message.kind) { default: return "kind: enum value expected"; case 0: + case 1: + break; + } + if (message.origin != null && message.hasOwnProperty("origin")) + switch (message.origin) { + default: + return "origin: enum value expected"; + case 0: case 1: case 2: break; @@ -10527,45 +10890,40 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * ErrorKind enum. - * @name flyteidl.core.ExecutionError.ErrorKind + * Kind enum. + * @name flyteidl.core.ContainerError.Kind * @enum {string} - * @property {number} UNKNOWN=0 UNKNOWN value - * @property {number} USER=1 USER value - * @property {number} SYSTEM=2 SYSTEM value + * @property {number} NON_RECOVERABLE=0 NON_RECOVERABLE value + * @property {number} RECOVERABLE=1 RECOVERABLE value */ - ExecutionError.ErrorKind = (function() { + ContainerError.Kind = (function() { const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "UNKNOWN"] = 0; - values[valuesById[1] = "USER"] = 1; - values[valuesById[2] = "SYSTEM"] = 2; + values[valuesById[0] = "NON_RECOVERABLE"] = 0; + values[valuesById[1] = "RECOVERABLE"] = 1; return values; })(); - return ExecutionError; + return ContainerError; })(); - core.TaskLog = (function() { + core.ErrorDocument = (function() { /** - * Properties of a TaskLog. + * Properties of an ErrorDocument. * @memberof flyteidl.core - * @interface ITaskLog - * @property {string|null} [uri] TaskLog uri - * @property {string|null} [name] TaskLog name - * @property {flyteidl.core.TaskLog.MessageFormat|null} [messageFormat] TaskLog messageFormat - * @property {google.protobuf.IDuration|null} [ttl] TaskLog ttl + * @interface IErrorDocument + * @property {flyteidl.core.IContainerError|null} [error] ErrorDocument error */ /** - * Constructs a new TaskLog. + * Constructs a new ErrorDocument. * @memberof flyteidl.core - * @classdesc Represents a TaskLog. - * @implements ITaskLog + * @classdesc Represents an ErrorDocument. + * @implements IErrorDocument * @constructor - * @param {flyteidl.core.ITaskLog=} [properties] Properties to set + * @param {flyteidl.core.IErrorDocument=} [properties] Properties to set */ - function TaskLog(properties) { + function ErrorDocument(properties) { if (properties) for (let keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -10573,101 +10931,62 @@ export const flyteidl = $root.flyteidl = (() => { } /** - * TaskLog uri. - * @member {string} uri - * @memberof flyteidl.core.TaskLog - * @instance - */ - TaskLog.prototype.uri = ""; - - /** - * TaskLog name. - * @member {string} name - * @memberof flyteidl.core.TaskLog - * @instance - */ - TaskLog.prototype.name = ""; - - /** - * TaskLog messageFormat. - * @member {flyteidl.core.TaskLog.MessageFormat} messageFormat - * @memberof flyteidl.core.TaskLog - * @instance - */ - TaskLog.prototype.messageFormat = 0; - - /** - * TaskLog ttl. - * @member {google.protobuf.IDuration|null|undefined} ttl - * @memberof flyteidl.core.TaskLog + * ErrorDocument error. + * @member {flyteidl.core.IContainerError|null|undefined} error + * @memberof flyteidl.core.ErrorDocument * @instance */ - TaskLog.prototype.ttl = null; + ErrorDocument.prototype.error = null; /** - * Creates a new TaskLog instance using the specified properties. + * Creates a new ErrorDocument instance using the specified properties. * @function create - * @memberof flyteidl.core.TaskLog + * @memberof flyteidl.core.ErrorDocument * @static - * @param {flyteidl.core.ITaskLog=} [properties] Properties to set - * @returns {flyteidl.core.TaskLog} TaskLog instance + * @param {flyteidl.core.IErrorDocument=} [properties] Properties to set + * @returns {flyteidl.core.ErrorDocument} ErrorDocument instance */ - TaskLog.create = function create(properties) { - return new TaskLog(properties); + ErrorDocument.create = function create(properties) { + return new ErrorDocument(properties); }; /** - * Encodes the specified TaskLog message. Does not implicitly {@link flyteidl.core.TaskLog.verify|verify} messages. + * Encodes the specified ErrorDocument message. Does not implicitly {@link flyteidl.core.ErrorDocument.verify|verify} messages. * @function encode - * @memberof flyteidl.core.TaskLog + * @memberof flyteidl.core.ErrorDocument * @static - * @param {flyteidl.core.ITaskLog} message TaskLog message or plain object to encode + * @param {flyteidl.core.IErrorDocument} message ErrorDocument message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ - TaskLog.encode = function encode(message, writer) { + ErrorDocument.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); - if (message.uri != null && message.hasOwnProperty("uri")) - writer.uint32(/* id 1, wireType 2 =*/10).string(message.uri); - if (message.name != null && message.hasOwnProperty("name")) - writer.uint32(/* id 2, wireType 2 =*/18).string(message.name); - if (message.messageFormat != null && message.hasOwnProperty("messageFormat")) - writer.uint32(/* id 3, wireType 0 =*/24).int32(message.messageFormat); - if (message.ttl != null && message.hasOwnProperty("ttl")) - $root.google.protobuf.Duration.encode(message.ttl, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.error != null && message.hasOwnProperty("error")) + $root.flyteidl.core.ContainerError.encode(message.error, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); return writer; }; /** - * Decodes a TaskLog message from the specified reader or buffer. + * Decodes an ErrorDocument message from the specified reader or buffer. * @function decode - * @memberof flyteidl.core.TaskLog + * @memberof flyteidl.core.ErrorDocument * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand - * @returns {flyteidl.core.TaskLog} TaskLog + * @returns {flyteidl.core.ErrorDocument} ErrorDocument * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ - TaskLog.decode = function decode(reader, length) { + ErrorDocument.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.core.TaskLog(); + let end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.core.ErrorDocument(); while (reader.pos < end) { let tag = reader.uint32(); switch (tag >>> 3) { case 1: - message.uri = reader.string(); - break; - case 2: - message.name = reader.string(); - break; - case 3: - message.messageFormat = reader.int32(); - break; - case 4: - message.ttl = $root.google.protobuf.Duration.decode(reader, reader.uint32()); + message.error = $root.flyteidl.core.ContainerError.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); @@ -10678,56 +10997,25 @@ export const flyteidl = $root.flyteidl = (() => { }; /** - * Verifies a TaskLog message. + * Verifies an ErrorDocument message. * @function verify - * @memberof flyteidl.core.TaskLog + * @memberof flyteidl.core.ErrorDocument * @static * @param {Object.} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ - TaskLog.verify = function verify(message) { + ErrorDocument.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.uri != null && message.hasOwnProperty("uri")) - if (!$util.isString(message.uri)) - return "uri: string expected"; - if (message.name != null && message.hasOwnProperty("name")) - if (!$util.isString(message.name)) - return "name: string expected"; - if (message.messageFormat != null && message.hasOwnProperty("messageFormat")) - switch (message.messageFormat) { - default: - return "messageFormat: enum value expected"; - case 0: - case 1: - case 2: - break; - } - if (message.ttl != null && message.hasOwnProperty("ttl")) { - let error = $root.google.protobuf.Duration.verify(message.ttl); + if (message.error != null && message.hasOwnProperty("error")) { + let error = $root.flyteidl.core.ContainerError.verify(message.error); if (error) - return "ttl." + error; + return "error." + error; } return null; }; - /** - * MessageFormat enum. - * @name flyteidl.core.TaskLog.MessageFormat - * @enum {string} - * @property {number} UNKNOWN=0 UNKNOWN value - * @property {number} CSV=1 CSV value - * @property {number} JSON=2 JSON value - */ - TaskLog.MessageFormat = (function() { - const valuesById = {}, values = Object.create(valuesById); - values[valuesById[0] = "UNKNOWN"] = 0; - values[valuesById[1] = "CSV"] = 1; - values[valuesById[2] = "JSON"] = 2; - return values; - })(); - - return TaskLog; + return ErrorDocument; })(); core.WorkflowClosure = (function() { @@ -17933,6 +18221,7 @@ export const flyteidl = $root.flyteidl = (() => { * @property {flyteidl.admin.ILabels|null} [labels] ExecutionSpec labels * @property {flyteidl.admin.IAnnotations|null} [annotations] ExecutionSpec annotations * @property {flyteidl.admin.IAuthRole|null} [authRole] ExecutionSpec authRole + * @property {flyteidl.core.IQualityOfService|null} [qualityOfService] ExecutionSpec qualityOfService */ /** @@ -18014,6 +18303,14 @@ export const flyteidl = $root.flyteidl = (() => { */ ExecutionSpec.prototype.authRole = null; + /** + * ExecutionSpec qualityOfService. + * @member {flyteidl.core.IQualityOfService|null|undefined} qualityOfService + * @memberof flyteidl.admin.ExecutionSpec + * @instance + */ + ExecutionSpec.prototype.qualityOfService = null; + // OneOf field names bound to virtual getters and setters let $oneOfFields; @@ -18068,6 +18365,8 @@ export const flyteidl = $root.flyteidl = (() => { $root.flyteidl.admin.Annotations.encode(message.annotations, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); if (message.authRole != null && message.hasOwnProperty("authRole")) $root.flyteidl.admin.AuthRole.encode(message.authRole, writer.uint32(/* id 16, wireType 2 =*/130).fork()).ldelim(); + if (message.qualityOfService != null && message.hasOwnProperty("qualityOfService")) + $root.flyteidl.core.QualityOfService.encode(message.qualityOfService, writer.uint32(/* id 17, wireType 2 =*/138).fork()).ldelim(); return writer; }; @@ -18113,6 +18412,9 @@ export const flyteidl = $root.flyteidl = (() => { case 16: message.authRole = $root.flyteidl.admin.AuthRole.decode(reader, reader.uint32()); break; + case 17: + message.qualityOfService = $root.flyteidl.core.QualityOfService.decode(reader, reader.uint32()); + break; default: reader.skipType(tag & 7); break; @@ -18178,6 +18480,11 @@ export const flyteidl = $root.flyteidl = (() => { if (error) return "authRole." + error; } + if (message.qualityOfService != null && message.hasOwnProperty("qualityOfService")) { + let error = $root.flyteidl.core.QualityOfService.verify(message.qualityOfService); + if (error) + return "qualityOfService." + error; + } return null; }; @@ -19337,6 +19644,7 @@ export const flyteidl = $root.flyteidl = (() => { * @property {flyteidl.admin.IAnnotations|null} [annotations] LaunchPlanSpec annotations * @property {flyteidl.admin.IAuth|null} [auth] LaunchPlanSpec auth * @property {flyteidl.admin.IAuthRole|null} [authRole] LaunchPlanSpec authRole + * @property {flyteidl.core.IQualityOfService|null} [qualityOfService] LaunchPlanSpec qualityOfService */ /** @@ -19426,6 +19734,14 @@ export const flyteidl = $root.flyteidl = (() => { */ LaunchPlanSpec.prototype.authRole = null; + /** + * LaunchPlanSpec qualityOfService. + * @member {flyteidl.core.IQualityOfService|null|undefined} qualityOfService + * @memberof flyteidl.admin.LaunchPlanSpec + * @instance + */ + LaunchPlanSpec.prototype.qualityOfService = null; + /** * Creates a new LaunchPlanSpec instance using the specified properties. * @function create @@ -19468,6 +19784,8 @@ export const flyteidl = $root.flyteidl = (() => { $root.flyteidl.admin.Auth.encode(message.auth, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim(); if (message.authRole != null && message.hasOwnProperty("authRole")) $root.flyteidl.admin.AuthRole.encode(message.authRole, writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim(); + if (message.qualityOfService != null && message.hasOwnProperty("qualityOfService")) + $root.flyteidl.core.QualityOfService.encode(message.qualityOfService, writer.uint32(/* id 16, wireType 2 =*/130).fork()).ldelim(); return writer; }; @@ -19516,6 +19834,9 @@ export const flyteidl = $root.flyteidl = (() => { case 9: message.authRole = $root.flyteidl.admin.AuthRole.decode(reader, reader.uint32()); break; + case 16: + message.qualityOfService = $root.flyteidl.core.QualityOfService.decode(reader, reader.uint32()); + break; default: reader.skipType(tag & 7); break; @@ -19578,6 +19899,11 @@ export const flyteidl = $root.flyteidl = (() => { if (error) return "authRole." + error; } + if (message.qualityOfService != null && message.hasOwnProperty("qualityOfService")) { + let error = $root.flyteidl.core.QualityOfService.verify(message.qualityOfService); + if (error) + return "qualityOfService." + error; + } return null; }; @@ -20758,6 +21084,7 @@ export const flyteidl = $root.flyteidl = (() => { * @property {number} CLUSTER_RESOURCE=1 CLUSTER_RESOURCE value * @property {number} EXECUTION_QUEUE=2 EXECUTION_QUEUE value * @property {number} EXECUTION_CLUSTER_LABEL=3 EXECUTION_CLUSTER_LABEL value + * @property {number} QUALITY_OF_SERVICE_SPECIFICATION=4 QUALITY_OF_SERVICE_SPECIFICATION value */ admin.MatchableResource = (function() { const valuesById = {}, values = Object.create(valuesById); @@ -20765,6 +21092,7 @@ export const flyteidl = $root.flyteidl = (() => { values[valuesById[1] = "CLUSTER_RESOURCE"] = 1; values[valuesById[2] = "EXECUTION_QUEUE"] = 2; values[valuesById[3] = "EXECUTION_CLUSTER_LABEL"] = 3; + values[valuesById[4] = "QUALITY_OF_SERVICE_SPECIFICATION"] = 4; return values; })(); @@ -21420,6 +21748,7 @@ export const flyteidl = $root.flyteidl = (() => { * @property {flyteidl.admin.IClusterResourceAttributes|null} [clusterResourceAttributes] MatchingAttributes clusterResourceAttributes * @property {flyteidl.admin.IExecutionQueueAttributes|null} [executionQueueAttributes] MatchingAttributes executionQueueAttributes * @property {flyteidl.admin.IExecutionClusterLabel|null} [executionClusterLabel] MatchingAttributes executionClusterLabel + * @property {flyteidl.core.IQualityOfService|null} [qualityOfService] MatchingAttributes qualityOfService */ /** @@ -21469,17 +21798,25 @@ export const flyteidl = $root.flyteidl = (() => { */ MatchingAttributes.prototype.executionClusterLabel = null; + /** + * MatchingAttributes qualityOfService. + * @member {flyteidl.core.IQualityOfService|null|undefined} qualityOfService + * @memberof flyteidl.admin.MatchingAttributes + * @instance + */ + MatchingAttributes.prototype.qualityOfService = null; + // OneOf field names bound to virtual getters and setters let $oneOfFields; /** * MatchingAttributes target. - * @member {"taskResourceAttributes"|"clusterResourceAttributes"|"executionQueueAttributes"|"executionClusterLabel"|undefined} target + * @member {"taskResourceAttributes"|"clusterResourceAttributes"|"executionQueueAttributes"|"executionClusterLabel"|"qualityOfService"|undefined} target * @memberof flyteidl.admin.MatchingAttributes * @instance */ Object.defineProperty(MatchingAttributes.prototype, "target", { - get: $util.oneOfGetter($oneOfFields = ["taskResourceAttributes", "clusterResourceAttributes", "executionQueueAttributes", "executionClusterLabel"]), + get: $util.oneOfGetter($oneOfFields = ["taskResourceAttributes", "clusterResourceAttributes", "executionQueueAttributes", "executionClusterLabel", "qualityOfService"]), set: $util.oneOfSetter($oneOfFields) }); @@ -21515,6 +21852,8 @@ export const flyteidl = $root.flyteidl = (() => { $root.flyteidl.admin.ExecutionQueueAttributes.encode(message.executionQueueAttributes, writer.uint32(/* id 3, wireType 2 =*/26).fork()).ldelim(); if (message.executionClusterLabel != null && message.hasOwnProperty("executionClusterLabel")) $root.flyteidl.admin.ExecutionClusterLabel.encode(message.executionClusterLabel, writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); + if (message.qualityOfService != null && message.hasOwnProperty("qualityOfService")) + $root.flyteidl.core.QualityOfService.encode(message.qualityOfService, writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim(); return writer; }; @@ -21548,6 +21887,9 @@ export const flyteidl = $root.flyteidl = (() => { case 4: message.executionClusterLabel = $root.flyteidl.admin.ExecutionClusterLabel.decode(reader, reader.uint32()); break; + case 5: + message.qualityOfService = $root.flyteidl.core.QualityOfService.decode(reader, reader.uint32()); + break; default: reader.skipType(tag & 7); break; @@ -21606,6 +21948,16 @@ export const flyteidl = $root.flyteidl = (() => { return "executionClusterLabel." + error; } } + if (message.qualityOfService != null && message.hasOwnProperty("qualityOfService")) { + if (properties.target === 1) + return "target: multiple values"; + properties.target = 1; + { + let error = $root.flyteidl.core.QualityOfService.verify(message.qualityOfService); + if (error) + return "qualityOfService." + error; + } + } return null; }; @@ -21901,6 +22253,7 @@ export const flyteidl = $root.flyteidl = (() => { case 1: case 2: case 3: + case 4: break; } return null; @@ -24925,6 +25278,7 @@ export const flyteidl = $root.flyteidl = (() => { case 1: case 2: case 3: + case 4: break; } return null; @@ -25188,6 +25542,7 @@ export const flyteidl = $root.flyteidl = (() => { case 1: case 2: case 3: + case 4: break; } return null; @@ -28454,6 +28809,7 @@ export const flyteidl = $root.flyteidl = (() => { case 1: case 2: case 3: + case 4: break; } return null; @@ -28734,6 +29090,7 @@ export const flyteidl = $root.flyteidl = (() => { case 1: case 2: case 3: + case 4: break; } return null; diff --git a/flyteidl/gen/pb-protodoc/flyteidl/admin/execution.proto.rst b/flyteidl/gen/pb-protodoc/flyteidl/admin/execution.proto.rst index 1b11172e894..3b87ec6073e 100644 --- a/flyteidl/gen/pb-protodoc/flyteidl/admin/execution.proto.rst +++ b/flyteidl/gen/pb-protodoc/flyteidl/admin/execution.proto.rst @@ -569,7 +569,8 @@ of an execution as it progresses across phase changes.. "disable_all": "...", "labels": "{...}", "annotations": "{...}", - "auth_role": "{...}" + "auth_role": "{...}", + "quality_of_service": "{...}" } .. _api_field_flyteidl.admin.ExecutionSpec.launch_plan: @@ -628,6 +629,12 @@ auth_role (:ref:`flyteidl.admin.AuthRole `) Optional: auth override to apply this execution. +.. _api_field_flyteidl.admin.ExecutionSpec.quality_of_service: + +quality_of_service + (:ref:`flyteidl.core.QualityOfService `) Indicates the runtime priority of the execution. + + .. _api_msg_flyteidl.admin.ExecutionTerminateRequest: @@ -635,7 +642,7 @@ auth_role flyteidl.admin.ExecutionTerminateRequest ---------------------------------------- -`[flyteidl.admin.ExecutionTerminateRequest proto] `_ +`[flyteidl.admin.ExecutionTerminateRequest proto] `_ Request to terminate an in-progress execution. This action is irreversible. If an execution is already terminated, this request will simply be a no-op. @@ -669,7 +676,7 @@ cause flyteidl.admin.ExecutionTerminateResponse ----------------------------------------- -`[flyteidl.admin.ExecutionTerminateResponse proto] `_ +`[flyteidl.admin.ExecutionTerminateResponse proto] `_ .. code-block:: json @@ -684,7 +691,7 @@ flyteidl.admin.ExecutionTerminateResponse flyteidl.admin.WorkflowExecutionGetDataRequest ---------------------------------------------- -`[flyteidl.admin.WorkflowExecutionGetDataRequest proto] `_ +`[flyteidl.admin.WorkflowExecutionGetDataRequest proto] `_ Request structure to fetch inputs and output urls for an execution. @@ -707,7 +714,7 @@ id flyteidl.admin.WorkflowExecutionGetDataResponse ----------------------------------------------- -`[flyteidl.admin.WorkflowExecutionGetDataResponse proto] `_ +`[flyteidl.admin.WorkflowExecutionGetDataResponse proto] `_ Response structure for WorkflowExecutionGetDataRequest which contains inputs and outputs for an execution. diff --git a/flyteidl/gen/pb-protodoc/flyteidl/admin/launch_plan.proto.rst b/flyteidl/gen/pb-protodoc/flyteidl/admin/launch_plan.proto.rst index 1834146912d..0ba3fa66095 100644 --- a/flyteidl/gen/pb-protodoc/flyteidl/admin/launch_plan.proto.rst +++ b/flyteidl/gen/pb-protodoc/flyteidl/admin/launch_plan.proto.rst @@ -8,7 +8,7 @@ launch_plan.proto flyteidl.admin.LaunchPlanCreateRequest -------------------------------------- -`[flyteidl.admin.LaunchPlanCreateRequest proto] `_ +`[flyteidl.admin.LaunchPlanCreateRequest proto] `_ Request to register a launch plan. A LaunchPlanSpec may include a complete or incomplete set of inputs required to launch a workflow execution. By default all launch plans are registered in state INACTIVE. If you wish to @@ -40,7 +40,7 @@ spec flyteidl.admin.LaunchPlanCreateResponse --------------------------------------- -`[flyteidl.admin.LaunchPlanCreateResponse proto] `_ +`[flyteidl.admin.LaunchPlanCreateResponse proto] `_ .. code-block:: json @@ -55,7 +55,7 @@ flyteidl.admin.LaunchPlanCreateResponse flyteidl.admin.LaunchPlan ------------------------- -`[flyteidl.admin.LaunchPlan proto] `_ +`[flyteidl.admin.LaunchPlan proto] `_ A LaunchPlan provides the capability to templatize workflow executions. Launch plans simplify associating one or more schedules, inputs and notifications with your workflows. @@ -92,7 +92,7 @@ closure flyteidl.admin.LaunchPlanList ----------------------------- -`[flyteidl.admin.LaunchPlanList proto] `_ +`[flyteidl.admin.LaunchPlanList proto] `_ Response object for list launch plan requests. @@ -122,7 +122,7 @@ token flyteidl.admin.Auth ------------------- -`[flyteidl.admin.Auth proto] `_ +`[flyteidl.admin.Auth proto] `_ Defines permissions associated with executions created by this launch plan spec. @@ -156,7 +156,7 @@ kubernetes_service_account flyteidl.admin.LaunchPlanSpec ----------------------------- -`[flyteidl.admin.LaunchPlanSpec proto] `_ +`[flyteidl.admin.LaunchPlanSpec proto] `_ User-provided launch plan definition and configuration values. @@ -171,7 +171,8 @@ User-provided launch plan definition and configuration values. "labels": "{...}", "annotations": "{...}", "auth": "{...}", - "auth_role": "{...}" + "auth_role": "{...}", + "quality_of_service": "{...}" } .. _api_field_flyteidl.admin.LaunchPlanSpec.workflow_id: @@ -227,6 +228,12 @@ auth auth_role (:ref:`flyteidl.admin.AuthRole `) +.. _api_field_flyteidl.admin.LaunchPlanSpec.quality_of_service: + +quality_of_service + (:ref:`flyteidl.core.QualityOfService `) Indicates the runtime priority of the execution. + + .. _api_msg_flyteidl.admin.LaunchPlanClosure: @@ -234,7 +241,7 @@ auth_role flyteidl.admin.LaunchPlanClosure -------------------------------- -`[flyteidl.admin.LaunchPlanClosure proto] `_ +`[flyteidl.admin.LaunchPlanClosure proto] `_ Values computed by the flyte platform after launch plan registration. These include expected_inputs required to be present in a CreateExecutionRequest @@ -287,7 +294,7 @@ updated_at flyteidl.admin.LaunchPlanMetadata --------------------------------- -`[flyteidl.admin.LaunchPlanMetadata proto] `_ +`[flyteidl.admin.LaunchPlanMetadata proto] `_ Additional launch plan attributes included in the LaunchPlanSpec not strictly required to launch the reference workflow. @@ -318,7 +325,7 @@ notifications flyteidl.admin.LaunchPlanUpdateRequest -------------------------------------- -`[flyteidl.admin.LaunchPlanUpdateRequest proto] `_ +`[flyteidl.admin.LaunchPlanUpdateRequest proto] `_ Request to set the referenced launch plan state to the configured value. @@ -348,7 +355,7 @@ state flyteidl.admin.LaunchPlanUpdateResponse --------------------------------------- -`[flyteidl.admin.LaunchPlanUpdateResponse proto] `_ +`[flyteidl.admin.LaunchPlanUpdateResponse proto] `_ Purposefully empty, may be populated in the future. @@ -364,7 +371,7 @@ Purposefully empty, may be populated in the future. flyteidl.admin.ActiveLaunchPlanRequest -------------------------------------- -`[flyteidl.admin.ActiveLaunchPlanRequest proto] `_ +`[flyteidl.admin.ActiveLaunchPlanRequest proto] `_ Represents a request struct for finding an active launch plan for a given NamedEntityIdentifier @@ -386,7 +393,7 @@ id flyteidl.admin.ActiveLaunchPlanListRequest ------------------------------------------ -`[flyteidl.admin.ActiveLaunchPlanListRequest proto] `_ +`[flyteidl.admin.ActiveLaunchPlanListRequest proto] `_ Represents a request structure to list active launch plans within a project/domain. @@ -439,7 +446,7 @@ sort_by Enum flyteidl.admin.LaunchPlanState ----------------------------------- -`[flyteidl.admin.LaunchPlanState proto] `_ +`[flyteidl.admin.LaunchPlanState proto] `_ By default any launch plan regardless of state can be used to launch a workflow execution. However, at most one version of a launch plan diff --git a/flyteidl/gen/pb-protodoc/flyteidl/admin/matchable_resource.proto.rst b/flyteidl/gen/pb-protodoc/flyteidl/admin/matchable_resource.proto.rst index fb77d04993c..3af5a609a2a 100644 --- a/flyteidl/gen/pb-protodoc/flyteidl/admin/matchable_resource.proto.rst +++ b/flyteidl/gen/pb-protodoc/flyteidl/admin/matchable_resource.proto.rst @@ -8,7 +8,7 @@ matchable_resource.proto flyteidl.admin.TaskResourceSpec ------------------------------- -`[flyteidl.admin.TaskResourceSpec proto] `_ +`[flyteidl.admin.TaskResourceSpec proto] `_ .. code-block:: json @@ -47,7 +47,7 @@ storage flyteidl.admin.TaskResourceAttributes ------------------------------------- -`[flyteidl.admin.TaskResourceAttributes proto] `_ +`[flyteidl.admin.TaskResourceAttributes proto] `_ .. code-block:: json @@ -74,7 +74,7 @@ limits flyteidl.admin.ClusterResourceAttributes ---------------------------------------- -`[flyteidl.admin.ClusterResourceAttributes proto] `_ +`[flyteidl.admin.ClusterResourceAttributes proto] `_ .. code-block:: json @@ -98,7 +98,7 @@ attributes flyteidl.admin.ExecutionQueueAttributes --------------------------------------- -`[flyteidl.admin.ExecutionQueueAttributes proto] `_ +`[flyteidl.admin.ExecutionQueueAttributes proto] `_ .. code-block:: json @@ -120,7 +120,7 @@ tags flyteidl.admin.ExecutionClusterLabel ------------------------------------ -`[flyteidl.admin.ExecutionClusterLabel proto] `_ +`[flyteidl.admin.ExecutionClusterLabel proto] `_ .. code-block:: json @@ -142,7 +142,7 @@ value flyteidl.admin.MatchingAttributes --------------------------------- -`[flyteidl.admin.MatchingAttributes proto] `_ +`[flyteidl.admin.MatchingAttributes proto] `_ Generic container for encapsulating all types of the above attributes messages. @@ -152,7 +152,8 @@ Generic container for encapsulating all types of the above attributes messages. "task_resource_attributes": "{...}", "cluster_resource_attributes": "{...}", "execution_queue_attributes": "{...}", - "execution_cluster_label": "{...}" + "execution_cluster_label": "{...}", + "quality_of_service": "{...}" } .. _api_field_flyteidl.admin.MatchingAttributes.task_resource_attributes: @@ -161,7 +162,7 @@ task_resource_attributes (:ref:`flyteidl.admin.TaskResourceAttributes `) - Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label ` may be set. + Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label `, :ref:`quality_of_service ` may be set. .. _api_field_flyteidl.admin.MatchingAttributes.cluster_resource_attributes: @@ -169,7 +170,7 @@ cluster_resource_attributes (:ref:`flyteidl.admin.ClusterResourceAttributes `) - Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label ` may be set. + Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label `, :ref:`quality_of_service ` may be set. .. _api_field_flyteidl.admin.MatchingAttributes.execution_queue_attributes: @@ -177,7 +178,7 @@ execution_queue_attributes (:ref:`flyteidl.admin.ExecutionQueueAttributes `) - Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label ` may be set. + Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label `, :ref:`quality_of_service ` may be set. .. _api_field_flyteidl.admin.MatchingAttributes.execution_cluster_label: @@ -185,7 +186,15 @@ execution_cluster_label (:ref:`flyteidl.admin.ExecutionClusterLabel `) - Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label ` may be set. + Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label `, :ref:`quality_of_service ` may be set. + +.. _api_field_flyteidl.admin.MatchingAttributes.quality_of_service: + +quality_of_service + (:ref:`flyteidl.core.QualityOfService `) + + + Only one of :ref:`task_resource_attributes `, :ref:`cluster_resource_attributes `, :ref:`execution_queue_attributes `, :ref:`execution_cluster_label `, :ref:`quality_of_service ` may be set. @@ -194,7 +203,7 @@ execution_cluster_label flyteidl.admin.MatchableAttributesConfiguration ----------------------------------------------- -`[flyteidl.admin.MatchableAttributesConfiguration proto] `_ +`[flyteidl.admin.MatchableAttributesConfiguration proto] `_ Represents a custom set of attributes applied for either a domain; a domain and project; or domain, project and workflow name. @@ -241,7 +250,7 @@ launch_plan flyteidl.admin.ListMatchableAttributesRequest --------------------------------------------- -`[flyteidl.admin.ListMatchableAttributesRequest proto] `_ +`[flyteidl.admin.ListMatchableAttributesRequest proto] `_ Request all matching resource attributes. @@ -263,7 +272,7 @@ resource_type flyteidl.admin.ListMatchableAttributesResponse ---------------------------------------------- -`[flyteidl.admin.ListMatchableAttributesResponse proto] `_ +`[flyteidl.admin.ListMatchableAttributesResponse proto] `_ Response for a request for all matching resource attributes. @@ -284,7 +293,7 @@ configurations Enum flyteidl.admin.MatchableResource ------------------------------------- -`[flyteidl.admin.MatchableResource proto] `_ +`[flyteidl.admin.MatchableResource proto] `_ Defines a resource that can be configured by customizable Project-, ProjectDomain- or WorkflowAttributes based on matching tags. @@ -313,3 +322,9 @@ EXECUTION_CLUSTER_LABEL ⁣Configures the K8s cluster label to be used for execution to be run +.. _api_enum_value_flyteidl.admin.MatchableResource.QUALITY_OF_SERVICE_SPECIFICATION: + +QUALITY_OF_SERVICE_SPECIFICATION + ⁣Configures default quality of service when undefined in an execution spec. + + diff --git a/flyteidl/gen/pb-protodoc/flyteidl/core/execution.proto.rst b/flyteidl/gen/pb-protodoc/flyteidl/core/execution.proto.rst index 39ff156f316..33a90594e08 100644 --- a/flyteidl/gen/pb-protodoc/flyteidl/core/execution.proto.rst +++ b/flyteidl/gen/pb-protodoc/flyteidl/core/execution.proto.rst @@ -339,3 +339,89 @@ CSV JSON ⁣ + +.. _api_msg_flyteidl.core.QualityOfServiceSpec: + +flyteidl.core.QualityOfServiceSpec +---------------------------------- + +`[flyteidl.core.QualityOfServiceSpec proto] `_ + +Represents customized execution run-time attributes. + +.. code-block:: json + + { + "queueing_budget": "{...}" + } + +.. _api_field_flyteidl.core.QualityOfServiceSpec.queueing_budget: + +queueing_budget + (:ref:`google.protobuf.Duration `) Indicates how much queueing delay an execution can tolerate. + + + + +.. _api_msg_flyteidl.core.QualityOfService: + +flyteidl.core.QualityOfService +------------------------------ + +`[flyteidl.core.QualityOfService proto] `_ + +Indicates the priority of an execution. + +.. code-block:: json + + { + "tier": "...", + "spec": "{...}" + } + +.. _api_field_flyteidl.core.QualityOfService.tier: + +tier + (:ref:`flyteidl.core.QualityOfService.Tier `) + + + Only one of :ref:`tier `, :ref:`spec ` may be set. + +.. _api_field_flyteidl.core.QualityOfService.spec: + +spec + (:ref:`flyteidl.core.QualityOfServiceSpec `) + + + Only one of :ref:`tier `, :ref:`spec ` may be set. + + +.. _api_enum_flyteidl.core.QualityOfService.Tier: + +Enum flyteidl.core.QualityOfService.Tier +---------------------------------------- + +`[flyteidl.core.QualityOfService.Tier proto] `_ + + +.. _api_enum_value_flyteidl.core.QualityOfService.Tier.UNDEFINED: + +UNDEFINED + *(DEFAULT)* ⁣Default: no quality of service specified. + + +.. _api_enum_value_flyteidl.core.QualityOfService.Tier.HIGH: + +HIGH + ⁣ + +.. _api_enum_value_flyteidl.core.QualityOfService.Tier.MEDIUM: + +MEDIUM + ⁣ + +.. _api_enum_value_flyteidl.core.QualityOfService.Tier.LOW: + +LOW + ⁣ + diff --git a/flyteidl/gen/pb-protodoc/flyteidl/core/workflow.proto.rst b/flyteidl/gen/pb-protodoc/flyteidl/core/workflow.proto.rst index 3ef7d40f909..3667016599e 100644 --- a/flyteidl/gen/pb-protodoc/flyteidl/core/workflow.proto.rst +++ b/flyteidl/gen/pb-protodoc/flyteidl/core/workflow.proto.rst @@ -8,7 +8,7 @@ workflow.proto flyteidl.core.IfBlock --------------------- -`[flyteidl.core.IfBlock proto] `_ +`[flyteidl.core.IfBlock proto] `_ Defines a condition and the execution unit that should be executed if the condition is satisfied. @@ -36,7 +36,7 @@ then_node flyteidl.core.IfElseBlock ------------------------- -`[flyteidl.core.IfElseBlock proto] `_ +`[flyteidl.core.IfElseBlock proto] `_ Defines a series of if/else blocks. The first branch whose condition evaluates to true is the one to execute. If no conditions were satisfied, the else_node or the error will execute. @@ -89,7 +89,7 @@ error flyteidl.core.BranchNode ------------------------ -`[flyteidl.core.BranchNode proto] `_ +`[flyteidl.core.BranchNode proto] `_ BranchNode is a special node that alter the flow of the workflow graph. It allows the control flow to branch at runtime based on a series of conditions that get evaluated on various parameters (e.g. inputs, primtives). @@ -113,7 +113,7 @@ if_else flyteidl.core.TaskNode ---------------------- -`[flyteidl.core.TaskNode proto] `_ +`[flyteidl.core.TaskNode proto] `_ Refers to the task that the Node is to execute. @@ -137,7 +137,7 @@ reference_id flyteidl.core.WorkflowNode -------------------------- -`[flyteidl.core.WorkflowNode proto] `_ +`[flyteidl.core.WorkflowNode proto] `_ Refers to a the workflow the node is to execute. @@ -173,7 +173,7 @@ sub_workflow_ref flyteidl.core.NodeMetadata -------------------------- -`[flyteidl.core.NodeMetadata proto] `_ +`[flyteidl.core.NodeMetadata proto] `_ Defines extra information about the Node. @@ -218,7 +218,7 @@ interruptible flyteidl.core.Alias ------------------- -`[flyteidl.core.Alias proto] `_ +`[flyteidl.core.Alias proto] `_ Links a variable to an alias. @@ -248,7 +248,7 @@ alias flyteidl.core.Node ------------------ -`[flyteidl.core.Node proto] `_ +`[flyteidl.core.Node proto] `_ A Workflow graph Node. One unit of execution in the graph. Each node can be linked to a Task, a Workflow or a branch node. @@ -339,21 +339,21 @@ branch_node flyteidl.core.WorkflowMetadata ------------------------------ -`[flyteidl.core.WorkflowMetadata proto] `_ +`[flyteidl.core.WorkflowMetadata proto] `_ Metadata for the entire workflow. Defines execution behavior that does not change the final outputs of the workflow. .. code-block:: json { - "queuing_budget": "{...}", + "quality_of_service": "{...}", "on_failure": "..." } -.. _api_field_flyteidl.core.WorkflowMetadata.queuing_budget: +.. _api_field_flyteidl.core.WorkflowMetadata.quality_of_service: -queuing_budget - (:ref:`google.protobuf.Duration `) Total wait time a workflow can be delayed by queueing. +quality_of_service + (:ref:`flyteidl.core.QualityOfService `) Indicates the runtime priority of workflow executions. .. _api_field_flyteidl.core.WorkflowMetadata.on_failure: @@ -368,7 +368,7 @@ on_failure Enum flyteidl.core.WorkflowMetadata.OnFailurePolicy --------------------------------------------------- -`[flyteidl.core.WorkflowMetadata.OnFailurePolicy proto] `_ +`[flyteidl.core.WorkflowMetadata.OnFailurePolicy proto] `_ Failure Handling Strategy @@ -395,7 +395,7 @@ FAIL_AFTER_EXECUTABLE_NODES_COMPLETE flyteidl.core.WorkflowMetadataDefaults -------------------------------------- -`[flyteidl.core.WorkflowMetadataDefaults proto] `_ +`[flyteidl.core.WorkflowMetadataDefaults proto] `_ Default Workflow Metadata for the entire workflow. @@ -420,7 +420,7 @@ interruptible flyteidl.core.WorkflowTemplate ------------------------------ -`[flyteidl.core.WorkflowTemplate proto] `_ +`[flyteidl.core.WorkflowTemplate proto] `_ Flyte Workflow Structure that encapsulates task, branch and subworkflow nodes to form a statically analyzable, directed acyclic graph. diff --git a/flyteidl/gen/pb_python/flyteidl/admin/execution_pb2.py b/flyteidl/gen/pb_python/flyteidl/admin/execution_pb2.py index 642310ce55e..49589ab16ab 100644 --- a/flyteidl/gen/pb_python/flyteidl/admin/execution_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/admin/execution_pb2.py @@ -26,7 +26,7 @@ package='flyteidl.admin', syntax='proto3', serialized_options=_b('Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/admin'), - serialized_pb=_b('\n\x1e\x66lyteidl/admin/execution.proto\x12\x0e\x66lyteidl.admin\x1a\x1b\x66lyteidl/admin/common.proto\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x1d\x66lyteidl/core/execution.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1egoogle/protobuf/duration.proto\x1a\x1fgoogle/protobuf/timestamp.proto\"\x9f\x01\n\x16\x45xecutionCreateRequest\x12\x0f\n\x07project\x18\x01 \x01(\t\x12\x0e\n\x06\x64omain\x18\x02 \x01(\t\x12\x0c\n\x04name\x18\x03 \x01(\t\x12+\n\x04spec\x18\x04 \x01(\x0b\x32\x1d.flyteidl.admin.ExecutionSpec\x12)\n\x06inputs\x18\x05 \x01(\x0b\x32\x19.flyteidl.core.LiteralMap\"`\n\x18\x45xecutionRelaunchRequest\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\x0c\n\x04name\x18\x03 \x01(\t\"Q\n\x17\x45xecutionCreateResponse\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"U\n\x1bWorkflowExecutionGetRequest\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"\xa3\x01\n\tExecution\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12+\n\x04spec\x18\x02 \x01(\x0b\x32\x1d.flyteidl.admin.ExecutionSpec\x12\x31\n\x07\x63losure\x18\x03 \x01(\x0b\x32 .flyteidl.admin.ExecutionClosure\"M\n\rExecutionList\x12-\n\nexecutions\x18\x01 \x03(\x0b\x32\x19.flyteidl.admin.Execution\x12\r\n\x05token\x18\x02 \x01(\t\"T\n\x0eLiteralMapBlob\x12+\n\x06values\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapH\x00\x12\r\n\x03uri\x18\x02 \x01(\tH\x00\x42\x06\n\x04\x64\x61ta\"1\n\rAbortMetadata\x12\r\n\x05\x63\x61use\x18\x01 \x01(\t\x12\x11\n\tprincipal\x18\x02 \x01(\t\"\xeb\x04\n\x10\x45xecutionClosure\x12\x31\n\x07outputs\x18\x01 \x01(\x0b\x32\x1e.flyteidl.admin.LiteralMapBlobH\x00\x12.\n\x05\x65rror\x18\x02 \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x12\x19\n\x0b\x61\x62ort_cause\x18\n \x01(\tB\x02\x18\x01H\x00\x12\x37\n\x0e\x61\x62ort_metadata\x18\x0c \x01(\x0b\x32\x1d.flyteidl.admin.AbortMetadataH\x00\x12\x36\n\x0f\x63omputed_inputs\x18\x03 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapB\x02\x18\x01\x12\x35\n\x05phase\x18\x04 \x01(\x0e\x32&.flyteidl.core.WorkflowExecution.Phase\x12.\n\nstarted_at\x18\x05 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12+\n\x08\x64uration\x18\x06 \x01(\x0b\x32\x19.google.protobuf.Duration\x12.\n\ncreated_at\x18\x07 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x08 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x33\n\rnotifications\x18\t \x03(\x0b\x32\x1c.flyteidl.admin.Notification\x12.\n\x0bworkflow_id\x18\x0b \x01(\x0b\x32\x19.flyteidl.core.IdentifierB\x0f\n\routput_result\"+\n\x0eSystemMetadata\x12\x19\n\x11\x65xecution_cluster\x18\x01 \x01(\t\"\xcb\x03\n\x11\x45xecutionMetadata\x12=\n\x04mode\x18\x01 \x01(\x0e\x32/.flyteidl.admin.ExecutionMetadata.ExecutionMode\x12\x11\n\tprincipal\x18\x02 \x01(\t\x12\x0f\n\x07nesting\x18\x03 \x01(\r\x12\x30\n\x0cscheduled_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x45\n\x15parent_node_execution\x18\x05 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\x12G\n\x13reference_execution\x18\x10 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\x37\n\x0fsystem_metadata\x18\x11 \x01(\x0b\x32\x1e.flyteidl.admin.SystemMetadata\"X\n\rExecutionMode\x12\n\n\x06MANUAL\x10\x00\x12\r\n\tSCHEDULED\x10\x01\x12\n\n\x06SYSTEM\x10\x02\x12\x0c\n\x08RELAUNCH\x10\x03\x12\x12\n\x0e\x43HILD_WORKFLOW\x10\x04\"G\n\x10NotificationList\x12\x33\n\rnotifications\x18\x01 \x03(\x0b\x32\x1c.flyteidl.admin.Notification\"\x9c\x03\n\rExecutionSpec\x12.\n\x0blaunch_plan\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12-\n\x06inputs\x18\x02 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapB\x02\x18\x01\x12\x33\n\x08metadata\x18\x03 \x01(\x0b\x32!.flyteidl.admin.ExecutionMetadata\x12\x39\n\rnotifications\x18\x05 \x01(\x0b\x32 .flyteidl.admin.NotificationListH\x00\x12\x15\n\x0b\x64isable_all\x18\x06 \x01(\x08H\x00\x12&\n\x06labels\x18\x07 \x01(\x0b\x32\x16.flyteidl.admin.Labels\x12\x30\n\x0b\x61nnotations\x18\x08 \x01(\x0b\x32\x1b.flyteidl.admin.Annotations\x12+\n\tauth_role\x18\x10 \x01(\x0b\x32\x18.flyteidl.admin.AuthRoleB\x18\n\x16notification_overridesJ\x04\x08\x04\x10\x05\"b\n\x19\x45xecutionTerminateRequest\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\r\n\x05\x63\x61use\x18\x02 \x01(\t\"\x1c\n\x1a\x45xecutionTerminateResponse\"Y\n\x1fWorkflowExecutionGetDataRequest\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"u\n WorkflowExecutionGetDataResponse\x12(\n\x07outputs\x18\x01 \x01(\x0b\x32\x17.flyteidl.admin.UrlBlob\x12\'\n\x06inputs\x18\x02 \x01(\x0b\x32\x17.flyteidl.admin.UrlBlobB3Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/adminb\x06proto3') + serialized_pb=_b('\n\x1e\x66lyteidl/admin/execution.proto\x12\x0e\x66lyteidl.admin\x1a\x1b\x66lyteidl/admin/common.proto\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x1d\x66lyteidl/core/execution.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1egoogle/protobuf/duration.proto\x1a\x1fgoogle/protobuf/timestamp.proto\"\x9f\x01\n\x16\x45xecutionCreateRequest\x12\x0f\n\x07project\x18\x01 \x01(\t\x12\x0e\n\x06\x64omain\x18\x02 \x01(\t\x12\x0c\n\x04name\x18\x03 \x01(\t\x12+\n\x04spec\x18\x04 \x01(\x0b\x32\x1d.flyteidl.admin.ExecutionSpec\x12)\n\x06inputs\x18\x05 \x01(\x0b\x32\x19.flyteidl.core.LiteralMap\"`\n\x18\x45xecutionRelaunchRequest\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\x0c\n\x04name\x18\x03 \x01(\t\"Q\n\x17\x45xecutionCreateResponse\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"U\n\x1bWorkflowExecutionGetRequest\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"\xa3\x01\n\tExecution\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12+\n\x04spec\x18\x02 \x01(\x0b\x32\x1d.flyteidl.admin.ExecutionSpec\x12\x31\n\x07\x63losure\x18\x03 \x01(\x0b\x32 .flyteidl.admin.ExecutionClosure\"M\n\rExecutionList\x12-\n\nexecutions\x18\x01 \x03(\x0b\x32\x19.flyteidl.admin.Execution\x12\r\n\x05token\x18\x02 \x01(\t\"T\n\x0eLiteralMapBlob\x12+\n\x06values\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapH\x00\x12\r\n\x03uri\x18\x02 \x01(\tH\x00\x42\x06\n\x04\x64\x61ta\"1\n\rAbortMetadata\x12\r\n\x05\x63\x61use\x18\x01 \x01(\t\x12\x11\n\tprincipal\x18\x02 \x01(\t\"\xeb\x04\n\x10\x45xecutionClosure\x12\x31\n\x07outputs\x18\x01 \x01(\x0b\x32\x1e.flyteidl.admin.LiteralMapBlobH\x00\x12.\n\x05\x65rror\x18\x02 \x01(\x0b\x32\x1d.flyteidl.core.ExecutionErrorH\x00\x12\x19\n\x0b\x61\x62ort_cause\x18\n \x01(\tB\x02\x18\x01H\x00\x12\x37\n\x0e\x61\x62ort_metadata\x18\x0c \x01(\x0b\x32\x1d.flyteidl.admin.AbortMetadataH\x00\x12\x36\n\x0f\x63omputed_inputs\x18\x03 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapB\x02\x18\x01\x12\x35\n\x05phase\x18\x04 \x01(\x0e\x32&.flyteidl.core.WorkflowExecution.Phase\x12.\n\nstarted_at\x18\x05 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12+\n\x08\x64uration\x18\x06 \x01(\x0b\x32\x19.google.protobuf.Duration\x12.\n\ncreated_at\x18\x07 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x08 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x33\n\rnotifications\x18\t \x03(\x0b\x32\x1c.flyteidl.admin.Notification\x12.\n\x0bworkflow_id\x18\x0b \x01(\x0b\x32\x19.flyteidl.core.IdentifierB\x0f\n\routput_result\"+\n\x0eSystemMetadata\x12\x19\n\x11\x65xecution_cluster\x18\x01 \x01(\t\"\xcb\x03\n\x11\x45xecutionMetadata\x12=\n\x04mode\x18\x01 \x01(\x0e\x32/.flyteidl.admin.ExecutionMetadata.ExecutionMode\x12\x11\n\tprincipal\x18\x02 \x01(\t\x12\x0f\n\x07nesting\x18\x03 \x01(\r\x12\x30\n\x0cscheduled_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x45\n\x15parent_node_execution\x18\x05 \x01(\x0b\x32&.flyteidl.core.NodeExecutionIdentifier\x12G\n\x13reference_execution\x18\x10 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\x37\n\x0fsystem_metadata\x18\x11 \x01(\x0b\x32\x1e.flyteidl.admin.SystemMetadata\"X\n\rExecutionMode\x12\n\n\x06MANUAL\x10\x00\x12\r\n\tSCHEDULED\x10\x01\x12\n\n\x06SYSTEM\x10\x02\x12\x0c\n\x08RELAUNCH\x10\x03\x12\x12\n\x0e\x43HILD_WORKFLOW\x10\x04\"G\n\x10NotificationList\x12\x33\n\rnotifications\x18\x01 \x03(\x0b\x32\x1c.flyteidl.admin.Notification\"\xd9\x03\n\rExecutionSpec\x12.\n\x0blaunch_plan\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12-\n\x06inputs\x18\x02 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapB\x02\x18\x01\x12\x33\n\x08metadata\x18\x03 \x01(\x0b\x32!.flyteidl.admin.ExecutionMetadata\x12\x39\n\rnotifications\x18\x05 \x01(\x0b\x32 .flyteidl.admin.NotificationListH\x00\x12\x15\n\x0b\x64isable_all\x18\x06 \x01(\x08H\x00\x12&\n\x06labels\x18\x07 \x01(\x0b\x32\x16.flyteidl.admin.Labels\x12\x30\n\x0b\x61nnotations\x18\x08 \x01(\x0b\x32\x1b.flyteidl.admin.Annotations\x12+\n\tauth_role\x18\x10 \x01(\x0b\x32\x18.flyteidl.admin.AuthRole\x12;\n\x12quality_of_service\x18\x11 \x01(\x0b\x32\x1f.flyteidl.core.QualityOfServiceB\x18\n\x16notification_overridesJ\x04\x08\x04\x10\x05\"b\n\x19\x45xecutionTerminateRequest\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\x12\r\n\x05\x63\x61use\x18\x02 \x01(\t\"\x1c\n\x1a\x45xecutionTerminateResponse\"Y\n\x1fWorkflowExecutionGetDataRequest\x12\x36\n\x02id\x18\x01 \x01(\x0b\x32*.flyteidl.core.WorkflowExecutionIdentifier\"u\n WorkflowExecutionGetDataResponse\x12(\n\x07outputs\x18\x01 \x01(\x0b\x32\x17.flyteidl.admin.UrlBlob\x12\'\n\x06inputs\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_literals__pb2.DESCRIPTOR,flyteidl_dot_core_dot_execution__pb2.DESCRIPTOR,flyteidl_dot_core_dot_identifier__pb2.DESCRIPTOR,google_dot_protobuf_dot_duration__pb2.DESCRIPTOR,google_dot_protobuf_dot_timestamp__pb2.DESCRIPTOR,]) @@ -698,6 +698,13 @@ message_type=None, enum_type=None, containing_type=None, is_extension=False, extension_scope=None, serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='quality_of_service', full_name='flyteidl.admin.ExecutionSpec.quality_of_service', index=8, + number=17, 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), ], extensions=[ ], @@ -714,7 +721,7 @@ index=0, containing_type=None, fields=[]), ], serialized_start=2252, - serialized_end=2664, + serialized_end=2725, ) @@ -751,8 +758,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=2666, - serialized_end=2764, + serialized_start=2727, + serialized_end=2825, ) @@ -775,8 +782,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=2766, - serialized_end=2794, + serialized_start=2827, + serialized_end=2855, ) @@ -806,8 +813,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=2796, - serialized_end=2885, + serialized_start=2857, + serialized_end=2946, ) @@ -844,8 +851,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=2887, - serialized_end=3004, + serialized_start=2948, + serialized_end=3065, ) _EXECUTIONCREATEREQUEST.fields_by_name['spec'].message_type = _EXECUTIONSPEC @@ -901,6 +908,7 @@ _EXECUTIONSPEC.fields_by_name['labels'].message_type = flyteidl_dot_admin_dot_common__pb2._LABELS _EXECUTIONSPEC.fields_by_name['annotations'].message_type = flyteidl_dot_admin_dot_common__pb2._ANNOTATIONS _EXECUTIONSPEC.fields_by_name['auth_role'].message_type = flyteidl_dot_admin_dot_common__pb2._AUTHROLE +_EXECUTIONSPEC.fields_by_name['quality_of_service'].message_type = flyteidl_dot_core_dot_execution__pb2._QUALITYOFSERVICE _EXECUTIONSPEC.oneofs_by_name['notification_overrides'].fields.append( _EXECUTIONSPEC.fields_by_name['notifications']) _EXECUTIONSPEC.fields_by_name['notifications'].containing_oneof = _EXECUTIONSPEC.oneofs_by_name['notification_overrides'] diff --git a/flyteidl/gen/pb_python/flyteidl/admin/launch_plan_pb2.py b/flyteidl/gen/pb_python/flyteidl/admin/launch_plan_pb2.py index 089ba190d20..a6b79976097 100644 --- a/flyteidl/gen/pb_python/flyteidl/admin/launch_plan_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/admin/launch_plan_pb2.py @@ -14,6 +14,7 @@ _sym_db = _symbol_database.Default() +from flyteidl.core import execution_pb2 as flyteidl_dot_core_dot_execution__pb2 from flyteidl.core import literals_pb2 as flyteidl_dot_core_dot_literals__pb2 from flyteidl.core import identifier_pb2 as flyteidl_dot_core_dot_identifier__pb2 from flyteidl.core import interface_pb2 as flyteidl_dot_core_dot_interface__pb2 @@ -27,9 +28,9 @@ package='flyteidl.admin', syntax='proto3', serialized_options=_b('Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/admin'), - serialized_pb=_b('\n flyteidl/admin/launch_plan.proto\x12\x0e\x66lyteidl.admin\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1d\x66lyteidl/admin/schedule.proto\x1a\x1b\x66lyteidl/admin/common.proto\x1a\x1fgoogle/protobuf/timestamp.proto\"n\n\x17LaunchPlanCreateRequest\x12%\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12,\n\x04spec\x18\x02 \x01(\x0b\x32\x1e.flyteidl.admin.LaunchPlanSpec\"\x1a\n\x18LaunchPlanCreateResponse\"\x95\x01\n\nLaunchPlan\x12%\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12,\n\x04spec\x18\x02 \x01(\x0b\x32\x1e.flyteidl.admin.LaunchPlanSpec\x12\x32\n\x07\x63losure\x18\x03 \x01(\x0b\x32!.flyteidl.admin.LaunchPlanClosure\"Q\n\x0eLaunchPlanList\x12\x30\n\x0claunch_plans\x18\x01 \x03(\x0b\x32\x1a.flyteidl.admin.LaunchPlan\x12\r\n\x05token\x18\x02 \x01(\t\"T\n\x04\x41uth\x12\x1c\n\x12\x61ssumable_iam_role\x18\x01 \x01(\tH\x00\x12$\n\x1akubernetes_service_account\x18\x02 \x01(\tH\x00\x42\x08\n\x06method\"\xa4\x03\n\x0eLaunchPlanSpec\x12.\n\x0bworkflow_id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12;\n\x0f\x65ntity_metadata\x18\x02 \x01(\x0b\x32\".flyteidl.admin.LaunchPlanMetadata\x12\x33\n\x0e\x64\x65\x66\x61ult_inputs\x18\x03 \x01(\x0b\x32\x1b.flyteidl.core.ParameterMap\x12/\n\x0c\x66ixed_inputs\x18\x04 \x01(\x0b\x32\x19.flyteidl.core.LiteralMap\x12\x10\n\x04role\x18\x05 \x01(\tB\x02\x18\x01\x12&\n\x06labels\x18\x06 \x01(\x0b\x32\x16.flyteidl.admin.Labels\x12\x30\n\x0b\x61nnotations\x18\x07 \x01(\x0b\x32\x1b.flyteidl.admin.Annotations\x12&\n\x04\x61uth\x18\x08 \x01(\x0b\x32\x14.flyteidl.admin.AuthB\x02\x18\x01\x12+\n\tauth_role\x18\t \x01(\x0b\x32\x18.flyteidl.admin.AuthRole\"\x8f\x02\n\x11LaunchPlanClosure\x12.\n\x05state\x18\x01 \x01(\x0e\x32\x1f.flyteidl.admin.LaunchPlanState\x12\x34\n\x0f\x65xpected_inputs\x18\x02 \x01(\x0b\x32\x1b.flyteidl.core.ParameterMap\x12\x34\n\x10\x65xpected_outputs\x18\x03 \x01(\x0b\x32\x1a.flyteidl.core.VariableMap\x12.\n\ncreated_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x05 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\"u\n\x12LaunchPlanMetadata\x12*\n\x08schedule\x18\x01 \x01(\x0b\x32\x18.flyteidl.admin.Schedule\x12\x33\n\rnotifications\x18\x02 \x03(\x0b\x32\x1c.flyteidl.admin.Notification\"p\n\x17LaunchPlanUpdateRequest\x12%\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12.\n\x05state\x18\x02 \x01(\x0e\x32\x1f.flyteidl.admin.LaunchPlanState\"\x1a\n\x18LaunchPlanUpdateResponse\"L\n\x17\x41\x63tiveLaunchPlanRequest\x12\x31\n\x02id\x18\x01 \x01(\x0b\x32%.flyteidl.admin.NamedEntityIdentifier\"\x83\x01\n\x1b\x41\x63tiveLaunchPlanListRequest\x12\x0f\n\x07project\x18\x01 \x01(\t\x12\x0e\n\x06\x64omain\x18\x02 \x01(\t\x12\r\n\x05limit\x18\x03 \x01(\r\x12\r\n\x05token\x18\x04 \x01(\t\x12%\n\x07sort_by\x18\x05 \x01(\x0b\x32\x14.flyteidl.admin.Sort*+\n\x0fLaunchPlanState\x12\x0c\n\x08INACTIVE\x10\x00\x12\n\n\x06\x41\x43TIVE\x10\x01\x42\x33Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/adminb\x06proto3') + serialized_pb=_b('\n flyteidl/admin/launch_plan.proto\x12\x0e\x66lyteidl.admin\x1a\x1d\x66lyteidl/core/execution.proto\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1d\x66lyteidl/admin/schedule.proto\x1a\x1b\x66lyteidl/admin/common.proto\x1a\x1fgoogle/protobuf/timestamp.proto\"n\n\x17LaunchPlanCreateRequest\x12%\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12,\n\x04spec\x18\x02 \x01(\x0b\x32\x1e.flyteidl.admin.LaunchPlanSpec\"\x1a\n\x18LaunchPlanCreateResponse\"\x95\x01\n\nLaunchPlan\x12%\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12,\n\x04spec\x18\x02 \x01(\x0b\x32\x1e.flyteidl.admin.LaunchPlanSpec\x12\x32\n\x07\x63losure\x18\x03 \x01(\x0b\x32!.flyteidl.admin.LaunchPlanClosure\"Q\n\x0eLaunchPlanList\x12\x30\n\x0claunch_plans\x18\x01 \x03(\x0b\x32\x1a.flyteidl.admin.LaunchPlan\x12\r\n\x05token\x18\x02 \x01(\t\"T\n\x04\x41uth\x12\x1c\n\x12\x61ssumable_iam_role\x18\x01 \x01(\tH\x00\x12$\n\x1akubernetes_service_account\x18\x02 \x01(\tH\x00\x42\x08\n\x06method\"\xe1\x03\n\x0eLaunchPlanSpec\x12.\n\x0bworkflow_id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12;\n\x0f\x65ntity_metadata\x18\x02 \x01(\x0b\x32\".flyteidl.admin.LaunchPlanMetadata\x12\x33\n\x0e\x64\x65\x66\x61ult_inputs\x18\x03 \x01(\x0b\x32\x1b.flyteidl.core.ParameterMap\x12/\n\x0c\x66ixed_inputs\x18\x04 \x01(\x0b\x32\x19.flyteidl.core.LiteralMap\x12\x10\n\x04role\x18\x05 \x01(\tB\x02\x18\x01\x12&\n\x06labels\x18\x06 \x01(\x0b\x32\x16.flyteidl.admin.Labels\x12\x30\n\x0b\x61nnotations\x18\x07 \x01(\x0b\x32\x1b.flyteidl.admin.Annotations\x12&\n\x04\x61uth\x18\x08 \x01(\x0b\x32\x14.flyteidl.admin.AuthB\x02\x18\x01\x12+\n\tauth_role\x18\t \x01(\x0b\x32\x18.flyteidl.admin.AuthRole\x12;\n\x12quality_of_service\x18\x10 \x01(\x0b\x32\x1f.flyteidl.core.QualityOfService\"\x8f\x02\n\x11LaunchPlanClosure\x12.\n\x05state\x18\x01 \x01(\x0e\x32\x1f.flyteidl.admin.LaunchPlanState\x12\x34\n\x0f\x65xpected_inputs\x18\x02 \x01(\x0b\x32\x1b.flyteidl.core.ParameterMap\x12\x34\n\x10\x65xpected_outputs\x18\x03 \x01(\x0b\x32\x1a.flyteidl.core.VariableMap\x12.\n\ncreated_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x05 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\"u\n\x12LaunchPlanMetadata\x12*\n\x08schedule\x18\x01 \x01(\x0b\x32\x18.flyteidl.admin.Schedule\x12\x33\n\rnotifications\x18\x02 \x03(\x0b\x32\x1c.flyteidl.admin.Notification\"p\n\x17LaunchPlanUpdateRequest\x12%\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12.\n\x05state\x18\x02 \x01(\x0e\x32\x1f.flyteidl.admin.LaunchPlanState\"\x1a\n\x18LaunchPlanUpdateResponse\"L\n\x17\x41\x63tiveLaunchPlanRequest\x12\x31\n\x02id\x18\x01 \x01(\x0b\x32%.flyteidl.admin.NamedEntityIdentifier\"\x83\x01\n\x1b\x41\x63tiveLaunchPlanListRequest\x12\x0f\n\x07project\x18\x01 \x01(\t\x12\x0e\n\x06\x64omain\x18\x02 \x01(\t\x12\r\n\x05limit\x18\x03 \x01(\r\x12\r\n\x05token\x18\x04 \x01(\t\x12%\n\x07sort_by\x18\x05 \x01(\x0b\x32\x14.flyteidl.admin.Sort*+\n\x0fLaunchPlanState\x12\x0c\n\x08INACTIVE\x10\x00\x12\n\n\x06\x41\x43TIVE\x10\x01\x42\x33Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/adminb\x06proto3') , - dependencies=[flyteidl_dot_core_dot_literals__pb2.DESCRIPTOR,flyteidl_dot_core_dot_identifier__pb2.DESCRIPTOR,flyteidl_dot_core_dot_interface__pb2.DESCRIPTOR,flyteidl_dot_admin_dot_schedule__pb2.DESCRIPTOR,flyteidl_dot_admin_dot_common__pb2.DESCRIPTOR,google_dot_protobuf_dot_timestamp__pb2.DESCRIPTOR,]) + dependencies=[flyteidl_dot_core_dot_execution__pb2.DESCRIPTOR,flyteidl_dot_core_dot_literals__pb2.DESCRIPTOR,flyteidl_dot_core_dot_identifier__pb2.DESCRIPTOR,flyteidl_dot_core_dot_interface__pb2.DESCRIPTOR,flyteidl_dot_admin_dot_schedule__pb2.DESCRIPTOR,flyteidl_dot_admin_dot_common__pb2.DESCRIPTOR,google_dot_protobuf_dot_timestamp__pb2.DESCRIPTOR,]) _LAUNCHPLANSTATE = _descriptor.EnumDescriptor( name='LaunchPlanState', @@ -48,8 +49,8 @@ ], containing_type=None, serialized_options=None, - serialized_start=1869, - serialized_end=1912, + serialized_start=1961, + serialized_end=2004, ) _sym_db.RegisterEnumDescriptor(_LAUNCHPLANSTATE) @@ -92,8 +93,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=238, - serialized_end=348, + serialized_start=269, + serialized_end=379, ) @@ -116,8 +117,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=350, - serialized_end=376, + serialized_start=381, + serialized_end=407, ) @@ -161,8 +162,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=379, - serialized_end=528, + serialized_start=410, + serialized_end=559, ) @@ -199,8 +200,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=530, - serialized_end=611, + serialized_start=561, + serialized_end=642, ) @@ -240,8 +241,8 @@ name='method', full_name='flyteidl.admin.Auth.method', index=0, containing_type=None, fields=[]), ], - serialized_start=613, - serialized_end=697, + serialized_start=644, + serialized_end=728, ) @@ -315,6 +316,13 @@ message_type=None, enum_type=None, containing_type=None, is_extension=False, extension_scope=None, serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='quality_of_service', full_name='flyteidl.admin.LaunchPlanSpec.quality_of_service', index=9, + number=16, 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), ], extensions=[ ], @@ -327,8 +335,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=700, - serialized_end=1120, + serialized_start=731, + serialized_end=1212, ) @@ -386,8 +394,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1123, - serialized_end=1394, + serialized_start=1215, + serialized_end=1486, ) @@ -424,8 +432,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1396, - serialized_end=1513, + serialized_start=1488, + serialized_end=1605, ) @@ -462,8 +470,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1515, - serialized_end=1627, + serialized_start=1607, + serialized_end=1719, ) @@ -486,8 +494,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1629, - serialized_end=1655, + serialized_start=1721, + serialized_end=1747, ) @@ -517,8 +525,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1657, - serialized_end=1733, + serialized_start=1749, + serialized_end=1825, ) @@ -576,8 +584,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1736, - serialized_end=1867, + serialized_start=1828, + serialized_end=1959, ) _LAUNCHPLANCREATEREQUEST.fields_by_name['id'].message_type = flyteidl_dot_core_dot_identifier__pb2._IDENTIFIER @@ -600,6 +608,7 @@ _LAUNCHPLANSPEC.fields_by_name['annotations'].message_type = flyteidl_dot_admin_dot_common__pb2._ANNOTATIONS _LAUNCHPLANSPEC.fields_by_name['auth'].message_type = _AUTH _LAUNCHPLANSPEC.fields_by_name['auth_role'].message_type = flyteidl_dot_admin_dot_common__pb2._AUTHROLE +_LAUNCHPLANSPEC.fields_by_name['quality_of_service'].message_type = flyteidl_dot_core_dot_execution__pb2._QUALITYOFSERVICE _LAUNCHPLANCLOSURE.fields_by_name['state'].enum_type = _LAUNCHPLANSTATE _LAUNCHPLANCLOSURE.fields_by_name['expected_inputs'].message_type = flyteidl_dot_core_dot_interface__pb2._PARAMETERMAP _LAUNCHPLANCLOSURE.fields_by_name['expected_outputs'].message_type = flyteidl_dot_core_dot_interface__pb2._VARIABLEMAP diff --git a/flyteidl/gen/pb_python/flyteidl/admin/matchable_resource_pb2.py b/flyteidl/gen/pb_python/flyteidl/admin/matchable_resource_pb2.py index 027bb0bb617..a6713ecde91 100644 --- a/flyteidl/gen/pb_python/flyteidl/admin/matchable_resource_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/admin/matchable_resource_pb2.py @@ -14,6 +14,8 @@ _sym_db = _symbol_database.Default() +from flyteidl.admin import common_pb2 as flyteidl_dot_admin_dot_common__pb2 +from flyteidl.core import execution_pb2 as flyteidl_dot_core_dot_execution__pb2 DESCRIPTOR = _descriptor.FileDescriptor( @@ -21,8 +23,9 @@ package='flyteidl.admin', syntax='proto3', serialized_options=_b('Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/admin'), - serialized_pb=_b('\n\'flyteidl/admin/matchable_resource.proto\x12\x0e\x66lyteidl.admin\"M\n\x10TaskResourceSpec\x12\x0b\n\x03\x63pu\x18\x01 \x01(\t\x12\x0b\n\x03gpu\x18\x02 \x01(\t\x12\x0e\n\x06memory\x18\x03 \x01(\t\x12\x0f\n\x07storage\x18\x04 \x01(\t\"~\n\x16TaskResourceAttributes\x12\x32\n\x08\x64\x65\x66\x61ults\x18\x01 \x01(\x0b\x32 .flyteidl.admin.TaskResourceSpec\x12\x30\n\x06limits\x18\x02 \x01(\x0b\x32 .flyteidl.admin.TaskResourceSpec\"\x9d\x01\n\x19\x43lusterResourceAttributes\x12M\n\nattributes\x18\x01 \x03(\x0b\x32\x39.flyteidl.admin.ClusterResourceAttributes.AttributesEntry\x1a\x31\n\x0f\x41ttributesEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\t:\x02\x38\x01\"(\n\x18\x45xecutionQueueAttributes\x12\x0c\n\x04tags\x18\x01 \x03(\t\"&\n\x15\x45xecutionClusterLabel\x12\r\n\x05value\x18\x01 \x01(\t\"\xd6\x02\n\x12MatchingAttributes\x12J\n\x18task_resource_attributes\x18\x01 \x01(\x0b\x32&.flyteidl.admin.TaskResourceAttributesH\x00\x12P\n\x1b\x63luster_resource_attributes\x18\x02 \x01(\x0b\x32).flyteidl.admin.ClusterResourceAttributesH\x00\x12N\n\x1a\x65xecution_queue_attributes\x18\x03 \x01(\x0b\x32(.flyteidl.admin.ExecutionQueueAttributesH\x00\x12H\n\x17\x65xecution_cluster_label\x18\x04 \x01(\x0b\x32%.flyteidl.admin.ExecutionClusterLabelH\x00\x42\x08\n\x06target\"\xa2\x01\n MatchableAttributesConfiguration\x12\x36\n\nattributes\x18\x01 \x01(\x0b\x32\".flyteidl.admin.MatchingAttributes\x12\x0e\n\x06\x64omain\x18\x02 \x01(\t\x12\x0f\n\x07project\x18\x03 \x01(\t\x12\x10\n\x08workflow\x18\x04 \x01(\t\x12\x13\n\x0blaunch_plan\x18\x05 \x01(\t\"Z\n\x1eListMatchableAttributesRequest\x12\x38\n\rresource_type\x18\x01 \x01(\x0e\x32!.flyteidl.admin.MatchableResource\"k\n\x1fListMatchableAttributesResponse\x12H\n\x0e\x63onfigurations\x18\x01 \x03(\x0b\x32\x30.flyteidl.admin.MatchableAttributesConfiguration*n\n\x11MatchableResource\x12\x11\n\rTASK_RESOURCE\x10\x00\x12\x14\n\x10\x43LUSTER_RESOURCE\x10\x01\x12\x13\n\x0f\x45XECUTION_QUEUE\x10\x02\x12\x1b\n\x17\x45XECUTION_CLUSTER_LABEL\x10\x03\x42\x33Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/adminb\x06proto3') -) + serialized_pb=_b('\n\'flyteidl/admin/matchable_resource.proto\x12\x0e\x66lyteidl.admin\x1a\x1b\x66lyteidl/admin/common.proto\x1a\x1d\x66lyteidl/core/execution.proto\"M\n\x10TaskResourceSpec\x12\x0b\n\x03\x63pu\x18\x01 \x01(\t\x12\x0b\n\x03gpu\x18\x02 \x01(\t\x12\x0e\n\x06memory\x18\x03 \x01(\t\x12\x0f\n\x07storage\x18\x04 \x01(\t\"~\n\x16TaskResourceAttributes\x12\x32\n\x08\x64\x65\x66\x61ults\x18\x01 \x01(\x0b\x32 .flyteidl.admin.TaskResourceSpec\x12\x30\n\x06limits\x18\x02 \x01(\x0b\x32 .flyteidl.admin.TaskResourceSpec\"\x9d\x01\n\x19\x43lusterResourceAttributes\x12M\n\nattributes\x18\x01 \x03(\x0b\x32\x39.flyteidl.admin.ClusterResourceAttributes.AttributesEntry\x1a\x31\n\x0f\x41ttributesEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\t:\x02\x38\x01\"(\n\x18\x45xecutionQueueAttributes\x12\x0c\n\x04tags\x18\x01 \x03(\t\"&\n\x15\x45xecutionClusterLabel\x12\r\n\x05value\x18\x01 \x01(\t\"\x95\x03\n\x12MatchingAttributes\x12J\n\x18task_resource_attributes\x18\x01 \x01(\x0b\x32&.flyteidl.admin.TaskResourceAttributesH\x00\x12P\n\x1b\x63luster_resource_attributes\x18\x02 \x01(\x0b\x32).flyteidl.admin.ClusterResourceAttributesH\x00\x12N\n\x1a\x65xecution_queue_attributes\x18\x03 \x01(\x0b\x32(.flyteidl.admin.ExecutionQueueAttributesH\x00\x12H\n\x17\x65xecution_cluster_label\x18\x04 \x01(\x0b\x32%.flyteidl.admin.ExecutionClusterLabelH\x00\x12=\n\x12quality_of_service\x18\x05 \x01(\x0b\x32\x1f.flyteidl.core.QualityOfServiceH\x00\x42\x08\n\x06target\"\xa2\x01\n MatchableAttributesConfiguration\x12\x36\n\nattributes\x18\x01 \x01(\x0b\x32\".flyteidl.admin.MatchingAttributes\x12\x0e\n\x06\x64omain\x18\x02 \x01(\t\x12\x0f\n\x07project\x18\x03 \x01(\t\x12\x10\n\x08workflow\x18\x04 \x01(\t\x12\x13\n\x0blaunch_plan\x18\x05 \x01(\t\"Z\n\x1eListMatchableAttributesRequest\x12\x38\n\rresource_type\x18\x01 \x01(\x0e\x32!.flyteidl.admin.MatchableResource\"k\n\x1fListMatchableAttributesResponse\x12H\n\x0e\x63onfigurations\x18\x01 \x03(\x0b\x32\x30.flyteidl.admin.MatchableAttributesConfiguration*\x94\x01\n\x11MatchableResource\x12\x11\n\rTASK_RESOURCE\x10\x00\x12\x14\n\x10\x43LUSTER_RESOURCE\x10\x01\x12\x13\n\x0f\x45XECUTION_QUEUE\x10\x02\x12\x1b\n\x17\x45XECUTION_CLUSTER_LABEL\x10\x03\x12$\n QUALITY_OF_SERVICE_SPECIFICATION\x10\x04\x42\x33Z1github.com/lyft/flyteidl/gen/pb-go/flyteidl/adminb\x06proto3') + , + dependencies=[flyteidl_dot_admin_dot_common__pb2.DESCRIPTOR,flyteidl_dot_core_dot_execution__pb2.DESCRIPTOR,]) _MATCHABLERESOURCE = _descriptor.EnumDescriptor( name='MatchableResource', @@ -46,11 +49,15 @@ name='EXECUTION_CLUSTER_LABEL', index=3, number=3, serialized_options=None, type=None), + _descriptor.EnumValueDescriptor( + name='QUALITY_OF_SERVICE_SPECIFICATION', index=4, number=4, + serialized_options=None, + type=None), ], containing_type=None, serialized_options=None, - serialized_start=1219, - serialized_end=1329, + serialized_start=1343, + serialized_end=1491, ) _sym_db.RegisterEnumDescriptor(_MATCHABLERESOURCE) @@ -59,6 +66,7 @@ CLUSTER_RESOURCE = 1 EXECUTION_QUEUE = 2 EXECUTION_CLUSTER_LABEL = 3 +QUALITY_OF_SERVICE_SPECIFICATION = 4 @@ -109,8 +117,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=59, - serialized_end=136, + serialized_start=119, + serialized_end=196, ) @@ -147,8 +155,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=138, - serialized_end=264, + serialized_start=198, + serialized_end=324, ) @@ -185,8 +193,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=375, - serialized_end=424, + serialized_start=435, + serialized_end=484, ) _CLUSTERRESOURCEATTRIBUTES = _descriptor.Descriptor( @@ -215,8 +223,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=267, - serialized_end=424, + serialized_start=327, + serialized_end=484, ) @@ -246,8 +254,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=426, - serialized_end=466, + serialized_start=486, + serialized_end=526, ) @@ -277,8 +285,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=468, - serialized_end=506, + serialized_start=528, + serialized_end=566, ) @@ -317,6 +325,13 @@ message_type=None, enum_type=None, containing_type=None, is_extension=False, extension_scope=None, serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='quality_of_service', full_name='flyteidl.admin.MatchingAttributes.quality_of_service', index=4, + number=5, 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), ], extensions=[ ], @@ -332,8 +347,8 @@ name='target', full_name='flyteidl.admin.MatchingAttributes.target', index=0, containing_type=None, fields=[]), ], - serialized_start=509, - serialized_end=851, + serialized_start=569, + serialized_end=974, ) @@ -391,8 +406,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=854, - serialized_end=1016, + serialized_start=977, + serialized_end=1139, ) @@ -422,8 +437,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1018, - serialized_end=1108, + serialized_start=1141, + serialized_end=1231, ) @@ -453,8 +468,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1110, - serialized_end=1217, + serialized_start=1233, + serialized_end=1340, ) _TASKRESOURCEATTRIBUTES.fields_by_name['defaults'].message_type = _TASKRESOURCESPEC @@ -465,6 +480,7 @@ _MATCHINGATTRIBUTES.fields_by_name['cluster_resource_attributes'].message_type = _CLUSTERRESOURCEATTRIBUTES _MATCHINGATTRIBUTES.fields_by_name['execution_queue_attributes'].message_type = _EXECUTIONQUEUEATTRIBUTES _MATCHINGATTRIBUTES.fields_by_name['execution_cluster_label'].message_type = _EXECUTIONCLUSTERLABEL +_MATCHINGATTRIBUTES.fields_by_name['quality_of_service'].message_type = flyteidl_dot_core_dot_execution__pb2._QUALITYOFSERVICE _MATCHINGATTRIBUTES.oneofs_by_name['target'].fields.append( _MATCHINGATTRIBUTES.fields_by_name['task_resource_attributes']) _MATCHINGATTRIBUTES.fields_by_name['task_resource_attributes'].containing_oneof = _MATCHINGATTRIBUTES.oneofs_by_name['target'] @@ -477,6 +493,9 @@ _MATCHINGATTRIBUTES.oneofs_by_name['target'].fields.append( _MATCHINGATTRIBUTES.fields_by_name['execution_cluster_label']) _MATCHINGATTRIBUTES.fields_by_name['execution_cluster_label'].containing_oneof = _MATCHINGATTRIBUTES.oneofs_by_name['target'] +_MATCHINGATTRIBUTES.oneofs_by_name['target'].fields.append( + _MATCHINGATTRIBUTES.fields_by_name['quality_of_service']) +_MATCHINGATTRIBUTES.fields_by_name['quality_of_service'].containing_oneof = _MATCHINGATTRIBUTES.oneofs_by_name['target'] _MATCHABLEATTRIBUTESCONFIGURATION.fields_by_name['attributes'].message_type = _MATCHINGATTRIBUTES _LISTMATCHABLEATTRIBUTESREQUEST.fields_by_name['resource_type'].enum_type = _MATCHABLERESOURCE _LISTMATCHABLEATTRIBUTESRESPONSE.fields_by_name['configurations'].message_type = _MATCHABLEATTRIBUTESCONFIGURATION diff --git a/flyteidl/gen/pb_python/flyteidl/core/execution_pb2.py b/flyteidl/gen/pb_python/flyteidl/core/execution_pb2.py index 70bdbf61894..51debef68e2 100644 --- a/flyteidl/gen/pb_python/flyteidl/core/execution_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/core/execution_pb2.py @@ -21,7 +21,7 @@ package='flyteidl.core', syntax='proto3', serialized_options=_b('Z0github.com/lyft/flyteidl/gen/pb-go/flyteidl/core'), - serialized_pb=_b('\n\x1d\x66lyteidl/core/execution.proto\x12\rflyteidl.core\x1a\x1egoogle/protobuf/duration.proto\"\x99\x01\n\x11WorkflowExecution\"\x83\x01\n\x05Phase\x12\r\n\tUNDEFINED\x10\x00\x12\n\n\x06QUEUED\x10\x01\x12\x0b\n\x07RUNNING\x10\x02\x12\x0e\n\nSUCCEEDING\x10\x03\x12\r\n\tSUCCEEDED\x10\x04\x12\x0b\n\x07\x46\x41ILING\x10\x05\x12\n\n\x06\x46\x41ILED\x10\x06\x12\x0b\n\x07\x41\x42ORTED\x10\x07\x12\r\n\tTIMED_OUT\x10\x08\"\x92\x01\n\rNodeExecution\"\x80\x01\n\x05Phase\x12\r\n\tUNDEFINED\x10\x00\x12\n\n\x06QUEUED\x10\x01\x12\x0b\n\x07RUNNING\x10\x02\x12\r\n\tSUCCEEDED\x10\x03\x12\x0b\n\x07\x46\x41ILING\x10\x04\x12\n\n\x06\x46\x41ILED\x10\x05\x12\x0b\n\x07\x41\x42ORTED\x10\x06\x12\x0b\n\x07SKIPPED\x10\x07\x12\r\n\tTIMED_OUT\x10\x08\"\x96\x01\n\rTaskExecution\"\x84\x01\n\x05Phase\x12\r\n\tUNDEFINED\x10\x00\x12\n\n\x06QUEUED\x10\x01\x12\x0b\n\x07RUNNING\x10\x02\x12\r\n\tSUCCEEDED\x10\x03\x12\x0b\n\x07\x41\x42ORTED\x10\x04\x12\n\n\x06\x46\x41ILED\x10\x05\x12\x10\n\x0cINITIALIZING\x10\x06\x12\x19\n\x15WAITING_FOR_RESOURCES\x10\x07\"\xa9\x01\n\x0e\x45xecutionError\x12\x0c\n\x04\x63ode\x18\x01 \x01(\t\x12\x0f\n\x07message\x18\x02 \x01(\t\x12\x11\n\terror_uri\x18\x03 \x01(\t\x12\x35\n\x04kind\x18\x04 \x01(\x0e\x32\'.flyteidl.core.ExecutionError.ErrorKind\".\n\tErrorKind\x12\x0b\n\x07UNKNOWN\x10\x00\x12\x08\n\x04USER\x10\x01\x12\n\n\x06SYSTEM\x10\x02\"\xbb\x01\n\x07TaskLog\x12\x0b\n\x03uri\x18\x01 \x01(\t\x12\x0c\n\x04name\x18\x02 \x01(\t\x12<\n\x0emessage_format\x18\x03 \x01(\x0e\x32$.flyteidl.core.TaskLog.MessageFormat\x12&\n\x03ttl\x18\x04 \x01(\x0b\x32\x19.google.protobuf.Duration\"/\n\rMessageFormat\x12\x0b\n\x07UNKNOWN\x10\x00\x12\x07\n\x03\x43SV\x10\x01\x12\x08\n\x04JSON\x10\x02\x42\x32Z0github.com/lyft/flyteidl/gen/pb-go/flyteidl/coreb\x06proto3') + serialized_pb=_b('\n\x1d\x66lyteidl/core/execution.proto\x12\rflyteidl.core\x1a\x1egoogle/protobuf/duration.proto\"\x99\x01\n\x11WorkflowExecution\"\x83\x01\n\x05Phase\x12\r\n\tUNDEFINED\x10\x00\x12\n\n\x06QUEUED\x10\x01\x12\x0b\n\x07RUNNING\x10\x02\x12\x0e\n\nSUCCEEDING\x10\x03\x12\r\n\tSUCCEEDED\x10\x04\x12\x0b\n\x07\x46\x41ILING\x10\x05\x12\n\n\x06\x46\x41ILED\x10\x06\x12\x0b\n\x07\x41\x42ORTED\x10\x07\x12\r\n\tTIMED_OUT\x10\x08\"\x92\x01\n\rNodeExecution\"\x80\x01\n\x05Phase\x12\r\n\tUNDEFINED\x10\x00\x12\n\n\x06QUEUED\x10\x01\x12\x0b\n\x07RUNNING\x10\x02\x12\r\n\tSUCCEEDED\x10\x03\x12\x0b\n\x07\x46\x41ILING\x10\x04\x12\n\n\x06\x46\x41ILED\x10\x05\x12\x0b\n\x07\x41\x42ORTED\x10\x06\x12\x0b\n\x07SKIPPED\x10\x07\x12\r\n\tTIMED_OUT\x10\x08\"\x96\x01\n\rTaskExecution\"\x84\x01\n\x05Phase\x12\r\n\tUNDEFINED\x10\x00\x12\n\n\x06QUEUED\x10\x01\x12\x0b\n\x07RUNNING\x10\x02\x12\r\n\tSUCCEEDED\x10\x03\x12\x0b\n\x07\x41\x42ORTED\x10\x04\x12\n\n\x06\x46\x41ILED\x10\x05\x12\x10\n\x0cINITIALIZING\x10\x06\x12\x19\n\x15WAITING_FOR_RESOURCES\x10\x07\"\xa9\x01\n\x0e\x45xecutionError\x12\x0c\n\x04\x63ode\x18\x01 \x01(\t\x12\x0f\n\x07message\x18\x02 \x01(\t\x12\x11\n\terror_uri\x18\x03 \x01(\t\x12\x35\n\x04kind\x18\x04 \x01(\x0e\x32\'.flyteidl.core.ExecutionError.ErrorKind\".\n\tErrorKind\x12\x0b\n\x07UNKNOWN\x10\x00\x12\x08\n\x04USER\x10\x01\x12\n\n\x06SYSTEM\x10\x02\"\xbb\x01\n\x07TaskLog\x12\x0b\n\x03uri\x18\x01 \x01(\t\x12\x0c\n\x04name\x18\x02 \x01(\t\x12<\n\x0emessage_format\x18\x03 \x01(\x0e\x32$.flyteidl.core.TaskLog.MessageFormat\x12&\n\x03ttl\x18\x04 \x01(\x0b\x32\x19.google.protobuf.Duration\"/\n\rMessageFormat\x12\x0b\n\x07UNKNOWN\x10\x00\x12\x07\n\x03\x43SV\x10\x01\x12\x08\n\x04JSON\x10\x02\"J\n\x14QualityOfServiceSpec\x12\x32\n\x0fqueueing_budget\x18\x01 \x01(\x0b\x32\x19.google.protobuf.Duration\"\xc2\x01\n\x10QualityOfService\x12\x34\n\x04tier\x18\x01 \x01(\x0e\x32$.flyteidl.core.QualityOfService.TierH\x00\x12\x33\n\x04spec\x18\x02 \x01(\x0b\x32#.flyteidl.core.QualityOfServiceSpecH\x00\"4\n\x04Tier\x12\r\n\tUNDEFINED\x10\x00\x12\x08\n\x04HIGH\x10\x01\x12\n\n\x06MEDIUM\x10\x02\x12\x07\n\x03LOW\x10\x03\x42\r\n\x0b\x64\x65signationB2Z0github.com/lyft/flyteidl/gen/pb-go/flyteidl/coreb\x06proto3') , dependencies=[google_dot_protobuf_dot_duration__pb2.DESCRIPTOR,]) @@ -225,6 +225,36 @@ ) _sym_db.RegisterEnumDescriptor(_TASKLOG_MESSAGEFORMAT) +_QUALITYOFSERVICE_TIER = _descriptor.EnumDescriptor( + name='Tier', + full_name='flyteidl.core.QualityOfService.Tier', + filename=None, + file=DESCRIPTOR, + values=[ + _descriptor.EnumValueDescriptor( + name='UNDEFINED', index=0, number=0, + serialized_options=None, + type=None), + _descriptor.EnumValueDescriptor( + name='HIGH', index=1, number=1, + serialized_options=None, + type=None), + _descriptor.EnumValueDescriptor( + name='MEDIUM', index=2, number=2, + serialized_options=None, + type=None), + _descriptor.EnumValueDescriptor( + name='LOW', index=3, number=3, + serialized_options=None, + type=None), + ], + containing_type=None, + serialized_options=None, + serialized_start=1104, + serialized_end=1156, +) +_sym_db.RegisterEnumDescriptor(_QUALITYOFSERVICE_TIER) + _WORKFLOWEXECUTION = _descriptor.Descriptor( name='WorkflowExecution', @@ -406,6 +436,79 @@ serialized_end=898, ) + +_QUALITYOFSERVICESPEC = _descriptor.Descriptor( + name='QualityOfServiceSpec', + full_name='flyteidl.core.QualityOfServiceSpec', + filename=None, + file=DESCRIPTOR, + containing_type=None, + fields=[ + _descriptor.FieldDescriptor( + name='queueing_budget', full_name='flyteidl.core.QualityOfServiceSpec.queueing_budget', index=0, + number=1, 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), + ], + extensions=[ + ], + nested_types=[], + enum_types=[ + ], + serialized_options=None, + is_extendable=False, + syntax='proto3', + extension_ranges=[], + oneofs=[ + ], + serialized_start=900, + serialized_end=974, +) + + +_QUALITYOFSERVICE = _descriptor.Descriptor( + name='QualityOfService', + full_name='flyteidl.core.QualityOfService', + filename=None, + file=DESCRIPTOR, + containing_type=None, + fields=[ + _descriptor.FieldDescriptor( + name='tier', full_name='flyteidl.core.QualityOfService.tier', index=0, + number=1, type=14, cpp_type=8, label=1, + has_default_value=False, default_value=0, + message_type=None, enum_type=None, containing_type=None, + is_extension=False, extension_scope=None, + serialized_options=None, file=DESCRIPTOR), + _descriptor.FieldDescriptor( + name='spec', full_name='flyteidl.core.QualityOfService.spec', index=1, + number=2, 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), + ], + extensions=[ + ], + nested_types=[], + enum_types=[ + _QUALITYOFSERVICE_TIER, + ], + serialized_options=None, + is_extendable=False, + syntax='proto3', + extension_ranges=[], + oneofs=[ + _descriptor.OneofDescriptor( + name='designation', full_name='flyteidl.core.QualityOfService.designation', + index=0, containing_type=None, fields=[]), + ], + serialized_start=977, + serialized_end=1171, +) + _WORKFLOWEXECUTION_PHASE.containing_type = _WORKFLOWEXECUTION _NODEEXECUTION_PHASE.containing_type = _NODEEXECUTION _TASKEXECUTION_PHASE.containing_type = _TASKEXECUTION @@ -414,11 +517,23 @@ _TASKLOG.fields_by_name['message_format'].enum_type = _TASKLOG_MESSAGEFORMAT _TASKLOG.fields_by_name['ttl'].message_type = google_dot_protobuf_dot_duration__pb2._DURATION _TASKLOG_MESSAGEFORMAT.containing_type = _TASKLOG +_QUALITYOFSERVICESPEC.fields_by_name['queueing_budget'].message_type = google_dot_protobuf_dot_duration__pb2._DURATION +_QUALITYOFSERVICE.fields_by_name['tier'].enum_type = _QUALITYOFSERVICE_TIER +_QUALITYOFSERVICE.fields_by_name['spec'].message_type = _QUALITYOFSERVICESPEC +_QUALITYOFSERVICE_TIER.containing_type = _QUALITYOFSERVICE +_QUALITYOFSERVICE.oneofs_by_name['designation'].fields.append( + _QUALITYOFSERVICE.fields_by_name['tier']) +_QUALITYOFSERVICE.fields_by_name['tier'].containing_oneof = _QUALITYOFSERVICE.oneofs_by_name['designation'] +_QUALITYOFSERVICE.oneofs_by_name['designation'].fields.append( + _QUALITYOFSERVICE.fields_by_name['spec']) +_QUALITYOFSERVICE.fields_by_name['spec'].containing_oneof = _QUALITYOFSERVICE.oneofs_by_name['designation'] DESCRIPTOR.message_types_by_name['WorkflowExecution'] = _WORKFLOWEXECUTION DESCRIPTOR.message_types_by_name['NodeExecution'] = _NODEEXECUTION DESCRIPTOR.message_types_by_name['TaskExecution'] = _TASKEXECUTION DESCRIPTOR.message_types_by_name['ExecutionError'] = _EXECUTIONERROR DESCRIPTOR.message_types_by_name['TaskLog'] = _TASKLOG +DESCRIPTOR.message_types_by_name['QualityOfServiceSpec'] = _QUALITYOFSERVICESPEC +DESCRIPTOR.message_types_by_name['QualityOfService'] = _QUALITYOFSERVICE _sym_db.RegisterFileDescriptor(DESCRIPTOR) WorkflowExecution = _reflection.GeneratedProtocolMessageType('WorkflowExecution', (_message.Message,), dict( @@ -456,6 +571,20 @@ )) _sym_db.RegisterMessage(TaskLog) +QualityOfServiceSpec = _reflection.GeneratedProtocolMessageType('QualityOfServiceSpec', (_message.Message,), dict( + DESCRIPTOR = _QUALITYOFSERVICESPEC, + __module__ = 'flyteidl.core.execution_pb2' + # @@protoc_insertion_point(class_scope:flyteidl.core.QualityOfServiceSpec) + )) +_sym_db.RegisterMessage(QualityOfServiceSpec) + +QualityOfService = _reflection.GeneratedProtocolMessageType('QualityOfService', (_message.Message,), dict( + DESCRIPTOR = _QUALITYOFSERVICE, + __module__ = 'flyteidl.core.execution_pb2' + # @@protoc_insertion_point(class_scope:flyteidl.core.QualityOfService) + )) +_sym_db.RegisterMessage(QualityOfService) + DESCRIPTOR._options = None # @@protoc_insertion_point(module_scope) diff --git a/flyteidl/gen/pb_python/flyteidl/core/workflow_pb2.py b/flyteidl/gen/pb_python/flyteidl/core/workflow_pb2.py index 69fee2a5db8..7bcf53935ee 100644 --- a/flyteidl/gen/pb_python/flyteidl/core/workflow_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/core/workflow_pb2.py @@ -14,6 +14,7 @@ from flyteidl.core import condition_pb2 as flyteidl_dot_core_dot_condition__pb2 +from flyteidl.core import execution_pb2 as flyteidl_dot_core_dot_execution__pb2 from flyteidl.core import identifier_pb2 as flyteidl_dot_core_dot_identifier__pb2 from flyteidl.core import interface_pb2 as flyteidl_dot_core_dot_interface__pb2 from flyteidl.core import literals_pb2 as flyteidl_dot_core_dot_literals__pb2 @@ -26,9 +27,9 @@ package='flyteidl.core', syntax='proto3', serialized_options=_b('Z0github.com/lyft/flyteidl/gen/pb-go/flyteidl/core'), - serialized_pb=_b('\n\x1c\x66lyteidl/core/workflow.proto\x12\rflyteidl.core\x1a\x1d\x66lyteidl/core/condition.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x19\x66lyteidl/core/types.proto\x1a\x1egoogle/protobuf/duration.proto\"f\n\x07IfBlock\x12\x33\n\tcondition\x18\x01 \x01(\x0b\x32 .flyteidl.core.BooleanExpression\x12&\n\tthen_node\x18\x02 \x01(\x0b\x32\x13.flyteidl.core.Node\"\xb6\x01\n\x0bIfElseBlock\x12$\n\x04\x63\x61se\x18\x01 \x01(\x0b\x32\x16.flyteidl.core.IfBlock\x12%\n\x05other\x18\x02 \x03(\x0b\x32\x16.flyteidl.core.IfBlock\x12(\n\telse_node\x18\x03 \x01(\x0b\x32\x13.flyteidl.core.NodeH\x00\x12%\n\x05\x65rror\x18\x04 \x01(\x0b\x32\x14.flyteidl.core.ErrorH\x00\x42\t\n\x07\x64\x65\x66\x61ult\"9\n\nBranchNode\x12+\n\x07if_else\x18\x01 \x01(\x0b\x32\x1a.flyteidl.core.IfElseBlock\"J\n\x08TaskNode\x12\x31\n\x0creference_id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.IdentifierH\x00\x42\x0b\n\treference\"\x87\x01\n\x0cWorkflowNode\x12\x33\n\x0elaunchplan_ref\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.IdentifierH\x00\x12\x35\n\x10sub_workflow_ref\x18\x02 \x01(\x0b\x32\x19.flyteidl.core.IdentifierH\x00\x42\x0b\n\treference\"\xa7\x01\n\x0cNodeMetadata\x12\x0c\n\x04name\x18\x01 \x01(\t\x12*\n\x07timeout\x18\x04 \x01(\x0b\x32\x19.google.protobuf.Duration\x12-\n\x07retries\x18\x05 \x01(\x0b\x32\x1c.flyteidl.core.RetryStrategy\x12\x17\n\rinterruptible\x18\x06 \x01(\x08H\x00\x42\x15\n\x13interruptible_value\"#\n\x05\x41lias\x12\x0b\n\x03var\x18\x01 \x01(\t\x12\r\n\x05\x61lias\x18\x02 \x01(\t\"\xd2\x02\n\x04Node\x12\n\n\x02id\x18\x01 \x01(\t\x12-\n\x08metadata\x18\x02 \x01(\x0b\x32\x1b.flyteidl.core.NodeMetadata\x12&\n\x06inputs\x18\x03 \x03(\x0b\x32\x16.flyteidl.core.Binding\x12\x19\n\x11upstream_node_ids\x18\x04 \x03(\t\x12,\n\x0eoutput_aliases\x18\x05 \x03(\x0b\x32\x14.flyteidl.core.Alias\x12,\n\ttask_node\x18\x06 \x01(\x0b\x32\x17.flyteidl.core.TaskNodeH\x00\x12\x34\n\rworkflow_node\x18\x07 \x01(\x0b\x32\x1b.flyteidl.core.WorkflowNodeH\x00\x12\x30\n\x0b\x62ranch_node\x18\x08 \x01(\x0b\x32\x19.flyteidl.core.BranchNodeH\x00\x42\x08\n\x06target\"\xdd\x01\n\x10WorkflowMetadata\x12\x31\n\x0equeuing_budget\x18\x01 \x01(\x0b\x32\x19.google.protobuf.Duration\x12\x43\n\non_failure\x18\x02 \x01(\x0e\x32/.flyteidl.core.WorkflowMetadata.OnFailurePolicy\"Q\n\x0fOnFailurePolicy\x12\x14\n\x10\x46\x41IL_IMMEDIATELY\x10\x00\x12(\n$FAIL_AFTER_EXECUTABLE_NODES_COMPLETE\x10\x01\"1\n\x18WorkflowMetadataDefaults\x12\x15\n\rinterruptible\x18\x01 \x01(\x08\"\xda\x02\n\x10WorkflowTemplate\x12%\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12\x31\n\x08metadata\x18\x02 \x01(\x0b\x32\x1f.flyteidl.core.WorkflowMetadata\x12\x30\n\tinterface\x18\x03 \x01(\x0b\x32\x1d.flyteidl.core.TypedInterface\x12\"\n\x05nodes\x18\x04 \x03(\x0b\x32\x13.flyteidl.core.Node\x12\'\n\x07outputs\x18\x05 \x03(\x0b\x32\x16.flyteidl.core.Binding\x12)\n\x0c\x66\x61ilure_node\x18\x06 \x01(\x0b\x32\x13.flyteidl.core.Node\x12\x42\n\x11metadata_defaults\x18\x07 \x01(\x0b\x32\'.flyteidl.core.WorkflowMetadataDefaultsB2Z0github.com/lyft/flyteidl/gen/pb-go/flyteidl/coreb\x06proto3') + serialized_pb=_b('\n\x1c\x66lyteidl/core/workflow.proto\x12\rflyteidl.core\x1a\x1d\x66lyteidl/core/condition.proto\x1a\x1d\x66lyteidl/core/execution.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x19\x66lyteidl/core/types.proto\x1a\x1egoogle/protobuf/duration.proto\"f\n\x07IfBlock\x12\x33\n\tcondition\x18\x01 \x01(\x0b\x32 .flyteidl.core.BooleanExpression\x12&\n\tthen_node\x18\x02 \x01(\x0b\x32\x13.flyteidl.core.Node\"\xb6\x01\n\x0bIfElseBlock\x12$\n\x04\x63\x61se\x18\x01 \x01(\x0b\x32\x16.flyteidl.core.IfBlock\x12%\n\x05other\x18\x02 \x03(\x0b\x32\x16.flyteidl.core.IfBlock\x12(\n\telse_node\x18\x03 \x01(\x0b\x32\x13.flyteidl.core.NodeH\x00\x12%\n\x05\x65rror\x18\x04 \x01(\x0b\x32\x14.flyteidl.core.ErrorH\x00\x42\t\n\x07\x64\x65\x66\x61ult\"9\n\nBranchNode\x12+\n\x07if_else\x18\x01 \x01(\x0b\x32\x1a.flyteidl.core.IfElseBlock\"J\n\x08TaskNode\x12\x31\n\x0creference_id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.IdentifierH\x00\x42\x0b\n\treference\"\x87\x01\n\x0cWorkflowNode\x12\x33\n\x0elaunchplan_ref\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.IdentifierH\x00\x12\x35\n\x10sub_workflow_ref\x18\x02 \x01(\x0b\x32\x19.flyteidl.core.IdentifierH\x00\x42\x0b\n\treference\"\xa7\x01\n\x0cNodeMetadata\x12\x0c\n\x04name\x18\x01 \x01(\t\x12*\n\x07timeout\x18\x04 \x01(\x0b\x32\x19.google.protobuf.Duration\x12-\n\x07retries\x18\x05 \x01(\x0b\x32\x1c.flyteidl.core.RetryStrategy\x12\x17\n\rinterruptible\x18\x06 \x01(\x08H\x00\x42\x15\n\x13interruptible_value\"#\n\x05\x41lias\x12\x0b\n\x03var\x18\x01 \x01(\t\x12\r\n\x05\x61lias\x18\x02 \x01(\t\"\xd2\x02\n\x04Node\x12\n\n\x02id\x18\x01 \x01(\t\x12-\n\x08metadata\x18\x02 \x01(\x0b\x32\x1b.flyteidl.core.NodeMetadata\x12&\n\x06inputs\x18\x03 \x03(\x0b\x32\x16.flyteidl.core.Binding\x12\x19\n\x11upstream_node_ids\x18\x04 \x03(\t\x12,\n\x0eoutput_aliases\x18\x05 \x03(\x0b\x32\x14.flyteidl.core.Alias\x12,\n\ttask_node\x18\x06 \x01(\x0b\x32\x17.flyteidl.core.TaskNodeH\x00\x12\x34\n\rworkflow_node\x18\x07 \x01(\x0b\x32\x1b.flyteidl.core.WorkflowNodeH\x00\x12\x30\n\x0b\x62ranch_node\x18\x08 \x01(\x0b\x32\x19.flyteidl.core.BranchNodeH\x00\x42\x08\n\x06target\"\xe7\x01\n\x10WorkflowMetadata\x12;\n\x12quality_of_service\x18\x01 \x01(\x0b\x32\x1f.flyteidl.core.QualityOfService\x12\x43\n\non_failure\x18\x02 \x01(\x0e\x32/.flyteidl.core.WorkflowMetadata.OnFailurePolicy\"Q\n\x0fOnFailurePolicy\x12\x14\n\x10\x46\x41IL_IMMEDIATELY\x10\x00\x12(\n$FAIL_AFTER_EXECUTABLE_NODES_COMPLETE\x10\x01\"1\n\x18WorkflowMetadataDefaults\x12\x15\n\rinterruptible\x18\x01 \x01(\x08\"\xda\x02\n\x10WorkflowTemplate\x12%\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.Identifier\x12\x31\n\x08metadata\x18\x02 \x01(\x0b\x32\x1f.flyteidl.core.WorkflowMetadata\x12\x30\n\tinterface\x18\x03 \x01(\x0b\x32\x1d.flyteidl.core.TypedInterface\x12\"\n\x05nodes\x18\x04 \x03(\x0b\x32\x13.flyteidl.core.Node\x12\'\n\x07outputs\x18\x05 \x03(\x0b\x32\x16.flyteidl.core.Binding\x12)\n\x0c\x66\x61ilure_node\x18\x06 \x01(\x0b\x32\x13.flyteidl.core.Node\x12\x42\n\x11metadata_defaults\x18\x07 \x01(\x0b\x32\'.flyteidl.core.WorkflowMetadataDefaultsB2Z0github.com/lyft/flyteidl/gen/pb-go/flyteidl/coreb\x06proto3') , - dependencies=[flyteidl_dot_core_dot_condition__pb2.DESCRIPTOR,flyteidl_dot_core_dot_identifier__pb2.DESCRIPTOR,flyteidl_dot_core_dot_interface__pb2.DESCRIPTOR,flyteidl_dot_core_dot_literals__pb2.DESCRIPTOR,flyteidl_dot_core_dot_types__pb2.DESCRIPTOR,google_dot_protobuf_dot_duration__pb2.DESCRIPTOR,]) + dependencies=[flyteidl_dot_core_dot_condition__pb2.DESCRIPTOR,flyteidl_dot_core_dot_execution__pb2.DESCRIPTOR,flyteidl_dot_core_dot_identifier__pb2.DESCRIPTOR,flyteidl_dot_core_dot_interface__pb2.DESCRIPTOR,flyteidl_dot_core_dot_literals__pb2.DESCRIPTOR,flyteidl_dot_core_dot_types__pb2.DESCRIPTOR,google_dot_protobuf_dot_duration__pb2.DESCRIPTOR,]) @@ -49,8 +50,8 @@ ], containing_type=None, serialized_options=None, - serialized_start=1481, - serialized_end=1562, + serialized_start=1522, + serialized_end=1603, ) _sym_db.RegisterEnumDescriptor(_WORKFLOWMETADATA_ONFAILUREPOLICY) @@ -88,8 +89,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=230, - serialized_end=332, + serialized_start=261, + serialized_end=363, ) @@ -143,8 +144,8 @@ name='default', full_name='flyteidl.core.IfElseBlock.default', index=0, containing_type=None, fields=[]), ], - serialized_start=335, - serialized_end=517, + serialized_start=366, + serialized_end=548, ) @@ -174,8 +175,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=519, - serialized_end=576, + serialized_start=550, + serialized_end=607, ) @@ -208,8 +209,8 @@ name='reference', full_name='flyteidl.core.TaskNode.reference', index=0, containing_type=None, fields=[]), ], - serialized_start=578, - serialized_end=652, + serialized_start=609, + serialized_end=683, ) @@ -249,8 +250,8 @@ name='reference', full_name='flyteidl.core.WorkflowNode.reference', index=0, containing_type=None, fields=[]), ], - serialized_start=655, - serialized_end=790, + serialized_start=686, + serialized_end=821, ) @@ -304,8 +305,8 @@ name='interruptible_value', full_name='flyteidl.core.NodeMetadata.interruptible_value', index=0, containing_type=None, fields=[]), ], - serialized_start=793, - serialized_end=960, + serialized_start=824, + serialized_end=991, ) @@ -342,8 +343,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=962, - serialized_end=997, + serialized_start=993, + serialized_end=1028, ) @@ -425,8 +426,8 @@ name='target', full_name='flyteidl.core.Node.target', index=0, containing_type=None, fields=[]), ], - serialized_start=1000, - serialized_end=1338, + serialized_start=1031, + serialized_end=1369, ) @@ -438,7 +439,7 @@ containing_type=None, fields=[ _descriptor.FieldDescriptor( - name='queuing_budget', full_name='flyteidl.core.WorkflowMetadata.queuing_budget', index=0, + name='quality_of_service', full_name='flyteidl.core.WorkflowMetadata.quality_of_service', index=0, number=1, type=11, cpp_type=10, label=1, has_default_value=False, default_value=None, message_type=None, enum_type=None, containing_type=None, @@ -464,8 +465,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1341, - serialized_end=1562, + serialized_start=1372, + serialized_end=1603, ) @@ -495,8 +496,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1564, - serialized_end=1613, + serialized_start=1605, + serialized_end=1654, ) @@ -568,8 +569,8 @@ extension_ranges=[], oneofs=[ ], - serialized_start=1616, - serialized_end=1962, + serialized_start=1657, + serialized_end=2003, ) _IFBLOCK.fields_by_name['condition'].message_type = flyteidl_dot_core_dot_condition__pb2._BOOLEANEXPRESSION @@ -617,7 +618,7 @@ _NODE.oneofs_by_name['target'].fields.append( _NODE.fields_by_name['branch_node']) _NODE.fields_by_name['branch_node'].containing_oneof = _NODE.oneofs_by_name['target'] -_WORKFLOWMETADATA.fields_by_name['queuing_budget'].message_type = google_dot_protobuf_dot_duration__pb2._DURATION +_WORKFLOWMETADATA.fields_by_name['quality_of_service'].message_type = flyteidl_dot_core_dot_execution__pb2._QUALITYOFSERVICE _WORKFLOWMETADATA.fields_by_name['on_failure'].enum_type = _WORKFLOWMETADATA_ONFAILUREPOLICY _WORKFLOWMETADATA_ONFAILUREPOLICY.containing_type = _WORKFLOWMETADATA _WORKFLOWTEMPLATE.fields_by_name['id'].message_type = flyteidl_dot_core_dot_identifier__pb2._IDENTIFIER diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/README.md b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/README.md index d8e2a0c56ad..e56d3073912 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/README.md +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/README.md @@ -260,6 +260,8 @@ Class | Method | HTTP request | Description - [CoreParameter](docs/CoreParameter.md) - [CoreParameterMap](docs/CoreParameterMap.md) - [CorePrimitive](docs/CorePrimitive.md) + - [CoreQualityOfService](docs/CoreQualityOfService.md) + - [CoreQualityOfServiceSpec](docs/CoreQualityOfServiceSpec.md) - [CoreResourceType](docs/CoreResourceType.md) - [CoreResources](docs/CoreResources.md) - [CoreRetryStrategy](docs/CoreRetryStrategy.md) @@ -301,6 +303,7 @@ Class | Method | HTTP request | Description - [ProtobufNullValue](docs/ProtobufNullValue.md) - [ProtobufStruct](docs/ProtobufStruct.md) - [ProtobufValue](docs/ProtobufValue.md) + - [QualityOfServiceTier](docs/QualityOfServiceTier.md) - [ResourcesResourceEntry](docs/ResourcesResourceEntry.md) - [ResourcesResourceName](docs/ResourcesResourceName.md) - [RuntimeMetadataRuntimeType](docs/RuntimeMetadataRuntimeType.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 c0dff83cdcc..139afebf05c 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/__init__.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/__init__.py @@ -163,6 +163,8 @@ from flyteadmin.models.core_parameter import CoreParameter from flyteadmin.models.core_parameter_map import CoreParameterMap from flyteadmin.models.core_primitive import CorePrimitive +from flyteadmin.models.core_quality_of_service import CoreQualityOfService +from flyteadmin.models.core_quality_of_service_spec import CoreQualityOfServiceSpec from flyteadmin.models.core_resource_type import CoreResourceType from flyteadmin.models.core_resources import CoreResources from flyteadmin.models.core_retry_strategy import CoreRetryStrategy @@ -204,6 +206,7 @@ from flyteadmin.models.protobuf_null_value import ProtobufNullValue from flyteadmin.models.protobuf_struct import ProtobufStruct from flyteadmin.models.protobuf_value import ProtobufValue +from flyteadmin.models.quality_of_service_tier import QualityOfServiceTier from flyteadmin.models.resources_resource_entry import ResourcesResourceEntry from flyteadmin.models.resources_resource_name import ResourcesResourceName from flyteadmin.models.runtime_metadata_runtime_type import RuntimeMetadataRuntimeType 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 7d0fdb2c8f3..457b86c48d9 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 @@ -1817,7 +1817,7 @@ def get_project_domain_attributes(self, project, domain, **kwargs): # noqa: E50 :param async_req bool :param str project: Unique project id which this set of attributes references. (required) :param str domain: Unique domain id which this set of attributes references. (required) - :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. :return: AdminProjectDomainAttributesGetResponse If the method is called asynchronously, returns the request thread. @@ -1841,7 +1841,7 @@ def get_project_domain_attributes_with_http_info(self, project, domain, **kwargs :param async_req bool :param str project: Unique project id which this set of attributes references. (required) :param str domain: Unique domain id which this set of attributes references. (required) - :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. :return: AdminProjectDomainAttributesGetResponse If the method is called asynchronously, returns the request thread. @@ -2517,7 +2517,7 @@ def get_workflow_attributes(self, project, domain, workflow, **kwargs): # noqa: :param str project: Unique project id which this set of attributes references. (required) :param str domain: Unique domain id which this set of attributes references. (required) :param str workflow: Workflow name which this set of attributes references. (required) - :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. :return: AdminWorkflowAttributesGetResponse If the method is called asynchronously, returns the request thread. @@ -2542,7 +2542,7 @@ def get_workflow_attributes_with_http_info(self, project, domain, workflow, **kw :param str project: Unique project id which this set of attributes references. (required) :param str domain: Unique domain id which this set of attributes references. (required) :param str workflow: Workflow name which this set of attributes references. (required) - :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. :return: AdminWorkflowAttributesGetResponse If the method is called asynchronously, returns the request thread. @@ -3280,7 +3280,7 @@ def list_matchable_attributes(self, **kwargs): # noqa: E501 >>> result = thread.get() :param async_req bool - :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. :return: AdminListMatchableAttributesResponse If the method is called asynchronously, returns the request thread. @@ -3302,7 +3302,7 @@ def list_matchable_attributes_with_http_info(self, **kwargs): # noqa: E501 >>> result = thread.get() :param async_req bool - :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run + :param str resource_type: - TASK_RESOURCE: Applies to customizable task resource requests and limits. - CLUSTER_RESOURCE: Applies to configuring templated kubernetes cluster resources. - EXECUTION_QUEUE: Configures task and dynamic task execution queue assignment. - EXECUTION_CLUSTER_LABEL: Configures the K8s cluster label to be used for execution to be run - QUALITY_OF_SERVICE_SPECIFICATION: Configures default quality of service when undefined in an execution spec. :return: AdminListMatchableAttributesResponse If the method is called asynchronously, returns the request thread. 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 802b4063d25..218445dad0f 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 @@ -156,6 +156,8 @@ from flyteadmin.models.core_parameter import CoreParameter from flyteadmin.models.core_parameter_map import CoreParameterMap from flyteadmin.models.core_primitive import CorePrimitive +from flyteadmin.models.core_quality_of_service import CoreQualityOfService +from flyteadmin.models.core_quality_of_service_spec import CoreQualityOfServiceSpec from flyteadmin.models.core_resource_type import CoreResourceType from flyteadmin.models.core_resources import CoreResources from flyteadmin.models.core_retry_strategy import CoreRetryStrategy @@ -197,6 +199,7 @@ from flyteadmin.models.protobuf_null_value import ProtobufNullValue from flyteadmin.models.protobuf_struct import ProtobufStruct from flyteadmin.models.protobuf_value import ProtobufValue +from flyteadmin.models.quality_of_service_tier import QualityOfServiceTier from flyteadmin.models.resources_resource_entry import ResourcesResourceEntry from flyteadmin.models.resources_resource_name import ResourcesResourceName from flyteadmin.models.runtime_metadata_runtime_type import RuntimeMetadataRuntimeType diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_execution_spec.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_execution_spec.py index b6dc818b5f8..d9687b567c9 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_execution_spec.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_execution_spec.py @@ -23,6 +23,7 @@ from flyteadmin.models.admin_notification_list import AdminNotificationList # noqa: F401,E501 from flyteadmin.models.core_identifier import CoreIdentifier # noqa: F401,E501 from flyteadmin.models.core_literal_map import CoreLiteralMap # noqa: F401,E501 +from flyteadmin.models.core_quality_of_service import CoreQualityOfService # noqa: F401,E501 class AdminExecutionSpec(object): @@ -46,7 +47,8 @@ class AdminExecutionSpec(object): 'disable_all': 'bool', 'labels': 'AdminLabels', 'annotations': 'AdminAnnotations', - 'auth_role': 'AdminAuthRole' + 'auth_role': 'AdminAuthRole', + 'quality_of_service': 'CoreQualityOfService' } attribute_map = { @@ -57,10 +59,11 @@ class AdminExecutionSpec(object): 'disable_all': 'disable_all', 'labels': 'labels', 'annotations': 'annotations', - 'auth_role': 'auth_role' + 'auth_role': 'auth_role', + 'quality_of_service': 'quality_of_service' } - def __init__(self, launch_plan=None, inputs=None, metadata=None, notifications=None, disable_all=None, labels=None, annotations=None, auth_role=None): # noqa: E501 + def __init__(self, launch_plan=None, inputs=None, metadata=None, notifications=None, disable_all=None, labels=None, annotations=None, auth_role=None, quality_of_service=None): # noqa: E501 """AdminExecutionSpec - a model defined in Swagger""" # noqa: E501 self._launch_plan = None @@ -71,6 +74,7 @@ def __init__(self, launch_plan=None, inputs=None, metadata=None, notifications=N self._labels = None self._annotations = None self._auth_role = None + self._quality_of_service = None self.discriminator = None if launch_plan is not None: @@ -89,6 +93,8 @@ def __init__(self, launch_plan=None, inputs=None, metadata=None, notifications=N self.annotations = annotations if auth_role is not None: self.auth_role = auth_role + if quality_of_service is not None: + self.quality_of_service = quality_of_service @property def launch_plan(self): @@ -268,6 +274,29 @@ def auth_role(self, auth_role): self._auth_role = auth_role + @property + def quality_of_service(self): + """Gets the quality_of_service of this AdminExecutionSpec. # noqa: E501 + + Indicates the runtime priority of the execution. # noqa: E501 + + :return: The quality_of_service of this AdminExecutionSpec. # noqa: E501 + :rtype: CoreQualityOfService + """ + return self._quality_of_service + + @quality_of_service.setter + def quality_of_service(self, quality_of_service): + """Sets the quality_of_service of this AdminExecutionSpec. + + Indicates the runtime priority of the execution. # noqa: E501 + + :param quality_of_service: The quality_of_service of this AdminExecutionSpec. # noqa: E501 + :type: CoreQualityOfService + """ + + self._quality_of_service = quality_of_service + def to_dict(self): """Returns the model properties as a dict""" result = {} diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_launch_plan_spec.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_launch_plan_spec.py index 9de7339b75f..b49abebe81b 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_launch_plan_spec.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_launch_plan_spec.py @@ -24,6 +24,7 @@ from flyteadmin.models.core_identifier import CoreIdentifier # noqa: F401,E501 from flyteadmin.models.core_literal_map import CoreLiteralMap # noqa: F401,E501 from flyteadmin.models.core_parameter_map import CoreParameterMap # noqa: F401,E501 +from flyteadmin.models.core_quality_of_service import CoreQualityOfService # noqa: F401,E501 class AdminLaunchPlanSpec(object): @@ -48,7 +49,8 @@ class AdminLaunchPlanSpec(object): 'labels': 'AdminLabels', 'annotations': 'AdminAnnotations', 'auth': 'AdminAuth', - 'auth_role': 'AdminAuthRole' + 'auth_role': 'AdminAuthRole', + 'quality_of_service': 'CoreQualityOfService' } attribute_map = { @@ -60,10 +62,11 @@ class AdminLaunchPlanSpec(object): 'labels': 'labels', 'annotations': 'annotations', 'auth': 'auth', - 'auth_role': 'auth_role' + 'auth_role': 'auth_role', + 'quality_of_service': 'quality_of_service' } - def __init__(self, workflow_id=None, entity_metadata=None, default_inputs=None, fixed_inputs=None, role=None, labels=None, annotations=None, auth=None, auth_role=None): # noqa: E501 + def __init__(self, workflow_id=None, entity_metadata=None, default_inputs=None, fixed_inputs=None, role=None, labels=None, annotations=None, auth=None, auth_role=None, quality_of_service=None): # noqa: E501 """AdminLaunchPlanSpec - a model defined in Swagger""" # noqa: E501 self._workflow_id = None @@ -75,6 +78,7 @@ def __init__(self, workflow_id=None, entity_metadata=None, default_inputs=None, self._annotations = None self._auth = None self._auth_role = None + self._quality_of_service = None self.discriminator = None if workflow_id is not None: @@ -95,6 +99,8 @@ def __init__(self, workflow_id=None, entity_metadata=None, default_inputs=None, self.auth = auth if auth_role is not None: self.auth_role = auth_role + if quality_of_service is not None: + self.quality_of_service = quality_of_service @property def workflow_id(self): @@ -291,6 +297,29 @@ def auth_role(self, auth_role): self._auth_role = auth_role + @property + def quality_of_service(self): + """Gets the quality_of_service of this AdminLaunchPlanSpec. # noqa: E501 + + Indicates the runtime priority of the execution. # noqa: E501 + + :return: The quality_of_service of this AdminLaunchPlanSpec. # noqa: E501 + :rtype: CoreQualityOfService + """ + return self._quality_of_service + + @quality_of_service.setter + def quality_of_service(self, quality_of_service): + """Sets the quality_of_service of this AdminLaunchPlanSpec. + + Indicates the runtime priority of the execution. # noqa: E501 + + :param quality_of_service: The quality_of_service of this AdminLaunchPlanSpec. # noqa: E501 + :type: CoreQualityOfService + """ + + self._quality_of_service = quality_of_service + def to_dict(self): """Returns the model properties as a dict""" result = {} diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_matchable_resource.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_matchable_resource.py index 1ffcecb350c..f78a47ca216 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_matchable_resource.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_matchable_resource.py @@ -30,6 +30,7 @@ class AdminMatchableResource(object): CLUSTER_RESOURCE = "CLUSTER_RESOURCE" EXECUTION_QUEUE = "EXECUTION_QUEUE" EXECUTION_CLUSTER_LABEL = "EXECUTION_CLUSTER_LABEL" + QUALITY_OF_SERVICE_SPECIFICATION = "QUALITY_OF_SERVICE_SPECIFICATION" """ Attributes: diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_matching_attributes.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_matching_attributes.py index 9fc0181a2fd..d6117258964 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_matching_attributes.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/admin_matching_attributes.py @@ -20,6 +20,7 @@ from flyteadmin.models.admin_execution_cluster_label import AdminExecutionClusterLabel # noqa: F401,E501 from flyteadmin.models.admin_execution_queue_attributes import AdminExecutionQueueAttributes # noqa: F401,E501 from flyteadmin.models.admin_task_resource_attributes import AdminTaskResourceAttributes # noqa: F401,E501 +from flyteadmin.models.core_quality_of_service import CoreQualityOfService # noqa: F401,E501 class AdminMatchingAttributes(object): @@ -39,23 +40,26 @@ class AdminMatchingAttributes(object): 'task_resource_attributes': 'AdminTaskResourceAttributes', 'cluster_resource_attributes': 'AdminClusterResourceAttributes', 'execution_queue_attributes': 'AdminExecutionQueueAttributes', - 'execution_cluster_label': 'AdminExecutionClusterLabel' + 'execution_cluster_label': 'AdminExecutionClusterLabel', + 'quality_of_service': 'CoreQualityOfService' } attribute_map = { 'task_resource_attributes': 'task_resource_attributes', 'cluster_resource_attributes': 'cluster_resource_attributes', 'execution_queue_attributes': 'execution_queue_attributes', - 'execution_cluster_label': 'execution_cluster_label' + 'execution_cluster_label': 'execution_cluster_label', + 'quality_of_service': 'quality_of_service' } - def __init__(self, task_resource_attributes=None, cluster_resource_attributes=None, execution_queue_attributes=None, execution_cluster_label=None): # noqa: E501 + def __init__(self, task_resource_attributes=None, cluster_resource_attributes=None, execution_queue_attributes=None, execution_cluster_label=None, quality_of_service=None): # noqa: E501 """AdminMatchingAttributes - a model defined in Swagger""" # noqa: E501 self._task_resource_attributes = None self._cluster_resource_attributes = None self._execution_queue_attributes = None self._execution_cluster_label = None + self._quality_of_service = None self.discriminator = None if task_resource_attributes is not None: @@ -66,6 +70,8 @@ def __init__(self, task_resource_attributes=None, cluster_resource_attributes=No self.execution_queue_attributes = execution_queue_attributes if execution_cluster_label is not None: self.execution_cluster_label = execution_cluster_label + if quality_of_service is not None: + self.quality_of_service = quality_of_service @property def task_resource_attributes(self): @@ -151,6 +157,27 @@ def execution_cluster_label(self, execution_cluster_label): self._execution_cluster_label = execution_cluster_label + @property + def quality_of_service(self): + """Gets the quality_of_service of this AdminMatchingAttributes. # noqa: E501 + + + :return: The quality_of_service of this AdminMatchingAttributes. # noqa: E501 + :rtype: CoreQualityOfService + """ + return self._quality_of_service + + @quality_of_service.setter + def quality_of_service(self, quality_of_service): + """Sets the quality_of_service of this AdminMatchingAttributes. + + + :param quality_of_service: The quality_of_service of this AdminMatchingAttributes. # noqa: E501 + :type: CoreQualityOfService + """ + + self._quality_of_service = quality_of_service + def to_dict(self): """Returns the model properties as a dict""" result = {} diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_quality_of_service.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_quality_of_service.py new file mode 100644 index 00000000000..b9bb2aadb98 --- /dev/null +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_quality_of_service.py @@ -0,0 +1,144 @@ +# 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 + +from flyteadmin.models.core_quality_of_service_spec import CoreQualityOfServiceSpec # noqa: F401,E501 +from flyteadmin.models.quality_of_service_tier import QualityOfServiceTier # noqa: F401,E501 + + +class CoreQualityOfService(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 = { + 'tier': 'QualityOfServiceTier', + 'spec': 'CoreQualityOfServiceSpec' + } + + attribute_map = { + 'tier': 'tier', + 'spec': 'spec' + } + + def __init__(self, tier=None, spec=None): # noqa: E501 + """CoreQualityOfService - a model defined in Swagger""" # noqa: E501 + + self._tier = None + self._spec = None + self.discriminator = None + + if tier is not None: + self.tier = tier + if spec is not None: + self.spec = spec + + @property + def tier(self): + """Gets the tier of this CoreQualityOfService. # noqa: E501 + + + :return: The tier of this CoreQualityOfService. # noqa: E501 + :rtype: QualityOfServiceTier + """ + return self._tier + + @tier.setter + def tier(self, tier): + """Sets the tier of this CoreQualityOfService. + + + :param tier: The tier of this CoreQualityOfService. # noqa: E501 + :type: QualityOfServiceTier + """ + + self._tier = tier + + @property + def spec(self): + """Gets the spec of this CoreQualityOfService. # noqa: E501 + + + :return: The spec of this CoreQualityOfService. # noqa: E501 + :rtype: CoreQualityOfServiceSpec + """ + return self._spec + + @spec.setter + def spec(self, spec): + """Sets the spec of this CoreQualityOfService. + + + :param spec: The spec of this CoreQualityOfService. # noqa: E501 + :type: CoreQualityOfServiceSpec + """ + + self._spec = spec + + 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(CoreQualityOfService, 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, CoreQualityOfService): + 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/flyteadmin/models/core_quality_of_service_spec.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_quality_of_service_spec.py new file mode 100644 index 00000000000..070989b1679 --- /dev/null +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_quality_of_service_spec.py @@ -0,0 +1,117 @@ +# 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 CoreQualityOfServiceSpec(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 = { + 'queueing_budget': 'str' + } + + attribute_map = { + 'queueing_budget': 'queueing_budget' + } + + def __init__(self, queueing_budget=None): # noqa: E501 + """CoreQualityOfServiceSpec - a model defined in Swagger""" # noqa: E501 + + self._queueing_budget = None + self.discriminator = None + + if queueing_budget is not None: + self.queueing_budget = queueing_budget + + @property + def queueing_budget(self): + """Gets the queueing_budget of this CoreQualityOfServiceSpec. # noqa: E501 + + Indicates how much queueing delay an execution can tolerate. # noqa: E501 + + :return: The queueing_budget of this CoreQualityOfServiceSpec. # noqa: E501 + :rtype: str + """ + return self._queueing_budget + + @queueing_budget.setter + def queueing_budget(self, queueing_budget): + """Sets the queueing_budget of this CoreQualityOfServiceSpec. + + Indicates how much queueing delay an execution can tolerate. # noqa: E501 + + :param queueing_budget: The queueing_budget of this CoreQualityOfServiceSpec. # noqa: E501 + :type: str + """ + + self._queueing_budget = queueing_budget + + 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(CoreQualityOfServiceSpec, 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, CoreQualityOfServiceSpec): + 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/flyteadmin/models/core_workflow_metadata.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_workflow_metadata.py index 885b546a372..2640cc425d3 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_workflow_metadata.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_workflow_metadata.py @@ -16,6 +16,7 @@ import six +from flyteadmin.models.core_quality_of_service import CoreQualityOfService # noqa: F401,E501 from flyteadmin.models.workflow_metadata_on_failure_policy import WorkflowMetadataOnFailurePolicy # noqa: F401,E501 @@ -33,49 +34,49 @@ class CoreWorkflowMetadata(object): and the value is json key in definition. """ swagger_types = { - 'queuing_budget': 'str', + 'quality_of_service': 'CoreQualityOfService', 'on_failure': 'WorkflowMetadataOnFailurePolicy' } attribute_map = { - 'queuing_budget': 'queuing_budget', + 'quality_of_service': 'quality_of_service', 'on_failure': 'on_failure' } - def __init__(self, queuing_budget=None, on_failure=None): # noqa: E501 + def __init__(self, quality_of_service=None, on_failure=None): # noqa: E501 """CoreWorkflowMetadata - a model defined in Swagger""" # noqa: E501 - self._queuing_budget = None + self._quality_of_service = None self._on_failure = None self.discriminator = None - if queuing_budget is not None: - self.queuing_budget = queuing_budget + if quality_of_service is not None: + self.quality_of_service = quality_of_service if on_failure is not None: self.on_failure = on_failure @property - def queuing_budget(self): - """Gets the queuing_budget of this CoreWorkflowMetadata. # noqa: E501 + def quality_of_service(self): + """Gets the quality_of_service of this CoreWorkflowMetadata. # noqa: E501 - Total wait time a workflow can be delayed by queueing. # noqa: E501 + Indicates the runtime priority of workflow executions. # noqa: E501 - :return: The queuing_budget of this CoreWorkflowMetadata. # noqa: E501 - :rtype: str + :return: The quality_of_service of this CoreWorkflowMetadata. # noqa: E501 + :rtype: CoreQualityOfService """ - return self._queuing_budget + return self._quality_of_service - @queuing_budget.setter - def queuing_budget(self, queuing_budget): - """Sets the queuing_budget of this CoreWorkflowMetadata. + @quality_of_service.setter + def quality_of_service(self, quality_of_service): + """Sets the quality_of_service of this CoreWorkflowMetadata. - Total wait time a workflow can be delayed by queueing. # noqa: E501 + Indicates the runtime priority of workflow executions. # noqa: E501 - :param queuing_budget: The queuing_budget of this CoreWorkflowMetadata. # noqa: E501 - :type: str + :param quality_of_service: The quality_of_service of this CoreWorkflowMetadata. # noqa: E501 + :type: CoreQualityOfService """ - self._queuing_budget = queuing_budget + self._quality_of_service = quality_of_service @property def on_failure(self): diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/quality_of_service_tier.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/quality_of_service_tier.py new file mode 100644 index 00000000000..9b8a45f842e --- /dev/null +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/quality_of_service_tier.py @@ -0,0 +1,95 @@ +# 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 QualityOfServiceTier(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + + """ + allowed enum values + """ + UNDEFINED = "UNDEFINED" + HIGH = "HIGH" + MEDIUM = "MEDIUM" + LOW = "LOW" + + """ + 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 = { + } + + attribute_map = { + } + + def __init__(self): # noqa: E501 + """QualityOfServiceTier - a model defined in Swagger""" # noqa: E501 + self.discriminator = None + + 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(QualityOfServiceTier, 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, QualityOfServiceTier): + 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_core_quality_of_service.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_core_quality_of_service.py new file mode 100644 index 00000000000..127aa3f11d4 --- /dev/null +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_core_quality_of_service.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.core_quality_of_service import CoreQualityOfService # noqa: E501 +from flyteadmin.rest import ApiException + + +class TestCoreQualityOfService(unittest.TestCase): + """CoreQualityOfService unit test stubs""" + + def setUp(self): + pass + + def tearDown(self): + pass + + def testCoreQualityOfService(self): + """Test CoreQualityOfService""" + # FIXME: construct object with mandatory attributes with example values + # model = flyteadmin.models.core_quality_of_service.CoreQualityOfService() # noqa: E501 + pass + + +if __name__ == '__main__': + unittest.main() diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_core_quality_of_service_spec.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_core_quality_of_service_spec.py new file mode 100644 index 00000000000..0a4234ebd6a --- /dev/null +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_core_quality_of_service_spec.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.core_quality_of_service_spec import CoreQualityOfServiceSpec # noqa: E501 +from flyteadmin.rest import ApiException + + +class TestCoreQualityOfServiceSpec(unittest.TestCase): + """CoreQualityOfServiceSpec unit test stubs""" + + def setUp(self): + pass + + def tearDown(self): + pass + + def testCoreQualityOfServiceSpec(self): + """Test CoreQualityOfServiceSpec""" + # FIXME: construct object with mandatory attributes with example values + # model = flyteadmin.models.core_quality_of_service_spec.CoreQualityOfServiceSpec() # noqa: E501 + pass + + +if __name__ == '__main__': + unittest.main() diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_quality_of_service_tier.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_quality_of_service_tier.py new file mode 100644 index 00000000000..d655c725ab7 --- /dev/null +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/test/test_quality_of_service_tier.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.quality_of_service_tier import QualityOfServiceTier # noqa: E501 +from flyteadmin.rest import ApiException + + +class TestQualityOfServiceTier(unittest.TestCase): + """QualityOfServiceTier unit test stubs""" + + def setUp(self): + pass + + def tearDown(self): + pass + + def testQualityOfServiceTier(self): + """Test QualityOfServiceTier""" + # FIXME: construct object with mandatory attributes with example values + # model = flyteadmin.models.quality_of_service_tier.QualityOfServiceTier() # noqa: E501 + pass + + +if __name__ == '__main__': + unittest.main() diff --git a/flyteidl/package.json b/flyteidl/package.json index 708e2573784..ae86fd8314e 100644 --- a/flyteidl/package.json +++ b/flyteidl/package.json @@ -1,6 +1,6 @@ { "name": "@lyft/flyteidl", - "version": "0.17.35", + "version": "0.17.36", "description": "Compiled protocol buffers and gRPC service clients/servers for Flyte IDLs", "repository": { "type": "git", diff --git a/flyteidl/protos/flyteidl/admin/execution.proto b/flyteidl/protos/flyteidl/admin/execution.proto index fd5031986fb..59e454dc766 100644 --- a/flyteidl/protos/flyteidl/admin/execution.proto +++ b/flyteidl/protos/flyteidl/admin/execution.proto @@ -237,6 +237,8 @@ message ExecutionSpec { // Optional: auth override to apply this execution. AuthRole auth_role = 16; + // Indicates the runtime priority of the execution. + core.QualityOfService quality_of_service = 17; } // Request to terminate an in-progress execution. This action is irreversible. diff --git a/flyteidl/protos/flyteidl/admin/launch_plan.proto b/flyteidl/protos/flyteidl/admin/launch_plan.proto index 4d62d590342..fc178757b94 100644 --- a/flyteidl/protos/flyteidl/admin/launch_plan.proto +++ b/flyteidl/protos/flyteidl/admin/launch_plan.proto @@ -3,6 +3,7 @@ syntax = "proto3"; package flyteidl.admin; option go_package = "github.com/lyft/flyteidl/gen/pb-go/flyteidl/admin"; +import "flyteidl/core/execution.proto"; import "flyteidl/core/literals.proto"; import "flyteidl/core/identifier.proto"; import "flyteidl/core/interface.proto"; @@ -91,6 +92,9 @@ message LaunchPlanSpec { Auth auth = 8 [deprecated=true]; AuthRole auth_role = 9; + + // Indicates the runtime priority of the execution. + core.QualityOfService quality_of_service = 16; } // Values computed by the flyte platform after launch plan registration. diff --git a/flyteidl/protos/flyteidl/admin/matchable_resource.proto b/flyteidl/protos/flyteidl/admin/matchable_resource.proto index 25c1830e80f..df4c68974c9 100644 --- a/flyteidl/protos/flyteidl/admin/matchable_resource.proto +++ b/flyteidl/protos/flyteidl/admin/matchable_resource.proto @@ -3,6 +3,9 @@ syntax = "proto3"; package flyteidl.admin; option go_package = "github.com/lyft/flyteidl/gen/pb-go/flyteidl/admin"; +import "flyteidl/admin/common.proto"; +import "flyteidl/core/execution.proto"; + // Defines a resource that can be configured by customizable Project-, ProjectDomain- or WorkflowAttributes // based on matching tags. enum MatchableResource { @@ -17,6 +20,9 @@ enum MatchableResource { // Configures the K8s cluster label to be used for execution to be run EXECUTION_CLUSTER_LABEL = 3; + + // Configures default quality of service when undefined in an execution spec. + QUALITY_OF_SERVICE_SPECIFICATION = 4; } message TaskResourceSpec { @@ -62,6 +68,8 @@ message MatchingAttributes { ExecutionQueueAttributes execution_queue_attributes = 3; ExecutionClusterLabel execution_cluster_label = 4; + + core.QualityOfService quality_of_service = 5; } } diff --git a/flyteidl/protos/flyteidl/core/execution.proto b/flyteidl/protos/flyteidl/core/execution.proto index 7aaca230fc2..3e0f506db6d 100644 --- a/flyteidl/protos/flyteidl/core/execution.proto +++ b/flyteidl/protos/flyteidl/core/execution.proto @@ -87,3 +87,27 @@ message TaskLog { MessageFormat message_format = 3; google.protobuf.Duration ttl = 4; } + +// Represents customized execution run-time attributes. +message QualityOfServiceSpec { + // Indicates how much queueing delay an execution can tolerate. + google.protobuf.Duration queueing_budget = 1; + + // Add future, user-configurable options here +} + +// Indicates the priority of an execution. +message QualityOfService { + enum Tier { + // Default: no quality of service specified. + UNDEFINED = 0; + HIGH = 1; + MEDIUM = 2; + LOW = 3; + } + + oneof designation { + Tier tier = 1; + QualityOfServiceSpec spec = 2; + } +} diff --git a/flyteidl/protos/flyteidl/core/workflow.proto b/flyteidl/protos/flyteidl/core/workflow.proto index 7d293c07d70..34f5a73c3f0 100644 --- a/flyteidl/protos/flyteidl/core/workflow.proto +++ b/flyteidl/protos/flyteidl/core/workflow.proto @@ -5,6 +5,7 @@ package flyteidl.core; option go_package = "github.com/lyft/flyteidl/gen/pb-go/flyteidl/core"; import "flyteidl/core/condition.proto"; +import "flyteidl/core/execution.proto"; import "flyteidl/core/identifier.proto"; import "flyteidl/core/interface.proto"; import "flyteidl/core/literals.proto"; @@ -128,8 +129,8 @@ message Node { // Metadata for the entire workflow. Defines execution behavior that does not change the final outputs of the workflow. message WorkflowMetadata { - // Total wait time a workflow can be delayed by queueing. - google.protobuf.Duration queuing_budget = 1; + // Indicates the runtime priority of workflow executions. + QualityOfService quality_of_service = 1; // Failure Handling Strategy enum OnFailurePolicy { diff --git a/flyteidl/setup.py b/flyteidl/setup.py index f021ceb148e..5f19a7f291a 100644 --- a/flyteidl/setup.py +++ b/flyteidl/setup.py @@ -1,6 +1,6 @@ from setuptools import setup, find_packages -__version__ = '0.17.35' +__version__ = '0.17.36' setup( name='flyteidl',