From b5625363035a4e12f8f498dbf49fd282449ce698 Mon Sep 17 00:00:00 2001 From: Dan Rammer Date: Tue, 19 Dec 2023 08:43:10 -0600 Subject: [PATCH 1/8] Ignore cache variables (#4618) * Provide a way to ignore portions of the signature for cache key calculation purposes Signed-off-by: troychiu * add stub Signed-off-by: troychiu * moved cache ignore input vars check to HashLiteralMap function Signed-off-by: Daniel Rammer * working with maptask Signed-off-by: Daniel Rammer --------- Signed-off-by: troychiu Signed-off-by: Daniel Rammer Co-authored-by: troychiu Co-authored-by: Kevin Su --- flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.cc | 214 ++++++---- flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.h | 92 +++++ flyteidl/gen/pb-go/flyteidl/core/tasks.pb.go | 239 +++++------ .../pb-go/flyteidl/service/admin.swagger.json | 7 + .../pb-go/flyteidl/service/agent.swagger.json | 7 + .../external_plugin_service.swagger.json | 7 + .../service/flyteadmin/api/swagger.yaml | 69 ++++ .../flyteadmin/model_core_task_metadata.go | 2 + .../gen/pb-go/flyteidl/service/openapi.go | 4 +- flyteidl/gen/pb-java/flyteidl/core/Tasks.java | 378 +++++++++++++++--- flyteidl/gen/pb-js/flyteidl.d.ts | 6 + flyteidl/gen/pb-js/flyteidl.js | 25 ++ .../gen/pb_python/flyteidl/core/tasks_pb2.py | 72 ++-- .../gen/pb_python/flyteidl/core/tasks_pb2.pyi | 6 +- .../flyteadmin/models/core_task_metadata.py | 34 +- flyteidl/gen/pb_rust/flyteidl.core.rs | 3 + flyteidl/protos/flyteidl/core/tasks.proto | 3 + .../catalog/async_client_impl.go | 2 +- .../tasks/pluginmachinery/catalog/client.go | 9 +- .../tasks/pluginmachinery/catalog/hashing.go | 8 +- .../pluginmachinery/catalog/hashing_test.go | 27 +- .../go/tasks/plugins/array/catalog.go | 13 +- .../nodes/catalog/datacatalog/datacatalog.go | 10 +- .../nodes/catalog/datacatalog/transformer.go | 6 +- .../catalog/datacatalog/transformer_test.go | 11 +- .../pkg/controller/nodes/task/cache.go | 9 +- 26 files changed, 943 insertions(+), 320 deletions(-) diff --git a/flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.cc index 7a06a09340..5646e9ab8c 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.cc @@ -484,6 +484,7 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fcore_2ftasks_2eproto::of PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskMetadata, generates_deck_), PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskMetadata, tags_), PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskMetadata, pod_template_name_), + PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskMetadata, cache_ignore_input_vars_), PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskMetadata, interruptible_value_), PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskTemplate_ConfigEntry_DoNotUse, _has_bits_), PROTOBUF_FIELD_OFFSET(::flyteidl::core::TaskTemplate_ConfigEntry_DoNotUse, _internal_metadata_), @@ -598,17 +599,17 @@ static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SE { 29, -1, sizeof(::flyteidl::core::RuntimeMetadata)}, { 37, 44, sizeof(::flyteidl::core::TaskMetadata_TagsEntry_DoNotUse)}, { 46, -1, sizeof(::flyteidl::core::TaskMetadata)}, - { 63, 70, sizeof(::flyteidl::core::TaskTemplate_ConfigEntry_DoNotUse)}, - { 72, -1, sizeof(::flyteidl::core::TaskTemplate)}, - { 90, -1, sizeof(::flyteidl::core::ContainerPort)}, - { 96, -1, sizeof(::flyteidl::core::Container)}, - { 110, -1, sizeof(::flyteidl::core::IOStrategy)}, - { 117, -1, sizeof(::flyteidl::core::DataLoadingConfig)}, - { 127, -1, sizeof(::flyteidl::core::K8sPod)}, - { 135, 142, sizeof(::flyteidl::core::K8sObjectMetadata_LabelsEntry_DoNotUse)}, - { 144, 151, sizeof(::flyteidl::core::K8sObjectMetadata_AnnotationsEntry_DoNotUse)}, - { 153, -1, sizeof(::flyteidl::core::K8sObjectMetadata)}, - { 160, -1, sizeof(::flyteidl::core::Sql)}, + { 64, 71, sizeof(::flyteidl::core::TaskTemplate_ConfigEntry_DoNotUse)}, + { 73, -1, sizeof(::flyteidl::core::TaskTemplate)}, + { 91, -1, sizeof(::flyteidl::core::ContainerPort)}, + { 97, -1, sizeof(::flyteidl::core::Container)}, + { 111, -1, sizeof(::flyteidl::core::IOStrategy)}, + { 118, -1, sizeof(::flyteidl::core::DataLoadingConfig)}, + { 128, -1, sizeof(::flyteidl::core::K8sPod)}, + { 136, 143, sizeof(::flyteidl::core::K8sObjectMetadata_LabelsEntry_DoNotUse)}, + { 145, 152, sizeof(::flyteidl::core::K8sObjectMetadata_AnnotationsEntry_DoNotUse)}, + { 154, -1, sizeof(::flyteidl::core::K8sObjectMetadata)}, + { 161, -1, sizeof(::flyteidl::core::Sql)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -660,7 +661,7 @@ const char descriptor_table_protodef_flyteidl_2fcore_2ftasks_2eproto[] = "r\"\225\001\n\017RuntimeMetadata\0228\n\004type\030\001 \001(\0162*.fl" "yteidl.core.RuntimeMetadata.RuntimeType\022" "\017\n\007version\030\002 \001(\t\022\016\n\006flavor\030\003 \001(\t\"\'\n\013Runt" - "imeType\022\t\n\005OTHER\020\000\022\r\n\tFLYTE_SDK\020\001\"\316\003\n\014Ta" + "imeType\022\t\n\005OTHER\020\000\022\r\n\tFLYTE_SDK\020\001\"\357\003\n\014Ta" "skMetadata\022\024\n\014discoverable\030\001 \001(\010\022/\n\007runt" "ime\030\002 \001(\0132\036.flyteidl.core.RuntimeMetadat" "a\022*\n\007timeout\030\004 \001(\0132\031.google.protobuf.Dur" @@ -670,69 +671,70 @@ const char descriptor_table_protodef_flyteidl_2fcore_2ftasks_2eproto[] = "erruptible\030\010 \001(\010H\000\022\032\n\022cache_serializable" "\030\t \001(\010\022\026\n\016generates_deck\030\n \001(\010\0223\n\004tags\030\013" " \003(\0132%.flyteidl.core.TaskMetadata.TagsEn" - "try\022\031\n\021pod_template_name\030\014 \001(\t\032+\n\tTagsEn" - "try\022\013\n\003key\030\001 \001(\t\022\r\n\005value\030\002 \001(\t:\0028\001B\025\n\023i" - "nterruptible_value\"\316\004\n\014TaskTemplate\022%\n\002i" - "d\030\001 \001(\0132\031.flyteidl.core.Identifier\022\014\n\004ty" - "pe\030\002 \001(\t\022-\n\010metadata\030\003 \001(\0132\033.flyteidl.co" - "re.TaskMetadata\0220\n\tinterface\030\004 \001(\0132\035.fly" - "teidl.core.TypedInterface\022\'\n\006custom\030\005 \001(" - "\0132\027.google.protobuf.Struct\022-\n\tcontainer\030" - "\006 \001(\0132\030.flyteidl.core.ContainerH\000\022(\n\007k8s" - "_pod\030\021 \001(\0132\025.flyteidl.core.K8sPodH\000\022!\n\003s" - "ql\030\022 \001(\0132\022.flyteidl.core.SqlH\000\022\031\n\021task_t" - "ype_version\030\007 \001(\005\0228\n\020security_context\030\010 " - "\001(\0132\036.flyteidl.core.SecurityContext\022<\n\022e" - "xtended_resources\030\t \001(\0132 .flyteidl.core." - "ExtendedResources\0227\n\006config\030\020 \003(\0132\'.flyt" - "eidl.core.TaskTemplate.ConfigEntry\032-\n\013Co" - "nfigEntry\022\013\n\003key\030\001 \001(\t\022\r\n\005value\030\002 \001(\t:\0028" - "\001B\010\n\006target\"\'\n\rContainerPort\022\026\n\016containe" - "r_port\030\001 \001(\r\"\255\003\n\tContainer\022\r\n\005image\030\001 \001(" - "\t\022\017\n\007command\030\002 \003(\t\022\014\n\004args\030\003 \003(\t\022+\n\treso" - "urces\030\004 \001(\0132\030.flyteidl.core.Resources\022(\n" - "\003env\030\005 \003(\0132\033.flyteidl.core.KeyValuePair\022" - "/\n\006config\030\006 \003(\0132\033.flyteidl.core.KeyValue" - "PairB\002\030\001\022+\n\005ports\030\007 \003(\0132\034.flyteidl.core." - "ContainerPort\0225\n\013data_config\030\t \001(\0132 .fly" - "teidl.core.DataLoadingConfig\022;\n\014architec" - "ture\030\n \001(\0162%.flyteidl.core.Container.Arc" - "hitecture\"I\n\014Architecture\022\013\n\007UNKNOWN\020\000\022\t" - "\n\005AMD64\020\001\022\t\n\005ARM64\020\002\022\n\n\006ARM_V6\020\003\022\n\n\006ARM_" - "V7\020\004\"\233\002\n\nIOStrategy\022=\n\rdownload_mode\030\001 \001" - "(\0162&.flyteidl.core.IOStrategy.DownloadMo" - "de\0229\n\013upload_mode\030\002 \001(\0162$.flyteidl.core." - "IOStrategy.UploadMode\"L\n\014DownloadMode\022\022\n" - "\016DOWNLOAD_EAGER\020\000\022\023\n\017DOWNLOAD_STREAM\020\001\022\023" - "\n\017DO_NOT_DOWNLOAD\020\002\"E\n\nUploadMode\022\022\n\016UPL" - "OAD_ON_EXIT\020\000\022\020\n\014UPLOAD_EAGER\020\001\022\021\n\rDO_NO" - "T_UPLOAD\020\002\"\363\001\n\021DataLoadingConfig\022\017\n\007enab" - "led\030\001 \001(\010\022\022\n\ninput_path\030\002 \001(\t\022\023\n\013output_" - "path\030\003 \001(\t\022A\n\006format\030\004 \001(\01621.flyteidl.co" - "re.DataLoadingConfig.LiteralMapFormat\022.\n" - "\013io_strategy\030\005 \001(\0132\031.flyteidl.core.IOStr" - "ategy\"1\n\020LiteralMapFormat\022\010\n\004JSON\020\000\022\010\n\004Y" - "AML\020\001\022\t\n\005PROTO\020\002\"\236\001\n\006K8sPod\0222\n\010metadata\030" - "\001 \001(\0132 .flyteidl.core.K8sObjectMetadata\022" - ")\n\010pod_spec\030\002 \001(\0132\027.google.protobuf.Stru" - "ct\0225\n\013data_config\030\003 \001(\0132 .flyteidl.core." - "DataLoadingConfig\"\374\001\n\021K8sObjectMetadata\022" - "<\n\006labels\030\001 \003(\0132,.flyteidl.core.K8sObjec" - "tMetadata.LabelsEntry\022F\n\013annotations\030\002 \003" - "(\01321.flyteidl.core.K8sObjectMetadata.Ann" - "otationsEntry\032-\n\013LabelsEntry\022\013\n\003key\030\001 \001(" - "\t\022\r\n\005value\030\002 \001(\t:\0028\001\0322\n\020AnnotationsEntry" - "\022\013\n\003key\030\001 \001(\t\022\r\n\005value\030\002 \001(\t:\0028\001\"~\n\003Sql\022" - "\021\n\tstatement\030\001 \001(\t\022+\n\007dialect\030\002 \001(\0162\032.fl" - "yteidl.core.Sql.Dialect\"7\n\007Dialect\022\r\n\tUN" - "DEFINED\020\000\022\010\n\004ANSI\020\001\022\010\n\004HIVE\020\002\022\t\n\005OTHER\020\003" - "B= 1900 TaskMetadata::TaskMetadata() @@ -2873,7 +2876,8 @@ TaskMetadata::TaskMetadata() } TaskMetadata::TaskMetadata(const TaskMetadata& from) : ::google::protobuf::Message(), - _internal_metadata_(nullptr) { + _internal_metadata_(nullptr), + cache_ignore_input_vars_(from.cache_ignore_input_vars_) { _internal_metadata_.MergeFrom(from._internal_metadata_); tags_.MergeFrom(from.tags_); discovery_version_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); @@ -2979,6 +2983,7 @@ void TaskMetadata::Clear() { (void) cached_has_bits; tags_.Clear(); + cache_ignore_input_vars_.Clear(); discovery_version_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); deprecated_error_message_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); pod_template_name_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); @@ -3148,6 +3153,25 @@ const char* TaskMetadata::_InternalParse(const char* begin, const char* end, voi ptr += size; break; } + // repeated string cache_ignore_input_vars = 13; + case 13: { + if (static_cast<::google::protobuf::uint8>(tag) != 106) goto handle_unusual; + do { + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.core.TaskMetadata.cache_ignore_input_vars"); + object = msg->add_cache_ignore_input_vars(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + if (ptr >= end) break; + } while ((::google::protobuf::io::UnalignedLoad<::google::protobuf::uint64>(ptr) & 255) == 106 && (ptr += 1)); + break; + } default: { handle_unusual: if ((tag & 7) == 4 || tag == 0) { @@ -3339,6 +3363,22 @@ bool TaskMetadata::MergePartialFromCodedStream( break; } + // repeated string cache_ignore_input_vars = 13; + case 13: { + if (static_cast< ::google::protobuf::uint8>(tag) == (106 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->add_cache_ignore_input_vars())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->cache_ignore_input_vars(this->cache_ignore_input_vars_size() - 1).data(), + static_cast(this->cache_ignore_input_vars(this->cache_ignore_input_vars_size() - 1).length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.core.TaskMetadata.cache_ignore_input_vars")); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -3483,6 +3523,16 @@ void TaskMetadata::SerializeWithCachedSizes( 12, this->pod_template_name(), output); } + // repeated string cache_ignore_input_vars = 13; + for (int i = 0, n = this->cache_ignore_input_vars_size(); i < n; i++) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->cache_ignore_input_vars(i).data(), static_cast(this->cache_ignore_input_vars(i).length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.core.TaskMetadata.cache_ignore_input_vars"); + ::google::protobuf::internal::WireFormatLite::WriteString( + 13, this->cache_ignore_input_vars(i), output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -3619,6 +3669,16 @@ ::google::protobuf::uint8* TaskMetadata::InternalSerializeWithCachedSizesToArray 12, this->pod_template_name(), target); } + // repeated string cache_ignore_input_vars = 13; + for (int i = 0, n = this->cache_ignore_input_vars_size(); i < n; i++) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->cache_ignore_input_vars(i).data(), static_cast(this->cache_ignore_input_vars(i).length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.core.TaskMetadata.cache_ignore_input_vars"); + target = ::google::protobuf::internal::WireFormatLite:: + WriteStringToArray(13, this->cache_ignore_input_vars(i), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -3654,6 +3714,14 @@ size_t TaskMetadata::ByteSizeLong() const { } } + // repeated string cache_ignore_input_vars = 13; + total_size += 1 * + ::google::protobuf::internal::FromIntSize(this->cache_ignore_input_vars_size()); + for (int i = 0, n = this->cache_ignore_input_vars_size(); i < n; i++) { + total_size += ::google::protobuf::internal::WireFormatLite::StringSize( + this->cache_ignore_input_vars(i)); + } + // string discovery_version = 6; if (this->discovery_version().size() > 0) { total_size += 1 + @@ -3749,6 +3817,7 @@ void TaskMetadata::MergeFrom(const TaskMetadata& from) { (void) cached_has_bits; tags_.MergeFrom(from.tags_); + cache_ignore_input_vars_.MergeFrom(from.cache_ignore_input_vars_); if (from.discovery_version().size() > 0) { discovery_version_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.discovery_version_); @@ -3816,6 +3885,7 @@ void TaskMetadata::InternalSwap(TaskMetadata* other) { using std::swap; _internal_metadata_.Swap(&other->_internal_metadata_); tags_.Swap(&other->tags_); + cache_ignore_input_vars_.InternalSwap(CastToBase(&other->cache_ignore_input_vars_)); discovery_version_.Swap(&other->discovery_version_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), GetArenaNoVirtual()); deprecated_error_message_.Swap(&other->deprecated_error_message_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), diff --git a/flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.h b/flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.h index 37446ea345..3bd1db9d2e 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/core/tasks.pb.h @@ -1179,6 +1179,28 @@ class TaskMetadata final : ::google::protobuf::Map< ::std::string, ::std::string >* mutable_tags(); + // repeated string cache_ignore_input_vars = 13; + int cache_ignore_input_vars_size() const; + void clear_cache_ignore_input_vars(); + static const int kCacheIgnoreInputVarsFieldNumber = 13; + const ::std::string& cache_ignore_input_vars(int index) const; + ::std::string* mutable_cache_ignore_input_vars(int index); + void set_cache_ignore_input_vars(int index, const ::std::string& value); + #if LANG_CXX11 + void set_cache_ignore_input_vars(int index, ::std::string&& value); + #endif + void set_cache_ignore_input_vars(int index, const char* value); + void set_cache_ignore_input_vars(int index, const char* value, size_t size); + ::std::string* add_cache_ignore_input_vars(); + void add_cache_ignore_input_vars(const ::std::string& value); + #if LANG_CXX11 + void add_cache_ignore_input_vars(::std::string&& value); + #endif + void add_cache_ignore_input_vars(const char* value); + void add_cache_ignore_input_vars(const char* value, size_t size); + const ::google::protobuf::RepeatedPtrField<::std::string>& cache_ignore_input_vars() const; + ::google::protobuf::RepeatedPtrField<::std::string>* mutable_cache_ignore_input_vars(); + // string discovery_version = 6; void clear_discovery_version(); static const int kDiscoveryVersionFieldNumber = 6; @@ -1292,6 +1314,7 @@ class TaskMetadata final : ::google::protobuf::internal::WireFormatLite::TYPE_STRING, ::google::protobuf::internal::WireFormatLite::TYPE_STRING, 0 > tags_; + ::google::protobuf::RepeatedPtrField<::std::string> cache_ignore_input_vars_; ::google::protobuf::internal::ArenaStringPtr discovery_version_; ::google::protobuf::internal::ArenaStringPtr deprecated_error_message_; ::google::protobuf::internal::ArenaStringPtr pod_template_name_; @@ -3705,6 +3728,75 @@ inline void TaskMetadata::set_allocated_pod_template_name(::std::string* pod_tem // @@protoc_insertion_point(field_set_allocated:flyteidl.core.TaskMetadata.pod_template_name) } +// repeated string cache_ignore_input_vars = 13; +inline int TaskMetadata::cache_ignore_input_vars_size() const { + return cache_ignore_input_vars_.size(); +} +inline void TaskMetadata::clear_cache_ignore_input_vars() { + cache_ignore_input_vars_.Clear(); +} +inline const ::std::string& TaskMetadata::cache_ignore_input_vars(int index) const { + // @@protoc_insertion_point(field_get:flyteidl.core.TaskMetadata.cache_ignore_input_vars) + return cache_ignore_input_vars_.Get(index); +} +inline ::std::string* TaskMetadata::mutable_cache_ignore_input_vars(int index) { + // @@protoc_insertion_point(field_mutable:flyteidl.core.TaskMetadata.cache_ignore_input_vars) + return cache_ignore_input_vars_.Mutable(index); +} +inline void TaskMetadata::set_cache_ignore_input_vars(int index, const ::std::string& value) { + // @@protoc_insertion_point(field_set:flyteidl.core.TaskMetadata.cache_ignore_input_vars) + cache_ignore_input_vars_.Mutable(index)->assign(value); +} +#if LANG_CXX11 +inline void TaskMetadata::set_cache_ignore_input_vars(int index, ::std::string&& value) { + // @@protoc_insertion_point(field_set:flyteidl.core.TaskMetadata.cache_ignore_input_vars) + cache_ignore_input_vars_.Mutable(index)->assign(std::move(value)); +} +#endif +inline void TaskMetadata::set_cache_ignore_input_vars(int index, const char* value) { + GOOGLE_DCHECK(value != nullptr); + cache_ignore_input_vars_.Mutable(index)->assign(value); + // @@protoc_insertion_point(field_set_char:flyteidl.core.TaskMetadata.cache_ignore_input_vars) +} +inline void TaskMetadata::set_cache_ignore_input_vars(int index, const char* value, size_t size) { + cache_ignore_input_vars_.Mutable(index)->assign( + reinterpret_cast(value), size); + // @@protoc_insertion_point(field_set_pointer:flyteidl.core.TaskMetadata.cache_ignore_input_vars) +} +inline ::std::string* TaskMetadata::add_cache_ignore_input_vars() { + // @@protoc_insertion_point(field_add_mutable:flyteidl.core.TaskMetadata.cache_ignore_input_vars) + return cache_ignore_input_vars_.Add(); +} +inline void TaskMetadata::add_cache_ignore_input_vars(const ::std::string& value) { + cache_ignore_input_vars_.Add()->assign(value); + // @@protoc_insertion_point(field_add:flyteidl.core.TaskMetadata.cache_ignore_input_vars) +} +#if LANG_CXX11 +inline void TaskMetadata::add_cache_ignore_input_vars(::std::string&& value) { + cache_ignore_input_vars_.Add(std::move(value)); + // @@protoc_insertion_point(field_add:flyteidl.core.TaskMetadata.cache_ignore_input_vars) +} +#endif +inline void TaskMetadata::add_cache_ignore_input_vars(const char* value) { + GOOGLE_DCHECK(value != nullptr); + cache_ignore_input_vars_.Add()->assign(value); + // @@protoc_insertion_point(field_add_char:flyteidl.core.TaskMetadata.cache_ignore_input_vars) +} +inline void TaskMetadata::add_cache_ignore_input_vars(const char* value, size_t size) { + cache_ignore_input_vars_.Add()->assign(reinterpret_cast(value), size); + // @@protoc_insertion_point(field_add_pointer:flyteidl.core.TaskMetadata.cache_ignore_input_vars) +} +inline const ::google::protobuf::RepeatedPtrField<::std::string>& +TaskMetadata::cache_ignore_input_vars() const { + // @@protoc_insertion_point(field_list:flyteidl.core.TaskMetadata.cache_ignore_input_vars) + return cache_ignore_input_vars_; +} +inline ::google::protobuf::RepeatedPtrField<::std::string>* +TaskMetadata::mutable_cache_ignore_input_vars() { + // @@protoc_insertion_point(field_mutable_list:flyteidl.core.TaskMetadata.cache_ignore_input_vars) + return &cache_ignore_input_vars_; +} + inline bool TaskMetadata::has_interruptible_value() const { return interruptible_value_case() != INTERRUPTIBLE_VALUE_NOT_SET; } diff --git a/flyteidl/gen/pb-go/flyteidl/core/tasks.pb.go b/flyteidl/gen/pb-go/flyteidl/core/tasks.pb.go index d7310cce31..1073668fea 100644 --- a/flyteidl/gen/pb-go/flyteidl/core/tasks.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/core/tasks.pb.go @@ -582,7 +582,9 @@ type TaskMetadata struct { // pod_template_name is the unique name of a PodTemplate k8s resource to be used as the base configuration if this // task creates a k8s Pod. If this value is set, the specified PodTemplate will be used instead of, but applied // identically as, the default PodTemplate configured in FlytePropeller. - PodTemplateName string `protobuf:"bytes,12,opt,name=pod_template_name,json=podTemplateName,proto3" json:"pod_template_name,omitempty"` + PodTemplateName string `protobuf:"bytes,12,opt,name=pod_template_name,json=podTemplateName,proto3" json:"pod_template_name,omitempty"` + // cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache. + CacheIgnoreInputVars []string `protobuf:"bytes,13,rep,name=cache_ignore_input_vars,json=cacheIgnoreInputVars,proto3" json:"cache_ignore_input_vars,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` @@ -707,6 +709,13 @@ func (m *TaskMetadata) GetPodTemplateName() string { return "" } +func (m *TaskMetadata) GetCacheIgnoreInputVars() []string { + if m != nil { + return m.CacheIgnoreInputVars + } + return nil +} + // XXX_OneofWrappers is for the internal use of the proto package. func (*TaskMetadata) XXX_OneofWrappers() []interface{} { return []interface{}{ @@ -1409,117 +1418,119 @@ func init() { func init() { proto.RegisterFile("flyteidl/core/tasks.proto", fileDescriptor_bd8423ba58d6ed80) } var fileDescriptor_bd8423ba58d6ed80 = []byte{ - // 1787 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x94, 0x57, 0xdd, 0x72, 0xdb, 0xb8, - 0x15, 0xb6, 0x24, 0x5b, 0xb2, 0x8e, 0x2c, 0x9b, 0xc2, 0x6e, 0x52, 0xc6, 0x4d, 0xd2, 0x0c, 0xa7, - 0x9b, 0xa4, 0xdb, 0x46, 0x6e, 0xb4, 0x19, 0xdb, 0x9b, 0xee, 0xa4, 0x23, 0x47, 0x4c, 0xac, 0xda, - 0xfa, 0x19, 0x48, 0xce, 0x36, 0xed, 0x74, 0x58, 0x98, 0x84, 0x69, 0xd6, 0x14, 0xc1, 0x80, 0xa0, - 0xbb, 0xca, 0x5b, 0xb4, 0x2f, 0xd1, 0xe9, 0x4c, 0x6f, 0x7b, 0xd9, 0x77, 0xe8, 0x55, 0xdf, 0xa4, - 0x77, 0xbd, 0xe8, 0x00, 0xfc, 0xd1, 0x8f, 0x9d, 0x78, 0x7c, 0x45, 0x9c, 0x73, 0xbe, 0x73, 0x00, - 0x1c, 0x9c, 0x3f, 0xc2, 0xbd, 0x33, 0x7f, 0x2a, 0xa8, 0xe7, 0xf8, 0x3b, 0x36, 0xe3, 0x74, 0x47, - 0x90, 0xe8, 0x22, 0x6a, 0x86, 0x9c, 0x09, 0x86, 0xea, 0x99, 0xa8, 0x29, 0x45, 0xdb, 0x0f, 0x17, - 0x91, 0x9e, 0x43, 0x03, 0xe1, 0x9d, 0x79, 0x94, 0x27, 0xf0, 0xed, 0x07, 0x4b, 0xf2, 0x40, 0x50, - 0x7e, 0x46, 0x6c, 0x9a, 0x8a, 0xef, 0x2f, 0x8a, 0x7d, 0x4f, 0x50, 0x4e, 0xfc, 0xe8, 0x7a, 0x69, - 0x44, 0xed, 0x98, 0x7b, 0x62, 0x9a, 0x4a, 0x1f, 0xba, 0x8c, 0xb9, 0x3e, 0xdd, 0x51, 0xd4, 0x69, - 0x7c, 0xb6, 0xe3, 0xc4, 0x9c, 0x08, 0x8f, 0x05, 0x99, 0xf6, 0xb2, 0x3c, 0x12, 0x3c, 0xb6, 0x45, - 0x22, 0x35, 0xfe, 0x5d, 0x84, 0x2a, 0xa6, 0x11, 0x8b, 0xb9, 0x4d, 0x23, 0x74, 0x00, 0xeb, 0x9c, - 0x7e, 0x88, 0x69, 0x24, 0x22, 0xbd, 0xf0, 0xa8, 0xf4, 0xb4, 0xd6, 0x7a, 0xdc, 0x5c, 0xb8, 0x68, - 0x33, 0xc7, 0xe6, 0x2b, 0x33, 0x10, 0x7c, 0x8a, 0x73, 0x3d, 0xf4, 0x0a, 0xca, 0xbe, 0x37, 0xf1, - 0x44, 0xa4, 0x17, 0x6f, 0x65, 0x21, 0xd5, 0xda, 0xfe, 0x23, 0xd4, 0x17, 0x04, 0xe8, 0x5b, 0x58, - 0x0d, 0xc8, 0x84, 0xea, 0x85, 0x47, 0x85, 0xa7, 0x9b, 0xad, 0xaf, 0x6e, 0x34, 0xd7, 0x27, 0x13, - 0x8a, 0x95, 0x0a, 0xfa, 0x12, 0xd6, 0x2e, 0x89, 0x1f, 0x53, 0xbd, 0xf8, 0xa8, 0xf0, 0xb4, 0x8a, - 0x13, 0xc2, 0xf8, 0x03, 0x6c, 0xcc, 0x63, 0x51, 0x0d, 0x2a, 0x27, 0xfd, 0xa3, 0xfe, 0xe0, 0xfb, - 0xbe, 0xb6, 0x82, 0x2a, 0x50, 0x7a, 0x3d, 0x3c, 0xd1, 0x0a, 0x72, 0xf1, 0x76, 0x78, 0xa2, 0x15, - 0x11, 0x40, 0xb9, 0x67, 0xf6, 0x06, 0xf8, 0xbd, 0x56, 0x92, 0xd0, 0xd1, 0x78, 0x80, 0xdb, 0x6f, - 0x4d, 0x6d, 0x15, 0xdd, 0x81, 0x86, 0x39, 0x3c, 0x34, 0x7b, 0x26, 0x6e, 0x1f, 0x5b, 0x19, 0x7b, - 0xcd, 0xf8, 0x4b, 0x01, 0x36, 0xdf, 0x0e, 0x4f, 0xda, 0xb6, 0x4d, 0x7d, 0xca, 0x89, 0x60, 0x1c, - 0xdd, 0x85, 0xb2, 0x43, 0x2f, 0x3d, 0x3b, 0xb9, 0x44, 0x15, 0xa7, 0x14, 0x7a, 0x0c, 0xf5, 0x38, - 0x08, 0x09, 0x17, 0x9e, 0x7c, 0x30, 0xea, 0xa8, 0x73, 0xae, 0x1f, 0xae, 0xe0, 0x45, 0x36, 0x7a, - 0x02, 0x9b, 0x39, 0x69, 0x45, 0xde, 0x47, 0xaa, 0x97, 0xa4, 0x1d, 0x09, 0xcc, 0xf9, 0x23, 0xef, - 0x23, 0x3d, 0xb8, 0x0b, 0x5f, 0x2e, 0x02, 0xad, 0xe4, 0xca, 0xbf, 0x87, 0x86, 0xf9, 0x83, 0xa0, - 0x81, 0x43, 0x9d, 0xd9, 0x6b, 0xbf, 0x81, 0x2d, 0x37, 0x8c, 0x2d, 0x32, 0x3b, 0xa8, 0x3a, 0x5e, - 0xad, 0xf5, 0x60, 0xc9, 0xc7, 0x8b, 0xb7, 0xc1, 0x9b, 0x6e, 0x18, 0xcf, 0xd1, 0xc6, 0x3f, 0x0a, - 0xb0, 0x85, 0xe3, 0x40, 0x78, 0x13, 0xda, 0xa3, 0x82, 0x38, 0x44, 0x10, 0xf4, 0x0a, 0x56, 0xc5, - 0x34, 0xcc, 0x1e, 0xed, 0xeb, 0xe5, 0x47, 0x5b, 0x44, 0x67, 0xf4, 0x78, 0x1a, 0x52, 0xac, 0xf4, - 0x90, 0x0e, 0x95, 0x4b, 0xca, 0x23, 0x8f, 0x05, 0xe9, 0xdb, 0x65, 0xa4, 0xf4, 0xe5, 0x99, 0x4f, - 0x2e, 0x19, 0x4f, 0x7c, 0x80, 0x53, 0xca, 0x78, 0x02, 0xb5, 0x39, 0x33, 0xa8, 0x0a, 0x6b, 0x83, - 0xf1, 0xa1, 0x89, 0xb5, 0x15, 0x54, 0x87, 0xea, 0x9b, 0xe3, 0xf7, 0x63, 0xd3, 0x1a, 0x75, 0x8e, - 0xb4, 0x82, 0xf1, 0xdf, 0x55, 0xd8, 0x18, 0x93, 0xe8, 0x22, 0x3f, 0xab, 0x01, 0x1b, 0x8e, 0x17, - 0xd9, 0xec, 0x92, 0x72, 0x72, 0xea, 0x27, 0x67, 0x5e, 0xc7, 0x0b, 0x3c, 0xb4, 0x0f, 0x15, 0x9e, - 0x58, 0x57, 0xe7, 0xa9, 0xb5, 0x1e, 0x7e, 0xfe, 0x4a, 0x38, 0x83, 0xa3, 0x6f, 0xa0, 0x22, 0xbf, - 0x2c, 0x16, 0xfa, 0xaa, 0xd2, 0xbc, 0xd7, 0x4c, 0x32, 0xb2, 0x99, 0x65, 0x64, 0xb3, 0x93, 0x66, - 0x2c, 0xce, 0x90, 0x68, 0x17, 0x2a, 0x9c, 0x0a, 0xee, 0xd1, 0x48, 0x5f, 0x53, 0x4a, 0xf7, 0xaf, - 0x84, 0xbd, 0xe0, 0xd3, 0x91, 0xe0, 0x44, 0x50, 0x77, 0x8a, 0x33, 0x30, 0xfa, 0x39, 0x34, 0xb2, - 0x63, 0x4f, 0xad, 0xcc, 0x81, 0x65, 0xe5, 0x27, 0x2d, 0x17, 0xbc, 0x4b, 0x3d, 0xb9, 0x0f, 0xba, - 0x43, 0x43, 0x4e, 0x6d, 0x22, 0xa8, 0x63, 0x51, 0xce, 0x19, 0xb7, 0x26, 0x34, 0x8a, 0x88, 0x4b, - 0xf5, 0x8a, 0xd2, 0xb9, 0x3b, 0x93, 0x9b, 0x52, 0xdc, 0x4b, 0xa4, 0x32, 0x6e, 0x55, 0x09, 0xe3, - 0x71, 0x28, 0x3c, 0xe9, 0xb2, 0xf5, 0x2c, 0x6e, 0x17, 0xd8, 0xe8, 0x19, 0x20, 0x9b, 0xd8, 0xe7, - 0xd4, 0x8a, 0x28, 0xf7, 0x88, 0xef, 0x7d, 0x54, 0xfe, 0xad, 0x2a, 0xff, 0x36, 0x94, 0x64, 0x34, - 0x27, 0x40, 0x5f, 0xc1, 0xa6, 0x4b, 0x03, 0x19, 0x55, 0x34, 0xb2, 0x1c, 0x6a, 0x5f, 0xe8, 0xa0, - 0xa0, 0xf5, 0x9c, 0xdb, 0xa1, 0xf6, 0x85, 0x2c, 0x08, 0x82, 0xb8, 0x91, 0x5e, 0x53, 0xf5, 0x65, - 0xb9, 0x20, 0xcc, 0x3f, 0x6d, 0x73, 0x4c, 0xdc, 0x28, 0x29, 0x2f, 0x4a, 0x05, 0x7d, 0x0d, 0x8d, - 0x90, 0x39, 0x96, 0xa0, 0x93, 0xd0, 0x27, 0x82, 0x5a, 0xaa, 0xb0, 0x6c, 0xa8, 0xbb, 0x6e, 0x85, - 0xcc, 0x19, 0xa7, 0x7c, 0x59, 0x16, 0xb6, 0xf7, 0xa0, 0x9a, 0xab, 0x23, 0x0d, 0x4a, 0x17, 0x74, - 0x9a, 0xa6, 0xaf, 0x5c, 0x5e, 0x5f, 0x5b, 0x5e, 0x16, 0xf7, 0x0b, 0x07, 0x77, 0xe0, 0x8b, 0x05, - 0x37, 0xa4, 0x39, 0xf8, 0x9f, 0xb5, 0x24, 0xee, 0xb2, 0x4d, 0xd0, 0xcf, 0xa0, 0xe8, 0x39, 0x69, - 0xca, 0xdd, 0x5b, 0xba, 0x45, 0x37, 0xef, 0x20, 0xb8, 0xe8, 0x39, 0x08, 0xa5, 0xe9, 0x94, 0xec, - 0x95, 0xa4, 0xc8, 0x1e, 0xac, 0x4f, 0xd2, 0x7b, 0xaa, 0x54, 0xa8, 0xb5, 0x7e, 0xfc, 0x19, 0x57, - 0xe0, 0x1c, 0x8c, 0x7e, 0x05, 0xd5, 0xbc, 0x01, 0xa5, 0x31, 0xb9, 0x9c, 0xf1, 0x32, 0x85, 0x9c, - 0x6e, 0x06, 0xc2, 0x33, 0x3c, 0xda, 0x81, 0xb2, 0x1d, 0x47, 0x82, 0x4d, 0xd2, 0xc0, 0xfc, 0xd1, - 0x95, 0x68, 0x1e, 0xa9, 0xfe, 0x82, 0x53, 0x18, 0xda, 0x87, 0xaa, 0xcd, 0x02, 0x41, 0xbc, 0x80, - 0x72, 0x15, 0x8a, 0xb5, 0x96, 0xbe, 0xb4, 0xdb, 0xeb, 0x4c, 0x7e, 0xb8, 0x82, 0x67, 0x60, 0xf4, - 0x4b, 0xa8, 0x5c, 0xec, 0x47, 0x56, 0xc8, 0x1c, 0xbd, 0xa1, 0xf4, 0xee, 0x2c, 0xe9, 0x1d, 0xed, - 0x47, 0x43, 0xe6, 0x1c, 0xae, 0xe0, 0xf2, 0x85, 0x5a, 0xa1, 0xc7, 0x50, 0x8a, 0x3e, 0xf8, 0x3a, - 0x52, 0x68, 0xb4, 0x84, 0x1e, 0x7d, 0xf0, 0x0f, 0x57, 0xb0, 0x04, 0xc8, 0x30, 0x90, 0xcd, 0xdc, - 0x92, 0x7e, 0xcc, 0xd3, 0x44, 0x86, 0xfc, 0x1a, 0xde, 0x92, 0x02, 0x79, 0xfd, 0x2c, 0x4b, 0xba, - 0xa0, 0x65, 0x1d, 0xd7, 0x92, 0x67, 0xa3, 0x3f, 0x08, 0x15, 0xee, 0x57, 0x4b, 0xc0, 0x28, 0x85, - 0xbd, 0x4e, 0x50, 0x78, 0x2b, 0x5a, 0x64, 0xa0, 0x01, 0x20, 0x9a, 0x56, 0x61, 0x8b, 0x67, 0x65, - 0x58, 0xa5, 0x43, 0xad, 0xf5, 0x68, 0xc9, 0xd8, 0x95, 0x72, 0x8d, 0x1b, 0xf4, 0x4a, 0x05, 0xff, - 0x35, 0x94, 0x6d, 0x16, 0x9c, 0x79, 0xae, 0xae, 0xa9, 0x5c, 0x78, 0x72, 0x4d, 0x00, 0x64, 0xe1, - 0x26, 0xbd, 0x7c, 0xe6, 0xb9, 0x69, 0xb3, 0x4d, 0xd4, 0xb6, 0xbf, 0x85, 0xda, 0x1c, 0xfb, 0x56, - 0x51, 0xbe, 0x0e, 0x65, 0x41, 0xb8, 0x4b, 0x85, 0xb1, 0x0b, 0xf5, 0xfc, 0x05, 0x87, 0x8c, 0x0b, - 0x99, 0xc7, 0xf9, 0x2b, 0x5a, 0x21, 0xe3, 0x42, 0x59, 0xac, 0xe3, 0xba, 0x3d, 0x0f, 0x33, 0xfe, - 0x57, 0x82, 0x6a, 0xae, 0x28, 0x77, 0xf2, 0x26, 0xb2, 0xf4, 0x24, 0xbb, 0x27, 0x84, 0xec, 0x03, - 0x36, 0x9b, 0x4c, 0x48, 0xe0, 0xa8, 0x71, 0xa2, 0x8a, 0x33, 0x52, 0xa6, 0x04, 0xe1, 0x6e, 0xa4, - 0x97, 0x14, 0x5b, 0xad, 0xd1, 0x2e, 0x54, 0x67, 0x7e, 0x5d, 0xbd, 0x36, 0xd6, 0x66, 0xfe, 0x9c, - 0x41, 0xd1, 0x33, 0x28, 0xd1, 0xe0, 0x52, 0x5f, 0x53, 0x4e, 0x5c, 0xce, 0xa2, 0x23, 0x3a, 0x7d, - 0x27, 0x6f, 0x3d, 0x24, 0x1e, 0xc7, 0x12, 0x87, 0xf6, 0x72, 0xb7, 0x97, 0x6f, 0xd4, 0x38, 0x28, - 0xea, 0x85, 0xcc, 0xdd, 0xa8, 0x05, 0x6b, 0xd2, 0x1d, 0x91, 0x5e, 0x51, 0x7a, 0xf7, 0x3f, 0x95, - 0x07, 0xd2, 0x3d, 0x38, 0x81, 0xa2, 0x36, 0xd4, 0x64, 0xd6, 0x5a, 0xe9, 0x8e, 0xd7, 0x47, 0x4b, - 0x87, 0x08, 0x72, 0xcc, 0x88, 0xe3, 0x05, 0x6e, 0xf2, 0x9e, 0x18, 0xa4, 0x52, 0xb2, 0x46, 0x5d, - 0xd8, 0x20, 0xdc, 0x3e, 0xf7, 0x04, 0xb5, 0x45, 0xcc, 0xa9, 0xaa, 0xaa, 0x57, 0x27, 0xa9, 0x7c, - 0xf7, 0x66, 0x7b, 0x0e, 0x8c, 0x17, 0x54, 0x8d, 0x2e, 0x6c, 0xcc, 0x4b, 0x17, 0x67, 0xa7, 0x2a, - 0xac, 0xb5, 0x7b, 0x9d, 0xdd, 0x17, 0x5a, 0x41, 0x2d, 0x71, 0x6f, 0xf7, 0x45, 0x32, 0x3f, 0xb5, - 0x71, 0xcf, 0x7a, 0xb7, 0xab, 0x95, 0xf2, 0xf5, 0x9e, 0xb6, 0x6a, 0xfc, 0xb3, 0x08, 0xd0, 0x1d, - 0x64, 0x3d, 0x0c, 0x1d, 0x41, 0xdd, 0x61, 0x7f, 0x0e, 0x7c, 0x46, 0x1c, 0x6b, 0xc2, 0x9c, 0x6c, - 0x74, 0x58, 0x1e, 0x1f, 0x67, 0x1a, 0xcd, 0x4e, 0x0a, 0xef, 0x31, 0x87, 0xe2, 0x0d, 0x67, 0x8e, - 0x42, 0x26, 0xd4, 0xe2, 0x70, 0x66, 0xaa, 0xa8, 0x4c, 0xfd, 0xf4, 0xd3, 0xa6, 0x4e, 0xc2, 0xdc, - 0x10, 0xc4, 0xf9, 0xda, 0x38, 0x86, 0x8d, 0xf9, 0x4d, 0x10, 0x82, 0xcd, 0xce, 0xe0, 0xfb, 0xfe, - 0xf1, 0xa0, 0xdd, 0xb1, 0xcc, 0xf6, 0x5b, 0x35, 0x5d, 0x7c, 0x01, 0x5b, 0x39, 0x6f, 0x34, 0xc6, - 0x66, 0xbb, 0xa7, 0x15, 0x12, 0xa6, 0xd5, 0x1f, 0x8c, 0xad, 0x4c, 0xa6, 0x15, 0x0d, 0x13, 0x60, - 0xb6, 0x8f, 0xb4, 0x75, 0x32, 0x54, 0x5a, 0x83, 0xbe, 0x65, 0xfe, 0xb6, 0x3b, 0xd6, 0x56, 0x90, - 0x06, 0x1b, 0x29, 0x2f, 0xb1, 0x5e, 0x40, 0x0d, 0xa8, 0xa7, 0x86, 0x12, 0x81, 0x56, 0x34, 0xfe, - 0x56, 0x84, 0xc6, 0x95, 0xf7, 0x96, 0x89, 0x42, 0x03, 0xd9, 0x45, 0x9d, 0x74, 0x7e, 0xc9, 0x48, - 0xf4, 0x00, 0xc0, 0x0b, 0xc2, 0x58, 0x58, 0x21, 0x11, 0xe7, 0x69, 0x1e, 0x57, 0x15, 0x67, 0x48, - 0xc4, 0x39, 0xfa, 0x09, 0xd4, 0x58, 0x2c, 0x72, 0x79, 0x32, 0x54, 0x41, 0xc2, 0x52, 0x80, 0x2e, - 0x94, 0xcf, 0x18, 0x9f, 0x90, 0x64, 0x7e, 0xd9, 0x6c, 0x3d, 0xbf, 0x29, 0xf6, 0x9a, 0xc7, 0xc9, - 0xff, 0x4b, 0x8f, 0x84, 0x6f, 0x94, 0x22, 0x4e, 0x0d, 0xa0, 0x97, 0x50, 0xf3, 0x98, 0x15, 0xa5, - 0x5e, 0x4f, 0x3b, 0xc8, 0xbd, 0x4f, 0x3e, 0x0b, 0x06, 0x8f, 0x65, 0x6b, 0xe3, 0x39, 0x68, 0xcb, - 0x76, 0xd1, 0x3a, 0xac, 0xfe, 0x66, 0x34, 0x90, 0xa1, 0xb7, 0x0e, 0xab, 0xef, 0xdb, 0xbd, 0xe3, - 0x24, 0xf2, 0x86, 0x78, 0x30, 0x1e, 0x68, 0x45, 0xe3, 0x5f, 0x05, 0x28, 0x27, 0x3d, 0x02, 0x7d, - 0x37, 0xd7, 0x2c, 0x0b, 0xd7, 0xa6, 0xd0, 0xd1, 0x7e, 0x34, 0x38, 0xfd, 0x13, 0xb5, 0xc5, 0x35, - 0x1d, 0xb3, 0x05, 0xeb, 0x72, 0x6c, 0x88, 0x42, 0x6a, 0xa7, 0xe3, 0xdf, 0x27, 0xdb, 0x5e, 0x25, - 0x64, 0xce, 0x28, 0xa4, 0xf6, 0x72, 0xde, 0x96, 0x6e, 0x9f, 0xb7, 0xc6, 0xdf, 0x8b, 0xd0, 0xb8, - 0x72, 0x2c, 0xd4, 0x81, 0xb2, 0x4f, 0x4e, 0xa9, 0x9f, 0xfd, 0xa2, 0xfd, 0xe2, 0xa6, 0x8b, 0x34, - 0x8f, 0x15, 0x3c, 0xfb, 0xcd, 0x52, 0x04, 0x1a, 0x41, 0x8d, 0x04, 0x01, 0x13, 0x6a, 0xf0, 0xcc, - 0xfe, 0xd5, 0x9e, 0xdf, 0x68, 0xaa, 0x3d, 0xd3, 0x49, 0xec, 0xcd, 0x5b, 0x91, 0xed, 0x64, 0x6e, - 0xaf, 0xdb, 0xb4, 0x93, 0xed, 0x57, 0xa0, 0x2d, 0xdb, 0xbe, 0x8d, 0xbe, 0xf1, 0xd7, 0x02, 0x94, - 0x46, 0x1f, 0x7c, 0x74, 0x1f, 0xaa, 0x91, 0x20, 0x82, 0x4e, 0x68, 0x20, 0x52, 0xcd, 0x19, 0x03, - 0xbd, 0x80, 0x8a, 0xe3, 0x11, 0x9f, 0xda, 0x22, 0xad, 0x09, 0xdb, 0x57, 0x87, 0x84, 0x66, 0x27, - 0x41, 0xe0, 0x0c, 0x6a, 0xec, 0x41, 0x25, 0xe5, 0xc9, 0x7f, 0x89, 0x93, 0x7e, 0xc7, 0x7c, 0xd3, - 0xed, 0x9b, 0x9d, 0x24, 0xec, 0xda, 0xfd, 0x51, 0x57, 0x2b, 0xc8, 0xd5, 0x61, 0xf7, 0x9d, 0xa9, - 0x15, 0x67, 0x7f, 0x1e, 0xa5, 0x83, 0xef, 0x7e, 0xf7, 0xd2, 0xf5, 0xc4, 0x79, 0x7c, 0xda, 0xb4, - 0xd9, 0x64, 0x47, 0xed, 0xc4, 0xb8, 0x9b, 0x2c, 0x76, 0xf2, 0xbf, 0x7a, 0x97, 0x06, 0x3b, 0xe1, - 0xe9, 0x33, 0x97, 0xed, 0x2c, 0xfc, 0xe8, 0x9f, 0x96, 0x55, 0x6c, 0x7d, 0xf3, 0xff, 0x00, 0x00, - 0x00, 0xff, 0xff, 0x61, 0xf6, 0x49, 0xdf, 0x87, 0x10, 0x00, 0x00, + // 1818 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x94, 0x58, 0xdd, 0x72, 0xdb, 0xb8, + 0x15, 0xb6, 0x24, 0x5b, 0xb2, 0x8e, 0x2c, 0x9b, 0xc2, 0x6e, 0xb2, 0x8c, 0x9b, 0xa4, 0x1e, 0x4e, + 0x37, 0x49, 0xb7, 0x8d, 0xdc, 0x68, 0x53, 0xdb, 0x9b, 0xee, 0xa4, 0x23, 0x47, 0x4a, 0xac, 0xda, + 0xfa, 0x19, 0x48, 0xf6, 0x36, 0xed, 0x74, 0x58, 0x98, 0x84, 0x69, 0xd6, 0x14, 0xc1, 0x80, 0xa0, + 0xbb, 0xca, 0x5b, 0xb4, 0x2f, 0xd1, 0xe9, 0xcc, 0xde, 0xf6, 0xb2, 0xef, 0xd0, 0xab, 0x3e, 0x4d, + 0x2f, 0x3a, 0x00, 0x7f, 0xf4, 0xe7, 0xac, 0xc7, 0x57, 0xc2, 0x39, 0xe7, 0x3b, 0x07, 0xc0, 0xc1, + 0xf9, 0xa3, 0xe0, 0xc1, 0x85, 0x37, 0x11, 0xd4, 0xb5, 0xbd, 0x5d, 0x8b, 0x71, 0xba, 0x2b, 0x48, + 0x78, 0x15, 0xd6, 0x03, 0xce, 0x04, 0x43, 0xd5, 0x54, 0x54, 0x97, 0xa2, 0xed, 0xc7, 0xf3, 0x48, + 0xd7, 0xa6, 0xbe, 0x70, 0x2f, 0x5c, 0xca, 0x63, 0xf8, 0xf6, 0xa3, 0x05, 0xb9, 0x2f, 0x28, 0xbf, + 0x20, 0x16, 0x4d, 0xc4, 0x0f, 0xe7, 0xc5, 0x9e, 0x2b, 0x28, 0x27, 0x5e, 0x78, 0xb3, 0x34, 0xa4, + 0x56, 0xc4, 0x5d, 0x31, 0x49, 0xa4, 0x8f, 0x1d, 0xc6, 0x1c, 0x8f, 0xee, 0x2a, 0xea, 0x3c, 0xba, + 0xd8, 0xb5, 0x23, 0x4e, 0x84, 0xcb, 0xfc, 0x54, 0x7b, 0x51, 0x1e, 0x0a, 0x1e, 0x59, 0x22, 0x96, + 0x1a, 0xff, 0xc9, 0x43, 0x19, 0xd3, 0x90, 0x45, 0xdc, 0xa2, 0x21, 0x3a, 0x84, 0x75, 0x4e, 0x3f, + 0x44, 0x34, 0x14, 0xa1, 0x9e, 0xdb, 0x29, 0x3c, 0xab, 0x34, 0x9e, 0xd4, 0xe7, 0x2e, 0x5a, 0xcf, + 0xb0, 0xd9, 0xaa, 0xed, 0x0b, 0x3e, 0xc1, 0x99, 0x1e, 0x7a, 0x0d, 0x45, 0xcf, 0x1d, 0xbb, 0x22, + 0xd4, 0xf3, 0x77, 0xb2, 0x90, 0x68, 0x6d, 0xff, 0x19, 0xaa, 0x73, 0x02, 0xf4, 0x0d, 0xac, 0xfa, + 0x64, 0x4c, 0xf5, 0xdc, 0x4e, 0xee, 0xd9, 0x66, 0xe3, 0xcb, 0x5b, 0xcd, 0xf5, 0xc8, 0x98, 0x62, + 0xa5, 0x82, 0x3e, 0x87, 0xb5, 0x6b, 0xe2, 0x45, 0x54, 0xcf, 0xef, 0xe4, 0x9e, 0x95, 0x71, 0x4c, + 0x18, 0x7f, 0x82, 0x8d, 0x59, 0x2c, 0xaa, 0x40, 0xe9, 0xb4, 0x77, 0xdc, 0xeb, 0x7f, 0xd7, 0xd3, + 0x56, 0x50, 0x09, 0x0a, 0x6f, 0x06, 0xa7, 0x5a, 0x4e, 0x2e, 0xde, 0x0d, 0x4e, 0xb5, 0x3c, 0x02, + 0x28, 0x76, 0xdb, 0xdd, 0x3e, 0x7e, 0xaf, 0x15, 0x24, 0x74, 0x38, 0xea, 0xe3, 0xe6, 0xbb, 0xb6, + 0xb6, 0x8a, 0xee, 0x41, 0xad, 0x3d, 0x38, 0x6a, 0x77, 0xdb, 0xb8, 0x79, 0x62, 0xa6, 0xec, 0x35, + 0xe3, 0x6f, 0x39, 0xd8, 0x7c, 0x37, 0x38, 0x6d, 0x5a, 0x16, 0xf5, 0x28, 0x27, 0x82, 0x71, 0x74, + 0x1f, 0x8a, 0x36, 0xbd, 0x76, 0xad, 0xf8, 0x12, 0x65, 0x9c, 0x50, 0xe8, 0x09, 0x54, 0x23, 0x3f, + 0x20, 0x5c, 0xb8, 0xf2, 0xc1, 0xa8, 0xad, 0xce, 0xb9, 0x7e, 0xb4, 0x82, 0xe7, 0xd9, 0xe8, 0x29, + 0x6c, 0x66, 0xa4, 0x19, 0xba, 0x1f, 0xa9, 0x5e, 0x90, 0x76, 0x24, 0x30, 0xe3, 0x0f, 0xdd, 0x8f, + 0xf4, 0xf0, 0x3e, 0x7c, 0x3e, 0x0f, 0x34, 0xe3, 0x2b, 0xff, 0x11, 0x6a, 0xed, 0xef, 0x05, 0xf5, + 0x6d, 0x6a, 0x4f, 0x5f, 0xfb, 0x2d, 0x6c, 0x39, 0x41, 0x64, 0x92, 0xe9, 0x41, 0xd5, 0xf1, 0x2a, + 0x8d, 0x47, 0x0b, 0x3e, 0x9e, 0xbf, 0x0d, 0xde, 0x74, 0x82, 0x68, 0x86, 0x36, 0x7e, 0xc8, 0xc1, + 0x16, 0x8e, 0x7c, 0xe1, 0x8e, 0x69, 0x97, 0x0a, 0x62, 0x13, 0x41, 0xd0, 0x6b, 0x58, 0x15, 0x93, + 0x20, 0x7d, 0xb4, 0xaf, 0x16, 0x1f, 0x6d, 0x1e, 0x9d, 0xd2, 0xa3, 0x49, 0x40, 0xb1, 0xd2, 0x43, + 0x3a, 0x94, 0xae, 0x29, 0x0f, 0x5d, 0xe6, 0x27, 0x6f, 0x97, 0x92, 0xd2, 0x97, 0x17, 0x1e, 0xb9, + 0x66, 0x3c, 0xf6, 0x01, 0x4e, 0x28, 0xe3, 0x29, 0x54, 0x66, 0xcc, 0xa0, 0x32, 0xac, 0xf5, 0x47, + 0x47, 0x6d, 0xac, 0xad, 0xa0, 0x2a, 0x94, 0xdf, 0x9e, 0xbc, 0x1f, 0xb5, 0xcd, 0x61, 0xeb, 0x58, + 0xcb, 0x19, 0x3f, 0xac, 0xc1, 0xc6, 0x88, 0x84, 0x57, 0xd9, 0x59, 0x0d, 0xd8, 0xb0, 0xdd, 0xd0, + 0x62, 0xd7, 0x94, 0x93, 0x73, 0x2f, 0x3e, 0xf3, 0x3a, 0x9e, 0xe3, 0xa1, 0x03, 0x28, 0xf1, 0xd8, + 0xba, 0x3a, 0x4f, 0xa5, 0xf1, 0xf8, 0xc7, 0xaf, 0x84, 0x53, 0x38, 0xfa, 0x1a, 0x4a, 0xf2, 0x97, + 0x45, 0x42, 0x5f, 0x55, 0x9a, 0x0f, 0xea, 0x71, 0x46, 0xd6, 0xd3, 0x8c, 0xac, 0xb7, 0x92, 0x8c, + 0xc5, 0x29, 0x12, 0xed, 0x41, 0x89, 0x53, 0xc1, 0x5d, 0x1a, 0xea, 0x6b, 0x4a, 0xe9, 0xe1, 0x52, + 0xd8, 0x0b, 0x3e, 0x19, 0x0a, 0x4e, 0x04, 0x75, 0x26, 0x38, 0x05, 0xa3, 0x5f, 0x40, 0x2d, 0x3d, + 0xf6, 0xc4, 0x4c, 0x1d, 0x58, 0x54, 0x7e, 0xd2, 0x32, 0xc1, 0x59, 0xe2, 0xc9, 0x03, 0xd0, 0x6d, + 0x1a, 0x70, 0x6a, 0x11, 0x41, 0x6d, 0x93, 0x72, 0xce, 0xb8, 0x39, 0xa6, 0x61, 0x48, 0x1c, 0xaa, + 0x97, 0x94, 0xce, 0xfd, 0xa9, 0xbc, 0x2d, 0xc5, 0xdd, 0x58, 0x2a, 0xe3, 0x56, 0x95, 0x30, 0x1e, + 0x05, 0xc2, 0x95, 0x2e, 0x5b, 0x4f, 0xe3, 0x76, 0x8e, 0x8d, 0x9e, 0x03, 0xb2, 0x88, 0x75, 0x49, + 0xcd, 0x90, 0x72, 0x97, 0x78, 0xee, 0x47, 0xe5, 0xdf, 0xb2, 0xf2, 0x6f, 0x4d, 0x49, 0x86, 0x33, + 0x02, 0xf4, 0x25, 0x6c, 0x3a, 0xd4, 0x97, 0x51, 0x45, 0x43, 0xd3, 0xa6, 0xd6, 0x95, 0x0e, 0x0a, + 0x5a, 0xcd, 0xb8, 0x2d, 0x6a, 0x5d, 0xc9, 0x82, 0x20, 0x88, 0x13, 0xea, 0x15, 0x55, 0x5f, 0x16, + 0x0b, 0xc2, 0xec, 0xd3, 0xd6, 0x47, 0xc4, 0x09, 0xe3, 0xf2, 0xa2, 0x54, 0xd0, 0x57, 0x50, 0x0b, + 0x98, 0x6d, 0x0a, 0x3a, 0x0e, 0x3c, 0x22, 0xa8, 0xa9, 0x0a, 0xcb, 0x86, 0xba, 0xeb, 0x56, 0xc0, + 0xec, 0x51, 0xc2, 0x57, 0x65, 0xe1, 0xd7, 0xf0, 0x45, 0x7c, 0x78, 0xd7, 0xf1, 0x19, 0xa7, 0xa6, + 0xeb, 0x07, 0x91, 0x30, 0xaf, 0x09, 0x0f, 0xf5, 0xea, 0x4e, 0xe1, 0x59, 0x19, 0x7f, 0xae, 0xc4, + 0x1d, 0x25, 0xed, 0x48, 0xe1, 0x19, 0xe1, 0xe1, 0xf6, 0x3e, 0x94, 0xb3, 0x5d, 0x91, 0x06, 0x85, + 0x2b, 0x3a, 0x49, 0xb2, 0x5e, 0x2e, 0x6f, 0x2e, 0x49, 0xaf, 0xf2, 0x07, 0xb9, 0xc3, 0x7b, 0xf0, + 0xd9, 0x9c, 0xf7, 0x92, 0xd4, 0xfd, 0x6f, 0x12, 0xae, 0xe9, 0xd9, 0xd0, 0xcf, 0x21, 0xef, 0xda, + 0x49, 0xa6, 0x3e, 0x58, 0xb8, 0x7c, 0x27, 0x6b, 0x3c, 0x38, 0xef, 0xda, 0x08, 0x25, 0x59, 0x18, + 0xef, 0x15, 0x67, 0xd6, 0x3e, 0xac, 0x8f, 0x13, 0xf7, 0xa8, 0x0c, 0xaa, 0x34, 0x7e, 0xf2, 0x23, + 0x1e, 0xc4, 0x19, 0x18, 0xfd, 0x06, 0xca, 0x59, 0xdf, 0x4a, 0x42, 0x79, 0xb1, 0x50, 0xc8, 0xcc, + 0xb3, 0x3b, 0x29, 0x08, 0x4f, 0xf1, 0x68, 0x17, 0x8a, 0x56, 0x14, 0x0a, 0x36, 0x4e, 0xe2, 0xf9, + 0x8b, 0xa5, 0x24, 0x18, 0xaa, 0xb6, 0x84, 0x13, 0x18, 0x3a, 0x80, 0xb2, 0xc5, 0x7c, 0x41, 0x5c, + 0x9f, 0x72, 0x15, 0xc1, 0x95, 0x86, 0xbe, 0xb0, 0xdb, 0x9b, 0x54, 0x7e, 0xb4, 0x82, 0xa7, 0x60, + 0xf4, 0x2b, 0x28, 0x5d, 0x1d, 0x84, 0x66, 0xc0, 0x6c, 0xbd, 0xa6, 0xf4, 0xee, 0x2d, 0xe8, 0x1d, + 0x1f, 0x84, 0x03, 0x66, 0x1f, 0xad, 0xe0, 0xe2, 0x95, 0x5a, 0xa1, 0x27, 0x50, 0x08, 0x3f, 0x78, + 0x3a, 0x52, 0x68, 0xb4, 0x80, 0x1e, 0x7e, 0xf0, 0x8e, 0x56, 0xb0, 0x04, 0xc8, 0xe8, 0x91, 0x33, + 0x80, 0x29, 0xfd, 0x98, 0x65, 0x97, 0xcc, 0x94, 0x35, 0xbc, 0x25, 0x05, 0xf2, 0xfa, 0x69, 0x72, + 0x75, 0x40, 0x4b, 0x1b, 0xb5, 0x29, 0xcf, 0x46, 0xbf, 0x17, 0x2a, 0x4b, 0x96, 0x2b, 0xc7, 0x30, + 0x81, 0xbd, 0x89, 0x51, 0x78, 0x2b, 0x9c, 0x67, 0xa0, 0x3e, 0x20, 0x9a, 0x14, 0x6f, 0x93, 0xa7, + 0xd5, 0x5b, 0x65, 0x51, 0xa5, 0xb1, 0xb3, 0x60, 0x6c, 0xa9, 0xca, 0xe3, 0x1a, 0x5d, 0x2a, 0xfc, + 0xbf, 0x85, 0xa2, 0xc5, 0xfc, 0x0b, 0xd7, 0xd1, 0x35, 0x95, 0x42, 0x4f, 0x6f, 0x08, 0x80, 0x34, + 0xdc, 0xa4, 0x97, 0x2f, 0x5c, 0x27, 0xe9, 0xd1, 0xb1, 0xda, 0xf6, 0x37, 0x50, 0x99, 0x61, 0xdf, + 0x29, 0xca, 0xd7, 0xa1, 0x28, 0x08, 0x77, 0xa8, 0x30, 0xf6, 0xa0, 0x9a, 0xbd, 0xe0, 0x80, 0x71, + 0x21, 0xd3, 0x3f, 0x7b, 0x45, 0x33, 0x60, 0x5c, 0x28, 0x8b, 0x55, 0x5c, 0xb5, 0x66, 0x61, 0xc6, + 0xff, 0x0a, 0x50, 0xce, 0x14, 0xe5, 0x4e, 0xee, 0x58, 0x56, 0xac, 0x78, 0xf7, 0x98, 0x90, 0xed, + 0xc3, 0x62, 0xe3, 0x31, 0xf1, 0x6d, 0x35, 0x85, 0x94, 0x71, 0x4a, 0xca, 0x94, 0x20, 0xdc, 0x09, + 0xf5, 0x82, 0x62, 0xab, 0x35, 0xda, 0x83, 0xf2, 0xd4, 0xaf, 0xab, 0x37, 0xc6, 0xda, 0xd4, 0x9f, + 0x53, 0x28, 0x7a, 0x0e, 0x05, 0xea, 0x5f, 0xeb, 0x6b, 0xca, 0x89, 0x8b, 0x59, 0x74, 0x4c, 0x27, + 0x67, 0xf2, 0xd6, 0x03, 0xe2, 0x72, 0x2c, 0x71, 0x68, 0x3f, 0x73, 0x7b, 0xf1, 0x56, 0x8d, 0xc3, + 0xbc, 0x9e, 0x4b, 0xdd, 0x8d, 0x1a, 0xb0, 0x26, 0xdd, 0x11, 0xea, 0x25, 0xa5, 0xf7, 0xf0, 0x53, + 0x79, 0x20, 0xdd, 0x83, 0x63, 0x28, 0x6a, 0x42, 0x45, 0x66, 0xad, 0x99, 0xec, 0x78, 0x73, 0xb4, + 0xb4, 0x88, 0x20, 0x27, 0x8c, 0xd8, 0xae, 0xef, 0xc4, 0xef, 0x89, 0x41, 0x2a, 0xc5, 0x6b, 0xd4, + 0x81, 0x0d, 0xc2, 0xad, 0x4b, 0x57, 0x50, 0x4b, 0x44, 0x9c, 0xaa, 0x62, 0xbc, 0x3c, 0x80, 0x65, + 0xbb, 0xd7, 0x9b, 0x33, 0x60, 0x3c, 0xa7, 0x6a, 0x74, 0x60, 0x63, 0x56, 0x3a, 0x3f, 0x72, 0x95, + 0x61, 0xad, 0xd9, 0x6d, 0xed, 0xbd, 0xd4, 0x72, 0x6a, 0x89, 0xbb, 0x7b, 0x2f, 0xe3, 0xb1, 0xab, + 0x89, 0xbb, 0xe6, 0xd9, 0x9e, 0x56, 0xc8, 0xd6, 0xfb, 0xda, 0xaa, 0xf1, 0xaf, 0x3c, 0x40, 0xa7, + 0x9f, 0xb6, 0x3e, 0x74, 0x0c, 0x55, 0x9b, 0xfd, 0xd5, 0xf7, 0x18, 0xb1, 0xcd, 0x31, 0xb3, 0xd3, + 0x89, 0x63, 0x71, 0xea, 0x9c, 0x6a, 0xd4, 0x5b, 0x09, 0xbc, 0xcb, 0x6c, 0x8a, 0x37, 0xec, 0x19, + 0x0a, 0xb5, 0xa1, 0x12, 0x05, 0x53, 0x53, 0x79, 0x65, 0xea, 0x67, 0x9f, 0x36, 0x75, 0x1a, 0x64, + 0x86, 0x20, 0xca, 0xd6, 0xc6, 0x09, 0x6c, 0xcc, 0x6e, 0x82, 0x10, 0x6c, 0xb6, 0xfa, 0xdf, 0xf5, + 0x4e, 0xfa, 0xcd, 0x96, 0xd9, 0x6e, 0xbe, 0x53, 0x43, 0xc9, 0x67, 0xb0, 0x95, 0xf1, 0x86, 0x23, + 0xdc, 0x6e, 0x76, 0xb5, 0x5c, 0xcc, 0x34, 0x7b, 0xfd, 0x91, 0x99, 0xca, 0xb4, 0xbc, 0xd1, 0x06, + 0x98, 0xee, 0x23, 0x6d, 0x9d, 0x0e, 0x94, 0x56, 0xbf, 0x67, 0xb6, 0x7f, 0xdf, 0x19, 0x69, 0x2b, + 0x48, 0x83, 0x8d, 0x84, 0x17, 0x5b, 0xcf, 0xa1, 0x1a, 0x54, 0x13, 0x43, 0xb1, 0x40, 0xcb, 0x1b, + 0xff, 0xc8, 0x43, 0x6d, 0xe9, 0xbd, 0x65, 0xa2, 0x50, 0x5f, 0x36, 0x5f, 0x3b, 0x19, 0x7b, 0x52, + 0x12, 0x3d, 0x02, 0x88, 0x3b, 0x5e, 0x40, 0xc4, 0x65, 0x92, 0xc7, 0x65, 0xc5, 0x19, 0x10, 0x71, + 0x89, 0x7e, 0x0a, 0x15, 0x16, 0x89, 0x4c, 0x1e, 0xcf, 0x62, 0x10, 0xb3, 0x14, 0xa0, 0x03, 0xc5, + 0x0b, 0xc6, 0xc7, 0x24, 0x1e, 0x7b, 0x36, 0x1b, 0x2f, 0x6e, 0x8b, 0xbd, 0xfa, 0x49, 0xfc, 0xd9, + 0xd3, 0x25, 0xc1, 0x5b, 0xa5, 0x88, 0x13, 0x03, 0xe8, 0x15, 0x54, 0x5c, 0x66, 0x86, 0x89, 0xd7, + 0x93, 0x0e, 0xf2, 0xe0, 0x93, 0xcf, 0x82, 0xc1, 0x65, 0xe9, 0xda, 0x78, 0x01, 0xda, 0xa2, 0x5d, + 0xb4, 0x0e, 0xab, 0xbf, 0x1b, 0xf6, 0x65, 0xe8, 0xad, 0xc3, 0xea, 0xfb, 0x66, 0xf7, 0x24, 0x8e, + 0xbc, 0x01, 0xee, 0x8f, 0xfa, 0x5a, 0xde, 0xf8, 0x77, 0x0e, 0x8a, 0x71, 0x8f, 0x40, 0xdf, 0xce, + 0x34, 0xcb, 0xdc, 0x8d, 0x29, 0x74, 0x7c, 0x10, 0xf6, 0xcf, 0xff, 0x42, 0x2d, 0x71, 0x43, 0xc7, + 0x6c, 0xc0, 0xba, 0x9c, 0x36, 0xc2, 0x80, 0x5a, 0xc9, 0xd4, 0xf8, 0xc9, 0xb6, 0x57, 0x0a, 0x98, + 0x3d, 0x0c, 0xa8, 0xb5, 0x98, 0xb7, 0x85, 0xbb, 0xe7, 0xad, 0xf1, 0xcf, 0x3c, 0xd4, 0x96, 0x8e, + 0x85, 0x5a, 0x50, 0xf4, 0xc8, 0x39, 0xf5, 0xd2, 0x2f, 0xbb, 0x5f, 0xde, 0x76, 0x91, 0xfa, 0x89, + 0x82, 0xa7, 0x5f, 0x67, 0x8a, 0x40, 0x43, 0xa8, 0x10, 0xdf, 0x67, 0x42, 0xcd, 0xab, 0xe9, 0x27, + 0xde, 0x8b, 0x5b, 0x4d, 0x35, 0xa7, 0x3a, 0xb1, 0xbd, 0x59, 0x2b, 0xb2, 0x9d, 0xcc, 0xec, 0x75, + 0x97, 0x76, 0xb2, 0xfd, 0x1a, 0xb4, 0x45, 0xdb, 0x77, 0xd1, 0x37, 0xfe, 0x9e, 0x83, 0xc2, 0xf0, + 0x83, 0x87, 0x1e, 0x42, 0x39, 0x14, 0x44, 0xd0, 0x31, 0xf5, 0x45, 0xa2, 0x39, 0x65, 0xa0, 0x97, + 0x50, 0xb2, 0x5d, 0xe2, 0x51, 0x4b, 0x24, 0x35, 0x61, 0x7b, 0x79, 0x48, 0xa8, 0xb7, 0x62, 0x04, + 0x4e, 0xa1, 0xc6, 0x3e, 0x94, 0x12, 0x9e, 0xfc, 0x04, 0x39, 0xed, 0xb5, 0xda, 0x6f, 0x3b, 0xbd, + 0x76, 0x2b, 0x0e, 0xbb, 0x66, 0x6f, 0xd8, 0xd1, 0x72, 0x72, 0x75, 0xd4, 0x39, 0x6b, 0x6b, 0xf9, + 0xe9, 0x07, 0x4b, 0xe1, 0xf0, 0xdb, 0x3f, 0xbc, 0x72, 0x5c, 0x71, 0x19, 0x9d, 0xd7, 0x2d, 0x36, + 0xde, 0x55, 0x3b, 0x31, 0xee, 0xc4, 0x8b, 0xdd, 0xec, 0xcf, 0x00, 0x87, 0xfa, 0xbb, 0xc1, 0xf9, + 0x73, 0x87, 0xed, 0xce, 0xfd, 0x3f, 0x70, 0x5e, 0x54, 0xb1, 0xf5, 0xf5, 0xff, 0x03, 0x00, 0x00, + 0xff, 0xff, 0x7b, 0x34, 0xd9, 0xba, 0xbe, 0x10, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json b/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json index 63ea63a40d..528231a896 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json +++ b/flyteidl/gen/pb-go/flyteidl/service/admin.swagger.json @@ -7018,6 +7018,13 @@ "pod_template_name": { "type": "string", "description": "pod_template_name is the unique name of a PodTemplate k8s resource to be used as the base configuration if this\ntask creates a k8s Pod. If this value is set, the specified PodTemplate will be used instead of, but applied\nidentically as, the default PodTemplate configured in FlytePropeller." + }, + "cache_ignore_input_vars": { + "type": "array", + "items": { + "type": "string" + }, + "description": "cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache." } }, "title": "Task Metadata" diff --git a/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json b/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json index 78aa113053..e623c1b872 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json +++ b/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json @@ -1037,6 +1037,13 @@ "pod_template_name": { "type": "string", "description": "pod_template_name is the unique name of a PodTemplate k8s resource to be used as the base configuration if this\ntask creates a k8s Pod. If this value is set, the specified PodTemplate will be used instead of, but applied\nidentically as, the default PodTemplate configured in FlytePropeller." + }, + "cache_ignore_input_vars": { + "type": "array", + "items": { + "type": "string" + }, + "description": "cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache." } }, "title": "Task Metadata" diff --git a/flyteidl/gen/pb-go/flyteidl/service/external_plugin_service.swagger.json b/flyteidl/gen/pb-go/flyteidl/service/external_plugin_service.swagger.json index 2196ca521f..31a12a9396 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/external_plugin_service.swagger.json +++ b/flyteidl/gen/pb-go/flyteidl/service/external_plugin_service.swagger.json @@ -934,6 +934,13 @@ "pod_template_name": { "type": "string", "description": "pod_template_name is the unique name of a PodTemplate k8s resource to be used as the base configuration if this\ntask creates a k8s Pod. If this value is set, the specified PodTemplate will be used instead of, but applied\nidentically as, the default PodTemplate configured in FlytePropeller." + }, + "cache_ignore_input_vars": { + "type": "array", + "items": { + "type": "string" + }, + "description": "cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache." } }, "title": "Task Metadata" 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 faeca2cd95..22adcb49d9 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api/swagger.yaml +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/api/swagger.yaml @@ -15760,6 +15760,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -16030,6 +16033,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -21307,6 +21313,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -21593,6 +21602,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -22292,6 +22304,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -22572,6 +22587,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -30864,6 +30882,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -31134,6 +31155,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -43550,6 +43574,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -43820,6 +43847,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -56183,6 +56213,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -56453,6 +56486,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -68595,6 +68631,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -68865,6 +68904,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -74885,6 +74927,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -87055,6 +87100,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -87325,6 +87373,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -95799,6 +95850,12 @@ definitions: \ to be used as the base configuration if this\ntask creates a k8s Pod.\ \ If this value is set, the specified PodTemplate will be used instead of,\ \ but applied\nidentically as, the default PodTemplate configured in FlytePropeller." + cache_ignore_input_vars: + type: "array" + description: "cache_ignore_input_vars is the input variables that should not\ + \ be included when calculating hash for cache." + items: + type: "string" title: "Task Metadata" example: retries: @@ -95815,6 +95872,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" coreTaskNode: @@ -95991,6 +96051,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -109001,6 +109064,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 @@ -109271,6 +109337,9 @@ definitions: interruptible: true timeout: "timeout" generates_deck: true + cache_ignore_input_vars: + - "cache_ignore_input_vars" + - "cache_ignore_input_vars" tags: key: "tags" task_type_version: 7 diff --git a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_task_metadata.go b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_task_metadata.go index 658e8e1607..7445d16032 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_task_metadata.go +++ b/flyteidl/gen/pb-go/flyteidl/service/flyteadmin/model_core_task_metadata.go @@ -29,4 +29,6 @@ type CoreTaskMetadata struct { Tags map[string]string `json:"tags,omitempty"` // pod_template_name is the unique name of a PodTemplate k8s resource to be used as the base configuration if this task creates a k8s Pod. If this value is set, the specified PodTemplate will be used instead of, but applied identically as, the default PodTemplate configured in FlytePropeller. PodTemplateName string `json:"pod_template_name,omitempty"` + // cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache. + CacheIgnoreInputVars []string `json:"cache_ignore_input_vars,omitempty"` } diff --git a/flyteidl/gen/pb-go/flyteidl/service/openapi.go b/flyteidl/gen/pb-go/flyteidl/service/openapi.go index 94b2afe544..7d709dd7e1 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/openapi.go +++ b/flyteidl/gen/pb-go/flyteidl/service/openapi.go @@ -78,7 +78,7 @@ func (fi bindataFileInfo) Sys() interface{} { return nil } -var _adminSwaggerJson = []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\xff\xec\xfd\x7b\x73\xeb\xb8\x95\x2f\x0c\xff\x3f\x9f\x02\x67\xcf\xa9\xea\xee\x44\xb6\x3b\xc9\x4c\xde\x94\xa7\x4e\xbd\x8f\xda\xd6\xde\xad\xd3\xbe\xc5\x97\xee\xe9\x67\x94\x52\x43\x24\x24\x21\x26\x01\x06\x00\xed\xad\x4e\xe5\xbb\x3f\x85\x85\x0b\x41\x8a\x94\xa8\x8b\x6d\x79\x37\x67\xaa\xd2\xde\x22\x89\xeb\xc2\xc2\xba\xfe\xd6\x3f\xff\x0d\xa1\x0f\xf2\x19\xcf\x66\x44\x7c\x38\x45\x1f\xfe\x78\xfc\xed\x87\x9e\xfe\x8d\xb2\x29\xff\x70\x8a\xf4\x73\x84\x3e\x28\xaa\x12\xa2\x9f\x4f\x93\x85\x22\x34\x4e\x4e\x24\x11\x4f\x34\x22\x27\x38\x4e\x29\x3b\xce\x04\x57\x1c\x3e\x44\xe8\xc3\x13\x11\x92\x72\xa6\x5f\xb7\x7f\x22\xc6\x15\x92\x44\x7d\xf8\x37\x84\xfe\x05\xcd\xcb\x68\x4e\x52\x22\x3f\x9c\xa2\xff\x31\x1f\xcd\x95\xca\x5c\x03\xfa\x6f\xa9\xdf\xfd\x1b\xbc\x1b\x71\x26\xf3\xd2\xcb\x38\xcb\x12\x1a\x61\x45\x39\x3b\xf9\xbb\xe4\xac\x78\x37\x13\x3c\xce\xa3\x96\xef\x62\x35\x97\xc5\x1c\x4f\x70\x46\x4f\x9e\xfe\x70\x82\x23\x45\x9f\xc8\x38\xc1\x39\x8b\xe6\xe3\x2c\xc1\x4c\x9e\xfc\x93\xc6\x7a\x8e\x7f\x27\x91\xfa\x17\xfc\x23\xe6\x29\xa6\xcc\xfc\xcd\x70\x4a\xfe\xe5\xdb\x41\xe8\xc3\x8c\xa8\xe0\x9f\x7a\xb6\x79\x9a\x62\xb1\xd0\x2b\xf2\x91\xa8\x68\x8e\xd4\x9c\x20\xd3\x0f\x72\x4b\xc4\xa7\x08\xa3\x53\x41\xa6\xa7\xbf\x08\x32\x1d\xbb\x85\x3e\x36\x0b\x7c\x01\xa3\xb9\x49\x30\xfb\xe5\xd8\x2e\x13\xb4\xcc\x33\x22\x60\x6e\xc3\x58\xb7\xfe\x89\xa8\x3e\x34\x5b\xbc\x1f\xbe\x2d\x88\xcc\x38\x93\x44\x96\x86\x87\xd0\x87\x3f\x7e\xfb\x6d\xe5\x27\x84\x3e\xc4\x44\x46\x82\x66\xca\xee\x65\x1f\xc9\x3c\x8a\x88\x94\xd3\x3c\x41\xae\xa5\x70\x30\x66\xaa\x7a\x63\xf1\x52\x63\x08\x7d\xf8\xdf\x82\x4c\x75\x3b\xff\x7e\x12\x93\x29\x65\x54\xb7\x2b\x0d\xfd\x04\xa3\x2d\x7d\xf5\xaf\x7f\xab\xfb\xfb\x5f\xc1\x8c\x32\x2c\x70\x4a\x14\x11\xc5\x8e\x9b\xff\xab\xcc\x45\xef\x91\xee\xbc\xd8\xc7\xea\xc0\x2b\xb3\xbd\xc2\x29\xd1\x7b\xa2\x77\xca\x7e\x01\x7f\x0b\x22\x79\x2e\x22\x82\x26\x24\xe1\x6c\x26\x91\xe2\x4b\x6b\x40\xa1\x05\x4d\x5e\xd5\x27\x82\xfc\x23\xa7\x82\xe8\xbd\x52\x22\x27\x95\xa7\x6a\x91\xc1\x20\xa5\x12\x94\xcd\xc2\xa5\xf8\x57\xaf\xd5\xd4\x0c\x55\x6e\x30\x33\xf3\x41\xe3\xc4\x46\xac\xef\x5e\x89\x30\x43\x13\x82\xf4\x59\xa4\x31\x11\x24\x46\x58\x22\x8c\x64\x3e\x91\x44\xa1\x67\xaa\xe6\x94\xe9\x7f\x67\x24\xa2\x53\x1a\xb9\x35\x3b\x9c\xb5\x81\x3f\x57\xaf\xcc\x83\x24\x42\x0f\xfc\x89\xc6\x24\x46\x4f\x38\xc9\x09\x9a\x72\x51\x5a\x9e\xe3\x11\xbb\x9f\xeb\x75\x48\x27\x94\xc1\xc9\xd3\x6b\xe9\x28\xe4\xf7\x6e\xb9\x7e\x8f\x74\x7f\x28\x67\xf4\x1f\x39\x49\x16\x88\xc6\x84\x29\x3a\xa5\x44\x56\x5b\xfb\x3d\x87\xfe\x71\x82\x8e\x90\x5e\x67\x22\x14\xac\x37\x67\x8a\x7c\x56\x12\x1d\xa1\x84\x3e\x12\xf4\xd5\x05\x95\x0a\xf5\x6f\x86\x5f\xf5\xd0\x57\xe6\xbc\x20\xe0\x4d\x5f\xbd\xc2\x0a\xfb\xbf\xff\x16\x1c\x3d\x85\x67\xd5\x43\xf7\xa1\xaf\x4f\xf3\x9d\xb9\x1a\x8a\x16\xfe\xf6\x6f\x61\x3b\x76\xbf\x56\xf3\xdb\x82\xd9\x5a\x4e\xdb\x96\xbf\xc2\x32\x95\x59\xab\xd4\x3b\xb4\x2b\x67\xd5\xed\x56\x59\xab\x7c\x5f\xbc\x55\x4f\xe1\xa5\xf9\xeb\x2e\xcc\x15\x2b\xa0\x7a\x4c\x99\x39\x24\xfe\xcc\x08\xa9\xcf\x89\xa3\xde\x03\x61\x29\xbb\xf0\xda\x60\x66\x01\xbb\x75\x5c\x34\x58\x95\x03\x9c\x77\x42\x53\xba\x6e\x7f\x87\x2c\xd6\x22\x97\x65\x76\x2c\x4f\x27\x44\xe8\x65\x70\x6c\x0f\x66\x3b\xd1\x6c\x50\xe5\x82\x91\xb8\xc5\x34\xff\x91\x13\xb1\x58\x31\xcf\x29\x4e\x64\xd3\x44\x29\x53\x44\xcb\xb7\x95\xc7\x53\x2e\x52\xac\xec\x0b\x7f\xfe\x8f\x4d\x17\x42\xf1\x47\xb2\x6e\xff\x87\x66\x37\x23\x2c\x81\x0c\xd2\x3c\x51\x34\x4b\x08\xca\xf0\x8c\x48\xbb\x22\x79\xa2\x64\x0f\x5e\xd3\x32\x35\x11\x47\xfe\x06\x82\x1e\xdc\xcd\x9b\x4b\xf8\x05\x4d\xbd\x00\xc9\xc8\x67\x05\x2d\x8d\x18\xdc\xbd\xb0\x44\xe1\x8d\xf2\x02\x4b\xb9\x1d\xcd\x48\x2e\xd4\x78\xb2\x38\x7e\x24\x4b\xfd\x36\x52\x0e\x66\x08\x2b\x25\xe8\x24\x57\x44\xcf\x5b\xb7\xe1\xee\x4e\x60\x8f\xe6\x82\x6e\xc3\x1a\xde\x6e\xc2\x31\x15\x24\x82\xb9\x6d\x72\x60\xfc\x57\x7a\xde\x5a\x7f\x59\x98\xd9\x3f\x92\x05\xc8\x23\x35\x2b\xe0\xb7\x7c\xc4\x46\x0c\x1d\xa1\xf3\xc1\xdd\xd9\xe0\xea\x7c\x78\xf5\xe9\x14\x7d\xb7\x40\x31\x99\xe2\x3c\x51\x3d\x34\xa5\x24\x89\x25\xc2\x82\x40\x93\x24\xd6\x32\x87\x1e\x0c\x61\x31\x65\x33\xc4\x45\x4c\xc4\xcb\x2d\x63\xe5\x29\x61\x79\x5a\xb9\x57\xe0\xf7\x62\xf4\x95\x2f\xb4\x88\xe1\x1f\x95\x9e\xfc\x6d\x69\x81\x61\xc6\xba\xef\xa0\xb5\x57\x13\x6a\xa2\x39\x4d\x62\x41\xd8\x89\xc2\xf2\x71\x4c\x3e\x93\x28\x37\x77\xf2\x3f\xcb\x3f\x8c\xb5\x64\xca\x63\x52\xfe\xa5\xf4\x8f\x42\x14\xda\xf8\x53\xaf\xa5\x6e\xfc\x25\xe8\xb4\xed\xbe\x83\x5f\x68\x5c\xfb\x36\xfc\xb2\x66\x0e\xee\x9d\x15\x83\x75\xaf\x34\x8e\xca\xbd\x60\x25\xbe\xda\x77\x04\x51\x62\x31\xc6\x4a\x91\x34\x53\x1b\xea\xeb\x18\x25\x5a\xae\x5c\x25\x47\x5e\xf1\x98\x0c\x5c\x7f\xbf\x20\x23\xce\x92\x18\x4d\x16\x96\x6b\x4d\x89\x20\x2c\x22\xcd\x2d\xdc\x63\xf9\x58\xb4\xb0\x4e\x18\x2d\xf5\x27\x3f\x72\xa1\x3f\x7f\x0f\x02\x69\x69\xe0\xaf\x21\x93\x6e\x7b\xe2\xbe\x38\x0b\xc1\x96\xfc\xa3\xb3\x27\xec\xbe\x92\x6d\xad\x0f\x5c\x20\xb9\x90\x8a\xa4\x6b\xed\x10\xef\x67\x21\xec\x05\x71\xa8\x03\xae\xdc\x51\xbf\x81\x53\x5f\xbe\x71\xbb\xe3\xbd\xc1\x92\xed\xcb\x8a\x78\xe8\xf3\x74\x3e\x9c\xd5\x53\xbd\x73\xdb\x17\x38\x31\xde\xc5\x34\x4b\xb2\xe0\xbe\x07\xf9\x42\xe6\x86\xc6\xbd\x72\xab\x3d\x86\x01\xac\x51\x34\xcb\x76\x68\x7f\xfe\xf4\xa7\xa1\x85\xc6\x98\xe3\xd4\x9c\xca\xc0\x58\x85\x22\x2e\x8c\x2c\x18\xdb\xf3\x6e\x74\xcd\xfe\x7d\xff\x6e\x70\x7f\x8a\xfa\x28\xc6\x0a\xeb\x03\x2e\x48\x26\x88\x24\x4c\x81\x1e\xaf\xbf\x57\x0b\x94\xf2\x98\x24\x46\xe3\xfc\xa8\x25\x5f\x74\x8e\x15\x3e\xc3\x0a\x27\x7c\x76\x8c\xfa\xf0\x4f\xfd\x31\x95\x08\x27\x92\x23\xec\xc8\x8a\xc4\xae\x09\xcc\x62\xc7\x5a\x30\x8a\x78\x9a\xd1\xc4\xdb\xe0\xbd\x71\x85\xb2\x98\x3e\xd1\x38\xc7\x09\xe2\x13\xcd\x55\xb4\x86\x3c\x78\x22\x4c\xe5\x38\x49\x16\x08\x27\x09\xb2\xdd\xba\x17\x90\x9c\xf3\x3c\x89\x75\xbb\x6e\x94\x92\xa6\x34\xc1\x42\xab\xe0\x66\xb4\xd7\xb6\x2d\x74\x3f\x27\x7e\xac\x30\x2e\xbd\x9a\x29\x7e\x24\x12\x51\x85\x32\x2e\x25\x9d\x24\xc5\x99\x7f\x18\x22\x18\xf7\xd9\xc5\x10\xf4\xf9\x48\x21\x6e\x78\xa8\xeb\xdc\xda\x6f\x5c\x8f\x29\x66\x8c\x40\xc7\x5c\xcd\x89\xb0\xdd\xdb\x97\xdf\x5a\x35\x7f\xb8\xba\xbb\x19\x9c\x0d\x3f\x0e\x07\xe7\xcb\xba\xf9\x7d\xff\xee\x87\xe5\x5f\x7f\xba\xbe\xfd\xe1\xe3\xc5\xf5\x4f\xcb\x4f\x2e\xfa\x0f\x57\x67\xdf\x8f\x6f\x2e\xfa\x57\xcb\x0f\x2d\x59\xb5\x56\xf3\xc3\x91\x6d\x78\xb6\x3a\x9b\xe6\x4b\xd9\x34\x7b\x5f\xae\x51\x73\x4a\x13\xd0\x41\x5b\x1b\x34\xbd\x0d\xc1\x7e\x89\x32\x2c\xa5\x91\x8c\xcc\x08\x8e\x47\xec\x92\x0b\xcd\xc0\xa6\x5c\xf3\x08\x2d\x3d\x29\x91\x47\x8a\xb2\x99\xff\xe8\x14\x8d\xf2\x6f\xbf\xfd\x53\x74\x41\xd9\x23\xfc\x45\x0e\x71\x71\x3a\x8b\x6f\x67\xf1\xfd\x6d\x59\x7c\xb5\xe8\x73\x12\x1a\x7a\xf7\x1b\x32\xa4\x85\x0b\x96\xe5\x0a\x44\x09\x9e\x2b\xfd\xa7\xee\x12\xc8\x63\x45\xe0\x50\x3b\x83\xe2\x27\xa2\xfc\x8b\x5a\xb4\x79\x0f\x76\xc4\x9f\xb8\x78\x9c\x26\xfc\xd9\x0f\xfc\x13\x51\x7a\xec\xb7\xb6\x97\x2e\x94\xa8\x0b\x25\x7a\xdb\x50\xa2\x83\x32\xe6\xbd\x3c\xf3\x2b\x5b\xfe\x0c\x07\x6c\xf0\x64\x35\x3a\xaa\x1a\xfc\x50\x81\x9b\xe9\x55\xb8\x66\xd9\x99\xb3\x86\x73\x96\x5e\x7e\x2f\xdc\xb3\x34\xe8\xd7\xe7\x9c\xbf\x09\x7f\x4b\xe7\x4e\xd9\x72\xa1\xde\x25\x83\x6d\x79\x77\xbc\x9a\x33\xe4\xe5\x19\xfe\x52\x6c\xc3\x26\xc1\x0c\x1b\x44\x2f\xb4\x0e\x57\x58\x13\x9f\x50\x1b\x90\x50\x17\x81\xb0\x1c\x72\x50\x1b\x63\xb0\x5b\x50\xc1\xb6\x77\x53\xfb\x30\x81\x4f\x44\x95\x5e\x7e\x2f\x77\x53\x69\xd0\xaf\x7f\x37\xfd\x46\xa3\x03\xba\x70\x80\x17\x5c\xba\x2f\xfd\x46\x3b\x5c\x87\xff\x6f\xc0\xc3\xdf\xb9\xf4\x37\x5a\xa3\x2f\xcb\x87\xff\xa5\x3a\xed\xdf\xa7\x97\xbe\x73\xcb\x77\x6e\xf9\xb7\xf0\x9f\xbc\x3f\xb7\xfc\xcb\xaa\xa7\xc5\xf1\x1a\x3b\x5a\xb0\xfa\x5a\x70\x28\xff\xd5\xc2\x49\x03\x7f\x39\x95\x6f\xd3\xa0\xf1\x46\x1d\xee\xbc\x18\xdf\x00\x8e\xd0\x2f\x96\x90\xd6\xa8\x73\x4b\xdf\xbd\x07\x75\x6e\x79\xd0\x2f\xaf\xc3\xbd\x19\xf3\x7d\xa1\xcb\xf3\x9d\xb0\x81\xcd\x6f\xcb\x2f\x58\x26\xef\x64\xf1\x97\xcf\xc6\x3f\x98\x09\xbd\x1f\xd9\xfb\x0d\x2e\xde\x96\xb7\xee\xde\x73\xb2\x6a\xae\xd9\xe0\x76\x5a\x97\x61\x55\xfd\x9a\x12\xf9\xc7\x77\x79\xdf\xbe\x46\x92\x55\x77\xe1\x76\x17\xae\x6d\xaa\xbb\x70\xbf\xe0\x0b\xf7\xe0\xe0\x6f\x0e\x26\x02\xb4\x0b\x22\xef\x80\x31\xba\x18\xf2\x3d\x2e\x4e\x17\x43\xde\xc5\x90\xff\xc6\x62\xc8\x77\xd1\x9e\xb6\xc5\xa2\x7c\x0b\x3d\xaa\x53\xa3\x3a\x35\x2a\xfc\xbd\x53\xa3\x3a\x35\xaa\x53\xa3\xbe\x70\x14\xd1\x4e\x87\x6a\xbf\x10\x9d\x0e\xd5\x7a\xa9\x3a\x1d\x6a\xc5\xe2\x74\x3a\x54\xa7\x43\xfd\xb6\x74\x28\xf2\x44\x98\x92\x90\x8c\x16\x6a\x14\x1f\x32\x2e\x9b\x35\xa1\x90\x3b\xd4\x68\x41\xd0\x66\x39\x29\x0c\x02\x97\x7e\x41\x73\x2c\x11\x8f\xa2\x5c\x54\xce\x40\x55\x0f\x3a\x13\x04\x2b\x02\x2d\xe8\x0f\xdf\x83\xfe\xb3\x3c\xdd\xd7\x8a\xc1\x9f\xf0\x78\x89\xda\xcd\x41\xa8\x7b\xb2\x5a\x1e\xd9\xdb\xd4\xff\x91\x93\x76\xea\xdf\x0b\x12\xb5\xc2\xf2\x71\xcf\x44\x5d\xca\xb5\xd8\x8a\xa8\xa1\x85\xf7\x42\xd4\xcb\xd3\xfd\xcd\x10\x75\xdd\xd4\x0f\x81\xa8\x9f\x6d\x1e\xff\x9e\x09\x7b\x09\x1e\x60\x2b\xe2\xf6\xad\xbc\x17\x02\xaf\x9f\xf6\x6f\x86\xc8\x9b\xa6\xff\xb6\x84\xee\x53\x24\x5b\x93\xf8\xbd\xa0\xb3\x99\x56\x33\x40\xc3\xd3\xa4\xb8\xbe\x46\x50\x91\x14\xb8\x96\xac\xfd\xab\xef\x81\xa4\xfd\x60\xcd\xd8\x7f\x33\xb4\xbc\x34\xef\x03\x21\xe2\x13\x41\x22\xfe\x04\xf5\xc2\xda\x11\xf3\x2d\x01\x0a\x06\x7e\x9d\x09\xf2\x44\x79\x2e\x93\xc5\x91\xc8\x19\x72\xcc\x1f\xf9\xe6\x8d\xb5\xfa\x99\x26\x09\xe2\x4c\xeb\x5f\x0a\x0b\xe5\x1e\x6b\xfd\x5b\xf0\x14\x4e\x45\x82\xa5\x42\x8f\x8c\x3f\x33\x34\xc5\x34\xc9\x05\x41\x19\xa7\x4c\x1d\x8f\xd8\x90\xa1\x5b\x33\x46\xc8\x1b\xe8\xa1\x5c\xea\xb3\x14\x61\xc6\xb8\x42\xd1\x1c\xb3\x19\x41\x98\x2d\x6c\x02\x6e\x41\x19\x88\x0b\x94\x67\x31\xd6\x8a\xef\x9c\x54\xa3\xf4\xfc\x18\xc1\x7c\x47\x25\xa2\x12\x91\xcf\x4a\x90\x94\x24\x0b\xdd\x87\xa6\x7d\xc5\x91\x5d\x1f\x33\x54\x9b\xce\x47\x84\xe0\x42\x42\xc6\xc1\x64\xf1\x2b\x66\x8a\x32\x82\x40\x51\x92\xc6\x34\x77\x84\x2e\xb8\x04\xb3\xcd\x0f\x7f\x91\x28\x4a\x72\xa9\x88\xe8\xa1\x49\x3e\x93\x5a\x53\xcc\x12\xac\xa6\x5c\xa4\x7a\x84\x94\x49\x85\x27\x34\xa1\x6a\xd1\x43\x29\x8e\xe6\xa6\x2d\x58\x03\xd9\x1b\xb1\x98\x3f\x33\xa9\x04\xc1\xbe\x77\xf7\x10\x7d\x1d\x3e\x33\x04\x20\xbf\xe9\x41\xda\x21\x4d\xb5\xba\x1b\x0c\xbf\xd8\x71\xb3\x27\xba\x11\x12\xa3\x09\x89\x70\x2e\xad\x87\x41\x89\x05\x22\x9f\xe7\x38\x97\xb0\x77\x7a\x7a\x36\x67\x23\xe2\x69\x96\x10\x45\x10\x9d\x22\x25\x28\x89\x11\x9e\x61\xaa\x97\xee\x8e\xac\x00\x41\xf7\x44\x6f\x37\xd0\x52\xfd\x2f\xa0\x7e\xa7\x5c\x10\x14\x13\x85\x69\xb2\xd2\xeb\x64\xbf\xed\xb8\xdc\x7b\xe2\x72\xe5\x0d\x3f\x08\x36\x67\x40\xfc\xf7\x70\x69\x33\x6b\xba\x8f\x70\xb2\xe3\xfd\x7d\x6b\x07\xd5\xd1\xf6\xfb\xa2\x6d\xb3\x6b\x87\x43\xdc\xaf\x16\x83\xdd\xbe\xa2\x45\x51\xcd\xe2\x5d\xd1\xf4\x6b\x84\x05\x74\x0e\xe7\xce\xe1\xdc\xb8\x32\xef\xd3\xe1\x7c\x30\x1e\xa3\xce\xe7\xfc\x42\x3e\x67\x2a\x3b\xa7\x73\xe7\x74\x6e\xbb\x40\x9d\xd3\xb9\x73\x3a\xbf\x5f\xa7\xf3\x4b\xe2\x3e\xef\x15\xdd\xf9\x5d\x89\xd6\x9d\x58\xdd\x89\xd5\x1d\x84\xb3\x9f\xda\xbe\x58\x98\xfb\xfa\x43\x4c\x12\xa2\x48\xb3\x3d\x8b\x88\x54\x6b\x0b\xe6\x7a\xa6\x4c\xcb\x71\x33\x41\xa4\xdc\x95\x21\xf9\x86\xdf\x27\x5b\xf2\xc3\xef\xa0\xe6\x3b\x3e\xd5\xf1\xa9\x6d\xa6\x76\x38\xa6\xd9\xe0\x30\xbf\x96\x6d\xd6\xf3\xdf\x2c\x6f\x96\xfe\x1e\x8c\x1b\xb2\xf0\x8b\x1a\x0a\xd7\x52\xbb\xe2\xfe\x70\x5b\x3a\xdf\x91\x1f\x9b\xbe\xde\x27\x33\x36\x63\xef\x38\x71\xc7\x89\x3b\x4e\xfc\xbe\x39\xb1\x3b\xc9\x6f\xea\x22\x33\x7e\xba\x71\x96\x60\x36\xa6\xb1\x3c\xf9\x67\xa1\xcb\xbf\x94\x87\x4c\x1f\xa8\xd8\xa4\x98\xfa\x94\x4e\xf1\x8b\xfe\x24\x29\x0c\xe6\x1e\x33\x73\x8d\x13\xcd\xd8\xd8\x6f\x12\xcc\x86\xf1\xbb\xf0\xa3\xd5\xce\xfe\x35\x7c\x6a\xbb\xf0\x71\xac\xc0\xd3\x81\x29\x33\x26\xbc\x22\xaf\xb6\x64\xa0\x3c\x8c\x13\xbe\x0b\x57\x0f\x26\x16\x30\x76\xc7\xaf\x83\x45\x39\xbc\x69\x77\x7e\x9d\x2e\x97\xb0\xf3\x5c\xb4\x9c\x70\xe7\xb9\x38\x5c\xcf\xc5\x5b\xb9\x23\x5f\xf9\x78\xbe\x96\x58\xd7\x3e\x08\xdf\x44\xab\x41\x50\x6b\x9e\x25\x1c\xc7\xab\x5c\x31\x85\xe0\x15\x82\xa3\xac\x8d\xc4\x2f\x3e\x7b\x0f\xc2\x5a\x31\xda\xdf\x58\x24\xdf\xf2\xc4\x0f\x45\x4b\x79\xc5\x50\xbe\x7a\x12\xdf\x40\x25\x79\x1f\xf8\xa9\xc5\x78\xbb\xd0\xbe\xce\xa2\xf4\xf6\x16\xa5\x2e\xb4\xaf\x53\x01\x0f\x4c\x05\xec\x42\xfb\xba\xd0\xbe\x4e\x41\x5e\x3d\xed\x4e\x41\xfe\x22\x42\xfb\x5a\x89\xda\x2f\x88\xbd\xb9\xbb\xd0\xdd\xc9\xdc\xee\xbd\x4e\xe6\xee\x64\xee\x2f\x54\xe6\x3e\x8c\x15\xee\x04\xee\x4e\xe0\xee\x04\xee\x4e\xe0\xee\x04\xee\xbd\x2f\x63\x27\x70\xbf\x66\x81\xce\x7a\xa9\x7b\x4d\x92\xcd\x7b\xf5\xe5\x74\xe2\x76\x27\x6e\x1f\xb6\xb8\x7d\x30\x13\x7a\x3f\x65\x1e\xdb\xcd\xa7\x2b\x52\xde\x15\x29\xef\x8a\x94\xbf\x78\x91\x72\xf7\x75\x8b\x8c\x0f\x7b\xb8\x14\x56\xb9\x34\x80\x8f\x82\xcc\xa8\x54\xc0\xfe\xdb\xc8\x2b\xeb\x13\x3d\xde\xab\x9c\xd2\xa5\x7a\xf8\xa7\x9d\xd4\xd2\x49\x2d\xbf\x51\xa9\xe5\x80\x62\xc1\x0e\x22\x63\x25\xc5\x2a\x9a\xe3\x49\x42\xc6\xde\xe8\x23\xdb\xea\xc1\x17\x54\x2a\x89\xa2\x5c\x2a\x9e\x36\x5f\x2e\x97\xae\x87\xbe\xef\xe0\x8c\xb3\x29\x9d\xe5\xe6\x6e\x31\xe0\x9c\xc1\x89\x2e\x24\xc1\x45\x46\xd6\x79\xaa\x6a\x5a\x7f\x17\xd7\x52\xfd\xd0\x5f\xeb\x76\xda\x44\x70\x2f\x8c\x7c\x56\xea\xd6\xb2\xd6\xf8\x76\x70\x77\xfd\x70\x7b\x36\x38\x45\xfd\x2c\x4b\xa8\xb1\xbb\x1b\x52\xa0\xbf\xea\x49\x21\x85\xe5\x63\xb1\x97\xc2\x90\xb9\xc1\xb0\x05\x43\xbf\x96\x8d\xd1\x11\x3a\xbb\x78\xb8\xbb\x1f\xdc\x36\x34\x68\x09\x05\xf2\x56\x49\x9a\x25\x58\x91\x18\x3d\xe6\x13\x22\x18\xd1\xd2\x8e\x45\xba\x2d\xcc\xff\xa6\xd1\xc1\x7f\x0f\xce\x1e\xee\x87\xd7\x57\xe3\xbf\x3e\x0c\x1e\x06\xa7\xc8\x51\x9c\x6e\x56\x8f\x4b\x8f\x22\x5e\x30\x9c\x6a\x0d\x44\xff\x50\x64\xca\xfe\x23\x27\x39\x41\x58\x4a\x3a\x63\x29\x01\x44\xe0\x52\x8b\x6e\xc0\x17\xfd\xef\x06\x17\xe5\x96\xe7\x24\x84\xdf\x45\x09\x9e\x90\xc4\xfa\x23\xc0\xc4\xae\x09\x3d\x80\x2a\x36\x8e\x8a\xdc\xac\xea\x5f\x1f\xfa\x17\xc3\xfb\x9f\xc7\xd7\x1f\xc7\x77\x83\xdb\x1f\x87\x67\x83\xb1\x95\x2a\xcf\xfa\xba\xdf\x52\x4f\x56\xf8\x44\xff\xc8\x71\xa2\xb5\x13\x3e\x75\x78\xbc\xe8\x79\x4e\x18\xca\x19\x50\x9c\x51\x79\xb4\x1e\xe4\x3b\xd5\xa7\xcc\xcc\xe8\xe6\xe2\xe1\xd3\xf0\x6a\x7c\xfd\xe3\xe0\xf6\x76\x78\x3e\x38\x45\x77\x24\x01\xa5\xc0\x2d\x3a\xec\x62\x96\xe4\x33\xca\x10\x4d\xb3\x84\xe8\xd5\xc0\x36\x9b\x78\x8e\x9f\x28\x17\xf6\xe8\xce\xe8\x13\x61\x66\x1d\xe1\xcc\x42\xfb\x4e\xf8\x1e\x07\x4b\x77\x7d\xf5\x71\xf8\xe9\x14\xf5\xe3\xd8\xcf\x41\x42\x1b\x25\xca\x71\xb0\xce\x47\xe5\x61\x6b\xe6\x00\xdd\x1b\x22\xe2\x4f\x44\x08\x1a\x93\x0a\x1d\xf5\xef\xee\x86\x9f\xae\x2e\x07\x57\xf7\xb0\x62\x4a\xf0\x44\xa2\x39\x7f\x06\x53\x36\xcc\x10\x2c\xdc\x4f\x98\x26\xd0\x99\xdb\x2c\xce\xd0\xf3\x9c\x82\xfb\x03\x80\x99\x7d\xcf\x46\x3f\x13\x39\x7b\x73\xeb\x6c\xe9\xe0\x2d\xab\x2d\xd5\x93\xb4\xfc\x46\xe5\x58\xac\x7a\xa1\x44\xe5\xcb\x2f\xae\xa3\xd6\xe5\x2f\x2a\xe4\xd6\xac\xac\x2d\xd1\x4b\xf3\x4c\x8b\xbd\x6e\xad\xab\x95\xd7\xf0\xf5\xae\x59\xa2\x04\x8d\xe4\xcb\x42\x3d\x89\x9c\x29\x9a\x12\x64\x3b\xb3\x87\x73\x8f\xf0\x4f\x97\xa6\xe1\xf7\x70\xc1\x2e\x95\x72\xf8\x44\x94\x1d\x7e\xa7\x02\x76\x2a\xe0\x61\xa8\x80\xef\x2d\xdb\x3f\x26\xd9\x72\x87\x95\x89\xc1\x3b\xc6\xeb\xb5\x14\xa4\x61\xec\x89\xd6\xa2\x9a\x90\x27\x92\x80\x94\xa7\x04\xd6\x4a\xa3\x95\x5d\x26\x82\xe0\x47\x2d\xf0\xc5\xfc\x39\x94\x5c\x6a\x90\xfb\xd1\x7e\x6e\xe1\x36\x41\x1c\x7f\xfa\xe3\xeb\x5d\x16\x7a\xb9\xe3\xd7\x28\xe1\x7d\x0b\x41\x32\x2b\x31\x02\x83\x04\xfb\x5f\xac\x25\x78\xcd\x6d\x11\x7c\xf1\x1e\x2e\x8a\x70\xb8\x07\xa4\x75\xdd\x86\x4a\xb0\x63\xa1\x29\x51\x38\xc6\x0a\xeb\x43\x33\x23\xea\x18\x5d\x33\x78\x76\x8f\xe5\x63\x0f\xb9\x2b\x4f\xb3\x95\xc2\xca\xf0\x0a\xa9\xf5\xef\xc4\x80\xbf\x39\x1f\xef\xae\xef\xee\xfa\xae\x5f\x99\x2e\xcc\xb3\x61\x85\xf7\x75\x31\x6e\xe4\xf3\xda\xdf\xfd\x65\x5a\x7c\xbf\x57\xd8\xeb\x3a\xb9\xf6\x7a\xa1\x99\xca\x59\xdd\x6d\x65\xfe\xaf\xbb\xad\xba\xdb\xaa\xbb\xad\x0e\x60\x85\xdf\xdc\x61\x58\xc3\xdd\xdf\xd4\x63\xb8\x4e\x3b\xdd\x1a\xf2\xae\xd0\x46\x37\x01\xbd\xfb\xa5\x2d\xb6\x5d\xf1\x0d\x7d\x1f\x3e\xc2\x60\x92\xaf\x91\xd6\xb6\xd7\xcb\xdc\xe4\x8b\x74\xfa\xe9\x0b\xde\xf8\x1d\x02\xe1\x5e\x11\x08\x0f\x63\xae\x2f\x92\x02\xf7\x36\x16\xd3\xb7\x4f\x7b\xeb\xa0\x06\xbb\xc4\xae\x2e\xb1\x0b\x7e\xef\xa0\x06\xf7\x47\xad\x2f\x2b\x5d\xf3\x98\x8c\x2b\x51\x02\xfe\x9f\xe3\xaa\xe7\xa7\xf4\x24\x74\x03\x95\x1e\x14\x99\x6e\xd0\x3a\x8d\xf7\x59\x44\xea\x8a\xc7\xa4\x75\x24\x41\xe9\xe5\x03\x97\xc1\xdd\x3c\x8d\x2c\x5e\x1a\xf8\x0b\x4b\xe2\x0d\x5b\xfe\x25\x1a\x76\x6a\x08\xb8\xb3\xf2\xac\x5d\xa8\x2f\x35\xbe\xa0\xe0\x50\xef\xc8\x53\xd1\x8e\x8d\xbb\x98\xc6\x71\x03\x33\xaf\x7f\xee\x59\x7a\xfd\xe3\x97\xc1\x0c\x6a\xcf\xd1\xc1\xac\x12\xbe\xfd\x3e\xec\x2a\xe1\x88\x5f\xc3\xb2\xb2\x72\xef\xbf\x38\xae\xbe\x8a\x92\x3b\xde\xde\x72\xb9\xbe\x54\x0e\xdf\x41\xfc\xac\xb2\x75\x74\x18\x3a\x9d\xa9\xe5\x70\x26\xdc\x99\x5a\xde\xb5\xa9\xc5\xb8\x68\xc7\x19\x16\x84\xa9\x1a\x91\xba\x7a\x9d\xc0\xeb\x21\xe6\x82\x93\x3a\xa0\x01\xa4\x25\x5a\x64\x2f\x64\x7f\x55\x7d\x59\xb6\x17\x2b\x18\x04\x99\x90\x27\xff\x2c\xfe\xf6\xc2\x7a\xa9\x02\xc4\x8a\xe8\x24\x83\xf5\x2f\xf5\x1d\x9d\xdb\x40\xa5\xdd\x73\x25\xb1\x2a\x89\x82\x10\x44\xbd\x36\x9e\xe9\xc6\xbc\xfd\xbe\x52\x24\x97\x06\xfd\xba\xb1\x4d\xcb\x1b\xdf\xee\x00\xb9\x9d\xa1\x26\xdd\x2f\xc8\x29\xd3\xd2\x28\x9f\x16\x17\x83\x44\xcf\x34\x49\x00\x51\x04\x32\x1e\x9b\x6e\x80\xdf\x5c\xc4\x43\xe3\xce\xbf\x69\xdc\x43\x1d\x77\xa8\x63\x09\x6d\xec\xa9\xfb\xca\x99\x76\xc4\x06\xe9\xac\xa0\x0d\xad\x31\xc0\x7e\x19\x9c\xe0\x13\x51\xaf\xc5\x06\xb6\x3d\xfb\x2b\xcf\xbd\x20\x53\x22\x08\x8b\xc8\x01\x7a\xdb\x37\x09\x03\xf9\xc9\x4c\xd2\xc6\x80\x78\x28\x81\x70\xaa\x8a\x5b\x3d\xad\x24\xea\x76\x99\xe4\x5d\x26\x79\x97\x49\x5e\x3d\xea\x5d\x26\x79\x97\x49\x5e\x9b\x03\x11\x93\x84\x28\xd2\x28\x55\x9c\xc3\xe3\xb7\x92\x2a\x4c\xef\x5f\x86\x60\x61\xe6\xd2\xc9\x16\xbf\x19\xcd\xc2\x6d\xf8\x41\x68\x16\xe6\xac\xad\x33\x3f\x94\x7e\xac\x09\xb1\x7e\x75\x93\xc4\x36\x4c\xa3\x64\x97\x38\x87\xd7\xdf\x25\xeb\xa8\x0e\xbd\xb3\x51\xa0\x60\xeb\x5e\x8e\x93\x2c\x1d\x81\x76\x13\xb7\x1e\xc3\xf7\x3b\xef\x43\xe1\xa0\x4d\x74\x7f\xa8\x7c\x74\xeb\xa4\x94\x43\xb1\xd8\x7c\x41\x3c\xb2\xb3\xde\xbc\x71\xae\xc4\x12\x33\x7c\xb7\xd3\xed\x8c\x55\x9d\xb1\xaa\x33\x56\x75\xc6\xaa\xce\x58\x85\x3a\x63\xd5\xc6\xc6\xaa\x2f\x48\xa6\xea\x0c\x57\x9d\x58\xb5\xbf\xe9\x1e\xaa\x96\x79\x48\xd6\xba\xd6\x28\xe9\x45\x0e\xd5\xda\xc8\x7b\x3b\xed\x5f\xd6\x84\xdc\xdf\xb8\x11\xbc\x1f\x7e\x25\x5f\x9a\x25\xed\x12\x58\xec\x76\xf4\x8b\x8d\x2b\xee\x4a\x87\xd6\xae\x55\x17\xf6\xbc\x62\x71\xba\xb0\xe7\x2e\xec\xf9\xe0\xc2\x9e\xf7\xae\xac\x64\x5c\xae\x02\x24\x32\xa5\xb3\x56\xe6\x3f\xbb\x3b\x1b\x12\x8d\x80\x14\x0c\xca\x71\x4c\xb2\x84\x2f\xc0\x92\xb2\xe2\x3a\x77\x5d\xdc\x2c\x49\xd4\x87\x7e\xa3\xbb\x91\xbf\x96\xce\x71\x28\x32\x69\x31\xef\x83\x90\x42\x4f\xfe\x59\x49\xe7\x6f\x85\x97\xc9\x10\xf9\x4c\x25\xdc\x4a\xeb\x09\x7b\xc4\xea\x9f\x04\xa5\x0b\xed\x3d\x38\xc9\x55\x90\xbb\x27\xb5\x60\x95\x11\xa1\x16\xc1\x9b\x24\xcd\xd4\xe2\xbf\x46\x8c\x2a\xef\x61\xa3\x33\xc6\x85\xe1\x6a\xfa\xe3\x39\x66\x71\x42\x84\xbe\x54\x5d\x3b\x11\x66\x8c\x2b\x10\x37\x60\x06\x31\x7a\xa2\xd8\x08\x27\xfd\x9b\x61\x6b\x3f\xf3\x3b\x3a\x5d\xaf\x5d\xac\x6e\xcd\x5d\xf7\x29\xe1\x13\xa8\x60\x99\x97\x75\x7a\xdd\x40\xe7\x19\x2d\xed\xdc\x5b\x31\x04\x85\xe5\x63\x15\x38\xa4\x9c\x85\x3e\x5e\x09\x25\xb2\xe6\xdd\x12\xc6\xfc\xea\x57\x2b\x70\x23\xe5\x67\x16\x80\x04\x1e\xc3\x90\xab\xe3\x70\x3f\x86\x1d\xba\xdf\x8a\x96\xdd\x2f\xae\x74\x37\xfc\x28\x88\x12\x8b\x31\x56\x4a\x33\x99\x7d\x62\x9c\xdc\x63\xf9\xd8\x1a\xe3\xa4\xf4\xf2\x81\xb3\x9c\x12\xc6\x49\x79\xe0\x2f\xce\x72\x5a\x52\xe7\x1a\xce\xf4\xfe\xf2\xe3\xdb\x9e\xb5\x0d\x26\xfe\x5b\xc9\x95\x6f\xc7\x7b\xd6\x99\x69\xdf\x63\xde\xfc\x2a\x66\x7a\x30\x23\xac\xf0\xf3\x2f\xf1\xe4\x96\x6f\xa7\xee\x88\xae\x5a\xa3\x2f\xae\x10\x6e\x45\xe8\x58\x33\xb7\x77\x52\x10\xb7\x2a\x37\xed\x7b\x54\x2f\x63\xe6\x0e\x76\x63\x93\x18\xa0\x61\x19\xad\xdc\x9f\x21\x17\x15\x54\x94\x9e\x9d\x43\xa2\x35\x95\x61\x42\x7c\xc4\x85\x91\xbc\x62\x7b\x66\x8d\xd9\xce\x80\xf9\x9e\xa2\x3e\x8a\x6d\x6d\x7e\x41\x32\x41\x24\x61\xca\xa8\xda\xa6\xde\x95\x2b\xef\x4f\x99\xb5\x10\x9d\x63\x85\xcf\xb0\xc2\x09\x9f\x1d\xa3\xbe\x2f\xec\x4f\x25\xc2\x89\xe4\x08\x3b\xc2\x21\xb1\x6b\x02\xb3\xd8\xb1\x07\x8c\x22\x9e\x66\x34\xf1\x48\xed\xde\x8a\x4f\x59\x4c\x9f\x68\x9c\xe3\xc4\x23\x63\x8f\xd8\xe0\x89\x30\x95\x83\x0a\x87\x93\x04\xd9\x6e\xdd\x0b\x81\x7e\xee\x46\x29\x69\x4a\x13\x2c\x90\xe2\x76\xb4\xd7\xb6\x2d\x74\x3f\x27\x7e\xac\x0e\x05\x1c\xa5\xf8\x91\x48\x44\x15\xca\xb8\x94\x74\x92\x14\xc7\xf8\x61\x88\x60\xdc\x67\x17\x43\x30\x8d\x46\x0a\x71\xc3\x07\x5d\xe7\xd6\x4f\xe0\x7a\x4c\x31\x63\x04\x3a\xe6\x6a\x4e\x84\xed\xde\xbe\xfc\xd6\x56\xce\xb7\xc6\x88\x6e\xb6\x98\x86\x23\x7b\x3b\xa5\xb3\xb5\xc6\xd9\x56\xdd\x6c\xa7\x6b\x36\x2b\x9a\x2f\xe0\xa5\x6d\xaf\x0d\x5e\x50\x59\x56\x07\xdf\x85\xcb\xb6\x34\xe2\xd7\xc0\x47\xfb\x8d\x2a\x82\x9d\x16\xf8\x22\xeb\xf6\xa5\xaa\x80\x07\xae\xff\x75\xc8\x6e\x1d\x8a\x7d\x17\x80\xb1\xc7\xc5\xe9\x02\x30\xba\x00\x8c\x2f\x36\x00\xa3\x59\x9b\xa0\xf1\xce\xe9\x7a\x1b\x56\x90\xf2\x46\x01\xf1\x0b\x88\x52\x58\x3e\xb6\xad\x29\xa5\x45\xe5\x61\xfc\x2e\xa4\xfa\xda\x09\xbf\x86\x74\xdf\xd5\x29\xda\x6b\x9d\xa2\x83\x9b\x76\x27\xf8\x75\x82\x5f\x27\xdb\xb4\x9c\x70\x27\xdb\x1c\xae\x6c\xf3\x56\x0a\xcb\x97\x04\xa1\xab\x85\xa7\x52\x66\xcc\xca\x00\x5b\x03\x47\x03\xee\x81\x3c\x4b\x38\x8e\xd7\x05\xe1\xfc\x82\x0a\xb9\x66\x85\x68\x66\xda\xd5\x1f\x1c\xb8\x64\xb6\x14\x7f\x63\x46\xfe\x5b\x88\xa9\x6d\x9c\xfa\x9b\x86\xd5\x02\xfd\x42\x30\x59\x29\x28\xed\xa5\xb4\x90\x2a\x4d\xb7\x52\x38\xe4\x1f\x0f\x9c\xaa\xfd\x96\xbe\x86\x7a\xf1\x05\x3b\x08\x3a\x27\xc0\x6f\xb3\xf0\xf9\xc1\x48\xad\x9d\x6a\xd7\x65\x55\x76\x46\xfd\x4e\xf1\xed\x14\xdf\xbd\x2f\xe3\x21\x29\xbe\x6f\x28\x51\x9b\x34\x91\x17\x29\x63\xb8\x9d\x6c\xdd\x89\xd6\x9d\x68\xdd\x89\xd6\x5f\xac\x68\x7d\x18\x2b\xdc\xc9\xd5\x9d\x5c\xdd\xc9\xd5\x9d\x5c\xdd\xc9\xd5\x7b\x5f\xc6\x4e\xae\xae\xc8\xd5\xf0\x97\x4b\x93\xde\x54\xc8\x6e\x2d\x5c\xb7\xc8\x89\x7e\x2f\x92\x75\x27\x55\x77\x52\xf5\x61\x4b\xd5\x07\x33\xa1\x2f\x2f\x11\xb2\x4b\x25\xec\x52\x09\xbb\x54\xc2\xb7\x48\x25\x74\xbc\x64\x95\x84\xb2\x2c\x58\xfc\xb8\xc4\x81\x0e\x56\xb6\x28\x46\xbb\x6d\x78\xc7\xbe\x96\xda\x01\xcd\x6f\x53\x69\xaa\xf4\x9b\x6b\xe8\x80\xea\x4f\xf5\x9c\xb4\xa0\x19\x85\x1b\xdf\x7a\x84\xb0\x9f\xec\x9b\xef\x0b\x0c\x7c\x79\xd4\x5d\xfd\x29\x14\xec\x5a\x57\x7f\xea\x05\xe7\xed\x0e\xd7\x9a\x99\x3b\x1a\x35\x36\xde\x77\x3a\xed\x37\x07\x97\x6b\x3e\xe9\x6f\x1a\x2e\x57\x7b\x93\x2c\x25\xef\x9c\xfc\xb3\xf6\xa2\x78\x83\xb2\x5b\x1b\xdf\x0e\x9f\x88\xfa\x52\xae\x86\xae\xec\x56\x57\x1f\x62\x4f\xd3\xdd\x8a\xf5\xbf\xdb\xd9\x76\x45\xc6\xba\x22\x63\x5d\x91\xb1\xae\xc8\x58\x57\x64\x0c\xfd\xc6\x8b\x8c\x6d\x2c\x3e\x9a\x71\x7c\x29\x12\x64\x57\x64\xac\x13\x22\xf7\x37\xdd\xdf\x96\x10\x79\x80\x16\x84\x83\xa8\xa6\xe6\x2d\x08\x6f\x8e\xfb\xe1\x46\xd2\x16\xfb\xc3\x2d\x68\x87\xff\x61\xff\xaf\xc3\xff\xe8\xf0\x3f\x1a\x66\xdd\x05\xb3\x76\xf8\x1f\xa8\x0b\xd7\xec\xc2\x35\x0f\x39\x5c\xb3\xc5\x36\x76\xf8\x1f\x2d\xc5\xb9\x17\xc2\x00\x71\x32\xd7\x46\x38\x20\x3f\x2d\x2b\x1a\x07\x2b\xa5\xb9\xb1\xfe\x76\x70\x40\x6a\xa7\x7d\x10\x2a\xc9\x2b\xe2\x80\xd4\xd1\x75\x6b\x05\xe4\x7d\xe0\x81\xb8\xd1\x76\x89\x8b\x5d\x88\xf5\xe1\x87\x58\x1f\x5c\xe2\xe2\xc1\x48\xb2\x9d\xba\xd7\xe5\x2e\x76\xb9\x8b\x9d\x32\xdc\x29\xc3\x7b\x5f\xc6\x43\x52\x86\xdf\x58\xc2\x7e\x41\x5c\x90\xdd\x64\xed\x4e\xd4\x36\xef\x75\xa2\x76\x27\x6a\x7f\xa1\xa2\xf6\x61\xac\x70\x27\x67\x77\x72\x76\x27\x67\x77\x72\x76\x27\x67\xef\x7d\x19\x3b\x39\xfb\xd5\x70\x42\xea\x84\xed\x96\xf9\x36\xef\x49\xd2\xee\xa4\xec\x4e\xca\x3e\x6c\x29\xfb\x60\x26\xd4\x61\x86\x74\x98\x21\x1d\x66\x48\x87\x19\xb2\x95\x7c\xf3\x6f\xf6\x58\x7e\x08\x6e\x62\x7f\x65\x7f\xf8\x2e\xe1\x93\xfb\x45\x46\xf4\x7f\xcf\x69\x4a\x98\x04\x69\x94\xaa\x45\x28\xcf\x34\xac\xfc\xf2\x9a\x7f\xb8\x1b\x5e\x7d\xba\x08\xb3\x69\x3e\x5c\x3e\x5c\xdc\x0f\x6f\xfa\xb7\x7e\x5d\xfc\xac\xc2\xb5\xb0\xdf\x95\x44\x32\x4b\xf2\xb7\x44\xeb\x9e\x70\x6a\xee\x14\x56\xb9\xdc\x6e\x64\xb7\x83\xbb\xc1\xed\x8f\x90\x0d\x34\x3e\x1f\xde\xf5\xbf\xbb\x28\x11\x44\xe9\x79\xff\xec\xaf\x0f\xc3\xdb\xe6\xe7\x83\xff\x1e\xde\xdd\xdf\x35\x3d\xbd\x1d\x5c\x0c\xfa\x77\xcd\x5f\x7f\xec\x0f\x2f\x1e\x6e\x07\x2b\xd7\x63\xe5\x68\x57\x2b\x21\x12\x16\x09\xe2\xfc\x51\x64\xb9\x86\x28\xd6\x10\x79\xf1\xd1\xb1\xc3\xba\xbe\x4e\xd1\x83\xd5\xe9\xa9\x6d\xdc\x30\xd8\xa0\x21\xa3\x8c\xc4\x54\xe2\x49\x42\xe2\xa5\x96\xdc\x1a\x36\xb5\x84\x4b\x83\x7a\xd6\xda\xb3\x17\x39\x35\xcf\x8b\x0c\x2f\x40\x90\xa3\xa8\x08\x8b\x6b\xfa\x30\xfb\xd0\xd8\x03\xd3\xbc\x8b\x3e\x91\x52\x4f\x51\x2e\x04\x61\x2a\x59\x20\xf2\x99\x4a\x25\x97\x1a\x75\xdb\xd7\xd4\xac\xbd\x53\x7d\x83\x73\x2c\xd1\x84\x10\x56\x1e\xbf\x20\x09\xc1\xb2\x66\xcc\x76\xf7\xdb\x2d\x8b\xdf\x2b\x6b\x8d\x31\x97\xd1\x14\xd3\x24\x17\xa4\x72\x5a\x78\x9a\x61\x41\x25\x67\x83\xcf\xfa\x2e\xd3\x07\xf9\x1a\x3e\xe7\x62\xbb\x13\x33\xf8\x6b\x48\xc1\x57\xe5\x7f\x7e\xba\x2f\xff\xab\x74\xe6\x2f\xee\xcb\xff\x5a\x4d\xeb\x41\xc3\x55\xca\x3e\x42\x9f\xee\x4f\xd1\x27\x08\x71\x12\xe8\x7e\x8e\x0d\xc5\x5e\xdc\x9f\xa2\x0b\x22\x25\xfc\x52\x7c\xac\xa8\x4a\x60\x6e\xdf\x51\x86\xc5\x02\xb9\xe9\x9b\x44\x57\x1c\xcd\x11\xf1\x4b\x53\x5d\x3c\xf6\xf7\x9c\x81\xea\x5e\xac\xde\x05\x9f\xd1\x08\x27\xbb\x2d\x62\xff\xaa\xc4\x07\xae\x6f\x57\x2e\x45\xf8\xf6\xf2\x5a\xf4\xaf\xce\x21\x89\xd4\x0d\xb5\x66\xe6\x57\x44\x6a\x22\x89\x38\x8b\xad\x97\x46\xdf\xfe\x8b\x40\xa8\xff\x3b\x87\x44\xdc\x5c\x52\x36\xd3\x2d\xa2\x13\x74\x7d\x3b\x62\xd7\x22\x36\x86\x50\xa2\xa5\x61\x43\x73\x54\x22\xc6\x15\xa2\x69\xc6\x85\xc2\x4c\x69\x45\x00\xc4\x00\xbb\x22\x86\x03\x9c\xf1\x34\xcd\x15\xd6\x07\x6d\x69\x51\x99\x31\x87\xdc\x11\x35\x8c\xc1\xb5\x52\xb3\x86\x46\x4e\x28\xe6\x92\x09\xdd\xbe\x96\x51\xca\x3a\x34\x8d\x97\x54\x59\xd7\x04\x16\x02\x97\xa5\x89\x0f\x54\x91\xb4\xfa\x7e\xcb\x20\xcf\x7f\xd5\x1a\x08\xce\x4c\x52\x05\x11\x7d\x11\xcd\xa9\x22\x91\xd2\x47\x70\x2b\x9a\x78\xb8\xfa\xe1\xea\xfa\xa7\x50\x82\xf8\xd0\xbf\x3c\xff\xf3\x7f\x94\x7e\xb8\xbd\x5c\xfa\x61\xfc\xe3\x9f\x97\x7e\xf9\xff\xad\xa4\xa7\x6a\x4f\x4b\x7a\x7e\x30\x97\x23\x10\xa9\xc1\x26\xec\xa6\x8a\x68\x8a\x67\x04\xc9\x3c\xd3\x14\x20\x8f\xcb\xfb\xab\x45\xca\x0b\x8e\x63\xca\x66\x26\x03\xf4\x82\x2a\x22\x70\x72\x89\xb3\x8f\xce\x7e\xbd\xc5\xea\xfc\xdf\xbb\x52\xbe\xee\x87\x9f\xfb\x97\x61\xc6\xef\x87\x9b\xdb\xeb\xfb\xeb\x95\xb3\x2e\xb5\xb0\x7c\x8c\xf4\xe3\x53\xf8\x5f\x74\x82\x74\xeb\x5e\xf2\x4d\x89\xc2\x5a\x23\x40\x5f\x9b\xa4\x39\x9f\x48\x43\x59\x02\xa7\x26\x13\x34\xa5\x70\xa5\x18\x0b\xde\x37\x46\xb8\xf6\xda\x83\x3f\x37\xe6\x03\xd0\x96\xdd\xa5\xcc\x62\x2c\x62\xf4\x77\x59\x4d\x1f\x07\xc3\xb1\xf9\x81\xc4\xe8\x08\xcd\x95\xca\xe4\xe9\xc9\xc9\xf3\xf3\xf3\xb1\x7e\xfb\x98\x8b\xd9\x89\xfe\xe3\x88\xb0\xe3\xb9\x4a\x13\x93\x2e\xaf\x57\xe1\x14\xdd\x08\xae\xaf\x10\x50\xd0\x89\xa0\x38\xa1\xbf\x92\x18\x4d\x0c\xff\xe3\x53\xf4\x4b\xc4\x05\x39\x2e\x36\xc6\x1a\x95\xec\x3d\x62\x0d\x4f\x27\xfa\xa5\x1a\x66\x52\xdd\x4f\x14\x93\x88\xc6\x56\xcc\x20\x2c\xe2\x60\x79\x34\xbe\x0a\xdd\x9e\xcb\x34\xd4\x1a\x4d\x96\xab\x62\x39\x03\x65\x05\xc7\x24\xc8\x76\x57\xbc\x4c\x70\x5a\xf1\x19\x1a\xb5\x35\xd7\x2a\xba\xbe\x5b\x31\xdc\xaa\xee\xd5\x4c\x4f\x38\xe2\x09\x9a\xe4\xd3\x29\x11\xa1\x43\xba\xa7\xb5\x19\x2a\x91\x20\x11\x4f\x53\x90\x18\xf4\x57\xb9\x34\x54\x0d\x2b\x66\x47\x7b\x3c\x62\xb0\xff\x5a\xcd\x01\x0a\x88\x39\xb0\x3a\x46\x48\x8c\x30\x5b\x98\x6e\x26\xf9\x34\x6c\xdf\xc0\x50\xe0\x18\x51\x35\x62\xfd\x24\x41\x82\xa4\x5c\x91\x20\x87\x12\x9c\x67\xe5\x05\x07\x16\x29\x48\x96\xe0\x88\xc4\x86\x1e\x12\x1e\xe1\x04\x4d\x69\x42\xe4\x42\x2a\x92\x86\x0d\x7c\x0d\xb6\x1a\xbd\x66\x54\xa2\x98\x3f\xb3\x84\x63\x3b\x8f\xea\x67\xdf\x94\x4f\xe3\xc0\x41\x04\x0c\x84\xe0\x02\xfe\xe7\x07\xca\xe2\xbd\x71\xa8\x87\xbb\xc1\x6d\xf8\xef\xbb\x9f\xef\xee\x07\x97\x9b\x71\x1f\x4f\x59\x30\x3c\xd0\xe1\x4f\xd1\x9d\x59\x04\x2e\xb4\x44\x24\x1a\x26\x75\x69\x49\xa9\xf8\x81\xc7\x5b\x72\xdf\xcb\xfe\xd5\x43\xbf\xc4\x51\xee\xce\xbe\x1f\x9c\x3f\x54\xf4\x01\x3b\xbf\x92\x0c\x6f\xd4\xbf\xf0\xb7\xb3\xef\x87\x17\xe7\xe3\x1a\x85\xf1\xc3\xed\xe0\xec\xfa\xc7\xc1\x6d\xa1\xdb\xd5\x2e\x51\x65\x30\x55\x66\x75\x6f\x98\xd2\x9c\xc7\x68\xb2\xa8\x07\x84\xd0\x92\x73\x02\xbe\xd8\x02\x12\xc5\xb4\x7a\x0a\xbc\xc9\x61\x73\x14\x5f\xa4\x3c\x26\x3d\xfb\x0e\x20\x69\x18\xe3\x8a\x91\x98\xeb\x1b\xd6\xbd\x63\x16\x18\x2a\x0c\xc8\x85\x5f\xb8\x53\xd4\x47\x52\xbf\x98\xeb\x43\x2d\xe8\x6c\x06\x86\xc3\xca\x50\x4d\x6b\xf6\x53\x58\x5e\xf8\xce\xec\x7f\x26\x38\x9c\x73\xdd\xad\xb5\x38\x7b\xab\x84\xf9\x10\x50\x57\xca\x2d\x0a\x0c\x06\x87\x9a\xa1\xb9\xcd\xd2\x8b\xd0\xb8\x5e\xe6\x3c\x1a\x7b\x91\x3e\x5c\xc0\xb6\xa4\xb1\x77\x66\x82\x3c\x51\x9e\x07\x9f\x5a\x60\x8f\xd2\x8e\xd7\x36\x5f\x2c\x00\x2c\x9b\x31\x8a\x54\x9a\xf1\xe4\x51\xdb\x82\x66\x61\x4f\xd0\xc2\x54\xf0\xb4\xa6\x8d\xf2\x31\x19\x5e\xdf\x29\x81\x15\x99\x2d\xce\x2d\xcb\xd8\xfe\x78\x9c\x5f\xff\x74\x75\x71\xdd\x3f\x1f\x0f\xfa\x9f\xca\x27\xde\x3f\xb9\xbb\xbf\x1d\xf4\x2f\xcb\x8f\xc6\x57\xd7\xf7\x63\xf7\xc6\x4a\x92\x6f\xe8\x60\xf9\x9e\x2e\xbf\x78\x8a\x34\xcb\x05\xd6\xe8\x00\xef\x02\xfe\x38\x21\x53\x2e\x0c\x9f\x4f\x5d\xe8\x82\x15\x61\xdc\xda\x5a\x5d\xac\x32\x8b\x53\xb0\x8c\xd5\x35\x69\xac\xde\x4a\x10\x9c\xc2\x3d\x81\x19\x1a\xb0\xf8\xe8\x7a\x7a\x74\x67\x7e\x4c\xb1\x78\x24\xc2\x7f\xfa\x2c\xa8\x52\x84\x95\x54\x3a\xec\x86\xec\x95\xc4\xa2\x83\x63\x74\xab\xf9\xbe\x7e\xdf\x5f\x6a\x9a\xd8\x63\xa2\x30\x4d\xa4\x1d\x6c\x69\x5d\x4f\xd1\x05\x16\xb3\xc2\x0e\xf7\x35\x9f\x4e\x4d\x63\xdf\x98\x61\xe8\x3b\xac\x34\x8b\x1a\xde\xab\x49\xc3\xdd\x8b\xd0\x9f\x7d\xd9\xcb\xc3\xcb\x54\xf5\x90\xed\x46\x53\x0f\x37\xb0\xe2\x46\x63\x2f\xe9\x86\xf6\x49\x0d\xad\xc1\xc4\xcd\xe3\xd5\x97\x4c\x7d\xdb\xcb\xe4\x54\x7e\xb1\x86\x9c\x4c\x2e\x95\xde\xf9\xa9\xd6\x36\x6b\x68\x89\x7c\xa6\xd6\x60\x10\x8e\xbb\x42\x42\x45\x33\x60\x5e\xc5\x59\x46\xb0\x90\x75\xbb\x5d\x16\x03\x1b\xf6\xde\xf4\x14\xf6\x61\x37\xd9\xf5\xd3\x43\x9c\x81\xc1\xc1\x0b\x11\x15\x8a\x6c\x41\x03\xa6\xad\x25\x0a\xb8\x01\xb4\xa5\x6b\x8b\x6c\x74\x49\xa5\x56\x1a\xcd\x8f\xdf\x59\xc8\xa5\xed\x08\xe2\x63\x7f\x78\x51\x11\x2e\xc6\xe7\x83\x8f\xfd\x87\x8b\xd5\x66\xc2\xd2\x77\xd5\x2d\x46\x47\x48\x3f\x2f\xfb\xcd\xe9\xd4\xdc\x19\x0e\x38\xca\xa8\xb4\x84\x81\xd1\xca\x42\xd5\x18\x7b\x75\x4c\xb2\x84\x2f\x52\xc2\xc0\xc4\x53\xba\x09\xf5\x7a\x4e\x31\xb5\x57\x4b\x30\x58\xb0\xe2\x58\xb3\x1b\x5c\x63\x47\x0e\xad\x8a\xc4\xfe\xe6\x2d\x83\x55\x55\x58\xf7\x8d\xf1\x9e\xd9\xff\xdc\x29\xac\xb6\x3c\x63\xfd\xb3\xfb\xe1\x8f\x83\xb2\x7e\x78\xf6\xfd\xf0\xc7\x3a\xa9\x66\xfc\x69\x70\x35\xb8\xed\xdf\xaf\x11\x4e\x2a\x4d\xd6\x09\x27\x52\x0f\xb8\xea\x3d\xa5\xd2\x47\x04\x45\x06\xf2\x0a\x51\x25\xd1\x13\x95\x74\x42\x01\x20\xcc\x7a\x22\x1f\x86\xc0\x59\x9f\x70\x42\x63\xaa\x16\x4e\x7c\x31\xfd\x96\xf7\x51\x73\x52\xdb\xbe\x31\x3b\x84\xfe\x49\xb0\xf2\x99\xcd\x71\x93\x3e\x45\xa0\xdb\x3e\x81\xd2\x16\x7c\xc6\xb4\x20\xcd\x66\x44\x98\xe1\x80\xf7\x25\x1c\x4b\xf0\x5c\x8f\x2a\x14\x56\x8a\x55\xf3\x42\xeb\x8c\x30\x22\x00\x04\xce\x77\x62\x04\x29\x41\xd8\x57\x5a\xe6\xca\x12\x1a\x51\x95\x2c\x50\x04\x36\x2c\x30\x67\xa6\x98\xe1\x99\x15\x0e\x40\xcd\xa9\x90\xc4\x5f\x0d\x8a\xda\xf5\xd4\x9a\xf6\xef\x29\xd9\xf2\x98\x3d\x5c\x9d\x0f\x3e\x0e\xaf\xca\x24\xf0\xfd\xf0\x53\x49\x84\xbd\x1c\x9c\x0f\x1f\x4a\xb7\xb9\x96\x64\x57\xcb\xf5\xd5\x66\x6b\x8e\xa2\x7f\xe9\x14\x9d\x9b\x4f\x4f\xf5\xe2\xd6\x40\xc4\x79\xe5\xb7\xb2\x0e\xb7\x2e\x24\xcf\xfd\x31\x60\x4a\xd4\xfa\x25\xda\x9a\x90\xac\x0f\xb2\x64\x43\xaa\x0f\x55\x58\xea\xfb\xaa\xea\x54\xae\x4e\xd9\xbd\x08\x41\x97\xc7\x85\x65\x29\x8c\x61\x00\xa3\x41\x93\x11\xab\xc6\xad\x55\x30\xec\x1f\xc1\x45\x9d\xe6\x52\x19\x57\x22\x10\x27\x7a\xfc\x8b\xd4\x0b\x0a\xae\xc6\x63\x74\x47\xc8\x88\x39\xeb\xc1\x8c\xaa\x79\x3e\x39\x8e\x78\x7a\x52\xe0\x13\x9e\xe0\x8c\xa6\x58\x4b\xd2\x44\x2c\x4e\x26\x09\x9f\x9c\xa4\x58\x2a\x22\x4e\xb2\xc7\x19\x44\xc0\x38\x77\xea\x89\x6f\x76\xc6\xff\xfd\xe2\x4f\xdf\x1e\x5d\xfc\xe5\xdb\x0f\xcb\x16\xb2\xa6\xfd\x1f\xb0\x08\x67\x32\x4f\x6c\xc4\x9c\x08\xd7\xc6\x1d\xf9\x9c\xac\xdb\xef\xab\xf2\x76\xed\xa6\xbf\x9e\xdd\x3c\x94\x2c\xd6\xe5\x7f\x5e\x0e\x2e\xaf\x6f\x7f\x2e\x71\xca\xfb\xeb\xdb\xfe\xa7\x12\x43\x1d\xdc\x7c\x3f\xb8\x1c\xdc\xf6\x2f\xc6\xee\xe1\x2e\xb6\xb7\x1f\x18\x7f\x66\xe5\xa5\x91\x8e\x03\x2e\xf5\x74\x8a\x3e\x72\x81\x7e\xf0\x3b\x79\x34\xc1\x12\xae\x18\x77\x67\xc9\x1e\xca\x78\x0c\x8c\x17\x91\x6c\x4e\x52\x22\x70\x62\x6d\x06\x52\x71\x81\x67\xe6\xa6\x97\x91\xc0\x2a\x9a\x23\x99\xe1\x88\xf4\x50\x04\xd4\x30\xeb\xc1\xa6\x80\xaa\xc5\x67\x55\x3b\xdf\x6d\xce\x14\x4d\x89\x53\xc1\xed\x3f\xef\xcd\x66\x6c\xb1\x39\xd7\xf7\xdf\x97\x85\xbd\x8f\x17\x3f\xdf\x0f\xc6\x77\xe7\x3f\xac\x5c\x4f\xf3\x59\x69\x64\x77\x10\x80\x74\xc6\x93\x3c\x65\xe1\xdf\xdb\x8f\x6d\x78\x75\x3f\xf8\x54\x1d\xdd\x75\xff\xbe\x4c\x19\xb7\xe5\x00\xb7\x0f\xdf\x5d\x5f\x5f\x0c\x4a\x2e\xe1\x0f\xe7\xfd\xfb\xc1\xfd\xf0\xb2\x44\x3f\xe7\x0f\xb7\x06\x8d\x70\xd5\x34\xdd\x08\x6a\x26\xaa\xa7\x15\x4e\x73\xdf\xac\xb0\x15\x27\xea\xdb\x80\x72\x73\x96\x8f\x02\xb8\x1d\x13\x0e\x06\x56\x9d\x23\x6f\x52\x8d\xcc\x48\x6b\xd9\xa1\x2a\x6f\x13\x6a\x66\xc7\x2b\x37\x7a\x15\x57\xbe\xf7\x43\x30\x50\xa0\x46\xd9\xc6\x49\xc2\x9f\x4d\x28\x6f\x4a\xf5\xad\x6c\x81\xd1\xf4\x2b\xb2\xf0\x10\x1e\xd7\x70\xbc\xf2\xb6\x90\x48\x10\x75\xc9\x73\xa6\xb6\x27\xb9\xfe\x55\x89\xef\x0c\xae\x7e\x1c\xff\xd8\x2f\x53\xe0\xf0\x62\x35\xab\x09\x9b\xa8\xb9\x8a\xfb\x57\x3f\xfb\x4b\x18\x02\xbe\x7b\x5e\x43\x35\xb2\x6b\x94\x50\x2d\xf6\x46\x58\x6b\xaf\x09\x48\x34\x88\x50\x30\x39\xa4\x7a\x72\x10\x60\x9a\x19\x7f\x92\xe1\x4f\x66\x90\xa7\xee\x8f\x4a\x7b\x12\xd6\x05\xac\xa9\x2e\x9e\x1e\xda\xb1\x5a\x35\x43\x84\x3d\x51\xc1\x01\xcf\x16\x3d\x61\x41\xb5\x34\x6e\x5a\xd6\x73\x3d\x85\xff\xdd\xac\x4d\x30\x8c\x56\x18\xd7\x1d\x17\xea\xdc\x07\xf2\x6e\x67\x0d\xa9\x0b\x68\x5d\x0e\x65\xad\x37\x74\x2c\x7f\x5b\xb3\x39\x3b\x06\xfc\x96\x27\xfc\x8f\xe4\x9c\xe2\x44\x33\x80\xfd\xc9\x8b\xfd\xab\xbb\x61\x59\x7e\x2c\xab\x19\x01\x5f\xde\x5a\x5e\x04\x43\xa5\x19\xb9\x53\x26\xee\xfe\x7a\x61\xb4\x0b\x00\x3d\x36\xe7\x36\x50\x2c\x40\x00\x72\x28\x28\x19\x16\xb2\xf2\x85\x44\x00\x84\x56\x04\x5c\xe9\x3b\x0b\xc2\x99\x9e\x38\x8d\x47\x8c\x7c\xce\x08\x93\x10\x1c\x60\xee\xb3\xc2\xd7\x2e\x8f\xd1\x70\x0a\x2c\x41\xbf\xce\x50\xce\xac\x03\x4c\x5f\xb8\x66\x90\x3d\x2d\xca\xda\x21\x78\x0d\x11\x0c\x2f\x8c\xb8\x60\xa9\x62\xf0\x23\xf6\x93\x77\xa2\xc1\xa3\x29\xd7\x0c\x48\xef\xa2\x6d\xef\x14\x61\x26\x69\x0f\x69\x85\xa5\xba\xa7\x90\x3a\xa0\x15\x4a\x1b\xc2\xa5\x39\x8d\xfd\xf3\xf5\xaf\x81\xa5\x38\xe1\xf0\x32\xa8\xbf\x0b\x2a\x57\x41\x83\x68\x9c\x18\x8f\xc9\xb8\xfd\x9d\x10\x71\x41\xac\x9f\x65\xe3\x6b\x60\x1d\x63\xbf\xc7\xf2\x71\xc9\xf7\x30\x64\x52\x61\x16\x91\xb3\x04\xcb\x2d\x83\x90\x9c\x8d\xa3\x57\x96\x38\x6e\x6f\x1f\x6e\xee\x87\xdf\xad\xe1\xf2\xd5\x8f\x97\xc3\x80\xa2\x24\x77\xee\xb9\x89\xe0\x38\x46\x9a\x7d\xce\xb8\x71\x05\x5a\xc1\xbf\x80\xfe\x36\x79\x3d\x3e\xa0\xb2\x04\x3b\x5e\xa4\x23\x58\x3b\x47\xe8\x4a\xa0\x76\x21\x50\xa4\x57\x02\x05\x26\x0f\xb7\xd5\xe0\x59\x34\x05\x49\xac\x75\x2b\x4b\xb0\x9a\x72\x91\x1a\x2e\x5f\x9a\xb4\x69\x7c\x75\xa3\x94\x29\x22\x44\x9e\x29\xea\xb0\xdc\xab\x52\x2a\x54\x78\xe7\xb3\x4b\x22\x25\x9e\x91\x5d\x1c\xd0\x75\xca\xc3\xdd\x8f\xe1\x3f\xc1\xc1\xdc\x46\xf6\x2f\x8d\xd0\x45\xbe\x3b\x7a\xba\x66\x1f\x4d\x20\xcf\x0d\x4f\x68\xb4\x65\xc0\xdd\xc7\xfe\xf0\x62\x3c\xbc\xd4\x4a\x7c\xff\x7e\x70\x51\x12\x25\xe0\x59\xff\xe3\xfd\xe0\xd6\x82\x58\xf7\xbf\xbb\x18\x8c\xaf\xae\xcf\x07\x77\xe3\xb3\xeb\xcb\x9b\x8b\xc1\x9a\xc8\x9c\xc6\xc6\x97\xad\xab\xd5\x57\x4f\x97\x7e\x81\x1d\xd6\xbc\x2c\xb4\x97\x41\xd6\x18\xa6\x09\x38\xc1\xb9\x71\x86\x63\xc4\x78\x4c\xe0\x67\xe9\xac\x33\x1e\x39\x1a\x0d\xd5\x57\x49\x82\x70\xae\x78\x8a\xc1\x6b\x93\x2c\x46\x0c\x4f\x34\x6b\xc5\x49\x12\x84\x77\x89\x9c\x31\xcd\x62\x75\x63\x06\xa2\x3d\x4a\x88\x66\xe7\x59\x90\xec\x67\xfd\x06\x53\xca\x20\xd2\x36\xc5\xe2\xd1\xb8\x99\x8a\x2e\x8b\x43\x21\x11\x96\x23\xa6\xc7\x45\xac\x61\xa8\xcd\x0a\x9f\xb6\x7a\xab\x71\x75\x52\xfc\x48\xf4\xaa\xa4\x79\x34\x47\x99\xe0\x33\x41\xa4\xb4\xb6\xe5\x08\x33\x13\x80\x60\x5f\xd7\xd7\xd0\x88\x31\xae\x97\xc2\x99\xb0\x63\x92\x11\x16\x13\x16\x51\x93\xd6\x07\xbe\x7b\x6f\xda\x9c\x09\x9c\xcd\x91\xe4\xe0\xf4\x86\x65\x07\xfb\x95\xf9\xc8\xdd\x64\x66\xc6\xe6\x71\x68\x81\x16\xb9\xe6\x13\xd7\x20\x27\x9a\x55\x86\x8f\xdd\x65\xe8\xdc\x2e\xc6\x0e\x98\x66\x09\x51\x06\xac\x1f\x96\x1c\x36\x43\xaf\x75\x69\x3f\xf4\x36\xd5\x6d\x82\xbe\xb0\xdd\x98\xb1\xb4\x23\x3a\xae\xb1\x6c\xdb\x23\x85\xbe\xc7\x2c\x4e\x74\x2b\xce\x87\x51\x3e\x8b\x90\x8a\xd2\xd7\x54\xe3\x4e\xe3\x2e\xb7\x68\x84\x73\xb9\xcb\x35\x5a\xc9\xc5\x34\x56\xc1\xa3\x22\x28\x04\xc8\xdb\x26\x62\xc2\xea\x66\x9a\x45\xe2\x84\xdb\x55\x32\xaf\xe7\xa6\xfe\x13\x82\xd1\x34\x5c\xb3\x99\xa0\x2c\xa2\x19\x4e\xb6\xd2\xfd\x2a\xc1\xf8\x36\xc6\xfd\x6b\x3a\xd5\xe4\xf3\xcd\x92\xdb\x56\x11\x91\x42\x82\xb2\x1d\xa6\xdf\xc2\x0d\x2c\x49\x36\xab\x81\xc8\x22\x9a\x04\x0b\x9e\x1b\x7f\x1c\xac\x0b\x89\x6b\x8e\xea\x71\xdd\x76\xeb\x93\x81\xcb\x01\xd0\x5b\x6c\xb6\x89\xfc\x69\x5a\xbf\x4a\x2b\xb6\x77\x13\x8c\x87\x93\x9b\xfa\x36\xeb\x76\x20\x78\xf8\xaf\x55\xb4\x73\x89\x33\x4d\x33\x16\xb6\x1f\x17\x73\xb4\x4a\x92\xad\x0a\xe6\xe2\x67\x02\xdf\xb9\xcf\x0b\x69\xbf\x1b\xc5\x12\xda\x00\xa8\xe5\x4e\x4a\x31\x04\x41\x8e\xb9\xa5\xf1\x69\xae\x65\x59\x84\x21\x0a\x01\x7d\x4d\x8e\x67\xc7\xc8\x15\x61\xe8\xa1\xfe\xcd\xcd\xe0\xea\xbc\x87\x88\x8a\xbe\x71\x31\x8b\x36\x60\x69\xc4\x14\xb7\xd2\xca\xc2\x15\xd0\x48\x89\x98\x91\xd2\x9c\x5d\x74\x13\x84\x2a\xcf\xa8\x54\x36\x7c\x56\xf3\x95\xa0\xd4\x09\x4d\xab\x62\xb6\xa1\x90\x5c\xcd\x77\x21\x0d\x2c\x65\x9e\x6a\x5d\x76\x4c\x71\x3a\x16\x3c\xd9\x85\x29\x9c\xc3\x54\x40\x5d\xf6\xe9\xf9\x14\xa7\x48\x37\x6b\x43\x41\xbc\xcb\xd1\x8b\x74\x5a\x30\xd2\x7c\x59\xdf\x9b\xc1\xbd\xe5\xbc\x0f\x36\x1e\x8d\xba\x10\x08\x48\xdf\x6f\x60\x15\x85\xd9\x78\x6c\x2d\xf5\x63\x1c\x45\x5a\xe5\xde\xf3\xa4\x82\xfa\x39\xce\x25\x60\x3b\x7a\xb1\x69\xae\xa3\x73\x37\xcc\x4c\x73\x30\x08\x06\xd6\x57\xae\xe4\x11\x2d\xda\xaf\xe9\x77\xb2\x58\xea\xd5\x55\xb8\x79\x90\xde\xa4\x62\x2e\x61\x49\x60\x27\xa5\xa9\x90\xa3\xe6\x64\x81\xe6\xf8\x89\x94\xba\x74\x09\x31\xba\xe1\x05\xcf\x45\x1d\xa3\x1b\xb1\x73\x92\x09\xa2\x25\xfd\xaa\x03\xc5\xd3\xf4\x6d\x99\x12\x3b\xba\xee\xe8\xfa\xdd\xd3\xf5\x99\x29\x94\xd4\xf7\x85\xb1\x76\x12\xe0\x4c\x63\xe3\x8c\xf3\x64\xdc\xc2\x26\xd2\x7e\xc5\x4b\x9e\xb0\x4a\xd9\x28\x80\x04\xe0\x39\xc8\x47\xa5\x6b\x93\xeb\xbb\x2e\x48\xb1\xb5\xc3\x5b\xb1\x0c\xce\x65\x16\xd4\xcb\xd9\xe5\xbc\xd7\xb5\xb2\xaa\x25\xf4\xe2\x62\xce\x99\x91\x6f\xbc\xbb\x2c\xac\x7f\x5a\x3a\x4c\x4e\x14\xa1\x6c\xa9\x1a\x9b\xa1\x67\xbd\xc0\x46\xee\xf8\x47\xce\x15\x96\xdf\x1c\x8f\x98\x16\xa2\x1e\xc9\xc2\x98\x5b\xb5\x98\xf2\x3b\x2d\x8b\x1f\x49\xc2\x24\x84\x7b\xff\xce\xb8\xe7\x34\x89\x3b\x73\xb5\x51\x4d\x4d\x11\x38\x08\xba\xf6\xbd\x40\x88\xae\x6d\xd4\x4a\x49\x45\x00\x34\xc8\xf9\x66\x2e\xf6\x99\x19\xfe\x8c\x28\x48\xb1\x56\x54\x81\xce\x14\x9b\x2a\x73\x4b\x43\x5f\x6b\xba\x32\x54\x21\x38\xf8\x49\xe2\x7c\x37\xc6\x2f\x97\xdb\x58\xcb\x19\xbd\xb6\x70\x67\x63\xde\x4f\x9c\xdd\x28\x12\x7c\xa9\x74\x1b\x96\xc8\xec\xf4\xc4\xb0\x03\xe7\xbf\x26\xec\xf8\x99\x3e\xd2\x8c\xc4\x14\x43\x04\xbc\xfe\xd7\x89\x9e\xd7\xbf\x9f\xdd\x5e\x5f\x8d\x8b\x4c\x9e\xff\x1a\xb1\x7e\x22\xb9\xcf\x52\x40\x8c\x33\x1f\x6e\x9f\x09\xe2\x44\x42\x3b\x17\xb0\xba\x16\x66\xc4\x11\x6b\x1a\x41\xcc\x23\x79\x8c\x9f\xe5\x31\x4e\xf1\xaf\x9c\x81\x2b\xbd\x0f\x7f\x9e\x25\x3c\x8f\x7f\xc2\x2a\x9a\x9f\xc0\xb9\x56\x27\xe4\x89\x30\x65\xdc\x54\x7a\xb9\x62\x48\xde\x95\x10\xad\xff\xef\x7a\xcc\x45\x52\x91\xd4\x9a\x6c\x44\x32\x85\xfe\x1f\x41\x26\x9c\xab\xfa\x4b\x8a\x4f\xa7\x92\x6c\x74\x21\x15\x4a\xda\xdd\x35\xfa\xcb\x9f\xbf\xfd\x83\x26\xa1\x6d\xd6\x78\x78\x77\x3d\xd6\xdf\xff\xfb\xb9\xfd\x5e\x6e\xc0\xee\xae\xb3\x82\xb5\x39\xe2\x31\x81\xf3\x39\x83\xdb\x4f\x80\xf3\x02\xd8\x1b\x90\x43\xb1\x8f\x75\xdc\xed\xbc\xd4\xfa\x6e\x2a\xdb\x56\x8b\x09\x2a\x76\x30\x47\x74\x84\x18\x47\xa9\x89\x35\xc5\x0c\xfd\xc7\x0f\xdf\xd5\x6f\x60\x2e\xe8\x56\x1d\x52\x0b\xd7\x10\x74\x29\xe9\xaf\x44\x22\x4d\x35\x9a\x8a\x79\xaa\xbb\x16\x44\xce\x79\x12\xa3\x67\x02\x6a\x92\x8d\x03\xf5\x5a\xb9\x20\x23\x16\x36\x01\x21\x87\x08\x27\x8a\xcf\x08\xdc\xd5\x4e\x51\x53\x44\x68\x51\xc5\x64\x69\x28\x2e\x48\xcf\x40\x7d\xdd\xfd\xc9\xc5\x56\xc3\x34\xe1\x91\x4b\x6a\xb1\x26\xb9\x78\x52\x3f\xf3\x69\xd5\xf4\x8a\x9a\x6d\xf8\xd5\x4d\xb6\x66\xdb\xfa\xa5\xb1\x49\x28\xd6\x86\x55\xdd\x99\xfa\xc1\xd0\x88\xb3\x71\x42\xd9\xe3\x56\x9b\x71\xed\x44\x39\xdd\x82\x5d\x33\xdd\xa2\xb7\x73\x1b\x0b\xc8\x06\xe7\xe3\x63\x9e\x24\x26\xb5\x25\xdc\x1e\x90\xbb\xcc\xba\x81\x30\x90\x99\x1c\x50\x12\x5b\xbf\x97\xd5\x84\x05\x61\x10\xf0\x36\x62\x93\x85\xf5\xd9\xca\x1e\x92\x79\x34\x77\x99\x79\x11\x67\x52\x8b\xd1\x5c\xa0\x88\xa7\xa9\x29\x6e\xca\x08\x52\x9c\x27\xd2\x46\xbb\xb3\x23\x85\x23\x35\x62\x45\x7f\x6b\x4e\x9e\xa9\x80\xb4\x5b\xea\x5e\x7b\x97\x4e\x51\x69\x69\xa5\xc0\x4d\xe3\x10\xb3\x01\x8c\x60\xc6\x13\x15\xa0\x3f\xf0\xe5\xb3\x64\x36\xac\x41\x33\x90\x73\x2e\xd4\x38\xae\xe5\x39\x6b\x89\xa6\xca\x08\x19\x39\x4a\x20\x68\x98\x3f\x69\xe1\x9f\x3c\x7b\xe3\xeb\xaa\x21\x68\xaa\x5e\x35\x82\x76\xc7\x68\xe5\xc8\x36\x25\xc1\x86\xb5\x32\x08\x1e\x51\x39\x26\x7c\xdd\x18\xef\xe0\xab\x33\xfd\xd1\xca\xc5\xab\x9e\x3b\x27\x04\xf1\xb8\x00\x9b\x33\xf7\xba\xcd\x08\x59\xb5\xa6\x16\x3a\xe1\xe5\x32\x47\x57\x4d\xe5\xa1\x6c\xc9\xd5\x63\x01\x93\xbd\x24\x20\x6b\x62\x31\xa1\x4a\x60\x51\x42\x0a\xf1\xfa\xa0\x24\x58\x40\x7c\xd6\x88\x19\xdc\x38\xa3\x29\xc4\x28\xa6\x12\x12\x44\xe0\x2e\x0d\x9c\x61\xa8\x9d\x12\x58\x39\xda\x45\x9e\xa3\x89\x3f\x87\xc0\xb2\x82\x34\x1c\xb3\xd3\x1d\x79\x7c\x2c\xad\x9f\xf1\x28\x2f\x04\xb9\x08\x24\x5c\x8b\xa9\x83\x28\x93\x74\x36\x57\x88\x32\x6b\x77\xc4\xc9\x8c\x0b\xaa\xe6\xa9\xec\xa1\x49\x2e\xb5\x16\x6a\x82\xd5\x4c\x3c\x0a\x51\x51\x2b\x2e\xb4\x6b\x12\x71\x5c\x69\x70\x59\x45\xd9\x82\x34\xda\x1d\xca\x41\xe5\xae\x58\x43\x38\x7d\x8f\x33\x58\x6d\x83\x42\xdd\x46\x03\x4f\x89\x4c\x1c\x20\x77\xc8\x4e\x50\x05\xa4\xe9\x1c\x00\x2a\xe4\xde\xbc\x14\xaf\x51\x88\x0b\x99\x64\x50\x41\x5c\xec\x36\x48\x5e\x65\x64\x4a\x83\xde\xe4\x9d\x4e\x69\xa6\x6a\x03\xb7\x96\x5d\x45\xb7\x01\xe6\x4f\xbb\xc5\x86\x64\x2c\xa0\x66\x40\x6a\x1b\xb1\x3b\x42\x9a\x81\xdc\x96\xf6\xde\x94\xc6\x85\x29\xd8\x44\x8f\xd5\x24\xbf\x8b\x13\xfb\x7c\x70\x77\x76\x3b\xbc\x31\x90\x13\xd7\xb7\x97\xfd\xfb\x71\x8d\x5f\xbb\xe6\xad\xcb\xfe\xed\x0f\xe7\xeb\x5f\xfb\xfe\xbe\x9c\x95\x5d\xf3\xca\xed\xdd\xea\x64\x8e\x16\x43\xac\x49\x0a\xab\xed\xe7\x14\x65\x0b\x35\xe7\xcc\x87\x28\xc4\x25\xde\x74\x84\x4c\x46\xb0\x82\x10\x22\x21\x55\x8d\xe3\xf0\x1e\xe2\x72\xd6\x4b\x98\xe5\xcd\x32\x30\x6c\x7b\x15\x8d\x36\x38\x91\x9f\x12\x3e\x01\xbf\x75\x5e\x2a\x71\xbb\x22\x02\x7d\xc7\x78\x9f\x73\x2a\xb3\x04\x2f\x96\x7a\x58\x77\xe5\x5c\xe1\x94\x40\xc4\x71\x81\x1f\xe7\x92\x45\xf4\xce\x40\x02\x93\xbf\xd7\xe9\x14\x32\x99\x14\xc5\x8a\xa0\x09\x51\xcf\x90\x37\xe7\x7e\xf5\xb6\x54\x17\x30\x22\x8f\x47\x0c\xcc\x39\x23\xbd\xc8\x71\x0e\xd1\x7e\xa3\x0f\x3d\x34\xfa\x10\x93\x27\x92\xf0\x4c\xef\xbc\xfe\xa1\xe1\x92\x19\xa4\x98\x26\x57\x5c\x79\xcb\xdc\x2e\xfb\x29\x48\x44\x33\x90\xcc\xc7\x44\xb7\xfb\x7a\x82\x47\x89\x92\x1d\x3b\x83\x31\x20\x1c\xc7\x5a\xc9\x06\x56\xe6\x86\x57\x84\x00\xb1\x60\xea\xa5\x5a\x99\x9b\x88\x14\xde\xfc\x6d\x7a\x0c\xdb\x2c\x9b\x3d\x6b\x77\x80\x3d\xbd\xa0\x4b\x76\xd7\x8b\x5c\x6b\x25\x3f\x90\x05\xa4\x60\xdc\x60\x2a\xb6\x74\xcd\xd6\xc5\xbc\xbe\x88\x93\x76\x50\xd3\xd1\x01\xb9\x6b\xeb\xd7\x61\x37\xc7\xad\x8f\xd5\x7b\x2d\x2d\xd5\xc5\x72\xf9\x8e\x5b\xaa\xad\x0f\x4d\x4a\x6a\x63\x08\x03\xaa\x2a\x5e\x19\x89\x36\xd0\xb8\xfc\x00\xef\xf4\x77\x6b\x35\x15\x2f\xae\x45\x61\x4d\x7f\xd8\x05\x9b\x1c\x5f\xcd\xc7\x27\x6b\x47\x1c\x25\x5c\x96\xb1\x72\x5a\x0f\xfa\xcc\x7e\xba\x6a\xdc\x83\x90\x7c\xb5\x5c\xb8\x51\x40\x43\xcd\xc2\x57\xc0\x20\xcd\x3d\xa3\xac\x87\xcc\xbe\xdd\x43\x14\xa2\x2d\x41\x21\x4b\x0a\xe4\x00\x16\xa3\xc2\x0d\x32\x62\x45\xcc\x8a\x44\xcf\x24\x81\x30\xb7\x88\xa7\x19\x98\xf8\xed\x70\x6d\x4b\x24\x36\x11\xc3\x3d\xc4\x73\xa5\x1b\x33\x39\x39\xce\x88\x6b\x13\x7e\x0a\xb7\x87\xf1\xbd\xd9\xe0\x77\x0f\x2c\x6d\x68\xdd\xdc\xa5\x94\xa1\x4f\x44\x41\x2b\x00\xdc\x1f\x4e\x10\xf4\x84\x6a\x08\x65\xfd\xda\xef\x70\xa2\xec\x4c\x36\xd8\xf9\x02\x38\xe5\xbb\x84\x4f\x56\x1b\x09\xa0\x71\xf4\x70\x3b\x74\x16\xc9\x22\x7e\x2a\x40\x2f\x2e\x79\x14\x07\x37\xb7\x83\xb3\xfe\xfd\xe0\xfc\x18\x3d\x48\xa2\x97\xc7\x4f\x17\xf2\xab\xbd\x4a\x62\x46\x6e\x91\x58\x98\x54\x04\x37\x19\x42\x88\x10\xa5\x2c\xe8\x35\x8c\xa3\x0c\xd3\xb2\x9a\xb0\x01\x24\x85\x5a\x43\x1d\x00\x0b\x55\xe7\x69\x23\xf3\xd6\x9d\x40\x88\x93\x1a\xbf\x9f\x28\x35\x33\xde\x74\x39\x32\x6f\x1d\xf9\x94\x23\xfa\x5e\x7a\x32\x70\xb4\xd4\x9c\x50\x81\x5a\x4d\xcb\x10\xd5\xb8\xfd\x9c\x82\x10\xf7\x4b\x9c\xad\x4e\x3f\xc5\xcf\x25\xa2\x35\xa2\x70\xe0\xbb\x7f\xe9\x73\xe0\xd8\xda\xd8\xb0\xc2\xdd\x27\x58\x38\xb4\x0c\x6f\xf5\x7c\xd3\x64\x7c\x48\x67\x24\x0b\x27\x56\x19\x84\x8d\x63\x95\x08\xce\x0e\xfc\x42\x19\x2a\x5d\x89\x3d\x34\xa5\x9f\x6d\xa3\x45\x7c\xbb\x7b\x35\x08\x78\x68\x88\xa7\x9c\xe3\xe5\x33\xb5\x81\xd8\x70\x03\xdf\xaf\x14\x22\xb9\xd4\x22\x51\xa4\xc5\x25\x41\x22\x2e\xf4\x4d\x01\xdd\x16\x5e\x88\x75\x22\x83\xc2\x42\x2f\xca\xb2\x57\x66\xd5\xe9\x2f\x6a\x90\xc4\x58\x91\x23\x2d\x7a\xad\x49\x80\xb6\x39\x32\x90\x4d\x83\x55\x00\x07\x56\xdc\x3c\x13\x32\xc3\xcc\x85\x66\x37\x0c\xd7\x5d\x79\x3b\xb0\x2a\xad\x02\x61\x48\x0f\x03\xf9\x0a\x52\x7f\x4a\xe3\x90\x19\xac\xe7\xca\x71\xd8\xe8\x97\x43\x58\xb6\x67\xec\x83\x71\x1a\x06\x9b\x67\xf1\x21\x0d\x36\xc1\x52\x21\x3b\xa6\x26\x53\x44\xa0\x22\xbe\xac\x11\xb6\xa4\xdb\xb7\x55\xde\x34\x09\x95\xb5\x58\x02\x9e\x11\xe9\x70\x53\x0c\x4a\x8c\xd6\x69\x9c\x20\x6c\x4a\x31\xfb\xb3\x6d\x6b\x32\xbb\x5b\x22\x64\x26\x10\xa4\xbf\xdc\xf4\x31\xea\xb3\x25\xbc\x2c\x17\x97\x55\x5a\x2f\x73\x27\xe1\xe4\x19\x2f\x24\xca\x84\x81\x96\x31\x91\xfb\x6e\xf2\xa0\x81\x95\x3f\xf2\xa1\x10\xca\xa5\x4e\x20\xb0\xc5\xac\x0f\x9a\x73\x72\xef\xf8\x05\x5c\x79\x95\xa8\x72\x2f\x90\x17\xcd\x15\xb6\x8a\x16\xac\x4e\x91\x71\x34\xc7\x6c\x46\xc6\xce\xc8\xba\x8d\xb6\xa4\xdb\x39\x83\x66\xce\x6d\x2b\xf5\x97\xd3\x8d\x51\x98\x6c\xfd\x17\xf3\xaa\x37\x20\xea\x43\x20\x15\x9e\x11\x64\x46\xd4\xca\x2c\x5d\x8a\x18\xb3\x60\xc3\xa0\x27\xd8\x56\x07\xe5\x28\xfa\x26\xe1\x1d\x42\x9f\x2e\xf0\x84\x24\x6f\x13\x39\x01\x5d\x5b\xe3\x3c\x78\xeb\x4c\x36\x00\x41\xcf\x60\xcf\xaf\xb0\x0c\x6b\xbd\x17\x79\x5d\x6e\xc0\xaa\x79\x96\xaa\x9f\xef\x30\x51\x57\x2b\x64\x9b\xa9\x36\x55\x10\x09\xaf\xbd\xa0\xd2\x46\x9d\x81\x2d\xbc\xfe\xaa\x36\xe5\xed\x06\x12\x14\xfc\x68\x18\xc7\xce\x15\x3f\xd6\x4e\x65\x6b\x90\x81\x96\x55\xf0\x86\x53\xc4\x38\x23\x88\xca\xe2\x65\x55\x4e\x87\xf2\x10\x3d\x5a\xc4\x37\xc6\x17\x5f\xa5\xcb\x17\x5f\x7a\x69\x4b\x4b\x01\x9e\xe0\x6d\x03\x2e\xbf\x9b\x11\xad\xa8\x62\xb1\x00\x88\x4f\xc3\x87\xcb\x32\xdd\xda\x71\xee\x5d\xe0\xbe\x77\x08\xae\x41\xa4\xae\xe2\x08\xc4\xc8\xca\xe0\x90\xc1\x41\xb5\x2f\xd9\x8f\x2c\x4c\xcd\x88\x79\xcb\x06\x10\x22\x95\x28\xc5\x19\xf8\xf4\x18\x57\xc5\x57\x06\x76\x49\xf9\x2d\xec\x39\x41\x5c\x9a\x1a\x5a\x0d\x2b\xb0\xce\xb4\xe3\xae\xdf\x62\x5d\xcb\xf0\x96\x0e\x9a\x77\x46\x9f\x08\x73\x34\xdd\x73\x67\x42\x0f\xca\x75\x9a\x2c\x8e\x30\x84\x19\x93\x38\xf4\x7c\xac\xe6\x48\xc6\x20\x73\x08\xf6\xc8\xf6\x4b\x76\x5f\x1b\x46\x63\x40\xd2\x4a\xe8\xf6\x2e\x30\x3c\xa4\x52\x8b\xdb\x6b\x32\xc1\xb1\x44\xbf\x63\x5c\xfd\x2e\x40\x36\x76\xc6\x0b\xf8\xd4\x99\xa0\x7a\x4b\x25\x5b\xe0\xd0\x5a\xc2\x41\x38\x40\xd8\x5a\xbb\xf2\xbb\xc6\x06\x14\x81\xef\x2f\x2a\x8d\x0e\x96\xb3\xe0\x9a\x6a\x5e\x75\x1e\x7b\x54\xbd\x16\xaa\x06\x4f\x53\x56\xaf\x38\xe9\x25\x43\xa7\x5c\xe7\xa2\xf7\x7b\xd1\xca\x35\xbf\x84\x08\xb0\x0b\xb5\xa5\xad\x23\xa7\xd6\x80\x20\xd7\xdb\x25\xb6\xc9\xf3\x6c\x92\xcb\x45\x39\x74\xcd\x96\xc1\x68\x40\xf9\x3d\x1e\xb1\x8f\x5c\xd8\x2b\x58\xda\x3a\x03\x13\x1c\x3d\x1e\x11\x16\x23\x9c\xab\xb9\x41\xdb\xb5\x7e\x85\x85\xa5\x06\x2d\x69\x00\xd9\x78\x28\x0d\x2a\x23\x2c\x62\x57\xf1\xe2\x89\xbb\x51\x8c\x58\xd0\x08\x54\x32\x80\x42\x4f\x50\xaa\xb6\x49\xd5\x24\x52\xeb\x57\x4d\x6b\x51\x57\x84\x75\xa9\x04\xeb\xea\x73\x56\x2a\x2a\x0b\x35\x18\x20\xc0\x89\x4f\x97\x57\x67\xe8\xac\x8d\x4e\xbf\xd3\xf4\xbc\xec\x85\xe8\x59\x8d\xc2\x98\xa4\xec\x0c\xb4\xa4\xf3\xad\xe3\xb5\x25\xd4\xe0\x69\x2e\x20\x5c\xb7\xae\xcd\xaf\xa3\x39\x4d\x0a\xdf\xc5\x37\x3d\x3f\x4c\xdd\x64\x42\x9e\x48\x62\x30\xeb\x23\x01\x91\xf9\xc6\x6a\xf8\x2d\xfa\x3f\xa6\x30\x29\xfa\xc3\x88\x7d\x02\x36\x9c\x24\x0b\x40\xd4\xf4\x2d\x63\x55\x69\xe6\xb1\x76\x00\xca\xa6\x02\xa1\xf2\x40\xcc\x5e\xcf\xf1\x13\x19\x31\xd7\xcc\xff\x41\x8f\xe8\xf7\xe8\x0f\x4d\xea\x9d\x0b\xb0\x7f\x61\x3b\xc7\xc7\x20\x7c\x3d\xb8\xe5\x2c\xa3\xb4\xfc\xc6\x99\x41\x4a\x46\xc8\x1a\x64\x0d\x0f\x8c\x4d\xd9\x13\x8f\x96\xb2\x38\xc2\x53\x8b\x05\x61\x6a\xcc\x78\x4c\xc6\xa4\xc6\xa5\xb9\x82\x49\x68\x21\xe0\x8a\xc7\x64\xad\x43\xd2\x33\xd3\x9f\xc0\x74\x23\xf3\x89\xdf\x0e\x48\xf0\xf7\xd9\xdc\xde\xfa\x50\xa6\xb4\xfa\x91\x7b\xf4\xd9\x6d\xc6\xbd\xad\x33\xd5\x85\x89\xf6\xe0\x42\xb0\x03\xa8\x77\xe8\x25\x58\x39\xf7\x7a\xf5\x38\x56\x1d\x01\xfa\x65\x3d\x73\x7b\x59\x05\xb8\xba\x50\xfb\x44\xd0\x19\xd5\xf2\x7b\x7b\x87\x2d\x70\xc2\x6d\xbc\x19\x06\x64\xb4\x95\x3b\xa3\x58\x0a\x07\xb4\x72\xe4\xe9\xaf\x70\x42\x4e\x78\x5e\x15\xe0\xed\x02\x50\x19\xba\xfb\xad\xac\xbe\xd0\x7c\x78\x66\x32\x00\xc9\x9c\x9a\x9c\xfb\xfe\xd9\x05\xd2\xa7\x83\xa7\x06\x98\x0a\x16\x2d\x57\x73\x2e\xe8\xaf\x8d\x19\x4a\xcd\x32\x7a\xe1\x69\x2d\x12\xba\xcc\x38\xcb\xd2\x3a\x10\xab\x11\x29\x54\x49\x2b\xa9\xd3\x99\xd0\x24\x07\x0c\x56\xcd\x66\xa7\x79\x62\x0a\x37\x44\x5c\xc4\xa6\x72\xba\x2c\xa5\x8f\x41\x18\xae\x13\xef\xb1\xf2\x0d\x52\x0b\x55\x69\x4b\x43\x18\x0b\xce\x4a\x01\xf4\xaf\x39\xc9\xf7\x94\x81\xf7\xa6\x31\xcb\xf7\x78\x26\x8b\x20\x64\xb3\x36\x9a\x37\x17\xeb\xfb\x0f\x3d\x53\x19\xe4\xac\x3a\xcb\xa2\x87\x80\x32\x2a\xb9\x29\x0c\xba\x91\x45\xe7\xd6\x40\xdf\xef\xc1\xa4\xf3\x1a\xf1\x1c\xcb\x32\x52\x0d\xfb\xb1\xe4\xf7\xe4\x33\x38\xab\x2c\xe2\x85\xec\x24\xae\x86\x40\x45\xfa\x78\x41\x93\xc9\x16\x4c\x6e\x59\xa8\x5e\x19\x15\x5d\x18\x50\x3c\x5b\xab\x49\xa6\x56\x1c\xd2\x2e\x9e\x05\x05\x84\xb8\x45\xf1\xb2\xaf\x81\xeb\xae\x8b\x90\xc7\x68\x29\xc5\x88\xb5\x10\xd7\xe1\x96\x70\x51\xcf\xe3\x37\x30\x40\xd8\x86\xca\x5d\x2f\xfb\xed\x9b\x4e\x84\x61\x49\x87\x7a\x24\x96\xe1\x61\xd6\x1e\x06\x5f\x09\xe4\x6d\x0c\x88\x5e\xb4\x79\xbd\x93\xe1\xc9\x71\x1c\xe1\x68\xde\x38\xa9\x09\xe7\x09\xc1\xac\x49\x7a\xad\x7d\x5c\x3d\x22\x06\xdc\x14\x58\x77\x92\x00\xc2\xaf\x5b\x02\x5b\x15\xb2\x10\xdf\x59\x0c\xc8\xec\x86\x87\x9b\xd8\x40\x37\x50\x45\x98\xb3\xfc\x50\x36\x4b\x48\x75\xad\x2c\x84\x7e\xcf\x76\x92\x44\x79\x12\x94\x85\xcc\x88\xd0\xa3\xd6\x4b\xfc\x44\x98\xd6\x19\xec\x38\x9c\x33\xe3\xd9\x25\x44\xfb\x62\x50\x3d\xdf\xb5\xf3\xa7\x41\xd6\x61\x3c\x62\x70\x70\x79\xf9\xb0\x6a\x5a\x95\x5a\xcd\x08\xed\x52\x5b\x9f\xce\x40\x88\xd8\xf8\x78\xde\x95\xcd\xc4\x1b\x9f\x49\xd3\xf7\x18\x62\x0c\x76\x76\xad\x05\xee\x97\x02\xaa\xc1\x6c\xac\x83\xe3\x7a\x25\x23\x32\x44\x6d\x94\xc3\x4e\x83\xa0\x8d\x26\x38\xa8\x17\xbd\x4b\x8a\xf2\x17\xee\x36\x68\x39\x94\x95\xae\xea\x96\x8e\x67\xb0\x4e\xae\x3a\xb7\x17\x36\x64\xbb\xec\xb2\xf5\xf9\x3d\x45\x98\xa3\x2d\xf0\xaa\x04\x06\x74\x02\xc8\x29\xff\xc9\x68\xd8\x54\x1a\x0b\x98\x2b\x73\x91\x66\x6a\x61\xab\xa2\xc1\xbd\x18\xe6\xf4\x1a\xc4\xb7\x3a\xf7\x70\xf5\x8e\x8c\x4b\x0e\xe2\xba\xce\xa0\x23\x6b\x56\xa8\x6d\xd2\x2d\x74\x88\x20\x52\x41\x6c\x68\x8a\x06\x31\x05\x66\xc7\x38\x69\xb4\x65\xed\x81\x69\x42\x9a\x6d\x81\xd2\x60\xc1\x5f\x95\xc8\x89\xe6\x5d\x38\x49\x2a\xf3\xc2\x90\x0e\xad\x7c\x91\xb9\x49\x51\x09\xb7\xbd\xb3\x3a\xc1\x13\xb2\x91\x7b\xfa\xc2\x7c\xb0\x92\x8a\xe0\x15\x88\xec\xce\xb2\x64\xd1\x2e\xa2\x3c\x0c\xbd\xab\x05\x49\x5b\x37\xb0\x10\x5a\x6d\xe5\xdd\x54\x86\x27\xdb\x6e\x88\x92\x44\xb9\xa0\x6a\x31\xb6\x46\xbf\xf6\x4c\xeb\xce\x7e\x79\x66\x3f\x6c\xa3\x51\x9f\x22\xd7\x9f\x33\x32\xc2\x3d\x25\xa8\xa9\xa0\x63\xa7\xd0\x66\xbb\xb5\x96\x5c\x0b\x9e\xb4\x6a\x61\x1d\x7a\x53\xbb\xa1\xea\x2e\xb6\x1d\x9e\xad\xcc\x31\xe6\x53\x87\x8b\xd4\x7e\x61\xab\x25\x4b\x36\xb0\x96\x3a\xf8\xe5\x4c\x50\x2e\x6c\x65\x90\x36\x41\x6d\x29\xfe\x3c\xce\xb0\xc0\x49\x42\x12\x2a\xd3\xed\x6d\xbb\x7f\xfa\xe3\xca\xd1\x9e\x99\x0a\x36\xd2\xd6\x83\xfa\x4c\xd3\x3c\x45\x2c\x4f\x27\x56\xca\xc5\xf2\x31\x04\xbf\x74\xa9\xfa\x06\xc3\xc9\x0d\xb0\x04\x18\x20\x02\x38\xd3\x11\x0b\x80\xad\xad\xa9\x02\x47\x73\x4a\x9e\x00\x76\x53\x30\x22\xe5\x31\xba\xe2\x8a\x9c\xa2\x4b\x9c\xdd\x83\xa0\x66\x4a\x4a\xce\x8c\x75\x1c\x4b\xa4\xa5\xd6\x9c\x51\xd5\x1b\x31\x8b\x86\xed\x56\xe5\x24\xe2\xcc\x20\xa2\x46\xb0\xb0\xbe\x09\x30\xf7\x3a\x68\x50\xe5\x12\x1b\xa9\x6c\x58\x6c\x81\x9f\xc7\x41\xf4\xea\xd8\x64\x07\x6c\x40\xc7\xb7\xf8\xd9\xc4\x6b\x9f\x63\x85\x4d\xb5\xd8\x55\x92\xbb\x0d\x88\xb2\x15\x84\x0c\x10\xb0\x0b\x1c\xe1\x16\x8d\xc2\xd7\x3e\x33\xd1\xa9\x5f\xd3\x63\x72\x8c\xbe\x4b\xf8\x44\xf6\x90\xf4\xa0\xd9\xf0\x50\x12\x25\x7b\xc6\x41\x05\xff\x36\xa9\x60\xdf\xb8\xd5\x2f\xf8\x3e\x94\xfd\x9b\xd2\xcf\x06\x04\x43\xfe\xe9\xf4\xe4\x24\x5d\x1c\x4d\xf2\xe8\x91\x28\xfd\x17\xc8\x14\xb5\x2b\xe4\x10\xa4\x70\x1d\x1e\xd5\xba\xd5\x59\xc6\xb2\x6a\x45\x91\x36\xad\x46\x12\xc0\x4d\xd7\x57\xba\x2f\xac\xea\xa0\x8f\x38\xab\xaf\x1a\x69\xa7\x2c\xf2\xa6\xe3\x55\x02\x5c\x7e\x1d\x6d\xc5\x14\x8e\x0d\x71\x9e\xa7\x09\x9e\x55\x54\x96\x0d\x94\x94\xeb\x94\x5a\x2a\xd2\x73\x87\x78\x0b\x7d\xca\xca\x51\x66\x5f\x39\x77\x24\xb8\x15\xad\xbb\xe5\x78\xc4\xfa\x12\x3d\x13\x53\x0f\x16\x72\x12\xc1\x3b\x91\x53\x39\xf7\x19\x89\x60\x2f\x85\x46\x0d\x1c\xae\x41\x4d\xb0\x8a\xa3\xd3\xac\x9c\xff\xc6\x6a\xa0\x38\x91\xa4\xa7\x1b\x06\x48\x34\x17\x48\x88\x9e\x05\xce\x32\x22\x46\xcc\x42\x9b\x02\x80\x37\xe7\x36\x48\xa4\x29\x9a\xbc\xd3\x28\x5f\x57\xa3\x0c\x93\x3e\xca\x09\x8b\xeb\xce\x37\xe4\x37\xae\x4c\xf5\x58\x91\x1b\xa8\x65\xd1\xb6\x91\xde\x6f\x6f\x36\x6e\x39\xe6\x75\xda\x79\xbf\x12\xa6\x0f\xe5\xa6\x53\x50\x20\x65\x51\x55\xd3\xd9\xfa\xbc\xfa\x5e\x12\x73\x00\x19\x1b\x3e\x8e\x39\x91\x81\x11\x1f\x79\x5b\x5c\x42\xa7\x44\x4b\x1f\x23\xa6\xc9\x38\x74\x38\x18\x80\x6d\x87\xb7\xad\x3b\x8d\x04\x97\xd2\x46\xde\x9b\x76\x56\xe7\x4f\xed\x50\xcb\xcf\xa0\x84\x0f\xaf\xaf\xc6\xcb\x55\xfd\x82\x67\xae\xbe\x9f\x7d\x58\x9b\x64\xdf\xd8\xd4\xda\x6a\x7e\xc5\x5a\x6c\x50\xcf\xef\xe4\xec\x62\xe8\x8b\x58\x55\xba\x5e\x2e\xe8\x17\x22\xab\x37\x97\xf4\x5b\x9e\x71\x50\xdc\xaf\xd2\xc4\x8a\xf2\x7e\xeb\x37\xab\x1c\xef\xbb\x0b\x6c\x5e\x65\xeb\xd7\xf2\x87\x32\xcd\xac\x0b\x4b\xdf\xd3\x36\x35\x5c\x2b\x11\x08\x8c\x2f\xed\x61\x07\xc1\x4b\xbf\x25\x15\x4e\xb3\x30\xe5\xd2\xe1\x86\xda\x69\x9a\xa3\xd6\x74\x09\xbe\x2a\x9e\x79\x84\x4d\x34\x4b\x75\x70\x4b\x5b\xb1\x99\xc7\xeb\xde\xc2\xa4\xef\x23\x8c\xf9\xf5\x72\x98\x93\x45\x11\xb5\x27\xad\xec\xe6\x4a\x70\x37\xd8\xfd\x27\xc4\x43\xc2\x37\x6e\xe8\xae\x49\x8a\x1e\x3a\x4a\x10\x2c\x6d\x38\x06\xe4\xf2\x55\xf2\x7c\x36\x30\x0f\xfb\x31\x9b\x6c\xe0\x23\x5f\x84\x21\xb8\x6a\x6c\x5d\xb1\xc8\x1d\x44\x2a\x04\x79\x22\x02\x68\xc7\xc6\xfc\xb0\xf2\x51\xc5\x89\x20\x38\x5e\x04\x2b\xe2\x03\x0e\x4c\xcf\x60\x1e\x93\x34\xd5\x0a\x3c\xa8\x26\x8c\x1f\xf1\xcc\xe9\x2c\xa5\xb7\xa0\x82\x06\x9d\xea\x1b\x2b\x08\x57\xd0\x5f\xb0\x23\xf2\x99\x4a\xa5\xe5\x8a\x9a\x58\x4d\xd7\x08\x48\x3c\x50\x57\x6b\x4e\xec\x0d\x37\xfa\xd0\xff\xee\xfa\xf6\x7e\x70\x3e\xfa\x50\x44\xe7\xbb\xf4\x33\x8f\x08\xe5\x00\xfe\x39\x1b\x31\x1f\x50\xeb\x01\x90\x61\x2f\x11\x8e\xe3\x02\xd9\xc0\x2a\x91\x46\x66\x5b\xc9\x91\x83\x53\xb1\x36\x94\x76\x45\x33\x0f\x90\x83\x74\xa8\x27\x6b\x85\xeb\xac\x74\x72\x4c\x26\xd5\x8a\x94\x97\x3d\x5d\x36\x21\x76\xab\x32\xba\x36\x51\x0e\x5c\x90\x91\x67\xa7\x2b\xc1\xed\x7c\x82\xcd\x25\xbc\x19\xb7\x73\x1b\xb2\xc5\xa6\x7e\xa4\x9f\x49\x7c\xdb\x20\x55\xed\x25\xa3\xa5\x55\x24\x60\xed\x2e\xe4\x8c\x6e\xa2\xf1\xfb\xa9\x3c\xe8\xef\xda\xb3\xa5\xeb\x02\x92\xad\x80\x57\x05\x6c\x55\x85\x30\x8a\x88\x50\x98\x32\x34\x85\x83\xcd\xa2\x05\x02\xc0\x0e\x02\x3e\xec\x3f\xa2\x94\x32\x40\x0e\x58\xb5\xb4\x0f\xe5\x79\x6c\x20\xb4\x5e\x0e\xaf\x1e\xee\x4b\xa2\xea\xf7\xd7\x0f\xe5\xa2\xee\xfd\x9f\x57\xca\xaa\x95\x16\x56\x05\x0b\x05\x53\x2c\xb2\x10\x2d\xca\xac\x5f\x99\xda\x89\x26\x0b\x45\x1e\x6e\x2f\x76\x92\xef\xea\x9d\x65\x8d\x18\xe1\xa1\x74\x55\x8f\x88\xd0\xe6\xd3\x98\x44\xeb\x50\x4c\xdb\xd3\x91\x89\x82\xd2\xeb\x60\xad\x89\x16\xe1\x0c\x4b\x94\x61\x61\xfd\x50\xb1\x09\x80\x2a\x57\x06\x33\x9a\xd7\x2a\x04\x89\x4f\x44\xfd\xa8\xaf\x3e\xce\xf6\x91\x05\x61\x45\x59\xf0\x8f\x92\xf1\x93\x69\x78\x83\x93\x66\x87\xb2\x22\xd5\xc5\x09\xcb\xd0\x03\xb2\x3d\x84\xb8\x0b\xc7\xa6\x42\x7c\x5f\x37\x07\x2b\xe2\xe2\x09\xb5\x4a\xca\x99\xa6\x48\x03\xa7\xea\x30\x58\x83\xe6\xf8\xd4\x7c\xdc\x12\x91\x2e\x88\x6a\xd7\x6d\x15\x4b\x89\xfa\x37\xc3\x9a\xb5\xbe\xa8\xba\x90\xbe\xac\x72\x36\x89\xf7\x66\xed\x1b\x24\x29\x48\x4f\x3c\x08\x54\x24\x3b\xd3\xdd\x60\x90\x8c\xd3\xff\xa6\x1c\x49\x70\x08\x68\xbd\x75\x2a\x43\x29\xed\x78\x0d\x30\xef\x66\x99\x78\xc5\x32\x6c\x08\x7a\x14\x0e\xc8\xa6\x81\x84\x40\x3f\xcb\x31\xc6\xbd\x10\xf8\x87\x9b\x82\xb9\x36\xb6\x60\x6f\x60\x48\xc5\x6c\xda\xa0\x21\xfd\x68\x28\xda\x83\x65\x00\xfc\x87\x2b\xc8\xe8\x62\x83\x6d\xee\x7a\x38\xdd\x90\xda\x36\x03\x50\x2a\xc6\xe7\xcc\xdf\x16\x8b\x1a\x67\xd8\xda\x1d\x40\x89\x72\x95\x12\xea\x0a\xeb\x1d\x8f\x58\x10\xb0\x22\x8d\xda\xa3\xcf\x88\x2b\x4e\x02\x15\x6f\x19\x00\x5b\x43\x92\x8e\x17\x7e\x4a\x3b\x50\x4d\x91\x57\xf3\x72\x79\x91\xa5\x7e\xec\xe9\x94\x73\xec\x12\x11\x9d\x05\xc5\xc6\x01\x86\xf6\x25\x68\x2f\x28\x28\x60\x3b\x06\x73\x34\x18\x2d\x70\x50\xae\x2e\x48\x5e\x8f\x39\x91\xec\x2b\xe5\x53\x3d\x69\x62\x4b\xa2\xe0\xaa\x7b\x40\x4b\x75\x98\xda\x96\x57\x1f\xf0\x3d\xa0\x33\x6d\xaa\x38\x04\xc7\x6a\xad\x99\xca\xf9\x78\x81\x12\xc2\x58\x24\xe8\xb4\xc9\xaa\xfe\x39\x23\xd1\x36\x10\x32\x37\x58\xe0\x94\x28\x22\x56\x85\x23\x95\x8b\x49\x83\x88\xe3\x76\xd0\xf6\x6b\x76\xd1\x54\xda\xa8\x96\x64\xf1\xda\xed\xc5\x3a\x48\x18\x3f\x8b\x8d\xd0\xaf\xf4\x34\x7e\xb4\x96\xff\x0d\x67\x61\xfb\x29\xa6\x61\xa3\xad\x02\x04\xa0\x5d\xe7\xf4\x3a\x50\x28\xf7\x4b\xa0\x22\xa5\x70\xa1\x03\xc1\x40\x59\x3f\xca\x26\xf0\x93\x75\xbc\x74\x2f\xbc\xdb\x65\x38\xb8\x14\xda\xca\xa1\x2a\xe5\x4e\x00\x95\x80\x4a\x65\x70\x40\xea\x01\x4c\x40\x68\xa9\x8b\x90\x0c\xdc\x7e\x16\xde\xae\x30\xe8\x5a\xc9\xaa\x5a\x5c\xaa\xb2\x5c\x6b\x78\xdc\xbe\xc0\x1d\x3a\x89\x66\xdf\x12\xcd\x3a\x52\x2e\x45\xd7\x6a\xea\x24\xa2\x82\x33\x63\x8b\x3e\x5b\x80\x80\xf2\x04\x21\xf7\xc8\x5e\x91\xb6\x72\x2c\x5c\xfd\x94\xf9\x7f\x95\x39\xb8\x23\xea\x90\x54\xeb\x92\x2a\x8f\x03\x17\x14\x78\xa0\x92\x50\x1a\xb0\x71\x35\x30\x5a\x13\x06\x69\xac\xfc\xc3\x2b\xe3\xc0\x82\xe4\xe6\x05\xcf\xd1\x33\x95\x73\xa4\xf8\x88\x41\x9c\xa0\xf7\x06\x28\x8e\xcc\x8b\x3d\x78\x0b\x60\x10\x64\x3e\x49\xa9\x42\x38\x98\x61\xc9\x24\xd9\xb3\xe7\x59\x7f\x00\x33\xae\xcd\xb3\xaf\x83\xe8\x59\x73\x68\xb6\xb0\xaf\x15\x8d\xec\x9a\x4a\x1f\xc4\x34\xbf\x6c\x32\x7d\xa0\xf1\x84\x1a\x66\xed\x99\xeb\xb2\xe9\x51\xbd\xb5\xc1\x82\x86\x02\xb2\x2b\x95\xaa\x72\xb7\x58\x43\xcf\x9a\x4c\xfa\x62\x23\x5a\xa5\xd2\x17\xaf\xef\x23\x97\xbe\xa9\x4c\xd9\xaa\xdc\x4a\xf7\x49\x83\xfd\xdb\xe5\xec\x2a\xee\x02\xe7\x43\x49\xe9\xa6\x51\x52\x3a\x34\x54\xb3\x22\x21\x60\xfb\xf0\xf2\x4d\xd4\xc1\x22\x3f\x2b\xa4\xa2\x20\xdd\xb2\x8c\x09\x43\xaa\x9c\x9f\x71\x05\x39\x35\x11\x94\x70\x5f\xca\xf3\x1c\xb1\x7a\x09\x64\x35\x4f\xdc\x35\x45\x63\xaf\xe8\x67\xc1\xf9\x73\xb3\xb0\x16\xad\x9f\x7c\x90\x9b\x51\x96\x6d\x31\xf6\xaa\x88\x59\xb8\xf8\x9a\x82\x93\xb4\xe0\xb1\x4d\xc2\x71\xcd\xa9\xac\x1f\xfa\x52\x02\xc5\xda\x73\x61\x2f\xdd\x3d\xaa\x76\x4b\xdc\xb9\x75\xbe\x89\x97\x91\x2d\x37\xb6\x01\xd3\xb1\xd7\xe3\x2b\xae\xda\x6d\xaa\xcc\x02\xaa\xe8\xde\xb0\x50\xab\xf0\x04\xba\xf1\x1e\xb8\x77\xed\xd8\xb1\x09\x75\xf1\x08\xdd\x95\x3d\x29\xcd\xd8\x56\xef\x7f\x89\x59\x6f\x5a\x1a\x38\xf0\x37\x0a\x1b\xef\x4b\x43\xcb\x01\xd4\x04\xb6\x61\x92\x15\x4e\xec\x85\xbb\x9c\xc5\x44\x30\x82\xd5\xfc\xf5\xb2\x2c\xce\x76\x35\x4f\x07\xe3\x7b\xd9\x8c\x8b\xb3\xbd\xd4\x85\x0f\x87\x5b\xae\x91\xbe\x76\x9c\xfa\xf5\x36\x96\x22\x1b\x7c\xe0\xab\x04\x2f\xa9\x8e\x35\x66\xc3\x00\x84\x66\x13\x2a\xdd\x29\x11\xa3\x5e\x9d\x7b\x99\x94\x94\x1a\xbb\xcf\x52\x32\x8a\x3e\xed\x61\x6d\xe5\x35\x4b\xf2\x45\xe4\x7e\xbc\x7c\x3a\xc2\xaa\x2a\xce\x79\x90\xa1\x00\xa5\xb4\x15\xa6\xcc\x72\xaf\x55\x49\x09\x5a\xa6\x4c\x71\x5d\x1e\xc2\xc1\x67\xb8\x7c\xf1\x09\x2e\x5d\xba\x43\x97\xee\x50\xb3\x47\x5d\xba\x03\x42\x87\x96\xee\xb0\x4e\x05\x5d\x65\x00\xf5\x3e\x39\xa8\xb6\x59\x2a\x71\x63\xf6\x77\x8d\x1e\xb9\x7d\x48\xbf\xb3\x21\x86\xf1\x50\xf6\x17\xfb\x43\x6d\x48\xd4\xd2\x67\xd5\xd9\x86\xf6\x4c\xb6\xa8\xba\x05\xb0\x88\x13\x8b\x43\x67\x03\x96\xcb\xf6\xa7\x55\xa6\xd2\x11\xfb\x9e\x3f\x93\x27\x22\x7a\x08\x2b\x94\x72\xa9\x80\x0f\xbb\xf8\x18\x38\x08\x25\x48\x73\x13\x07\x81\xd1\x15\x4e\x49\x6c\x2a\x1e\x06\x61\x8d\xd6\x60\x6b\x5d\xad\x75\x70\xab\x80\x1c\x6a\xb6\xc1\xc5\x4d\x8c\x98\x09\x35\x34\xe1\x6d\x20\x2b\x50\x37\x31\x20\x98\xdf\x79\x47\xf0\xef\x8e\xd1\xbd\xbe\x9f\xa8\x2c\x8f\x37\x40\x5f\x6b\x1a\xdb\x88\xcd\x04\xcf\x33\x6f\x43\xe3\x13\x53\xfa\xd6\x44\x3f\x2d\x3b\x82\x61\x30\xce\x0b\x1c\xe1\x58\xeb\xe2\xab\x09\xe7\x4d\xa2\x50\xb7\x82\x30\x0a\x09\x48\x1f\x43\x1f\x5a\x67\x43\xdd\x8d\xff\x36\x00\x6e\x59\x05\xc4\xfe\x42\xce\xe5\x73\x22\xc1\x2a\xe4\xad\xee\xa5\x3c\xf2\x32\x56\x41\xed\x38\x57\xd9\x44\xbd\xdf\xc2\xd9\xf6\xeb\x61\x10\x8a\xce\x6d\xcc\x97\x49\x52\xb5\xf7\xc4\x8b\x59\x4b\x5b\x47\xcf\x36\xf1\x8b\x9b\x5c\x64\x1c\x24\xb1\x64\xe1\x60\x1b\x2c\xd2\x5b\xc6\xb3\xdc\xc4\xb5\xd1\x30\xcc\xa9\x96\xb2\xa9\x54\x97\x58\x45\x73\xcd\xb9\x0b\xc4\xb3\x3d\xc5\xfb\x15\x5c\xf9\x65\x2d\xa8\x35\x33\x38\x0b\x7b\x6f\x70\x29\xb4\xb0\xa8\x9b\x7b\xdf\x85\xd7\x3b\x49\x22\xd5\xfd\x19\xb7\x9b\x2d\x68\x1d\xd8\x45\xdd\x27\xf6\x89\x9e\xe8\x3a\x2a\x5a\x37\xfe\x76\xb4\x55\xae\xb8\xb5\xf7\x48\xc2\x1d\x20\x64\xce\x2d\x60\x57\xf1\xa2\xad\xd0\xda\xe0\xfe\x17\x74\xbb\x2c\x20\x8b\x92\xff\xa4\xc5\x11\x6f\x71\x4d\x71\xa6\x95\x08\xc5\xf5\x2d\x29\x66\x46\x8e\x35\x71\xb2\x08\xa3\x5c\x50\x77\xf6\x2b\x39\xe1\xcd\xd4\x01\x16\xca\x93\xb0\xa2\x52\x84\x83\x62\x73\xc6\xe1\x8f\x23\x95\x63\x1f\x98\x08\x34\xe1\x8a\xa0\x9b\xfc\x77\xe7\x58\x17\x4e\xbc\xab\xd9\xd3\xb5\x84\xbd\xc3\x2e\xe3\x3a\x7c\xc3\x56\x27\x8d\xb2\x59\x00\x8e\x58\x6f\x25\x6e\x53\xfb\xa0\xf6\xcb\x76\xf5\x1b\x6a\x3f\x75\xb2\xcf\x36\xdf\xae\x00\x6f\xda\x3a\x36\xbb\x14\xe7\x6e\x03\x61\xad\xf4\x14\xc2\x56\x5a\xfb\x1d\xa0\xcf\x52\x70\xd4\x63\x2b\x4d\xfd\x97\xff\xcb\xd4\xca\x32\x4b\xf3\x5f\x88\x8b\x11\x33\xbf\xf7\x7c\x9d\x0a\xfd\x42\x01\x00\x8b\x53\x52\x40\x64\x8a\x32\x98\x1e\x40\x8a\x58\x30\x34\x03\xf6\xeb\x61\xfa\xf5\x18\x1e\xf3\x09\x11\x8c\xe8\xa1\x39\xf0\x01\xcf\xcc\x52\xcc\xf0\x0c\xa0\x85\x7b\x10\x19\x07\xe2\x6a\xa1\x8a\x18\x92\x36\xf5\x0e\x81\x5b\x69\x66\x69\xf3\x6d\x8b\xba\xbf\xd0\xa7\x11\x65\x2d\xb2\x69\x11\x5e\x51\x4f\xfd\xb7\xb6\xff\xed\x24\xf6\xfb\xfe\xdd\x0f\xe3\xdb\xc1\xdd\xf5\xc3\xed\x59\x49\x6c\x3f\xbb\x78\xb8\xbb\x1f\xdc\xd6\x3e\x2b\x72\x55\xff\xfa\x30\x78\x68\x78\xe4\x1a\xb8\xe8\x7f\x37\x28\x15\xd1\xfe\xeb\x43\xff\x62\x78\xff\xf3\xf8\xfa\xe3\xf8\x6e\x70\xfb\xe3\xf0\x6c\x30\xbe\xbb\x19\x9c\x0d\x3f\x0e\xcf\xfa\xfa\xcb\xf0\xdd\x9b\x8b\x87\x4f\xc3\xab\xb1\x0b\x3b\x0e\x1f\xfd\x74\x7d\xfb\xc3\xc7\x8b\xeb\x9f\xc6\x41\x97\xd7\x57\x1f\x87\x9f\xea\x66\xd1\xbf\xbb\x1b\x7e\xba\xba\x1c\x5c\xad\x2e\xd6\x5d\xbf\x1a\x8d\x75\x80\x83\x8b\x2c\x30\x1a\x05\x62\xd2\x64\x61\x49\x9b\xfe\x0a\xbe\x8b\x1b\x43\x8f\x47\x3d\xf7\x97\x29\xad\x7d\xa4\x59\xa0\xf3\x8b\x15\xdc\x63\xc4\xbc\xe3\xd2\x5f\xaa\x0a\xcf\xa4\x4b\x3d\x2e\x8d\xf6\x14\xf5\xe1\xac\x80\xc2\x50\xea\x14\x32\x1b\xfc\x48\x9d\xab\x1b\xe8\x30\xa1\x29\x05\xaf\x37\x3a\x42\xd5\x0d\x2f\x37\x68\xe7\x04\x43\xb0\x7e\xbb\x78\xd5\x69\x90\xd5\xac\x66\xa0\x94\x53\xe4\x38\x34\x31\xe6\x04\x83\x3d\xbb\x60\x38\xa5\x51\x35\x05\x03\xe0\x57\x51\x01\x35\x52\x6d\xb1\x44\x60\xe5\x96\xe7\x04\xfd\xf0\x97\x62\x50\xe0\xc1\xb0\x9a\x77\xbe\x54\x51\xcf\x3e\x10\xb9\x59\xd5\x75\xe4\x59\xea\xc9\x1d\x73\x6b\x5a\x86\x73\x6b\x2b\x77\x83\xbb\x29\x67\x01\xdc\x58\xc9\xf7\xa4\x8f\xb7\x99\x51\x85\xc6\x4f\xd1\x1d\x40\x9d\xc8\x42\x75\xd7\xbb\x98\x25\xf9\x8c\x32\x44\xd3\x2c\x21\x45\xcd\xf7\x09\x99\xe3\x27\xca\x5d\xf9\x0a\x53\xe5\x03\xd6\xd1\x8a\x56\xe8\x08\x35\x1e\x94\x53\xd4\x8f\x63\x59\x66\x70\x25\xca\x71\x2c\xf3\xa8\x3c\xec\x10\x21\x8c\xc5\x9e\x6d\x56\xe8\xa8\x38\x72\xb0\x62\xfb\x07\x73\x59\x66\x87\xe5\xbb\x77\x87\xeb\x5f\xaf\xe0\xd8\x91\xf2\x78\x2b\x61\xe0\x1e\xcb\x47\xc7\x9a\xd7\x09\x04\x0e\x56\x67\xb7\x1e\x2d\xbe\x4e\xdb\x4e\xfd\xca\x8e\xe1\xa0\x6d\xd7\x67\x23\x2a\xf4\x9a\x2e\xdd\x8c\x93\x4a\xe9\xae\xd6\xfd\x95\x4a\x7f\xd5\x76\xb6\x57\x6f\x4f\xbd\x34\x06\x47\x72\xec\xe9\x7f\x83\x79\xdc\xc0\xa7\xd7\xfe\xcb\x95\x22\xdb\x38\x58\xb7\x4d\x7d\x40\x4b\x49\xba\xd6\x0f\xb4\x92\x0e\xf7\x04\xef\xd4\x5e\x18\x84\xc2\x0b\x34\x02\x77\x1f\xa6\xcc\x96\xe3\x21\xde\x1f\xe5\x0a\x50\xeb\x73\xec\x4b\xc4\xe1\x09\x7f\x2a\x29\x97\x29\x91\x12\x37\x00\x96\x04\x26\xb1\x5d\x18\x83\x3f\xa1\xf6\xc3\x96\xf4\xe4\xce\xe4\xbd\xfe\x6a\x95\xd1\xe7\x36\xd4\x8c\xdd\x44\xb5\xc0\x1a\xbb\x48\x5b\x74\x6d\xf2\xed\x34\x7f\xe9\x15\xc1\x34\x5c\x04\x31\x46\x4d\xee\x9f\x96\x66\xb5\xea\x82\xd5\x56\x59\x0a\x5d\x78\x9b\xc7\xe0\x04\xad\x6f\x8d\x88\x6d\xfd\x2a\xb8\xbc\x3e\x1b\x50\x5d\xc9\xdf\x19\x56\xa0\x8e\x78\x9a\x1a\xb9\xa0\x64\x4b\xed\x21\x6c\xd2\x1c\x0b\x69\x4a\xe6\xd1\xdc\x78\x99\xf4\x95\xd1\x1b\xb1\xe7\x60\x43\x4a\x81\xc0\xfd\xb0\x25\x40\x13\xfd\xac\x8f\x1b\x7d\x2a\x85\x57\x83\xc8\x48\x21\xd6\x37\x20\x04\xe3\x10\x2c\xca\x47\xad\x21\xf0\x60\xbf\x76\x20\xf5\x2d\x6a\x05\x56\xd6\xb7\xa9\x62\xa0\x9f\x5b\x50\xa8\x6f\x07\x4d\xb9\xed\x10\x82\x5a\x81\x75\x23\xd8\x43\xa9\xc0\x57\x85\xf7\xf6\xe9\x9a\x26\xbb\x37\x9d\x58\x8c\x0a\x3d\x5d\xb7\xda\xbf\x77\x33\xfa\xbd\xf1\x3b\xe4\x0d\xa0\x26\x41\x6b\x1e\xe1\x1b\x1d\x69\x99\xd5\x25\xdb\xdb\x40\x0c\x89\x8e\x0c\x6a\xe0\x57\x10\x69\xd9\xbf\x19\x7e\xd5\x43\x5f\x85\xd9\x66\x5f\x6d\x75\x00\xed\xb8\x6d\xb9\x40\xd0\xa6\x4a\x29\x07\xe5\x63\x07\x7b\x55\x39\x89\x76\xcf\xec\x41\x44\x4d\xe7\x50\x7f\x59\xfa\x06\x9c\xd3\x50\xfe\xce\xf8\x6f\x7d\xc0\xb3\x75\x01\x19\x19\x97\xca\x9a\xb5\x8b\x47\x6c\xb2\xa8\x3a\x79\x7a\xde\xcb\xd3\xfa\x94\xee\x5c\xd2\x4d\xb7\xb7\x9c\x9e\xbc\xe7\x40\xdc\xd5\xf7\xc1\x9a\x84\xe7\xbe\x89\xb9\xe6\xd3\x80\x8b\x35\x45\x29\x74\x11\xec\x75\xb3\x2a\xd9\xcb\xdc\x62\xd6\x6e\xca\x3a\xf9\xe7\xbd\x91\x5b\x8b\xb0\xef\x7e\xdd\x8a\xd8\x88\xff\x06\xe1\xba\xa3\xb2\x97\xa5\xb2\x7d\x64\x3c\x94\x07\xb7\xf9\x05\x7a\x66\xe4\xb8\xa0\x19\x67\x70\xd5\xca\x84\x67\xf0\xa5\xba\x7f\xeb\x0b\xe6\x6e\xe8\xf3\x0d\xd6\x64\xbd\xd3\xf7\xce\x04\x0e\x18\xb7\xeb\xf2\x58\xab\x43\xed\x2b\x5b\x84\x88\x53\x93\xdd\xa8\x68\x4a\x7a\x88\xb3\x64\x11\x04\x3b\xd8\xf3\x0a\xe4\x66\x62\x94\xe6\x84\x0a\xd7\x89\xc5\x18\xdc\x28\x1d\x7e\x43\x69\xbc\x89\x46\x76\x88\x34\xb9\xea\x5f\x0e\xce\xc7\x83\xab\xfb\xe1\xfd\xcf\x35\xf8\x91\xe5\xc7\x0e\x42\x32\x78\xe1\xee\xe7\xbb\xfb\xc1\xe5\xf8\xd3\xe0\x6a\x70\xdb\xbf\x5f\x03\x2f\xb9\xaa\xb3\x26\xe8\xc2\x5c\xd6\xa9\x6f\x9b\xc0\x17\x3a\x33\x6f\x4d\xef\xcb\x20\x93\x41\x27\x94\x34\x00\x4d\x9a\xd4\x7f\x16\x13\x81\x62\xf2\x44\x12\x9e\x15\x66\xd5\xda\x05\x0b\x10\x28\x6b\xda\x5f\x85\x42\x09\x6d\x56\xd7\xf8\x14\x99\x5a\x6f\x41\xb9\x5b\xdf\x20\x88\x7c\x58\x10\xf6\x95\x42\xe4\x73\x96\xd0\x88\xaa\x20\x35\x90\x0b\xeb\x5e\x31\xee\x43\x88\x4e\x5d\x43\x5c\x7b\x8b\x46\xd9\xbb\xce\x1f\x7a\xd2\x97\xb5\x7d\x7f\xa2\x3c\x22\xda\xda\x02\x42\x7b\x50\xec\x1b\x9c\xc6\x4b\x80\x6d\x5b\x8c\xee\x25\xcc\x03\xcb\x39\x3a\x36\xbd\xaf\x01\xcc\xad\x7e\x90\xeb\x6f\xc3\x55\x71\x32\xa5\x73\xbd\x3a\x50\xa6\x1d\xa5\xbe\x71\xb8\x4b\xa9\xb0\xe6\x1e\x90\x37\x6c\xec\xfa\x86\x01\x0b\x4b\xf5\x62\x98\x89\x39\xc5\x48\x90\x94\x2b\xad\x80\x99\x88\x80\x9e\x16\xaa\x28\x4e\xe8\xaf\x80\x51\x25\xc8\x71\x10\x41\xe1\x90\xbd\x0a\xf7\x81\xc5\x8f\x38\x1e\xb1\xf3\xc1\xcd\xed\xe0\x4c\x33\xa4\x63\xf4\x20\x01\x7e\xaa\x34\xf5\x73\x4b\xde\x46\x1c\x0b\x23\x19\x28\x93\x8a\xe0\xa6\x60\x30\x22\x04\x17\xed\xf9\x83\xef\x6f\x00\xdf\xd5\x93\x37\x3c\x2b\xd9\xa6\x9c\x01\xe0\xaa\xb1\x2a\x72\x90\x33\xb0\xf7\x9c\xac\x5b\xfc\x5c\x5a\x91\x10\x7e\x03\x24\x91\xf2\xaa\xbf\xe0\x6a\x03\x80\x67\xfb\xf9\x95\xfa\xbc\x81\x6f\x57\xcd\xf3\x1e\x42\xec\xa4\x2a\xd0\x40\x0d\x60\xa8\xaf\x7a\x53\x99\x67\xa3\xa8\x28\xde\x02\xaa\xa3\x42\xfa\x13\x32\xc3\x0c\x89\x9c\xb1\x0a\x3c\x6c\x68\x69\x5b\x0e\x9a\xd9\xf4\xa8\xea\x35\xc3\x29\xcf\x19\x28\x0d\x10\xc6\x5a\x33\x18\x99\x11\xa6\xd6\x0c\xe6\xad\x80\x58\x2a\x43\x3d\x5c\x2c\x96\x9a\x81\x36\xc1\xb1\xd4\xf9\x93\xa0\xf4\xf2\x66\xd7\xb2\x0b\xca\x2b\x39\x95\xf4\xa1\xf2\xf7\x73\xbd\x96\x8d\xe5\xe3\xce\xdd\xdd\x63\xf9\xb8\xbe\xab\x98\x44\x8f\x9b\x5e\x36\xd5\xcc\xcc\xc4\x56\xae\x5e\x32\xf6\x2d\xf4\x53\x5b\x9a\x05\x0a\x96\x47\x8f\xe8\xfb\xfb\xcb\x0b\x34\xa5\x5a\xee\xd5\xd7\xca\x15\xd6\x32\xf6\x83\x48\x9c\x5d\xd8\xda\x56\x73\x91\xf8\xbb\x17\x36\xde\x89\x52\x81\x94\xa0\x6f\x34\x3c\x23\xce\xd8\x2b\x2c\xda\x5e\xa5\x34\x8b\xc0\x2c\xe6\xa9\x99\xc7\x89\xcc\xa7\x53\xfa\xf9\x58\x61\xf1\x4d\xc3\x7a\x98\xa8\x8a\xf1\xdf\xf9\x64\xac\x47\xb4\xe3\x45\x5c\xd7\x1c\xb2\x05\x95\xfd\xb2\xd9\x99\x9d\x9b\x77\xff\x2f\x9f\x40\xb6\x7b\x26\x38\x20\x00\x82\x77\xce\x46\x2a\xd8\x57\x1c\x25\x1d\x23\x97\x40\x55\x02\x39\x89\xb8\x10\xc4\x26\xc9\x9b\xda\xa2\x19\x16\x8a\x82\xb5\xd6\x81\xa4\x94\xd0\xf1\x8b\x2d\x0a\x4b\x7e\xcf\x71\x81\x44\x3d\x21\x04\x1c\x3c\x19\x4d\x36\x53\x7a\xcf\x4a\xbe\xc9\xca\x09\xb4\x91\xa7\x16\x37\x13\x0c\x32\x6b\x45\xac\xc1\x13\x61\x6a\x2f\xfa\x09\x34\x51\x93\xb6\xdf\xce\xcb\x60\x4a\x7c\x0e\xcf\x8b\xcb\xcd\x85\xf4\x86\x51\x4d\x4a\x60\xb8\xe7\x6d\xa2\x94\x75\xa9\x37\x39\xfa\x9f\x5a\xfb\x8e\xe1\xd5\xe5\x75\x59\x13\x1a\x6f\x57\xbb\x28\xf5\x5d\x84\xb5\x3a\x68\xff\x2d\x81\x7c\x24\x31\x56\x8c\x00\x40\xc2\x2a\xa7\xd5\x3d\x37\x7d\x6a\xda\xaa\x74\xb9\x76\xcb\xb7\x40\xad\x29\x35\xf3\x89\x40\x4a\xe7\x3e\x02\xd1\x37\xc9\xdd\x87\x81\x3c\x88\x04\x42\xa8\x57\x5a\xb1\x4c\x99\x71\xcd\xf9\xbc\x64\x87\x5b\xc8\xe8\x66\x30\x5a\x68\x24\x99\x20\x91\xbe\xca\x4e\xd1\x4d\x42\xb4\xe4\x95\x6b\xe9\x2b\x4f\x12\x87\xf0\xb5\x5a\x3a\xdc\x08\x95\xee\xc5\xe7\x15\xe8\x1e\x2b\x26\xe6\x10\xee\x56\xcf\x2c\x58\x83\xfd\x23\x2e\x04\xeb\x0b\x26\x64\x30\x24\x96\xb5\x48\xe0\xf0\x0b\x13\x37\x0b\xa6\x24\x5c\xba\xc8\xe8\xaf\x9a\xfd\x0a\x22\xe7\xbc\x31\xc9\x31\x9c\xed\xcb\xcc\xc1\x2d\xe5\x0b\x4e\xc2\xdd\x87\x4d\x71\xd5\x2d\xe4\x9a\xca\x1d\x58\x12\x71\x56\x4d\xd1\x57\x7f\xf0\xd1\x1f\x16\x6f\xd5\xde\xad\x76\x68\x70\x4b\x16\xa6\xb6\x10\xfb\xac\x70\x5d\x14\xca\xcc\xc2\xf8\x5e\xfd\xe7\x85\x01\xb9\x48\x09\xa0\x4a\x16\x55\xe7\x90\xbe\x6b\x9b\xb6\x58\xcf\x73\x9c\x8b\x8d\x20\x29\x0a\xd4\xf2\x4d\x38\xb7\x4d\x46\x29\x86\xa5\x17\xa1\x9e\x5d\xda\x62\x12\x20\x46\xdb\x50\x23\x59\x42\x82\xb3\x64\x63\x96\xb1\x56\xc5\x6b\x66\xca\xbb\xba\xd5\x40\x4a\x2e\x44\x99\x97\xf2\xae\x95\x28\xb0\x34\x81\x0e\x5b\x6c\x73\x6c\x31\x5b\x59\xc4\xd3\x1e\x20\x01\x2a\x01\x89\xff\x85\x03\xad\x2a\x38\x58\xa3\xf7\xba\xcc\xa7\xd2\xee\xb4\x4a\x73\x2a\x7d\xa1\x79\xc9\xf9\x8e\x1e\x38\x3d\x99\xc5\x18\x12\x47\x77\x89\xc2\x29\xcd\xdf\x78\x0f\xa0\x4d\x12\x23\x83\x5e\x60\x90\x8f\xed\xda\x79\xcf\x49\x86\x05\x61\x6a\xc4\x6e\xf5\x28\xcc\x17\x45\x24\x86\x8b\xc3\x71\x68\xf4\x50\xb3\x76\x8a\xb0\xfd\x0a\x16\xbd\x29\x10\x4e\x8e\xcd\x4b\xa0\x9a\xbe\x60\x92\xfd\x77\xe6\x1d\x83\x79\x60\x31\x7f\xf4\x54\xe9\xb4\x50\xe3\xb5\x00\x19\xcd\x29\x40\x0e\xc4\x44\xda\x0b\x89\x2a\x8b\x29\xe1\xc5\xef\x9c\x38\xfc\x65\xf8\xcc\xf3\xaf\x3a\x86\xed\x0c\x05\xcc\x19\xe8\xe4\x88\x05\x7d\xac\x80\xeb\x34\xca\xfa\x96\xaa\x04\xec\x33\x8d\xbd\xe3\x0b\xfe\x69\x76\x88\x0b\x3a\xa3\x2c\x28\x9a\x64\xa7\x97\xe2\x0c\xcc\xbb\xe6\x0c\xf2\xa9\xbf\xd3\xee\x6d\x96\xc1\x31\x8c\xf8\x7f\xfe\xfb\x6f\xc7\xb4\xc9\xfb\x21\xc7\x76\x05\x0e\x61\x27\x37\xdb\x96\x70\xe7\x03\x14\x91\x06\x74\x8a\x40\xa7\x95\xa5\xcc\x89\xe2\x57\x7b\xb9\x69\xa2\xe1\x6a\x6e\xdc\xbd\x65\x72\x07\xdf\x88\xc8\x57\x9c\x0d\x73\xc5\xbc\xed\x5a\x52\x09\xd9\x01\x7a\x24\xe6\x24\x7b\x03\x41\x58\x90\x7c\xc9\x4c\x33\x62\xc5\x27\xd2\xe0\xa1\x18\x78\x57\xf3\x43\xb1\x3a\x2d\x17\x66\x15\xef\x2f\x22\x25\x0a\x77\x78\x10\x8d\xec\xca\x67\x98\x28\x52\xdd\x7e\xe5\xa6\xad\x70\xee\x00\xe7\x70\x97\xa8\xcd\x39\x96\x2f\x17\x9a\x53\x5b\xf6\xc9\x58\xd3\x43\xe1\x61\x5d\x90\x8e\x19\xa4\xc9\xf6\xd4\x1b\x92\x4b\x22\x0c\xa7\xf3\x70\x58\x96\x12\x42\x14\x47\x88\xd1\x5c\xe3\x6b\x24\x29\xa6\x1b\xe5\x13\xe8\xf7\xeb\x31\x26\x4b\xce\x06\x3c\x23\x62\x1c\xe7\x6a\xe9\x58\xac\x8a\xf1\xd7\x1f\x9d\xe7\x6a\xb1\xbe\x7d\x99\xe0\xe5\xb2\x37\xab\x70\x3d\xf5\xfb\x0d\xcd\xae\x97\x98\x83\x10\x9f\xb2\xd4\xdc\x80\x9a\x49\x2a\xa8\x99\x36\xe6\xb4\x64\x22\x81\x1b\x98\x29\x80\xd4\x2b\x34\x29\x7b\x45\x1b\x6c\x6f\x18\x39\x9a\xe4\x85\x49\xc9\x57\x4b\x88\x8f\x47\xec\xa3\x29\x37\x02\x5a\x9e\x19\x40\x04\x09\x3f\xe4\x73\xc6\x25\x29\x65\xa0\xd5\x54\x40\xb0\x19\xa4\x76\x18\xf5\xc2\x7a\xf1\xd1\xee\xb2\xfa\x9b\xe3\x9f\x2e\x6f\xf8\xf2\x94\xeb\x29\x70\x27\x71\x30\xa2\x19\xd5\xb4\x33\xae\x3d\x69\x2f\x57\x85\xb7\x88\xe9\x02\x1c\x2c\x95\x2c\x7a\xc8\x4f\xaf\x42\x10\x09\x79\x22\x60\x4e\x87\x31\x86\x75\x2e\xca\x76\xbd\x06\x76\xb2\xee\x00\x15\xe9\x9f\xc0\x16\x50\x5c\x1d\x41\x39\x49\xae\x8e\x16\xcb\xe9\x3f\x3b\x67\xaa\xd5\x05\xa6\x6c\x20\x9e\xf7\xc3\x7a\x1f\x0b\xa2\x10\xf9\xac\x88\xad\x08\x7a\xef\x72\x09\x97\xd3\x0f\x50\x7d\x3a\x54\xb3\xec\xf8\xe2\xb5\x99\xfb\x2e\x83\xdc\x25\x4b\xc6\xee\xca\xb7\xc9\x83\x73\xcc\x62\x9b\x11\x6b\x95\x0c\x2d\x6c\xc1\xec\x8c\xd1\xcd\xe7\x0a\xd8\xbc\xce\x00\x28\xdd\xb4\x69\x10\xdd\xe1\x22\x73\x0a\xa3\x56\x59\x20\xbc\x82\x0b\x2d\xb9\xe7\x4c\xd1\x44\x13\x87\x1d\x83\x44\x53\x88\x8c\xb3\x40\x85\x10\xd9\xde\x84\x85\x47\xa5\xa4\x6c\x36\xb6\x2b\xe9\x92\x3b\xdb\x5d\x0c\x65\x9a\xba\x34\x4d\x99\x1f\xbf\x73\x0d\xad\x36\xaa\x1b\xb2\x06\x9c\x32\x97\x56\x0a\x1a\x07\xe3\x6e\x32\x16\x60\xce\x65\xa3\x8e\x69\x6c\x96\x82\x9a\xc2\xd3\x30\xd1\x4d\xec\xee\x20\xd3\x2d\xe3\x38\x14\x57\x88\xb4\xa9\xa2\x26\x01\x0c\x22\xf5\x55\x43\x2e\xac\x6c\xcc\x81\x1d\x32\x2f\xa2\xd9\xb2\x57\x3e\xd3\xbf\x92\x4e\x8b\x5d\x77\x36\x1d\x01\x27\xc9\x04\x47\x8f\x5e\x0b\xf3\xb6\x08\x2e\x5c\xd9\x00\x2d\x57\x42\x5d\x34\x43\x5c\x7a\xa0\x11\x48\x37\xa1\xb7\xd0\x20\xf9\xd8\x61\x17\x9d\x9b\x55\xb3\x10\x69\x06\xba\xc9\x8c\xde\xe4\x36\xc4\x24\x4b\xf8\x22\x6d\xb8\xcf\xaa\x29\x84\xbb\x44\xea\x34\x65\x30\xee\xf5\x2a\xab\x30\xbd\x8d\x2f\xb3\xa5\x7c\xa4\x3d\xe0\x4a\x6d\xc0\x25\x3f\x25\x7c\x02\x26\x55\x6b\x7e\x70\x39\x36\x41\xaa\x47\xf5\x3c\x6f\x9a\xf9\x53\x3d\x91\x54\x66\x89\x56\x66\x9a\x7b\x30\x39\x27\x2f\xbb\x6f\x06\xa3\x60\xbd\x75\xb0\x7d\xb4\x76\xed\xe7\x2f\x81\x60\x7c\xe1\x24\x01\xf3\xae\xe1\x5f\x15\x2b\x9b\x49\xf6\x3b\x36\x4e\x6a\xc5\x47\x4c\xe1\x99\xdb\x5c\x2b\x5c\xf2\x67\x46\x84\x9c\xd3\xac\x54\x2f\x71\xe7\xf0\x70\x4b\xd1\xf6\x3f\x26\x18\x7a\x03\xde\xc9\xb3\x23\x83\x50\xa2\xe9\x43\x66\x38\x2a\xac\xa2\x51\x82\xa5\xa4\xd3\x45\x00\x2c\xe2\x23\x6d\x21\x7d\xab\x6c\x46\x08\x4a\x94\xd5\x31\x1a\x33\xbe\xfd\x64\xd6\xef\x9e\x55\xf8\x50\x3e\x7e\x34\x0e\x11\xdc\xf4\x7d\xb2\x8c\x22\xe3\x6e\x6a\x8b\x26\xd3\x88\x44\x6b\x20\x04\xb6\xcb\x84\x5f\x09\xfe\xd3\x6c\x46\x28\x84\x49\x3b\x6c\xab\xc8\x78\xc0\x8f\x10\x0c\x47\x95\x52\x29\x61\xf3\xb5\xe2\xe4\xec\xc2\x9a\x38\x3d\x58\x08\x60\x2a\x14\x1f\xf7\x90\xdc\x09\x64\xab\x0d\x5d\x9c\x93\x84\xec\x25\xe2\x7a\x0b\x22\xa9\x86\x33\x04\xe4\xb1\x92\x34\x8a\x32\x03\xeb\x8d\x0b\x5b\x04\x82\x37\x40\xf5\xd4\x0f\xfd\x27\x33\x50\x1b\x0b\x5e\xb7\x8b\x60\x18\x84\x55\x6e\xab\xbb\xd4\x61\xfe\x99\x16\x2c\xc9\x15\xdd\x94\xe8\xaa\xe8\xd4\xcb\x2b\x87\x48\x6a\x6f\x1c\x32\xbd\x34\xae\x4f\xa4\x4d\x78\xc7\xda\x03\xb0\x15\x07\x5a\xe6\xd3\xed\xe8\xc2\x3a\x50\x15\x47\x33\xa2\x4c\xf5\xff\x98\x3e\xd1\x38\xc7\xc9\xbb\xa2\x89\xbd\x25\x7c\xec\x69\xf5\xeb\x0f\xf9\x66\xa7\xf6\x8e\x28\xe9\xae\x84\x25\x18\x45\xbb\x39\x07\xb8\x05\x87\x71\x2c\x8d\xe0\xfa\xc5\xcb\x2d\x3b\x83\x24\xd8\x91\x59\xa8\x80\xdf\x90\x40\x65\xe6\x18\xdb\x2f\x3c\x2c\x40\x09\x10\x0b\x97\x40\x04\xcd\x1a\xbd\x3d\xd7\xab\x92\xf6\x97\x2e\x7a\x6d\x4e\xe3\xd5\x51\x15\xd4\xdd\xc9\x83\x9b\xc9\x83\x0e\x64\xf3\x00\x2f\xff\xa6\x63\x70\x98\xf7\xcf\x01\x08\x87\x4b\x57\xe2\xfe\x44\xc4\x77\x44\x26\x07\x21\x29\x2e\x6d\xc5\x6b\xc9\x8b\x47\x0e\xe5\xa8\xc0\x0c\x3a\xdc\x2d\x3a\x8c\x93\x7c\x6b\xdd\x40\x2f\x77\xc1\xae\xa7\x97\xbd\xd0\x07\x00\x7e\x62\xc8\x8b\xce\x6d\x05\x11\x38\xbc\x41\x2c\xdd\x92\xef\x61\x4d\x94\xa2\x1d\x5e\xab\xf8\xc4\xa5\xe5\x7c\x89\xed\xb5\x49\x70\xad\x37\xf7\x25\x49\x6d\xd3\xb1\xec\x43\x47\x79\x61\x2f\x8e\xa5\xc6\xe0\x83\x2e\x58\xb8\xdd\x2d\x5a\x03\xad\xe3\xb6\x6c\x9f\x87\xac\xae\xec\xdb\xee\x69\xfc\x2e\xc7\x6f\x9c\x09\x32\xa5\x9f\xb7\x12\xc5\x6f\xe0\x53\xab\x5e\xea\x65\xae\x14\x92\x03\xf7\x0c\x14\x9e\x0b\x02\x1a\xed\x4a\xdb\x62\x53\x23\x56\x64\x46\xda\xb4\xc8\x47\xb2\x40\x5c\x94\x7e\xda\x16\x04\x72\xff\x45\xef\xcc\xbe\xce\x95\xca\xe4\xe9\xc9\xc9\x8c\xaa\x79\x3e\x39\x8e\x78\x6a\xe2\xf0\xb9\x98\x99\x3f\x4e\xa8\x94\x39\x91\x27\x7f\xfc\xc3\x1f\x8a\x2d\x9e\xe0\xe8\x71\x66\x60\x75\x96\xfd\x4e\xe5\x2d\x27\x58\xee\x16\xd9\xe3\x52\xd8\x5e\x38\x95\x39\xe8\xc6\x25\x8f\xea\x6f\xa4\xc2\x69\x16\x86\x82\x9a\xb2\x71\x52\xe1\xa2\x58\x05\xe4\x25\xea\x69\xa2\x39\xce\x32\xc2\x9a\xcd\x0e\x26\xd1\x74\x07\xd6\xe3\x52\x55\xed\x08\xc9\xe7\x2c\xc1\xac\x0c\xbf\x00\x95\x97\x04\x89\x08\x53\x16\x1a\xa0\x28\x25\x0d\xd4\x68\x20\x80\x0c\xff\xdf\x2c\x15\x11\xe6\x48\x65\x51\x52\xcd\x0d\xc7\x96\x37\x75\x45\x2f\x71\xb0\x74\xd5\x92\xb2\xc5\xda\x11\xb7\x6a\xab\x92\x14\xef\x96\x4b\x8b\x6f\x5e\xd2\x46\x70\x36\x26\x9f\x35\x93\x93\xdb\x02\x76\x3d\x48\x22\x51\xff\xa7\x3b\x24\x17\x4c\xe1\xcf\xa7\xe8\x92\x32\x10\x60\xbf\xe7\xb9\x90\xe8\x1c\x2f\x8e\xf8\xf4\x28\xe5\x4c\xcd\xd1\x25\xfc\xaf\xfd\xe9\x99\x90\x47\xf4\x33\xc1\xc2\xf2\x07\x5b\x92\xce\xd7\x37\xd7\x24\x24\x72\x26\x11\x79\xd2\x27\xf4\x0f\xff\x89\x52\xd3\xf2\x29\xfa\xf6\xe4\x0f\xff\x89\x7e\x07\xff\xff\xff\x47\xbf\x6b\xd0\xf4\x37\x83\xfc\x82\xca\xc5\xb7\x65\x77\x6e\xaf\xb2\x52\x5b\x54\x73\x3f\x13\xbc\xd8\xa9\xda\x96\x1f\x69\xf4\xc8\xa7\xd3\xb1\x26\x0c\x93\xc8\x37\xc6\x62\x09\x2e\x7a\x4b\xfc\x54\x6a\x6b\x4f\x9b\x4a\x76\x45\x0d\x19\xdb\xa9\x41\x7c\x70\xec\x5a\xe6\x45\xe5\x5d\x08\x22\x2a\x55\x33\xa6\x12\xbe\x22\xb1\xe6\xaa\x9b\x9c\x0e\x67\xdd\x73\xc9\xdf\xce\x82\x13\x22\xa4\x84\xf5\xd4\x7d\xe0\x5f\x18\xc5\x6a\x02\x7d\xec\x42\xd6\x1e\x87\xa5\xf0\xda\x2f\x26\x66\x12\xa6\xf6\x56\xf1\x92\x72\xa9\xf3\xf5\xa1\x92\x77\x5c\xec\xa4\x6f\x3d\x92\xc6\x54\x86\x35\xf5\x92\x5c\x0d\xdf\xb0\xb2\x3f\x64\x88\x73\xe1\x71\x8c\x8d\x5d\xc4\x56\x55\x5c\x6f\xc5\xa4\xc2\x04\x97\xb5\x3b\xf4\x7a\xea\xe7\xfe\x93\x75\xc3\x84\x48\x33\xf7\x76\x51\x2f\x0e\x46\xab\x45\x24\xcd\x12\x6b\x46\x5c\x03\x76\xb8\x6e\x43\xef\x3c\xbe\x05\x34\x0e\x61\x8f\x90\xbf\xc1\x9c\x64\x6b\x01\x04\xea\xf7\x33\x17\x11\x39\xe3\xbb\x85\xbd\x26\x94\x2d\xc5\xcb\xb7\x2f\x45\xe4\x57\xef\xc2\x16\x9d\x72\x78\xc0\x3c\x2e\x94\x05\xe3\x16\xb0\x55\x28\x02\x20\xd2\xf2\x6c\x00\xd0\x6e\x1f\x58\x97\x4b\xb5\x11\x76\xe0\xda\xc6\x70\x5c\x30\x3c\x57\x5a\xa3\x52\x51\x43\x60\xcd\x0b\x57\xc4\xae\x41\x50\xd1\xce\xe3\x08\xaa\xc4\x14\x91\x4a\x95\x6a\xec\xd8\x94\x4a\x11\x5b\x62\x95\x9a\x82\x4d\x3d\x24\x30\x04\x65\xaa\xb9\x6e\x4f\x12\x71\x34\xc5\x11\x65\xb3\x5e\x00\x53\x09\x90\x11\xe1\x75\x50\x47\xa4\xf7\x58\x3e\xee\x37\xd0\x70\xe7\x02\x96\x34\x2e\x8a\xa8\x59\x60\x19\xe3\xd8\xa0\x4b\x18\x7d\x0a\xcb\xc7\x26\x64\xa5\x25\x58\xb7\x15\xa3\xf3\x4b\xe1\xc0\xe0\x56\x8d\xcf\xa5\xa0\x93\x50\x9f\x82\x9a\x0d\xae\xa4\xb2\x05\x79\x74\x19\x7f\xd8\xa3\xb0\x54\xd1\x4d\x57\x8c\x5f\xce\xb9\x50\xe3\x2d\x71\x61\xab\x69\xf4\x8c\x1c\x25\x00\xe8\xc2\x9f\x88\x78\xa2\xe4\xb9\x0c\xaf\xba\x09\x2d\x1a\xa3\x59\x10\x55\x07\xf8\x9b\x69\xc6\x21\x85\x66\x8a\x52\xcc\x16\x86\x51\x6a\xe6\x82\xe5\xa3\xf4\x85\x5c\x91\x4c\x71\x92\xf4\x90\x20\xb9\x34\x05\x8e\x25\x49\xa6\x47\xae\x14\x46\x8c\x12\x3e\xa3\x11\x4e\xd0\x24\xe1\xd1\xa3\x34\x19\x6e\x6c\x66\x98\x54\x26\x78\x44\xa4\x0c\x24\xab\x22\x9b\xdd\xe6\x18\x42\x15\x57\x45\x44\x4a\x19\x95\x8a\x46\x4e\x64\x2a\x40\x29\x4c\x2d\xf1\x08\x83\x49\x18\x32\x36\x61\xb8\x5a\xd2\x23\x06\x9c\x33\x67\xb6\x68\x12\x5c\xd7\x16\x73\xcf\x05\x89\x37\x1d\xa0\x3d\x40\x08\x3a\x0a\x19\xab\xf2\x81\x5c\x73\xa4\xce\xec\x67\x70\x8c\x57\x91\xc0\x6d\xf9\x44\x79\x82\xf4\x27\xad\x04\x6b\x04\x31\xe5\x3e\x04\xbe\x24\xb9\xf8\xc8\xf0\x03\x43\x34\x83\x21\x37\xe0\x98\xad\xa3\x69\xbd\x8a\x20\xf2\x40\x9d\xae\xaa\xd7\x9c\xb2\x28\xc9\x63\x5f\xa9\x51\x8b\x00\x4f\x9a\x48\xdc\xf2\xe8\xb5\xd7\x82\x42\x0f\x61\x89\x9e\x49\x92\xe8\xff\x9a\x08\xf8\x23\x5f\x38\x41\xb3\x64\x53\xdc\x02\x3a\x71\x5c\xba\x89\xa2\x0e\x0e\x9d\xf2\x06\xab\xb9\xc9\xf9\x4f\xb9\x32\x45\x32\x0d\x3a\xa5\xb3\x6f\x19\x38\xc3\x49\xc2\x27\x70\xd2\x01\xb8\xd2\xe5\xb9\x06\x69\x75\x79\x14\x11\x12\x93\x18\x7d\x1d\x1c\x5c\x8f\x47\xf1\x4d\x3d\x8c\x62\x69\x45\x0e\x00\xb4\xb2\x6a\x58\x6b\x84\xae\x2c\xd7\x79\x3b\x46\x37\x15\x60\x96\xb0\x7e\x3b\xae\xc2\x74\xf5\x96\xb6\xf0\x6d\x80\x2e\x2b\x93\x78\xb9\x1d\xda\x10\xe8\xb2\xd4\xe7\x1e\x80\x2e\x2b\xf3\x6c\x88\xdd\xe7\xb3\x17\xcd\x39\xd6\x93\xba\xe0\xed\x13\xc1\x0c\x40\x98\xb9\x3b\x4b\x24\xe8\x0e\xe4\xa2\x8e\x10\x0f\x0b\xc4\xb3\x52\x0d\xf1\x6d\x41\x3c\x2b\x83\x39\x64\x10\xcf\xca\x50\x0f\x17\xc4\xb3\x66\xa0\x2d\x40\x3c\x8d\x73\x7f\xac\x89\xba\x1d\x53\x80\xc4\x96\x49\x3e\xbd\x83\x54\xef\x95\x63\x3c\x33\x81\x03\xe6\x1a\x73\x77\xb4\xc5\xb4\x86\xd1\xda\x1c\xc8\xa6\x70\xa8\x8a\x13\x62\x53\xda\xf3\xde\x37\x03\xfe\xb0\xa9\xd9\xbd\x17\x5a\xbb\xc1\x0e\x19\xe1\xcc\xe6\x94\x37\x95\x9a\x39\x9c\xec\xd9\xed\xf0\x51\x01\x83\xb0\xc4\xf2\x5b\x21\x88\x5d\x56\xaa\x36\xcc\xf9\xb3\xad\x9c\x04\x64\x68\x88\xb2\x91\x04\xa1\xd3\xb1\x55\xda\x9a\x56\x8e\x32\x45\x66\x55\x9d\xb6\x38\x34\x94\xa9\x3f\xfd\x71\x2d\x27\x32\x10\x8b\x4e\x3d\x0c\x6a\x27\x78\x67\x87\x7d\x46\x62\x14\xcd\xb5\x56\x24\xb5\xfa\xa2\xa7\x63\x6e\x56\x89\x52\x4c\x9d\x22\x95\x4b\xe3\x5a\xa2\x72\xc4\x4a\x98\xa4\xc7\xe8\x23\x14\x84\xc5\x69\xa6\xf5\x2f\x3f\x3f\xaa\x29\x69\x94\x7f\xfb\xed\x9f\x08\xfa\x16\xa5\x04\xb3\x92\x0e\x0b\x6a\x93\xbe\xfa\x00\xc3\x4f\xcd\xc9\x88\xd5\x6e\x05\x1a\x7c\x36\x35\xa6\x5c\xbc\xdf\x90\x4d\xb9\xd3\x89\xa1\xd0\x21\x8e\xe6\x48\xe6\x13\x53\xa9\x37\xb0\x61\x38\x41\xfa\x82\xcf\xc0\x51\x0d\x37\xb2\x1b\xf4\xaa\x53\xf8\xb2\x31\x00\xd6\xdd\xd8\xf6\x36\xee\xc3\x3d\x72\x24\x49\x09\xdb\xa9\xc6\x69\x66\x38\x5f\x78\xf0\xa5\xc1\x7d\xe9\x19\x1f\x82\xd6\xcf\xb0\xb5\xec\x6b\x59\x1a\xc2\x79\xc1\x4b\x96\x27\x58\xd8\xa3\x3f\x62\x5a\xd1\x10\xe4\x89\xf2\x5c\x26\x0b\x14\x73\x46\x7a\x40\x09\x79\x34\x37\x8e\x55\xad\xb3\x60\x5b\xb0\xe2\x89\xca\x5c\x2b\xb4\xd0\x96\xab\x8f\x21\x15\x36\x98\x54\x73\x0a\xfd\x68\xf5\x9b\xc0\x57\x61\x96\x1c\x6a\xa7\x45\x85\xb0\xb1\x15\x9e\xdf\x12\x36\xb6\x44\x55\x1d\x6c\xac\x87\x8d\x5d\x5e\x97\x43\x84\x8d\xad\xec\x79\x3b\xd8\xd8\xba\x2d\xdf\x02\x36\xb6\xd4\xcc\x17\x03\x1b\x5b\x59\xd1\x2f\x06\x36\xb6\x32\xaf\x0e\x36\xf6\xcb\x83\x8d\xdd\x11\x18\xb5\x9e\x17\x1b\x7c\x25\x45\xd9\x62\x63\x22\xfb\x4a\xa2\xe1\xb5\x26\xb0\xe8\xb1\x1c\xd4\xe6\xaf\xab\xdd\xc1\x58\xeb\x99\xd0\x66\x60\xac\xb5\xaa\x7a\x33\xab\xdb\x15\xe0\x09\x14\x83\x57\x06\x63\x2d\x4d\xa0\x8b\xaf\xdc\x3c\xbe\xb2\x96\xf8\x6c\xdf\x7a\x78\x2e\xe8\xb2\x7a\x21\xb7\x84\x63\x2d\xed\x4f\xab\x48\x4c\x10\xdd\xf7\x40\x89\x2f\x2b\xcd\xdf\x97\x0e\xf9\x5a\x59\x3e\x5c\x45\x69\x81\xa1\xb5\x84\xe7\xd0\xe2\x8c\x12\x1e\xfa\xff\x3b\xca\xdd\x22\x32\xb8\xb2\xbc\xde\xaf\x62\x68\xb1\x05\xa9\xb6\xa6\x50\xa7\x95\xee\x27\x51\xd6\x25\x4f\x6e\xe8\x62\x76\x83\xb8\xcb\x48\xd4\x60\x63\xa6\x29\xdd\x57\xb3\xeb\x2e\x32\x8f\x85\x05\x0a\xf9\x52\x5e\xa8\xbe\x9e\xcc\x70\x8c\x8c\x5f\x49\x87\x05\xa0\x0e\xf3\xe5\x8c\x4a\x25\x1a\x63\x9b\x96\x46\xb8\x8b\xab\x34\xcb\x5b\x07\xc4\x04\xab\x3a\xdb\xee\xb3\x94\xa4\x5c\xac\x0b\xac\xaa\xfd\xd2\x96\xba\xd9\xe6\x53\x92\xcd\x49\xaa\x25\x99\xf1\xa6\x8d\xb4\xdd\x6f\x9f\x34\x6c\x73\xd7\x4c\xa0\x63\x89\x08\x02\x47\xa8\x7e\x37\x36\x88\x94\xad\xb7\x7b\xd7\x6d\xb6\x98\x99\x1b\x3a\x84\x1c\x98\xf2\x6a\x83\x9b\x7d\xa9\xe4\xee\x06\xfa\xae\x8d\xe9\xf0\x21\x35\xeb\xa3\x36\x56\xc4\x6b\xac\xc2\x9d\x2a\xbe\xb2\x85\xa0\x37\x70\xe5\x97\xbd\xf3\x9a\x13\x86\x55\x80\x37\x0f\xf0\x68\x40\x4d\x5d\x5e\x1e\x88\xcc\x91\x44\x1c\x85\x9a\x41\x69\x30\xcb\xeb\x55\xa2\x12\xa7\x51\xee\x40\x24\xb9\x68\x8c\x32\x6d\x63\xd0\x8e\x54\x8e\x13\xd0\x24\xc2\xea\x95\xd5\x4d\x9d\x2c\x6a\xd2\x1e\xdb\x79\x4c\x28\x53\x7f\xfe\x8f\x8d\x76\x53\xab\x56\x76\xdd\xa0\xe2\x16\x8e\x22\x22\x8d\x8d\xdd\x46\x21\xe3\x09\x7f\x82\x62\x5b\xbb\xec\xaa\x3e\xca\x7a\xde\x9a\xc1\x7b\x28\xe2\xb8\x20\x75\x23\x2e\xcc\x05\xcf\x67\x73\x67\x43\xd2\x67\x46\x4f\xad\x6e\x2f\x7f\x5c\xb2\x91\x6f\xbc\x97\xdf\xe5\x34\xd9\xce\x42\x77\x57\x2a\x43\xf6\x69\x78\x8f\xe4\xdc\x9f\xd6\x09\x34\x5b\xbb\xb1\xcb\x83\x6e\xdf\xa7\xfd\xd6\xfb\x6b\xa0\x9b\x9e\x83\xdf\x9c\xf2\x24\x01\x4f\x83\x24\xe9\x13\x11\xf5\xdd\xc3\x84\xef\xe9\x66\xc8\x79\x7e\x00\xf0\x75\x91\x18\xd1\x4a\xfe\xba\x31\xa2\xa1\x44\x6e\xf4\xd5\xa0\x05\x13\xaa\xc6\x19\x61\x75\x36\xb6\x9f\x96\x2b\xc0\xbc\xb3\x80\x41\x17\x3d\xb6\xb7\xa0\x41\xb7\x24\xaf\x1c\x38\xb8\x66\x1e\x87\x1a\x3c\x58\x61\x76\x3e\x96\xaf\xb8\x66\x5c\xe0\x90\x51\x7c\xfa\x7a\x89\x47\xac\x5f\xca\xa7\x70\x95\xb2\x27\x8b\x22\x20\xdb\xe8\x10\x21\x33\x83\x3a\x1b\xd6\xb0\x02\x6e\x34\xfd\x17\x68\x3a\x06\xbc\xd6\x84\x14\xba\xb0\x41\x88\x26\x27\xf1\x11\x8e\x16\x51\x42\xa3\x40\x67\x9e\x09\x9c\xcd\xeb\x38\x9e\xdb\xf9\x0e\x75\xe7\xad\x50\x77\x9a\x0a\x52\x6d\x12\xb7\xed\xe8\x8a\xe1\x94\x74\x68\x40\x75\x68\x40\x3d\x8f\x77\xc1\x8a\xd2\x5a\x6f\x08\xa3\xb0\x7c\xee\x3a\x48\xa0\x37\x80\x04\xda\xe6\xf0\x15\x78\x3f\xa5\x63\xd7\xc1\x14\x7d\x68\x05\x53\xe4\x2f\xc1\x83\x42\x9e\x69\x3e\x8f\x6f\x8c\x68\xb2\x3c\xb0\xb7\x84\x25\xaa\x11\x17\x36\x91\x9b\x56\xe1\x12\xad\xa2\x8b\x56\xeb\xf2\xb6\x28\x41\x9b\xad\xcc\x46\x00\x40\xb5\x77\xd7\x81\xc0\x01\x35\x6f\xc3\x81\x9c\x9b\x7d\x66\xb5\x6c\x56\x3b\x34\xcc\x6c\xd9\x44\xc1\xda\x2c\xc9\xc5\xd3\xc3\xfb\x4a\x74\x29\x8a\xac\x6d\x97\xec\xd2\x77\x3e\x68\x22\xd0\x9c\x27\xb1\x03\xa1\xf0\xab\xe5\x3b\xf0\x99\x00\x7e\x81\xdc\x66\x40\xb1\x73\xd0\xb6\x8a\x82\x60\xab\x52\x5a\xfc\x26\xc2\x70\xf7\xc0\x68\xf6\x61\x45\xf0\x9c\x64\x1b\xfb\xc1\x5a\x59\x44\x96\xcd\xdf\x2b\xc6\x58\x5a\x21\xb0\x9a\xd7\x0f\x73\xad\xdd\x77\xcd\xe0\x56\x89\x1e\x81\x71\x50\xd4\x95\xfa\x34\x74\x06\x4f\x9f\xa8\x33\x44\xe0\xb0\xc7\x95\x5e\x3a\x37\xbb\x56\x9e\xba\x2a\xb1\x6c\x11\x0c\xb6\x54\xb9\x6d\x77\x70\xa0\x14\x7f\x1e\x67\x58\xe0\x24\x21\x09\x95\xe9\x8b\x05\x03\x9f\x95\xdd\xb5\xfa\xac\x0a\x6e\x4c\x44\x2c\x4f\x27\x86\x14\xdd\x40\x6c\xb1\x3f\xc5\x91\xc8\x59\x08\x6d\xe6\x37\xc6\x17\x13\xcc\xe1\x5e\x00\xab\x52\x34\x87\xaa\xad\x53\x4c\x05\x23\xb2\xb1\x46\x26\x89\x72\x41\xd5\x62\x6c\x4b\x8e\xb6\x3f\x70\x77\xf6\xcb\x33\xfb\xe1\x6a\x0f\xb7\xcb\xea\x77\xfd\xf9\x12\xa7\x19\x11\x50\x26\xc8\x15\xbc\x09\xca\xaa\x5a\xd4\x06\xe2\x6b\x0d\x41\xf8\xf3\xd2\xb5\xdd\x14\x38\x8c\x9f\xc7\x41\x46\xd5\x38\xaa\x12\xc7\xba\xc3\x5a\x87\x3b\xb5\x6a\x92\x2f\x8c\xbc\xd4\xe0\x45\x7e\x81\x2a\x23\x36\x6d\xc2\x34\xad\x07\x1c\xb8\x82\xc1\x5e\x59\x6c\x4c\x90\xf2\x6e\x95\xaa\x86\x71\x5a\xac\x9f\xba\xe0\xa3\x15\x83\xed\x07\x5f\xb5\x18\x71\xd0\xc9\x9e\x86\xad\x0f\xba\x10\x79\xa6\xe8\x64\x19\xda\x46\xed\xaf\x84\x68\x3f\x81\x34\x6b\xe7\x66\x28\x75\x6b\xea\x8a\x96\x38\xb1\x9d\x9d\x96\xff\x2d\x8e\x98\x43\x08\x32\x08\x4b\x61\x1e\xdf\x75\x4a\x95\x72\x89\x02\xc6\x00\xad\xa9\xb3\x6c\x9b\xfd\xca\x85\x7b\x60\xa8\xf4\x6a\x4c\x44\xc7\x23\xd6\x97\xe8\x99\x20\x46\x2c\x84\x44\x4d\x0d\x57\x6f\xd5\x86\xda\x4f\x13\xa2\x7b\xf2\xb1\x29\x5a\x78\xa0\x4a\xfa\xf2\x63\xa6\x8f\x29\x4e\x24\xe9\xe9\x86\xa1\x6a\xa9\xe2\x10\xfc\x89\xd1\xb3\xc0\x59\x46\xc4\x88\xd9\x2c\x0e\x70\xb8\x70\x9e\x98\xf6\x9b\x42\x5c\xed\x1a\x90\x71\x84\xa3\xf9\x2b\xed\x11\x86\x64\x9c\x68\x4e\x62\x97\x2f\x5c\xde\x1e\x37\x6f\x63\xb0\xde\x60\xb3\x86\x53\x57\x3e\xab\x67\x3b\x49\x22\xcd\x51\x7c\x99\xe9\x8c\x08\x3d\x6a\x4d\xc3\x4f\x84\x21\x3a\x75\xe3\xb0\xb1\x3b\xe8\x19\x3c\x53\x9a\xf4\x9f\x30\x4d\x4c\x02\xbe\xeb\xda\x09\x81\xc6\xfc\x3e\x62\xc6\xdd\xcd\xa2\x52\x86\x2a\x65\x54\xce\x35\xa7\xce\xc1\x27\x09\x6a\x46\x53\xe2\x0c\x7b\xda\xe4\x34\x0f\xf4\xeb\xab\x39\xe8\x13\x15\x9c\xa5\x90\x24\x63\x71\x99\xdc\xf2\x49\xa2\xfc\xf1\xa8\x4d\x71\x5c\x2b\x11\xc7\xb1\x2c\x1b\x3f\x8d\x5a\x49\x7f\x2d\x99\x5d\x8e\x4a\x59\x81\x51\x00\x2b\x04\x41\x9c\xae\xb2\xd8\x2a\xf9\xb7\x4b\x6d\x58\x4e\x6d\xa8\x5f\x9b\x43\x4c\x6f\xf0\x87\x78\xd3\x14\x87\xa6\xed\xdf\x87\x64\xbb\xc7\x54\x87\x37\xce\x09\x78\x99\x74\x80\xb7\xcd\xdf\x78\x89\xd4\x8d\x2e\xc1\xe1\x0d\x13\x1c\x5a\x5b\x6a\xcb\xb1\xd9\xcd\xc7\x76\xa3\xe4\x80\x35\x60\x4e\x75\xbd\x5c\x12\x25\x68\x24\xf7\xc1\x1f\x64\x86\x5b\x46\xb5\x81\x16\x98\xad\x91\x9a\xf4\x0b\xde\x09\x09\x71\x62\xbe\xce\xdf\x44\x10\xfc\x18\xf3\xe7\x25\x5b\x9d\x0c\xd1\x34\x2e\xb9\x16\x7b\x04\x89\xa8\x24\xa5\x48\x16\x2a\x11\x23\xd2\x1a\x3b\xf1\x88\xcd\x29\x11\x58\x44\x73\xc8\x6e\x2c\x36\xc6\x64\xc9\x1a\x40\x23\x13\xcb\x10\x7a\x9b\x36\xd8\xf4\x16\xeb\x5e\xb5\x30\x79\x7c\x3a\xbb\xe7\x7a\x24\xa9\xf9\xc4\x0b\x33\x56\xca\x08\x4d\x72\xad\xb6\x7f\xd7\x40\x7c\xbf\xd8\x2f\x1a\x8c\xef\x83\x89\x82\x2f\x5a\x06\xe4\x17\xd4\xd0\x05\xe5\xbf\x50\x50\x7e\xcd\x12\x6f\x16\x98\xbf\x95\xc9\xef\xf5\x63\x86\x5d\xcf\xaf\x11\x37\xbc\x2e\x68\x2b\x9f\x8c\x5f\xfc\xe8\xd5\xce\xb9\xed\x09\xfc\xc9\x13\x85\x91\x88\x85\xa6\xb3\x09\x89\x63\xe0\xb4\x8a\xdb\x4a\xd1\x05\xed\x38\xf3\x80\xbe\x7b\xb1\xd4\xc4\x8e\x13\xce\x66\x92\xc6\x06\x6c\x25\xc3\x50\xb1\x35\x34\x5e\x00\xb8\x00\xec\x6f\x92\x10\xe1\xbc\x12\x02\x7d\x2d\x29\xb3\x68\x8a\xfe\xb7\x98\x13\xc9\xbe\x52\xc6\x58\x80\xd9\x02\x3d\x32\xfe\x9c\x90\x78\x06\x3b\x54\x1d\xcc\x11\xa2\xa4\x87\xa8\xf2\x9f\x09\x40\x23\xe0\xb9\x1a\xe9\xb1\x43\xac\x99\xd1\x00\x88\xfd\x36\xa8\x89\xee\x9b\xf9\xe6\x18\xa1\x21\x43\x53\x1c\xa9\x1e\x92\xf9\xa4\x68\x3f\xe6\xa6\xc8\xb5\xd6\xbe\x83\x89\x17\x8d\x74\x31\xe3\x35\x9d\xd7\x9f\x0d\xc7\x1d\x34\xb9\xf6\x13\x8a\x77\x8a\xad\x7b\xc2\xbb\x40\x8c\x5e\xe6\xd2\x06\x61\x20\xce\xfc\xd1\xb7\xf0\x4a\x1e\x23\x1a\xf0\x3e\x0d\xde\x32\xe3\x71\xa3\xad\xb3\x32\x95\x4d\xc7\x52\x04\x42\x5a\x41\xc9\x3a\xaa\xa0\x5d\xb3\xdc\x5a\x6a\x92\x4a\x10\x9c\x5a\xe7\x80\xbe\x6a\x40\xac\x31\x61\x90\x7a\xf4\x54\x18\x09\x73\x93\x2d\xbe\xa0\xec\x51\xef\x6e\x81\x8a\x0d\xf5\xe5\xa1\xe7\xba\x4d\xcb\xf4\x8d\x47\xce\x38\x33\x0e\xc2\x9d\xe4\x4e\x3a\x63\x38\xd9\xd0\xc6\xb1\xb4\x72\xcb\x3e\x3d\x27\x67\x59\x71\x41\x4b\x11\xc6\xd8\x87\x4c\x8f\x1b\xd9\x90\x2a\xf3\x0d\xe5\x3d\x8c\x62\x92\x11\x16\x13\x16\x2d\x80\x44\x18\x20\xe7\x08\x86\x13\x84\xe1\x3b\x9c\x1c\xa3\x73\x93\x5f\xe3\x25\x3c\x7b\xad\xc3\x85\x9e\x62\x46\xa7\x5a\x4f\x00\x23\xac\x1d\xe5\x88\x99\x61\x3a\x1f\x48\x50\xb4\xdf\xaf\x58\xdd\xce\xe8\x1b\xe4\x6a\x47\x54\x62\x56\xfe\x1e\xad\xbe\x70\xa0\xb7\x55\xbb\xa3\x9b\x73\x35\x08\x64\x3e\x39\x82\x7f\x97\x12\xce\x1c\x50\x4f\x81\x22\x43\x12\x02\xe6\x40\xeb\xf1\x82\x8b\xb1\x09\x58\x6e\x1f\x7e\xbb\x35\x79\x1c\x41\x1f\x25\xa5\x26\xa5\x8c\xa6\x79\x1a\x38\xef\x4c\xc5\x82\xc8\xda\x2f\x4d\x26\x46\xa6\xf5\x80\xc8\x81\x97\x23\x7d\xb9\xb2\x05\x9a\xd1\x27\xc2\x46\x2c\xe3\x94\xa9\x63\x74\xc5\x15\x09\x4a\x44\x18\xe8\x28\x9e\x29\x9a\x1a\xb4\x53\x41\xf4\x39\x30\xa0\xd8\x00\x34\x39\xc7\xaa\x87\xe2\x1c\x8e\x2a\x23\x4a\xb3\x0e\x7d\xe3\x2a\xd8\x19\x88\x8f\x16\x23\x66\x6e\xba\x29\xa6\x49\x2e\x88\x95\x59\xb1\xc9\x8b\x29\x86\x5c\x8c\xcc\x22\xa1\x05\x93\x48\xe9\x6c\xae\xf4\x16\x69\x19\xcf\xfa\x1b\xe7\x9a\x1b\xf1\x11\x9b\x10\x84\x51\xc6\x25\x55\xf4\xc9\xfb\x2f\xe9\x14\x61\x29\xc1\x82\x72\x8c\xce\x4b\xf6\x7f\x2a\x41\xf5\x6e\x8a\xab\xa5\x6c\x6c\x6d\xcf\xcd\xf9\x38\x3b\x6f\x64\xa9\x17\xbb\xca\x78\x22\x79\x92\xab\xd0\x05\x5b\xbf\xb7\x85\x69\xdc\x01\xf7\x83\x81\x98\x4f\x47\xcc\xd1\xb5\x3c\x46\x7d\x89\x24\xd7\xbb\x24\xcd\x56\x46\x82\x2a\x22\xa8\x41\x71\x22\xca\x6c\x82\x3f\xa7\xfe\x0c\xa4\x58\x3c\x6a\x11\x2a\xb4\xc0\x1b\x4c\xd1\x92\xb5\x63\x62\x24\x24\x80\xb5\x0a\xb7\x03\x4c\xff\x88\x71\x76\xc4\xc8\x0c\xaf\xdb\x91\x11\x2b\x6d\x09\xfa\x9a\x4e\x0b\x85\xb4\xc9\xe7\x18\xac\xdd\x18\x22\x9f\x9a\x76\xc9\x74\xdc\xb4\x49\xd3\x84\xe3\x35\x6e\xe3\x69\x71\xe8\xd1\xdf\xf9\xc4\x8c\x51\xeb\xfd\x5c\x81\x14\xa8\xd5\xab\x29\x17\x64\x8e\x59\xdc\x73\x9b\x55\x1e\x1b\xdc\x8c\xd6\xd4\xe6\x94\x31\x90\x04\x1d\x88\x30\x31\x58\x4c\x98\x05\x7b\x61\x15\x37\xbb\x15\xc5\x3e\x6c\x74\x57\xf8\xd6\xa0\xf6\x89\x31\x40\x18\x96\xb7\xc8\xec\x11\x97\x34\xcd\x92\x22\xa7\x29\xb0\x8d\x4e\xb5\x88\xe5\x78\x24\x7f\x02\xd3\x95\xd3\xda\xe0\x56\xb7\x3b\xa7\xe9\xac\x66\xe4\x9e\x91\xc2\xad\xe1\x6c\x5e\xa6\x0c\x66\xc0\xc2\xbe\x96\x44\xff\x53\x91\x42\xed\x33\xc2\xfa\x88\x39\x11\xe4\x1b\xe0\x32\xb6\xd9\xc0\x78\xa6\x45\x68\x03\xf3\x6a\xd7\x0f\x45\xc6\xc9\x5d\x3a\x27\xf6\x30\xb8\x57\x6b\x2e\xaa\xef\x28\xc3\xa5\xcc\xdb\x2d\x04\xbf\x24\xdf\x28\xb9\x2a\x70\xfb\x2d\x9a\x6a\x9a\x28\xbc\xae\xcc\xc8\x06\x94\x60\xf6\x99\x20\xdd\x9d\xa5\x66\x57\xf1\x06\x43\x44\xc0\x9c\x24\x19\x8a\xe9\x14\xcc\x52\x0a\xd8\xb7\x07\x16\x33\x58\xf0\xfa\xb0\xa7\x39\x33\x20\x71\xc6\x23\xf2\x6c\xf1\xb6\xed\xd5\x58\x34\x7e\x3c\x62\x43\xf5\x95\xd4\x22\x3a\x67\x33\x7d\xd1\xc4\x4f\x54\x16\x45\x4e\x22\xce\x64\x9e\x12\x61\xbb\xd0\x37\xb2\xa6\x48\x5b\x20\x00\x3b\x19\x4a\x8f\x4d\xef\xfd\x13\x4e\x68\xec\x0a\xf1\xe8\x1f\xcd\x99\xd3\xa3\x94\xce\xa3\x58\x13\x12\x66\x37\x37\xd6\x6b\xf5\x66\x62\xfd\x8f\xa1\xe4\x8e\xd2\x42\xc8\xc7\xd6\x56\x7f\x52\x15\xf1\xed\xaa\xaf\x10\xef\x27\x4b\x93\x42\xab\x05\x23\xbb\x0a\xe7\xeb\x50\x0c\x1d\xa2\x6e\x6e\x42\x80\x75\x3f\xce\xe8\x63\x06\xb7\x11\xfb\xa9\x4c\xd0\x8e\xda\x70\x96\x50\xbc\x27\x14\x64\x03\xa9\xb0\x16\x2f\xcc\x75\xc0\x85\xd5\x70\xec\x9d\xd3\xbc\xb5\xe7\x3b\x96\x89\x90\x11\x4e\x96\x77\x78\x85\xbd\xd9\xbc\xbf\x5a\x09\xb0\xc7\xcd\xb4\xbd\x32\xe9\x37\xe2\x49\xb2\x49\x09\x93\xca\xcc\xcf\x8a\xcf\x57\x8f\xa8\xe8\x47\x6f\x80\xdb\x0b\x38\x35\xe6\xf2\xc6\x89\x35\xa5\x48\x65\x77\x29\x7c\xc9\xa8\x61\x0b\xcb\x5a\x47\x8c\x4f\xa1\xc8\x4d\xd2\x14\xd5\x95\x09\x9e\xd2\x4d\x50\x96\x4d\xa0\xd3\xad\xb3\x8b\xaf\xb1\x32\x38\xeb\x39\x88\xa6\x86\xbc\x6c\x8f\x90\xaf\x87\xad\xb8\xb9\xe2\x0c\xa5\x38\xdb\x6a\xc1\xd7\x79\x85\xfa\x28\x35\x2e\x39\xbb\x7a\x80\xb7\x48\xa0\x5e\x0c\x2c\xf2\x33\x5e\x14\xa9\xd1\x4d\xf8\xb9\x6c\x23\x72\x78\xd0\xaf\x0f\xd9\x94\x6f\x70\x38\x8b\x54\x66\x7b\xfa\xb0\xa3\xd9\xe0\xfc\x79\x2f\x85\xd9\x7d\xb3\xa6\x6d\xce\xe3\x59\x1d\x51\x6f\x7c\x32\xdd\x0a\xbe\xa4\x8d\x32\x64\x22\xa1\x79\x72\x93\xbb\xb5\x7c\xb4\x82\x16\x11\x0c\x67\xf5\x52\x5d\x96\xe8\x70\xef\x6b\x54\x69\x07\x19\x53\xb8\x0b\xa6\xbe\xa9\x6f\xf5\x15\xd6\xcc\x1e\x92\x56\x8b\xb5\x23\x76\xc3\x66\x38\xc0\xae\x47\x8f\xfa\x5b\x7f\x42\xd7\x16\x39\x68\xbf\x18\xc0\xcd\xa4\xb5\x73\x15\x91\x99\x36\x45\x6d\x4a\x13\x2d\x62\x0f\x6b\x0c\x9c\x2e\x41\xcc\x07\x54\x99\x50\x79\x27\x3d\xe5\x82\x06\x85\x41\x9d\x8c\x84\x28\x14\x28\x09\x9d\x3c\x81\x42\x0f\xa6\xc5\x39\x7f\x36\xd1\xe9\x82\x6a\x9e\x65\x84\x55\x05\xe6\x1e\xcd\x0b\xa8\xb5\x96\x18\x63\x93\xff\x80\x9b\x98\x41\x6c\x6b\x1f\x17\xa3\x6a\xd8\xd2\x7d\x94\x78\x6a\x9f\x7f\xe7\x7a\xbd\xd7\x5f\x2c\xef\x4d\xed\x08\xef\xcb\xad\x6f\x3c\x3a\x2f\xe5\x6f\x1e\x30\xf5\x11\x3e\x75\x4a\x0f\x46\x53\x41\xc0\xc1\x9f\x7a\x4c\x0d\x03\xaa\xcb\x39\xdc\x77\x77\xe7\x3f\x9c\x3c\x0c\x11\x51\x11\x4a\xe8\x23\x19\xb1\x48\x3e\xf5\xb4\x78\xfc\x8f\x9c\x28\xfd\x73\x83\x47\x80\xa6\x84\x49\xe0\x04\x54\x2d\x61\x0f\xd5\x2f\xa4\x5b\x18\xfd\xdf\xf3\xf2\xf7\x2b\x48\x7e\x29\x7d\x18\x68\xd7\xd5\xbb\x01\x32\x85\x92\x1e\x66\x69\x65\x0d\xc5\x18\x5b\xe4\xa0\xae\x1a\xe6\x16\xe9\x42\xec\xef\x39\xdb\x50\xe8\x3a\x2b\x3e\x0a\x46\xd1\x20\xd3\xa5\x19\x06\xac\xeb\xcd\xf2\x90\xcc\x37\xb5\xad\xaf\x63\x22\x45\x5a\xb6\xb3\x2d\x17\x85\x43\x91\x12\x84\x00\x0b\xf1\xf4\x64\xef\x7a\x8b\xc4\xe1\x27\x16\x7c\x74\x3c\x62\x97\xce\xe3\x5c\xfc\x2a\x0b\x3d\x3c\x9d\x04\x10\xe0\xe5\x56\xa0\xd9\x98\x4a\xff\x03\x14\x74\x91\x79\xa2\x4c\x45\xbb\x29\x65\x38\xf1\x03\x35\x4f\xea\xb8\x84\xc0\x2c\x9a\xef\x6a\x42\xa6\xd3\x31\x49\x36\x91\x44\x87\xd3\x41\x22\x35\x7d\x47\x8f\x0d\xa7\x73\x9b\x9a\x8d\xc5\x64\x6c\x25\x5a\x53\xf7\x09\x15\x26\x68\x9c\x98\x8a\x72\x04\x81\x8f\xb2\x9a\x3d\x66\x00\x22\xf4\x2e\x5a\x49\xdd\xb8\x28\x4d\xda\x86\x0f\xc9\x86\x5e\x10\x56\x23\x26\x72\x06\xc5\x26\x7c\xc4\x02\x46\x05\x5e\x78\xe4\xfc\x07\xd6\x9b\x33\xd3\x6c\xc2\xc0\x71\x9b\x97\xb5\x7e\xc6\x73\x09\xb6\x9a\x94\x28\x7d\x41\x7d\x0d\x75\x60\x4d\xc8\x50\x0f\x65\x82\xa6\x60\x6e\x95\xdf\xd4\x6c\xdd\x19\x56\x38\xe1\xb3\xbe\x50\x74\x8a\x23\x75\x8f\x77\xd2\xc0\xb1\x6d\x66\xdb\xf0\x53\x37\x0c\x34\x3c\xd7\x8b\x3f\x23\x8c\x08\x98\xa8\xd6\xc9\xeb\x8f\x30\x3c\xd9\x8a\x73\x83\x95\xcd\x1a\x46\xa5\xb7\x58\xe0\x5c\xf1\x54\xeb\xb7\x38\x49\x16\x3d\x63\x91\x25\x68\x8e\xe5\xdc\x6d\xb4\x31\xa6\xb5\xb9\x9b\xec\xe2\x9e\xe1\x68\x4e\xee\xa0\x2a\x72\xdd\xe2\x56\x46\xf9\x81\xb0\x3c\xfd\x70\x8a\xfe\xa7\x98\xe3\x59\xff\xec\xfb\xc1\xf8\x7c\x78\xd7\xff\xee\x62\x70\x1e\xcc\xc7\x3e\xb9\x1c\xde\xdd\x2d\xff\xfa\xfd\xf0\x7e\xf9\xc7\x9b\xeb\x9b\x87\x8b\xfe\x7d\x5d\x2b\x17\xd7\xd7\x3f\x3c\xdc\x8c\x3f\xf6\x87\x17\x0f\xb7\x83\x9a\x4f\x1f\xee\x9b\x1f\xde\xfd\x30\xbc\xb9\x19\x9c\xbb\x55\xf9\x5b\x70\xba\xc0\x7a\x0c\xa9\x17\xf5\xd3\xa8\x1e\xc0\x23\x54\x7e\xf1\x14\x3d\x54\x4b\x1f\xd8\x58\x64\x83\x63\xf1\x8c\xa5\xe6\x61\x10\x0a\x3f\x62\xc8\x7d\xae\x17\xa5\xe9\x53\x13\xae\x13\xcd\x09\x4a\x38\x7f\xcc\x33\xcb\xda\x4c\x7c\x18\xe3\xc6\xf0\x43\x64\xd0\xda\xf7\xc3\xfb\xd3\xe5\x12\x0c\xbe\xb1\x00\x31\xcb\x9d\x01\x18\x17\x76\xec\x14\x6c\x29\x0e\x9a\xbf\xb0\xde\x06\x3d\xf8\x9d\x59\xd5\x8f\x69\x0d\x33\x55\xe9\x26\x8e\x6d\xd1\x5f\x37\xb1\xa0\xe1\xf2\xbe\xae\x5a\x4d\xbf\x1c\xa6\xf6\x14\x9a\x90\x08\xe7\x26\xa8\x49\xdf\x53\x42\x70\x11\x0e\xb8\xa0\x87\xfd\x35\x6a\xe9\xa8\xb6\xc1\xca\x9e\xe9\x89\xcb\x47\x9a\x65\x24\xfe\xb0\x2c\xbf\x94\xab\xc3\xda\x9a\xe4\x7c\x8a\x82\x33\xa9\xf5\x7a\xd0\xf9\x5d\xe1\x94\xf9\xc2\x7b\xd2\x20\x70\xa3\x08\x65\x01\x20\x67\x7d\x27\xf8\xc2\x16\x14\x5c\x63\x58\xa1\x67\x02\x29\xd5\xb9\xad\x1c\x65\x74\x6f\x7d\xb6\xa1\x3b\x63\xd3\x76\x75\xe0\x4a\xa9\xd6\x8d\xcc\x78\x1f\x02\xb7\xfe\x5e\x92\x3a\x46\xbc\x43\x5e\xec\xb9\x69\x14\xb8\xb3\x8b\x79\x83\x11\x37\x04\x37\xb8\xdb\xa0\xc6\x42\xbe\x42\xbe\x5a\xbe\x91\xd6\x5c\x16\x9a\x6d\xb7\x19\x8f\xc3\x02\x29\x01\x5c\xb7\x1f\x58\x09\x04\x79\xed\x5a\xdd\xf3\x18\x2f\x34\x71\x40\xac\xb1\xcc\xb3\x8c\x0b\x85\x1a\xda\x30\x6e\x7c\x33\x3e\xb8\x73\xec\x3c\x3c\x8f\x83\x46\xb4\x84\x21\x6b\x6a\x69\xb4\x83\x47\xb0\xeb\x5a\x30\x8e\x30\x40\x16\x14\x41\x5f\xf7\x28\x2d\xa9\xd4\x25\x0a\xad\x13\x7e\x77\xc9\x30\xc8\xf4\x05\xdf\xb6\x0c\x5f\x5d\xef\xd7\xae\x85\xda\x2d\x4f\xc8\x54\x8d\x6b\xbd\x3e\x2b\x0c\x9c\xba\x45\xd6\x84\x28\x43\x67\xf3\x3d\xb4\xd8\x5e\x4b\xf8\xa3\x0d\xec\xd1\xaa\x41\x60\x21\x10\x9c\x2b\x23\x9f\x16\x3a\x0c\x72\xab\x09\xe6\x05\xdb\xa9\xcd\x05\xf3\x42\xa0\x96\xf9\x8d\x3f\xd4\xa7\x4d\x1d\x8f\xd8\x00\x02\x28\x0a\x45\xc4\xa5\x88\x81\x16\xb0\x56\xfe\x2f\x15\x1d\x7d\xd5\x68\xcd\x66\x84\xd7\x82\xee\x6d\xbd\xfc\x64\x81\x8a\xc2\xb2\xa5\xef\xda\x9c\x1e\x63\xf5\x76\x22\xa0\x99\xb0\x2d\xe3\xae\x48\x66\x2d\xf3\x66\x9e\x45\xa4\x0f\xc4\x87\xe9\xae\x8e\xd1\x4f\xce\xf2\x03\x81\xaf\x45\x4d\x66\x1b\xbb\x91\xe0\x85\x03\x85\xac\x5b\xd8\x7d\xe0\x2c\xee\x3b\x14\x76\xf5\x02\x7b\x40\xa7\x9a\x55\x2e\x29\xe0\x8c\x19\x8b\xec\x06\x69\x1f\x67\xfe\xa3\x3b\xb2\x3a\x2a\xe0\x23\x94\xe1\xb4\x91\x55\x20\x74\xb0\x64\xf1\xbf\xcc\x66\x99\x4c\x54\x57\x58\xcb\x96\x45\xb4\x1e\x54\x7d\x7e\xc0\x03\x68\x12\x55\xd1\x94\x26\x09\xc8\x01\xc7\xa8\x0f\xe5\x81\x21\x91\x53\x5f\x85\x2e\xc0\x82\xce\x18\x5f\x97\x63\xd6\x40\x4c\x51\x40\x4c\x77\xcd\xc4\x24\x81\x9a\x8a\x3c\xfe\xfd\x50\xd4\x1e\x30\x5d\x34\x6f\xc1\xcb\x88\xd8\xed\x91\x5c\x36\x50\xde\xdf\x22\x3a\x7a\x69\xb8\xc1\x87\xff\xaa\x1f\xfa\xa7\x1c\x0b\xcc\x14\xc4\xfc\x5a\xd1\x5d\x90\x20\xf5\x88\x7c\x86\xf8\x0c\x66\x0c\xc1\xf0\x53\xb8\xb9\xce\xe5\x0f\xe1\x5e\x88\xc6\x3d\x44\x8f\xc9\x31\x54\x67\x13\x5a\x96\x98\x14\x6f\xce\xb5\xe4\x30\x62\x4b\xb1\x8c\xc7\xa8\x9f\x48\x6e\xbf\x20\x2c\x4a\xa0\x1c\x77\x10\x9e\xec\x29\xdf\xba\x95\x26\x0b\x50\x50\x60\x2b\x8b\xe6\xb9\x7d\x10\x7c\x08\x45\xc6\xc0\x27\x9e\xc0\x49\x2f\x7e\xff\x3d\xcf\x8c\xb7\xa2\x29\x4e\xe2\x05\xcb\x39\x2c\x5d\x43\x2f\xb6\x49\xa6\x54\xe0\xaa\x0d\x82\x37\x60\x63\x8a\x18\xd3\x00\x81\x05\x7d\x8d\x15\x4a\x08\x96\x0a\xfd\xe1\x9b\x8d\x62\x43\xdc\x04\x0b\xee\x6a\x8f\x6f\x91\x28\xe6\x52\x0d\x42\xe1\xce\x77\x0c\xb5\xe3\xb0\x50\x08\x23\x46\x9e\xc3\xc8\x52\x0e\xc1\xc0\xae\x20\x1c\x09\x72\x5b\x4d\x3c\x99\xc9\xcc\x87\x6c\x0d\xa3\x32\x35\xf0\x11\x07\x77\x6c\xdd\xa7\x76\x58\x35\x94\x65\x95\x27\x1b\xe2\x09\x90\x5c\x45\xd0\xff\x1c\xab\x11\xb3\x9c\xd5\x85\x8d\x04\x69\x5e\xfd\x24\x29\x07\xda\x63\xc8\x25\x61\x7a\xc2\x50\x9f\xfd\xd8\x2f\xd0\x15\xa8\x5f\x3e\xda\xb9\x64\xa7\x2b\x0e\x8b\x89\xc7\xf3\x78\x47\x61\xdb\xb5\xd2\x4e\x9d\x7d\xf9\x15\x85\xe0\x9a\xee\x2f\x4c\xa1\xfc\x16\xc2\x30\xa9\x1b\xf2\x9a\x83\xb5\x6c\xd3\x5f\x21\x1b\xef\xbb\x83\xf6\xa2\x72\xbd\x7d\x1c\xae\xd9\x67\x5e\x63\x6e\x6f\xd8\xdc\x40\xb6\xd8\x45\x01\xf7\x61\xf7\xaf\xe5\xf1\x2d\x0d\x7d\x18\x43\xd2\xdf\x7a\x2e\x58\x24\xd1\x39\xd6\x61\x62\xaf\xe3\x20\xa7\x27\x48\x21\x80\xe0\x3f\xc7\xf8\xec\x9b\x0d\x9e\xd7\xec\x7d\x4f\xbf\x57\xcc\xdf\x4d\xc5\x07\xc1\x2d\x4f\xbc\x59\xd8\xeb\xc7\x7f\xc7\x11\x44\xfa\x43\x4f\x2e\xc7\x60\x19\x90\xc9\xc1\x58\x63\x30\xe6\xd7\x8a\x87\x99\xe0\x11\x91\xf2\x18\x0d\xe0\xa2\xb1\xff\x44\x78\xea\x1c\x12\xc1\xcb\x23\xa6\x35\x13\x87\xdf\x12\xb4\x5f\x26\xf1\xba\x13\x60\xc0\xe0\x76\xf2\xe5\xa4\xeb\x6b\x94\x34\x69\x13\x0e\x8b\x0e\xda\x80\xb2\x06\x68\x30\x3b\x45\x31\x8f\x1e\x89\x38\x11\x24\xa6\xf2\x14\x7c\xeb\xaa\xd1\xa9\x97\x6a\x6d\x7b\x67\x49\xa3\x29\x50\x60\x4d\x52\xdc\x99\xe9\xdf\x06\x58\xbb\xf0\xda\x1e\xa2\x53\x50\x27\x5c\x4e\x86\x09\x42\x76\x70\x37\x84\x29\xb1\x80\xb8\x7e\x6f\xca\xaa\x2c\x84\xd3\x34\xb4\xd0\xd6\x94\x4d\x24\xf6\x11\x83\xb3\xe5\xb4\xef\xe7\x44\x12\x17\x70\x60\x26\xa5\xb8\x8d\x65\x36\xec\x22\xc3\x6a\x2e\x21\x75\xb5\xbc\x06\x56\xe9\x82\x4f\xf5\x0a\xe1\x0c\xe2\x15\x8c\x95\xa2\xf8\xc8\x27\x58\x4a\x45\x93\x64\xc4\x18\x21\xb1\x44\x90\x65\xfa\x55\x6d\x86\xbc\xfe\xb4\x87\x70\x1c\xa3\xff\xfd\xf5\xc7\x8b\x9f\xef\x07\xe3\xe1\x15\x18\xad\x87\x17\x83\x6f\x7a\xfe\xc7\xeb\x87\x7b\xff\xab\xb1\xb0\x3c\x11\x81\x52\xfc\x08\x2a\x1e\x93\xc4\x26\x4f\x90\x11\x0b\x47\xea\xb0\x03\xf4\x13\x49\x5c\xa4\xab\x15\x53\x3c\x84\xa2\xdd\xc3\xc6\x8a\xc5\xc6\xe6\xb7\x81\xf2\x7b\xeb\x3f\x59\x4d\x83\x8e\x78\x7c\x17\x4e\x0c\x84\x1c\x19\x2c\x83\x64\x72\xab\xfb\x16\x04\x47\xd8\x8c\xb2\xa6\x78\x3c\xc2\x9e\x5e\x52\x88\xff\x81\x2c\x7e\xd4\xea\xf5\x0d\xa6\xa2\x35\xed\xd5\xa3\x01\xb9\x13\xa3\xf5\x74\x2c\xab\x87\x4a\x1a\x59\xd8\x64\xdb\x34\xc6\x7c\xd6\x01\xc1\xbd\xf9\x74\x2d\xbc\x14\xf9\xac\x84\x43\xa9\xf0\xf9\x1c\x0e\xca\xc9\x5f\x34\x05\x0d\x8e\xd8\xfd\xf5\xf9\xf5\x29\x22\x09\x9e\x70\x08\xe5\xb7\x21\x41\xae\x09\xbb\x60\x11\x4f\x83\x86\x4a\x08\x25\x3d\x94\x15\x08\x25\xa1\x11\xed\xd8\xb4\xb1\x06\xa9\x24\xe3\x62\x19\xdf\x63\xbf\x2a\xa0\x9d\xec\x0d\x17\x6d\xae\x7f\xfd\x1a\x2c\x1d\xcf\xb4\x22\x57\xe1\xbc\xf6\x6e\x9e\x12\x6c\x6a\xe9\x1b\xb7\x90\xb5\xe5\xdb\x00\xd6\x24\x29\xd5\x53\xd4\x07\x47\x1e\x5b\x17\x7c\xf1\x26\x67\xe8\x87\xbf\x48\x34\xc9\xd5\x88\x95\xdb\xe0\x0c\xf5\x7f\xba\x43\xdf\x61\x15\xcd\xbf\x19\xb1\x6b\xad\x66\xfe\xf0\x97\x06\x28\xa5\x8d\xd1\x09\xf5\x9a\x9c\x63\x85\x2f\x38\x8e\x29\x9b\xd5\x41\x13\x16\xf5\x63\x06\xf7\xfd\x53\x74\x6d\x75\xf8\x22\x13\xc4\xa7\x04\x07\x0d\x01\x43\x86\x89\x38\x2e\x02\xac\x9c\x95\xe1\xdb\x8c\x66\x06\x17\xd6\x88\xdd\x1b\x4c\x46\xcd\x55\xa9\x42\x19\xb7\x35\x8c\xb4\x56\x66\xd0\x2a\xb1\xcb\x90\x22\xc9\x02\xe9\xd5\x01\x32\xf6\x9b\x61\xe5\x31\x90\x67\x96\x99\xfd\x88\x81\x82\xee\x73\x53\x12\x1e\xe1\x04\x62\xf2\x8e\x02\x9b\x9e\x56\xdb\x79\x0e\xf9\xe1\xa6\xe8\xf9\xa2\x1c\x3a\xeb\x21\x0b\xbc\x50\x16\x6e\x14\x18\x00\x60\x1f\xad\x37\x36\xe5\x9a\xe3\x18\x2c\x36\x30\xbe\x25\x66\x75\xf4\x87\x1e\x9b\xcd\x2c\x8b\x7e\xea\xd3\xb6\x78\xce\x1c\x16\x49\x04\xe6\x7b\xb6\x80\xf0\x6d\x28\x3a\xc2\x21\xf4\xa3\xe0\xce\x96\x28\x97\x76\xd1\xdf\x89\xc1\x67\x23\x66\x22\x05\x4b\xfb\x12\xa2\xf7\x04\xbd\x73\x06\x81\x8c\xcb\xb9\x62\x79\x66\x03\x1b\xad\xac\x9f\x09\x72\xe4\x33\xa0\xe2\xd2\x9a\xea\x1b\xf6\x18\xdd\x86\xea\x75\xcc\xa3\x3c\x75\xc8\xca\x90\x3d\x55\x94\x95\x2f\x49\x3c\xe6\x62\x5f\x47\xf1\x80\xd2\xa2\x08\xa4\x8f\xb7\xd6\x8f\x0d\xc1\xf4\xc3\x4f\x97\x25\xf5\x66\xc1\x17\x78\xc7\x6e\x51\x6b\xa6\xa1\x71\x56\x6e\xa9\xd4\xda\xce\x79\x89\x57\x05\xfa\x2b\x17\x20\x6c\x91\xcf\x19\x07\x23\xb7\x49\xcf\xe2\xf1\x57\x12\x0d\x6f\xb4\x04\xa4\x35\x5e\x7f\x06\x73\xa9\x4c\x70\x19\xa4\xeb\x98\xaf\x4d\xba\x40\x0f\x7d\x8b\x46\xf9\xb7\xdf\xfe\x29\x42\x9f\xdd\x1f\x7f\xfe\xcf\xff\xfc\xd3\x9f\x37\x49\x27\x71\x0a\x39\xb4\x5b\xac\x91\x2f\x27\x55\x16\x89\xc2\x1d\x58\xe6\x54\x3b\xec\x82\x3d\x80\x4d\xcb\xbf\x0d\xca\x63\x10\x3b\x84\x67\xf6\x84\xcb\xf0\x64\xa2\xd2\xd1\x2c\x22\x09\x24\x51\xbd\x32\x87\xf0\xc2\xae\x95\xe8\xff\xd7\x0a\xb0\xb2\xb1\x3e\x2a\xdb\xc5\x38\xd1\xc4\x8b\xd7\xba\x11\xf4\xb5\xb5\xff\x29\x70\x20\x7e\xe3\x2e\x38\x9e\xc4\x44\x98\x31\x79\x93\x9d\x37\x24\x02\x73\x20\x9f\xb3\x84\xc7\x0e\x1e\xb5\xc8\x05\xa4\x20\x20\x0c\x3e\x63\xcd\xb9\x7b\x16\x46\xcb\x7c\x64\x3c\x2f\x53\x1c\x19\x54\x50\x89\xbe\xfe\x7c\xaa\x7f\xeb\xa1\xc5\x29\x04\x91\xf6\xd0\xaf\xa7\x16\x2d\x07\x0b\x35\xd6\x3f\x7d\xe3\x64\x6d\xdb\x04\x0c\x9a\x4a\xf4\xd5\xc9\x13\x16\xa6\x66\xf4\x89\x19\xd1\x57\x96\xb3\xfa\xba\x78\xa1\x6c\x9e\x70\xfe\x68\x03\x6c\x97\x3e\x3c\x71\xc0\x6b\x40\xde\xde\x6f\x62\xb6\xde\x27\xe6\x2b\x74\x04\x2f\x10\x74\x9c\x4d\xd0\xf1\xdf\x25\x67\xe8\x78\x81\xd3\xc4\xfe\xea\x9e\xda\xf8\x5f\x2c\x6d\x4e\x5c\xec\x83\x7c\x92\x85\xb1\x94\x7e\x97\xf0\x09\xcc\xea\xd2\xcd\xd4\x44\xd0\xc2\x40\x8b\xdb\xa7\xb8\xb0\xec\x44\x5c\x22\x2a\xe0\x07\xa5\x5c\x99\x57\x80\xc7\xd5\xcd\xea\xb3\x1f\xd2\x7f\x1b\xbf\x30\x2c\x8a\x4b\xe2\x33\xc6\x61\x1f\xbd\xa6\x1b\xfd\x8c\xbe\xb6\x2c\xe8\x1b\x7d\xc7\xd8\x70\x65\xb3\x0c\x75\x1d\x2c\x7c\x07\x3f\x07\x1d\x50\x86\x4c\x5a\xe6\x8a\x2f\x7f\x3d\x39\x3e\x3e\xf6\x5f\x43\xd6\xfa\xff\x8b\xa8\x92\x24\x99\x9a\x96\xdc\x0d\xb6\x18\xb1\x4b\x57\x78\xc1\x19\xaf\x0b\x48\xc7\x4c\x70\xc5\x23\x9e\xa0\xa3\xc2\xa0\x1b\xf3\x48\xa2\x7f\xd7\x62\x6d\xb0\x94\xf0\xa3\xd6\xe3\x1a\x60\x60\x0d\xd2\xf3\x2b\x1d\x2a\x6b\x10\xaf\x1e\xab\x10\xc5\xcd\x2b\xb6\x58\x86\x55\x3c\x80\x16\x34\xe5\x9c\x58\xa4\x37\x21\xf4\xcb\xe4\xb3\x82\x47\x0d\x40\x7a\xb5\xa1\xec\xf5\x37\xe5\x12\xbb\x2d\xf0\xf4\x0c\x59\x37\x2c\x80\xc5\xbb\xb2\x9c\xc1\xcc\xb3\x17\xba\x4f\xf4\xe5\xc2\xc2\x52\x00\x32\x4f\x53\x2c\x16\x27\xc5\x69\x5b\x26\xce\x02\x69\x0d\x78\x4c\xe2\x16\x00\x5c\xb8\x89\x3d\x5a\x36\x8a\xc1\x8a\x97\xee\x46\xf3\x67\x37\x82\x5a\x86\x01\x62\x01\x61\x11\x8f\x2d\x5d\x17\xd9\xa7\x65\x89\xc5\xbf\xb3\x2c\xab\xb8\x88\x18\x59\x18\xe3\x98\x32\x10\x1e\xf6\x0d\xf7\x71\x03\xfb\xe6\x63\xa8\x8a\x4b\x66\x1b\xb8\x47\x87\xd7\x77\xee\x9b\xf6\x97\x2e\xac\x43\x59\x64\xc7\x49\x88\x8f\xc7\x66\x48\xe0\xe7\xe2\xfa\x85\xd8\x0e\x63\x9d\xc9\x7d\x6e\xae\xf9\xf7\x19\xbf\xa1\x89\xbe\xb5\x80\xc6\x8f\x47\xac\xf4\x73\x0f\x91\x84\xa6\x94\xf9\xd8\x3a\xc3\xdc\xf9\xd4\x48\xcf\x8f\x54\xe9\x2d\x93\xf1\xa3\xe6\x60\x0e\xd7\x29\x50\xa9\xfa\x6c\xe1\x48\xc7\x3b\xa6\xac\x05\x22\x97\x7a\x5c\x85\x8e\xae\x85\x59\xdd\xc4\x91\x15\x48\x69\x40\x78\x70\x7e\x47\x4c\xb7\xe6\xce\x52\x11\x2e\x1c\xb4\x17\x34\x77\xe4\x00\xf1\x03\x0e\x00\x7d\x94\x62\x7e\xbd\xfc\x5b\x23\xa0\x0c\x58\x9e\xee\x9a\x6c\x62\xc3\x87\xdf\xca\x4c\x77\x23\x88\xbb\xa9\x6c\xe2\x12\x61\x79\xea\x0e\xd4\x06\x14\x37\xb0\xe2\x4f\x4c\xa2\x04\x1b\xa4\x1a\xdd\x10\x44\x3e\xf6\x8c\x83\x34\x0b\xfa\x32\xd7\x8b\xe9\xc6\xd4\xd8\x49\x08\xfb\xda\xfc\xfb\x1b\x64\xef\x86\x6f\x7b\xf6\x3e\x17\xd2\x23\x80\x98\x3d\x87\x1a\x8d\x24\x36\x36\x74\x40\x25\x9e\x61\x11\x1b\x6b\x79\xa8\x55\x98\x0c\x5e\x2d\x7f\x2d\x78\x8e\x9e\xa9\x9c\x8f\xd8\x3d\x77\x06\x47\xc4\xb8\xc7\x75\xee\x81\x32\xba\xd4\x1f\x96\xc0\x04\x60\xd4\x75\x14\xa0\x99\xf0\x4e\xb9\x46\x10\x05\x3b\x66\x3c\x26\xbb\x01\x18\xdd\x17\xbe\x0a\xe7\xbf\x16\xc4\xe4\x83\xc1\x4d\xd1\x94\x4e\x4b\xa4\xdc\xd0\x36\x5f\xdd\x78\xb8\x87\x6c\x3b\x50\x12\xf8\x79\x23\x74\xed\x10\x1b\xcc\xdf\x6a\xd0\x8a\xd3\x38\x83\x6c\xe0\xd2\xda\x7b\xb4\xe4\x5d\x37\x21\xaa\x41\x2b\x6a\x75\xf7\x9b\xb9\x47\xb0\xec\x3e\xc0\x18\xa3\x99\xe0\x79\xe6\x53\xe6\x5d\xba\x9f\xd9\x06\x2b\xd3\x0c\xd9\x94\x9f\x5a\x9d\xea\x82\xb2\x47\x43\xf1\x2f\xb5\x47\x06\x10\x9b\xc4\x25\x18\x37\x57\xa5\x15\xe6\x70\x84\x28\x8b\x92\x1c\x2e\x3e\xa9\x70\xf4\x68\x40\xbd\x9b\x8c\xbe\xfa\x9b\xf1\xfa\x64\xca\x06\x89\x29\x4f\x12\xdb\x6d\x71\x81\x16\x65\xac\x9f\x28\x46\x18\x3d\xdc\x0e\xeb\xfb\x7e\xa4\xcb\xce\x9c\xfa\xdb\xb3\x4c\x20\xf0\x3f\x3f\xd0\x8d\xe2\x2e\x2b\xb0\x78\xa4\x44\xea\xde\xb8\xd4\x04\xba\x6a\x88\x54\x69\x05\x22\xbe\xad\x31\xed\x6f\x4c\xa7\xb3\x2c\x1f\xeb\x85\x4a\x36\x09\x10\xd0\xa3\xf8\x74\xf3\xd0\x0f\xbe\x5b\x45\x2a\x9f\x6e\x1e\x50\xd0\x87\x01\x3c\x4c\x48\xa4\x7c\xa4\xf1\x31\x3a\x2b\x70\x88\xab\x92\x79\x4c\x9e\x68\x64\x52\x5c\x7b\x5a\x2a\x1a\x31\x80\xf7\xd4\xba\xce\x91\xc3\x84\x42\x9f\x6e\x1e\x2c\x92\x94\x87\x9b\xb2\x90\xca\x00\x61\xb1\xd9\xb5\x53\x01\xd6\x64\x9c\x1d\x81\xc4\x86\x45\x5c\x78\x3b\x7a\xa0\x5c\xff\x7f\xec\xbd\x5b\x73\x1b\x49\x72\x36\x7c\xbf\xbf\xa2\x22\x7c\xa1\xd1\xf7\x81\xe0\x68\xf6\xb5\x63\xad\x08\x5f\x50\x14\xb5\xc3\x5d\x89\xd2\xf2\x30\xb3\x7e\x0d\x07\x54\xe8\x2e\x00\x65\x36\xaa\xa0\xae\x6e\x72\x60\xaf\xff\xfb\x1b\x95\x99\x75\xe8\x23\xba\x01\x52\x1a\xaf\xe7\xc2\xde\x11\xd1\x5d\x5d\xe7\xca\xca\x7c\xf2\x79\x12\xbe\x2d\x4a\x32\x30\x1e\x5e\x4d\xdd\x98\x5c\x87\x48\x88\xad\x96\x9e\x29\x6b\x2b\x61\x96\x01\xa8\x7f\x34\xf5\xe9\x5b\x3a\xf5\x18\x70\x00\x74\xda\x51\x9b\xbf\xf4\x19\x7e\x5c\xed\x18\xcf\x17\xb2\xc8\xed\x35\x0c\x5f\x86\xa1\x70\x77\x8f\x85\xbb\x51\x05\xcb\x88\x04\x5b\x60\x80\xa5\x2a\xcc\x4c\x45\x19\x2c\x3e\x2b\x18\x93\x17\xa4\x62\x40\x87\x07\xd8\x1b\x47\xcf\x95\x64\xba\x4c\xdd\xb1\x9a\x7b\x01\x98\xdd\x16\x8d\xa8\x99\x02\x66\x12\x7b\xb6\x82\xf0\x79\x38\xfb\x5f\xb3\xcf\xea\x41\xa6\x92\x9f\x14\xc2\x64\xfc\xa4\xf8\x3f\x9f\x27\xb5\x3f\xf1\x57\xdf\x7f\xff\x19\xb5\x6c\xba\x68\x17\xfc\x34\x3a\xda\xc1\xd3\x1e\xa7\x70\xc5\xcf\xed\x2c\x3d\x62\x9c\xde\xcb\x7b\xc1\x3e\xe3\x70\x7f\x26\x02\xbf\xc3\x86\x6d\xa6\xda\xc6\x8d\x1d\x32\x6c\x40\xa7\xda\x3e\x6e\xac\x67\xd8\x5e\xad\xa6\xff\xb8\x5a\xd8\xd1\xfa\x61\x35\x7d\xf5\x3d\xfc\x67\x6d\x8c\xf6\x2d\x5e\x9f\x3d\xd3\x56\xed\x96\x8d\xa8\x65\x59\xfa\xbd\x68\xa6\xf6\x6f\x46\x6c\xdc\x5e\x04\xb3\xb6\x6d\xe1\xf3\x42\x1c\x9b\xdd\x8a\xbc\x8e\x23\xd0\xd7\x0d\xc2\xcc\xde\x88\xe0\x91\x6c\x93\x81\x29\x12\xe0\x9e\xdd\xb4\x97\x31\x00\x17\x7e\x1c\xc1\xc7\x03\xcf\x0f\x6b\x4f\xed\xd9\x3d\xcd\xe9\xaf\x66\x26\xc4\x08\x06\x99\x1b\xfb\xf8\xc0\x4a\x56\x1e\xed\xab\xe3\x23\x47\x45\x9d\x26\x91\x7b\x4a\xb7\xf5\x31\xab\xc8\x4d\x47\x74\x99\x18\x9f\xf7\xe7\x6b\xe2\xa0\x95\xfe\x7e\xed\xbe\xbb\xa2\xb5\x14\x0b\xf6\xf8\xa8\x5b\xcb\xc4\x8f\x5c\x11\x47\x42\xe1\xec\x95\x7a\xbe\x19\x4c\x12\x1a\x3e\xfc\x96\x5e\xfe\xd0\xa0\x0c\xf5\xe6\xe5\x07\xc8\xcc\xf6\x64\x58\x1b\xae\xac\xb5\xe6\xbe\xda\x11\x58\xc2\x5b\xfe\x41\x55\xba\xdb\x1e\x54\x21\xfc\xe2\x40\x2d\x5b\xfa\x94\x2b\xe5\x11\x63\xab\x3c\xc3\xd8\x41\xb1\x06\xb7\x72\xd0\x80\x73\xdb\x5c\x70\x2f\xa3\x5e\x5c\xc6\xf3\x15\x3a\xbd\x8c\x28\xcc\xcb\x96\x11\x0e\x79\x6c\x47\x8c\xf0\x01\x3a\xdb\x31\x96\x05\x5c\x2a\x7d\x2b\xcd\xd7\xb2\x4a\x18\xed\x6f\x5a\x5e\xb1\x3e\x62\x43\x0d\xc9\x75\x89\xce\x51\x5d\x21\xb5\x6b\xa5\x9b\x07\x6b\xac\xd4\x7b\x3d\x1e\xc7\x37\x9e\xe5\xc5\xa9\xbe\x53\xce\x2e\x56\x6e\x21\x80\xeb\xbc\xbb\x0e\xe3\x75\xdd\x7b\xaa\x40\x42\xc7\x5d\x35\x98\xa9\x33\xf7\x48\x60\x6c\x34\x12\xbd\x2c\x98\x8e\x58\x2e\x30\xc3\x05\x7c\x66\x3c\xf4\x3a\x35\xae\xa3\x11\x63\x13\xf2\x6b\x4d\xb8\x33\x22\x0f\xa7\x11\xa9\xc0\x79\x5e\xe6\x5e\x05\xbe\x07\x91\xb7\xc1\x8e\x47\x7c\xfc\xc6\x35\x91\x8a\x72\x7d\xd9\xf6\xe1\xe1\x17\x15\x2a\x08\x12\x8e\x08\x55\x8b\x79\x01\xd9\x2e\x4c\xd3\x40\xfc\x59\xfb\x58\x73\xb5\x16\x47\xed\xc6\x92\x6f\xe6\xb9\xee\x96\x28\x1c\xd0\x4d\xae\x88\x8a\xcf\x7e\x8d\x92\x45\x3b\xf6\xa5\xe4\x19\x1e\x6e\x8a\xa6\xa3\xab\x36\xb8\x3f\x7e\xf8\x27\x76\x06\xa7\x0f\xfb\x00\xfb\x22\x80\xb6\xa0\xb4\x42\x33\xb9\xd9\x8a\xdc\x68\xc5\x3b\xb5\x3a\xef\xff\x60\xe6\xa4\x37\x66\xaf\xc6\xba\x6c\x6a\x8b\x8d\x68\x49\x4b\x69\x71\xa3\x38\xbb\x2f\x17\x22\x57\x02\xf5\x48\xe1\x39\xe6\x9e\x1b\x54\x5d\xcd\xcb\x62\xfd\xc3\x3c\xc9\xe4\x60\x11\x34\xc8\x18\x3d\xb3\xaf\x9d\xe3\x5b\x7d\x0d\xa8\x94\x5f\xa9\xba\x62\xf8\x1b\xc3\xdf\xa6\xec\x0d\x4f\xee\x85\x4a\xd9\x36\x2b\x57\x92\x08\x62\xd0\xdc\x97\xd5\x8b\x7d\xb5\x61\x68\x5b\x60\xf9\xf6\x18\x9a\xa9\x0d\xbf\x47\x62\x72\x32\x22\xed\xcd\xa1\x8b\x5e\xd0\xbb\x4a\xe6\xb2\x39\x77\xf7\x8e\x96\x3f\x0f\x9b\xc5\xd4\xe7\x9e\x29\x31\x5f\xee\x71\xad\x09\x65\x54\xf1\xd4\x8c\x58\xb8\x7e\xb6\x36\x78\xbc\x1c\xd7\x8a\x57\xa6\xa5\xca\xe0\xea\x85\x10\x1e\x90\xeb\x97\x8a\x71\xa0\x02\x7b\x61\x58\xb9\x75\xf6\x19\xc4\x96\x32\x40\xfa\xe0\x10\xd8\x1f\xb6\x32\xb9\x47\x6c\x29\x64\x4f\x30\xdf\xbc\x86\x80\x21\x13\x01\xe4\xd8\xb6\x35\x2c\x91\x08\xe7\x38\xdc\x4a\x83\x9b\x7f\xcf\x3c\x1d\x98\x19\x52\xac\x85\x9a\x1f\x40\x11\x3f\x7c\xd0\x2a\x59\x20\x64\x06\xfb\x18\x9d\xef\xc2\x52\x49\x12\x05\x0c\x77\x6c\xcf\x7f\x2c\x97\x35\x33\x5a\x1a\x66\x78\x21\x8d\xdd\xcb\x5a\x7b\x3c\xd0\x0f\x1d\xd3\xeb\x7c\x1c\xe7\x51\x0b\xdf\x51\xad\x2f\x7c\xa6\xd9\x94\xbd\x83\xc8\x46\x74\x33\xd0\x9e\x3d\xa8\x6b\xc3\x2a\xd6\xa2\x93\x46\xf7\x29\x20\x9a\xae\x05\xd1\xf3\xbd\x01\x2b\x9f\x55\x38\x65\x67\x21\xa2\x8c\xfc\x49\x18\x2b\xde\xd3\x22\x91\x19\x71\xc8\xe4\x1b\x14\x7c\x01\xd4\x15\x4c\x20\x06\x96\x94\xb1\x7f\x0f\xaa\x20\xbe\x9a\x8f\x90\xb8\xcf\xef\x85\xea\xf3\xb0\x0f\xaf\x21\x86\x40\x7a\x5d\x02\x3e\xb6\xa2\x31\xbc\x72\x48\x05\x87\x2f\xbb\x40\x59\x25\x97\xa7\xb6\xcb\xed\x35\x24\xb9\xa7\x74\x41\x8c\xb0\x11\xe9\xd5\xe3\x5a\x9b\x78\x9d\xb9\xf1\xc3\x9b\x6c\x5e\x7a\xe5\x07\x48\xb7\xf4\x1d\x8c\x38\x4b\xa5\x63\x4e\x2c\xa8\xb5\x5f\xa4\xe8\xd6\xf1\xe3\xcd\xdc\x16\x0a\xdd\x00\xc8\x04\x57\x54\x73\x35\xff\xf9\x0f\xe6\x23\xac\xd8\xa7\x60\x5f\x69\x97\xda\x3e\x3e\xf3\xe9\xc0\x98\xaf\xc7\xf4\x06\x9d\x6e\x9e\x7a\xbe\xa0\xad\x4e\x59\x98\x5e\xe3\x45\xb9\xbf\x7d\xb3\x6a\x62\xde\x83\xda\xb6\x6f\x66\x7f\x88\x80\x61\x6c\x51\xca\x2c\x45\xfa\xbc\xc8\x20\xd4\xce\xe2\x00\x4e\x7b\x38\xfe\xa5\xf1\xe7\x49\xfb\x1c\xfb\xa4\xd3\x63\x26\xd6\x78\x8a\xd4\xe6\xbc\x1e\x90\x37\x62\x62\xf0\xce\x66\x7f\x4f\x6c\x75\x37\xe2\x3f\x9d\x9b\xaa\x88\x5b\x4f\x85\x01\xe2\xb5\x28\x97\x37\xa0\x18\xd5\xc5\x42\x14\x89\xa9\xb8\xb4\x62\x3b\xce\xf6\x33\x3e\xc9\xad\x6b\x50\x08\x31\x14\x8e\x7f\xce\xfe\x74\xf3\xf1\xea\x64\xc3\x73\xb3\xe6\xc0\xf2\xe0\xca\x9a\x38\x11\x4e\xbc\x1e\x3b\x24\x83\x54\x33\x75\xc2\x56\x7a\x82\xb8\x99\xd7\x6c\x5d\x14\x5b\xf3\xfa\xf4\x74\x25\x8b\x75\xb9\x98\x26\x7a\x73\x1a\xba\xe6\x94\x6f\xe5\xe9\x22\xd3\x8b\xd3\x5c\x40\xe6\xc4\xc9\xab\xe9\x0f\xaf\x60\x64\x4e\x1f\x5e\x9d\x02\x5a\x62\xba\xd2\xff\xf0\xfe\x87\x7f\xfe\xfd\x3f\xd9\x82\xb7\xbb\x62\xad\xd5\x6b\x02\xe5\xf4\x96\x7d\x82\x56\xf9\x29\xbe\x52\xfb\xca\x3f\x4f\xbf\x8f\xab\x41\x8f\x6e\x74\x2a\x32\x73\xfa\xf0\x6a\xee\x06\x66\xba\xdd\xfd\x96\x6b\xf0\xcd\x72\x0d\xee\x65\xf1\x5b\xae\xc1\x37\xcd\x35\x18\x6e\xe1\xf8\x3d\x06\xc8\x9b\xc3\xfe\x68\xff\xee\xf7\x48\xe7\x7a\xdf\xb7\x0f\xb5\x1c\x0e\x71\x26\xd8\x11\x47\xc4\xbd\x18\x75\xc5\xae\x35\xd7\x5f\x1d\x3a\x5c\x6c\x63\x05\x54\x3a\x8d\xf9\x51\xc4\x17\x80\xec\x93\x09\x90\xf3\xa3\x4b\x70\xcb\x65\x5b\x06\x01\x21\x58\x8f\xe9\xbf\xe7\x94\x99\x78\x6a\x7d\x09\x6a\xee\x81\xda\x12\x19\xbe\xed\xf0\xb6\xfa\xd1\x69\x4a\x3c\x85\x12\xc3\x40\x6d\x6e\x4f\x30\x8f\x93\x07\xea\xe2\xea\xd5\x51\x8d\x35\x37\x87\x01\xb7\xcf\x90\xc6\xd5\xc7\xe9\x10\xf5\x2a\x8d\xfb\xa0\x3b\x38\x1c\x33\x8e\x3d\x87\x1c\x01\xdf\xb6\xcc\xb7\xda\x08\x33\x65\xef\x6a\xea\xb5\x01\x8c\x7e\xfd\xee\x9c\xbd\xfa\xc3\x3f\xff\x7e\xa6\xbe\x6b\x39\xb7\x61\xbf\xd7\xf9\x8a\xb0\xf1\x70\x5a\x6f\xb8\x29\x44\x7e\x9a\x2f\x93\x53\xdc\xe5\x4e\xed\xfb\x27\xf4\xd1\x13\xbd\x3c\xf1\x34\xf3\x27\xc4\xb8\x3d\xdd\xa4\xe3\x48\x63\x2a\x53\x0f\xcf\x1a\x3a\x68\x0c\x1c\x4a\x48\x2f\xa7\x97\x5e\x50\x04\x73\x17\x51\x7b\x48\x2f\x5b\xfe\xe3\x4d\xa6\x17\xe6\xa5\x27\xb5\xe4\xc6\x7d\x23\xb0\xcc\x75\x2f\xcd\xa7\x51\x9c\x70\x53\xe4\x39\x1d\x15\x6e\x2f\x89\xaf\x23\x63\x3a\xbe\x7d\xb1\x85\xe3\x1e\x39\x76\x78\xae\x4b\xe5\x18\xfb\xb5\x12\x7a\x09\xd0\x0d\xb0\x84\x1d\xf2\x0c\x7c\xb5\x80\x67\xf2\x7c\x3a\xb9\xd8\xe2\x01\x03\x51\x85\xee\xee\x3e\x52\xb5\x62\x5f\x3f\x3f\x87\x6a\xc5\xb1\xfd\x4e\x1b\xca\x37\xea\xf0\x63\xe1\xe1\xb8\x94\xc6\xa0\x2a\xec\xf3\x7b\x23\xa8\x7e\x1f\x08\x8a\x72\x81\x20\x7e\xcb\x73\x30\xd2\xc4\x49\xa1\x4f\x80\x88\x0c\xe8\xad\x50\x47\xa6\x0b\x56\x01\x91\xe7\x31\xc7\xa4\x7d\x7e\x40\x3d\xd1\x30\xff\x25\xaa\x28\xd9\x24\x06\x69\x99\x09\x66\x2b\x95\x12\x39\xc5\xd4\xf6\x9e\xa8\x23\xe3\xd2\xf1\x50\xf6\xa3\x6c\xc3\x4d\x34\xd6\xf8\xf0\x39\x56\x3c\xda\x04\xa6\x0c\xac\xcf\xb5\xde\x68\x6b\xce\xe8\xd2\x44\x3f\xe2\xed\x05\x0e\xe1\x4e\xdb\x6b\xc3\xb7\x48\x3c\xfa\xed\x5a\x63\x97\x96\xfd\x09\x9d\x7a\xf1\x43\xa3\x64\x93\x16\x55\xa1\x98\x3d\xf5\xf7\x0a\x1f\xfd\xf3\x06\x50\x0f\xa8\x3d\x0a\xf2\xdf\xc4\xdb\x2f\xff\xd3\xde\x6b\xec\x94\xf2\x37\x05\x7f\x72\x23\x48\x07\xf9\x75\x63\x48\x9a\xb3\xe6\x3b\x19\x30\xca\xcd\xc8\x31\xf0\x89\x23\x43\x06\x80\x2b\x4c\xa5\x70\x39\x14\x27\xad\x49\x14\x5d\xeb\xd2\x89\x6d\xa7\x73\xc7\x01\x3d\xae\xaa\x37\xbe\x00\xa2\x7b\x6e\xd6\x3b\x50\xe8\x41\xc6\x0d\xf6\x31\x6e\x08\xce\xb6\xe8\x02\x6e\x8e\x5f\x8c\x20\x9a\x35\xa6\xef\xe0\x23\x38\x39\x1b\x3d\x18\xad\x85\xae\x0e\x1c\xe7\x62\xeb\xf3\x58\xb5\x61\x76\x91\x75\x34\x64\x64\xda\x5a\x36\x2e\x8f\xfe\xc5\x07\xbf\xbe\x10\xd2\xb8\x28\xe1\xf7\xab\x8f\xb7\x31\x5a\x43\x62\x6b\x4f\x92\xb5\x48\xee\xc1\x61\x82\x47\x9e\x17\xe2\x25\x86\xd3\x99\x0a\x72\x8e\x85\x76\xd0\x83\x9d\x57\xb8\xf0\x2a\x2f\x3a\x67\xa9\x34\xdb\x8c\xef\x20\xc8\xab\x30\xf7\x2a\x04\x88\x7d\xd2\xa2\xdd\x0a\xf6\xf9\x8b\x87\x8f\xb4\x1d\x95\xb3\xf0\xde\xd8\xbe\x0c\x60\xda\xd0\x99\xcd\xfd\x80\x19\xb1\xe1\xaa\x90\xc9\x4c\x6d\x04\x57\x31\x2a\x8f\x82\xdc\xb6\x93\x53\x2d\x88\x03\x7e\xb9\x14\x49\x11\x48\x64\xc1\x78\xf7\x3d\xb5\x6f\x0d\x8e\x6b\xbb\x5f\x79\xbd\x4d\xff\x11\x70\xbf\x18\xa3\xcf\xf5\x03\x6d\xc3\xee\x68\x3c\x30\x78\x03\xf2\x9f\x74\xe4\xba\xcb\x20\xfc\xcb\xcd\x29\xb6\x10\xc5\xa3\x00\x8e\x14\x4a\xea\x6e\xb3\xf1\x8f\x96\x80\x39\x4e\xd1\xbd\x5d\x0b\x3f\x42\x82\xe1\x02\x8b\xc1\x64\x9e\xcc\x4d\xd5\x58\xd9\x5e\x50\x9a\x39\x78\x7b\x5e\x90\xdf\xea\x05\x1c\xd3\xf6\xf6\x98\x3f\x88\x74\xa6\xaa\x54\x79\x64\x33\x86\x05\xc7\x82\xb8\xe1\xd3\xec\x36\xae\x8f\x07\xf9\xf2\x2f\x80\x1e\x28\x10\x03\xfb\x44\xea\x1e\xb1\x45\x6c\xf4\x73\xde\xaa\x9c\xce\x6b\x6c\xdd\x0f\x80\x64\x09\xe3\xc4\xcb\x48\xeb\xb4\x82\xa7\xf0\x93\xd2\x13\x81\x21\x4b\xa8\x07\xc0\x92\x5f\xb2\xe1\xe9\x6c\x2b\x63\xa6\x1c\x43\xc6\xb2\xcc\x90\xf9\xb9\x2b\x0f\x81\x78\x01\x5d\x36\xdf\xb7\xcb\xea\xf4\x7e\x35\x16\xe9\x45\x7a\xd8\x43\x04\x46\xc6\xbd\xce\xcd\x7a\xa1\x4c\x09\x26\x85\x93\x8a\x03\xc7\xf3\x4a\x14\x70\x9a\xa7\x65\x86\x84\x0f\xe0\x31\x07\x8e\x41\x9e\x65\x4c\x16\x66\xa6\x3c\x25\x22\x26\x1b\xc0\x0e\xeb\x5c\xea\x4e\x65\x5c\x79\xad\x72\xf8\x99\x2b\xb0\xc3\x64\x22\x8b\x06\x84\x7b\x17\xcb\x2b\x6d\xb7\x82\x63\x7e\x32\x0e\xdb\x4c\xc5\x77\xae\xfa\x20\x50\x32\x2f\xcf\x24\xef\x51\x81\x7f\x8a\xa9\x7b\x66\x3f\x71\x10\x6e\x01\x5b\x67\x2f\x5c\x4e\x39\x19\x6b\x4b\x9c\x28\x84\xb4\xb4\xb7\x9a\xc2\x38\x1f\x79\xb8\xb7\x42\x9e\x42\x52\x66\x3c\xc7\x04\x8d\x65\x99\x31\xb9\x8c\x44\xa0\x61\x0c\x90\x10\xcf\x0e\x57\xa2\xe1\xac\x76\x5e\x72\xc3\x37\x22\xe2\xe2\x20\xf7\x4e\x16\x61\x28\x90\xe5\x1f\x83\xf3\xb6\xac\x97\x53\xf6\x36\x50\x7e\xe2\x08\xc3\x9a\x88\x88\x74\xa5\xc1\xed\xcf\xd7\x37\x4a\x23\x87\xd6\xd9\x2a\x6a\x65\x57\xa4\x5f\x75\x1d\x23\x08\x82\x1c\xe3\x00\x1a\x4e\x8e\xa5\x1f\x35\xdc\x4a\x23\x61\x5f\xad\xc1\x36\xfc\x82\xe8\xa8\xa0\x3b\x15\x46\x56\x32\x26\x21\x3e\xa0\xa2\x9e\xe4\xb9\xa5\xb2\x9b\x1e\xcd\x69\x18\xc7\x91\x55\x8d\x14\xdc\xc6\x57\x34\x9a\x39\x31\x1c\x67\x48\xcf\xae\x78\x31\x16\x9b\xe3\x93\x71\xc6\x57\xb4\x15\x07\x35\xa4\x9a\xb0\x7b\x8c\xac\xa7\x17\xda\x3f\xa0\xa2\x5e\xce\x3f\x68\xbc\xc0\x56\x21\x78\xb2\xae\xe6\xc5\x3b\xf6\x5a\xdf\x02\xc8\x8b\x82\xf5\x38\x3e\xa5\xff\x2c\xcc\x39\x10\xb1\x63\xb6\xfa\x53\xf6\x51\x09\x44\xce\xe9\x65\x74\xa8\x50\x05\x48\xed\x0e\x04\x44\xfc\x2e\xb7\xb0\x15\x53\xf7\x8e\x2e\xc8\x2e\xb9\x09\xe3\xa1\x74\xd8\xf5\x70\xda\xe0\x2e\xd2\x61\x4b\xb6\xc9\xed\x1c\x61\x5e\x0e\x4b\xba\x6f\xbf\xf3\x47\x00\xd4\xf1\x3b\x40\x5b\x3b\x86\x0f\x4b\x2f\x92\xdc\xdf\xe2\x1c\x7c\xbc\x3a\x6f\x18\xc2\x49\xf7\xf5\xef\xa7\x75\x15\x85\x38\x42\x9c\xee\xee\xea\xed\xc5\xbb\xcb\xab\xaa\xa2\xdc\x5f\xee\x2e\xee\xaa\x7f\xb9\xbe\xbb\xba\xba\xbc\xfa\x63\xfc\xa7\x9b\xbb\xf3\xf3\x8b\x8b\xb7\xd5\xe7\xde\x9d\x5d\xbe\xaf\x3d\x67\xff\x54\x7d\xe8\xec\xcd\xc7\xeb\x9a\x86\x9d\x13\xa0\x8b\xfe\x74\x7b\xf9\xe1\xe2\xed\xfc\xe3\x5d\x45\x06\xef\xed\xbf\x5e\x9d\x7d\xb8\x3c\x9f\xb7\xd4\xe7\xfa\xe2\xfc\xe3\x4f\x17\xd7\x7b\x54\xec\x42\x7b\x5b\xbb\xf4\x29\xe0\x63\x07\x6b\x1a\x9e\xb1\x65\x2e\x85\x4a\xb3\x1d\x62\xef\xdd\xcd\xb6\x06\xa6\x8d\xcf\x5e\xb9\x11\xba\x3c\x06\x42\x7f\xbb\x16\x4c\x3f\x88\x1c\x98\x8d\xb0\x34\xa2\x41\x08\x59\xd4\xf5\xaf\xe6\xa2\xc8\x9b\x51\x81\xde\x4c\xa1\x22\xdf\xf9\x5c\xb4\xbe\xea\x04\x56\x3c\xfa\x08\xdb\x8a\xbc\xaf\x2e\x60\x19\xe5\xe5\xb6\x90\x8b\xee\xa4\x88\xd1\xc9\xc4\x43\xef\xde\xc8\xe1\xda\x4e\x78\x75\xd5\xbe\x31\x56\x72\x03\x8e\x01\x1e\x43\x09\x87\x4a\x75\xfa\xb7\x1d\x58\x73\x5b\x2e\x32\x99\x30\x99\xd6\xfd\x29\x94\xe3\x0f\x2e\xe3\x3a\xd5\xf3\x56\xe4\x60\xaa\xda\x1b\xc0\x36\x17\x27\xbc\x2c\xd6\x48\x4b\x48\xa9\x08\x24\xcc\x31\x53\x46\x24\xb9\xc0\x58\x80\x30\xe0\xa4\x45\x8d\xc6\xe8\x4b\x50\x19\x62\xe5\x48\x81\x00\x6c\x1a\xc9\x6e\x74\xc4\x08\xf0\x4d\x2c\x7d\x84\x93\x14\x9f\xef\xed\x1a\xaa\xb1\x34\x75\x81\x7e\x38\xe1\xf1\x47\xa7\xf4\x68\xdb\x6d\x77\x6a\xaf\x74\x88\x83\xec\x72\x37\xda\x9b\xb1\x6f\x8e\xc5\x13\xa5\x9a\xcc\x40\xa5\xd3\x4f\xe7\xb9\x80\x43\x84\xa0\x00\xce\x7f\x01\xd0\x15\xca\xf5\x80\x14\x0f\x7b\x55\x5b\x88\x35\xcf\x96\x68\x71\xd8\xa1\x69\x67\x4a\xc0\xf2\x6f\xf5\xbd\x50\xd7\x38\x60\xdf\x64\x3b\x54\x78\xf3\x09\x3c\x2d\xde\x23\x14\x5c\x98\xb6\x8e\x6e\x56\xb9\x5c\x37\x30\xa6\x0a\xbc\x27\x44\x3f\x63\x4a\x47\x60\x61\x77\x69\x72\xcb\xa5\xfc\xc5\x16\x38\x53\xa2\x95\x87\x1a\xf0\x42\x8e\x31\xcf\xef\xcb\x80\x8d\x42\xda\xb1\x7b\xa1\x40\x23\x12\x25\xe4\xf7\xce\xd9\x71\xfe\xf3\xe6\x58\xf4\x38\xf4\xc1\xe7\x27\x2b\xd2\x99\x71\x94\xc7\xf5\x53\x81\x39\x36\x9e\x57\x00\xe6\xcd\xf9\xfb\xcb\x8b\xab\xdb\xf9\xf9\xf5\xc5\xdb\x8b\xab\xdb\xcb\xb3\xf7\x37\x43\x97\xdf\x53\xe4\x45\xd5\x56\x5f\x3d\x3d\xc8\xef\x10\xa7\xb4\xf2\x42\x7a\xae\x6f\x54\x58\x76\x30\x24\xfb\x6b\x2f\xd3\xed\x3c\x95\x26\xb1\xc7\xdf\x6e\x2e\x54\x0a\x04\xfe\x07\x4d\xd5\xf6\xa2\xea\xad\xf0\x4f\x30\xff\x84\xdb\x41\xf0\xb4\x7b\x70\x33\xda\xff\x0e\xa8\x3b\x70\x43\xe6\xc2\x2e\xfe\xb4\xc2\x9b\x30\xdd\xaf\xda\x64\x8b\x3b\xae\x6d\xd5\x22\xea\x6d\xc2\xfa\x4a\x63\x4a\xa0\x67\x70\x8f\x01\xe4\xb0\xa3\x57\x88\x55\x35\x56\x11\x90\x91\x02\x36\x93\x66\xa6\x36\x5c\xa5\xbc\xd0\xf9\xae\xa3\x89\xc3\x36\xcf\x78\xd9\x54\xb7\xd0\xf8\xc8\x56\x42\xa4\x6e\x14\xf0\x51\xae\xea\x53\x09\xb5\x06\x6e\x3f\xfe\xf9\xe2\xea\x66\x7e\x71\xf5\xd3\xfc\xd3\xf5\xc5\xbb\xcb\xbf\x7a\x24\xe4\x96\x9b\x36\xc5\xdb\x6d\x2e\xec\xee\xe2\xa8\x9b\x5a\xf7\x17\x94\xa1\x75\xe5\x90\xf4\xa0\x5c\xce\x94\xdb\x59\xf2\x50\xfc\x3a\xd7\xe5\x6a\xdd\x5e\x50\xbd\x96\x9f\xce\x6e\x7f\x3c\xa8\x9a\x40\xac\x87\x5a\x95\xb8\xda\x9a\x88\x50\xb9\xa4\x7d\x0f\x61\xa4\xb5\xea\x01\x3d\x24\x3c\xda\x16\x65\xe8\xd8\xd1\x0e\xba\xbd\x34\x37\xad\x5e\xe3\xbf\xe5\xf1\xae\x09\x74\x1b\xed\x9b\x95\x63\x04\x10\xca\x28\x79\xdc\x28\xed\x75\xcb\xdf\x2a\x27\xd8\x0f\x27\x99\x58\xad\x44\x8a\xd3\xab\x5e\x30\xf9\xe0\x68\x0b\x4c\xc2\xb9\xde\xd6\x8b\x24\x4a\x7a\xc4\xc1\xec\xf1\x5e\xc3\x37\xf0\x4f\xfe\x95\xf6\xbd\xe2\x9c\xc8\x71\x20\xbe\x59\x70\xd5\x11\x48\x7e\x68\x22\x34\x07\x6d\x45\x1f\x73\xe6\x93\x9f\xc8\x61\xe2\x42\x06\x61\x1d\x74\x01\x5e\x8e\xc7\x85\xfa\x7a\x5c\x8b\x6d\xc6\x13\xe1\x73\x18\x90\xd5\x14\xee\xf5\x87\x04\xf0\x48\xfa\x55\x91\xbf\x25\x92\x84\x0d\x6a\x57\x6d\x53\x00\x3c\xb7\xd7\x6e\x3f\x7e\x7e\xd7\x4a\xef\xc5\x8d\xb8\x0c\xc1\xd1\x8c\xda\x7b\x04\x7d\x47\x5f\x14\x08\x5a\x76\xc2\x92\x47\x4d\x87\xda\x97\x7f\xa2\x81\xc7\x3b\x73\xd5\xd1\xcd\x1d\x5b\xa8\x9f\x1e\xde\x74\xec\xf3\x17\x16\x45\xde\x4b\x30\xfc\x14\xe1\x88\x4f\xb9\xde\x48\x23\xce\x8a\x22\x97\x8b\x32\x56\x58\x1d\x09\x98\xab\x5c\x4e\x42\x83\xb7\xb9\x4e\xcb\xc4\x51\x02\x41\x6b\x03\xec\x87\xbc\x7c\xce\xea\x48\xd9\x89\x9d\x7d\x74\x73\x13\xe9\x09\x00\xfa\x91\xb3\xaa\x2d\xc6\xe6\x36\xc6\x0e\xdf\xdf\x27\x77\x94\x1f\x33\x25\x5b\x26\x45\x77\x67\xba\x39\x30\x2c\xb1\x96\xb9\xc7\xc1\x02\xee\x40\x4d\xd1\x74\x59\x70\x0c\xa0\x57\x6d\x94\x2e\x06\x10\x7f\xd4\x8c\x03\x77\x0d\xc3\xc6\x54\x33\x66\xd0\x6e\x58\x73\x83\xe6\x7c\x91\xac\xab\x15\x87\xd6\x54\x99\x50\xeb\xd5\xf5\xe6\xf1\x71\x6e\x93\x41\x61\xb4\x09\x3a\x1a\x24\x39\xb6\x2b\xaa\x96\x5e\xa2\x77\x9c\xb7\x3b\xb6\x18\xfd\x8d\x0e\x0f\x03\xd8\x47\x33\x5e\xaa\x64\xcd\xb6\x19\xc7\x64\xf2\x35\x37\x38\xa5\x1d\x96\x84\x2f\x64\x26\x0b\x60\xe9\xc1\x10\x67\xad\x87\xed\x35\x8f\xe7\xf7\x8e\xec\x9c\x07\x4a\xa6\xbe\x49\x7f\x24\x66\xd7\xb7\xea\xab\xa2\x76\xc3\x92\x8d\xb7\xa1\x61\xd3\x92\x10\xbb\x61\x38\xec\x46\x0c\xd3\x32\xb4\x65\xdc\xc8\x52\x89\x9f\xea\xaf\x57\xfa\xbb\xc5\x7a\x19\x8f\x58\x21\x15\x8f\x11\xa7\x4f\x5d\xe3\xa3\x75\x65\x2d\x33\xcd\x3b\x74\xe6\x5d\xd9\x28\xd9\xd1\x55\x76\xaa\xcb\x45\x17\x49\x3c\xd6\xaa\xbf\xf4\xbe\x60\x88\x5b\xb7\x4f\xe5\x2c\x8d\x37\x40\x5e\x88\x42\x8e\xf3\xf7\x44\x8d\xe6\x85\x38\x81\xd7\xdb\x0b\xa7\x0c\xc3\xc1\x6d\x6e\x4c\xb4\x20\x1c\xe5\x8d\x36\xc0\x12\xb6\xcd\xae\xda\xe9\x7c\x0c\x26\xfc\xc8\xf1\x92\x6a\xcf\x54\xda\xaf\x45\xf3\xfb\x1f\x5a\xba\xa5\xd1\xe8\xbf\x94\xdc\xee\x87\x1f\x97\x37\xc8\x95\x73\x4c\xa3\x0b\xd9\x5c\x56\xed\xdb\x4f\xfd\xab\xb7\xd5\xf0\x5a\x3c\xf1\x07\x67\x22\xb7\xb5\xe6\xc6\xbe\x3d\x7c\x17\xba\xac\xb8\xd1\xb6\xb9\xd4\xc0\x19\xa3\x97\xc8\xc0\xd8\x4d\x21\xdc\xfa\xdd\x23\x7a\xf2\x4b\x29\x4a\x61\x27\xd0\xa2\x4c\x57\x4d\x2f\xf7\x08\x4b\x39\x34\x69\xad\x1f\xd9\xa6\x4c\xd6\xcc\x15\xce\x52\x91\xf1\x5d\xa5\x69\x60\x24\x16\x1a\xf8\x3c\x47\x51\x67\x45\x2c\xcc\x49\x69\x0a\xbd\x01\x80\x71\x28\x37\x2f\x15\xac\x72\xc6\xdd\xea\x6a\xdb\xdf\x2b\xec\x72\x07\x86\x36\x6f\x3e\x5d\x9c\x5f\xbe\xbb\xac\xc5\x15\xcf\x6e\xfe\x1c\xff\xfb\xe7\x8f\xd7\x7f\x7e\xf7\xfe\xe3\xcf\xf1\xdf\xde\x9f\xdd\x5d\x9d\xff\x38\xff\xf4\xfe\xec\xaa\x12\x7d\x3c\xbb\x3d\xbb\xb9\xb8\xdd\x13\x60\x6c\x7e\xb5\x7b\x20\x78\x44\x7e\xe7\x20\xcf\x4e\xd9\xc1\xf9\x19\xe8\xab\xaf\xd9\x99\xa3\x02\xac\x90\x55\xba\x20\x31\xa0\x4a\x32\x04\xc7\x61\x2c\xf9\x2d\x2f\xf8\x39\x2f\x78\xa6\x57\x53\x76\xc6\x08\x10\x8e\x40\x7f\x63\x2d\x24\xe2\x49\xb3\xa3\x83\x45\x58\x33\x29\x09\x77\xf8\x20\x5d\xab\x97\xc4\x50\x98\x89\x58\xe4\xc4\x65\xb5\xcd\xd4\xc5\x83\x50\x45\x09\x24\xb4\x3c\xcb\x18\x7d\xd6\x3d\x10\x65\xec\xbb\x5a\x1a\xb9\x91\x19\xcf\x83\xca\xe8\x47\x2a\x0b\x6e\x29\xae\xae\x9e\xa0\xa9\x99\x0e\xee\x2e\x72\x77\x97\x0c\xea\x7d\xfe\xfe\x12\xec\xbe\xa4\x70\x12\x5a\xee\xe3\x33\x85\x0c\x78\xf4\xc5\x0d\x87\xe4\x93\x42\x93\x67\x15\x3f\x4f\x0f\x77\x4f\xc4\xa3\xa8\xc0\x5d\x0c\xe2\xb9\x6e\x94\xbe\x92\xee\x3f\x2e\x54\x91\xef\x06\x1b\x73\xb7\x90\x6d\x6d\xc0\x20\x27\x2c\x5b\x55\x79\x14\x1d\x5f\xcc\x95\x7e\x05\x16\x9e\x03\x5a\x52\x5c\xc6\x87\x5f\x10\xd7\xd2\x71\xe9\xc8\xec\xc9\xfb\x6b\xed\x87\x98\x10\x07\x7a\x61\xa1\x4b\x95\x1a\x42\xdd\x6d\xa4\x3a\xdd\xf0\x5f\x5e\xba\x96\x22\xc1\x84\xd7\xff\x01\xf2\x30\x91\xd9\xeb\xd7\xce\x6e\x72\xfd\xdd\x35\x53\x3d\xfd\xb5\xdf\x44\x76\x3b\x2b\xdc\xf5\xc2\xc5\x1c\xf1\x83\x0f\x62\xd7\x36\x7e\x0d\x0d\x37\x16\x13\x91\x43\x21\xdb\x5c\xd8\x07\x3d\x38\x31\x43\xcc\xa9\xff\x37\x24\x21\x54\x74\x66\xdb\xf7\xee\x38\xde\x7f\xd4\xb2\x69\x45\x1a\x0c\x37\x7c\x06\x8b\xf0\xd1\x97\xec\x98\x21\xee\xc0\xb9\xbc\x29\xe9\x82\x02\xaa\x76\xb0\xfe\x43\x2f\xd8\x12\x32\x90\x30\xd1\x8e\xe5\x02\x42\x1c\x30\x14\x4e\x35\x02\x28\xa6\x1a\x60\x06\x37\x05\x32\x61\xc0\xf1\xaf\xec\x1d\x53\x7c\x29\x29\x76\xfb\xea\xfb\x71\xe7\x6c\x81\xd4\xe3\xc8\x35\x5b\x27\xe5\xf6\x67\x39\xd4\xab\x54\xb2\x8d\x77\xee\xba\x54\xf6\x28\x7e\x0a\xd8\xcb\xf0\xb8\x66\xed\xa3\xf4\xcf\xbd\x49\x42\xce\x25\x9f\xe3\xf3\xcf\x46\x23\xfa\x53\x8d\x3d\x94\x3e\x07\x90\x74\x2a\x3d\x3e\xd0\x16\x3c\xb9\x7f\xe4\x79\x8a\x7e\x5b\xc0\xa1\x4c\xd9\x8f\xfa\x51\x3c\x88\x7c\xc2\x12\x91\x17\x9c\xa8\xbb\x0c\x04\xe2\x61\x41\x51\x39\x33\x05\x19\x1a\xc8\x83\xa6\x4c\x99\x0b\x56\xc8\xd5\xda\x5e\xa2\x23\x18\x85\xce\xed\x76\x54\x20\x6b\xe3\x56\x24\x44\x96\xd4\xd1\x01\xcb\x8c\x3f\x34\xb9\xc8\x0e\x61\x79\x60\x97\x3e\xcd\xd4\xc5\x29\x9d\x12\x4f\x1f\xf0\x85\x3a\x8c\x36\x4d\xa4\xb7\x99\xb0\x95\xce\xb8\x5a\x4d\xa7\x53\x60\x9d\x7f\x39\x6a\xa2\x53\x81\x71\xe4\xd3\xc3\xab\x33\xad\x8d\xc8\x76\x9e\xe0\xc7\x27\xc0\x00\xe2\xf2\x97\x42\x28\x23\xd1\xcf\xd3\x32\xfd\x6f\xea\x51\x81\xaf\x1b\x44\x69\xbf\x9e\x8f\x4e\xaf\xec\x28\x07\x84\xfd\x46\x94\x84\xcf\xb7\xdf\xbc\x0e\x4a\x17\x6e\x2f\x4b\x69\x35\x36\x07\xf6\x27\x2d\x3b\x62\xf8\x07\xf1\xee\xb5\x96\x44\x24\x25\x07\xe5\x0d\xb6\xf7\x59\x23\x95\xf3\x88\x2c\xce\x9e\x84\xcc\x91\xb9\x98\x43\x1c\x01\x37\xf5\xe1\x1e\xbd\x2c\xf6\x6b\x0d\xb5\x36\x68\x64\xae\x6b\x48\x4a\x1f\x63\x3a\x61\xba\x5c\xb6\x83\x1b\x97\xcf\x7c\x05\x77\x7a\x1a\x85\x03\x2a\xd1\x0e\xc8\xc1\x0a\xe1\x12\x4f\x1e\x15\x45\x47\x4c\xa1\x73\xbe\x12\x6c\x23\x52\x59\x6e\x5a\x37\x1b\x5f\xdd\x63\x70\x7f\x3a\x2b\x37\xdd\x34\x7e\xc7\x1a\xd0\xa1\x92\xf8\x5f\xe7\xf0\xb9\xc1\x06\xf4\x99\x87\xb4\x3b\xc9\x37\xaa\x2f\xfa\xfe\xa9\xaf\xed\x49\x99\x4b\x03\x84\x93\x87\xa4\x3c\xfa\x62\xb0\x68\x88\x9c\xee\xb6\xe8\x73\xae\x8c\xee\x89\x0b\x69\xd1\x2b\x06\x47\x15\xc2\xad\xdd\x87\x42\x1d\x4d\x38\x5e\xf8\x29\xd7\x65\x83\x6c\x67\x50\x84\x1b\xcc\xc6\x88\x06\x9e\xe0\x4e\x50\x20\x61\x32\x0a\xcd\x96\x2e\x89\xee\x5e\x44\xb4\x64\x29\x10\xc4\x3f\x22\xc7\xcd\x9f\xff\x60\x1c\x7a\x83\x00\x36\xc1\x62\x29\xc2\x47\x30\x20\xf2\xf0\xca\xe1\xaa\xb0\x85\x58\x04\x90\x87\xa5\x5c\x15\xad\x05\x04\xd8\x21\x94\x85\xaf\xfc\xc4\xcb\xac\xfd\x71\x2a\x1f\x1e\x45\x01\xc1\xb3\x9f\x6f\x18\x76\x35\x51\x89\xe7\x7d\x15\x8d\x0a\xd9\x8f\xec\x82\xee\x9a\x1f\x60\x09\x56\xc6\x01\x3b\xdd\x71\xc9\xdb\x6e\x17\x45\xb2\x0e\x96\x07\x90\xa7\x79\xd2\x37\x52\x87\xa5\x76\x6e\x02\x39\x3a\x82\x66\x63\xf4\xa1\x5c\x29\x1d\xeb\x7a\x68\x25\x20\x32\x65\x37\x20\x1d\x17\xcb\x64\xb1\x1f\xe2\x35\x92\x31\x6c\xdf\x54\x2b\x34\x42\x77\xa8\x9d\x95\x00\x23\x5c\x29\x24\xf2\x0c\x39\x7c\x2c\xde\x89\x48\x6c\xb4\x4e\x9a\x5d\x65\x6e\x98\xa9\xea\xa7\x1a\x9d\xe4\x30\x58\x32\x17\xc8\x75\x6b\xac\xf5\x56\xc8\x07\xbb\x50\x9b\xd3\xda\x4f\x50\xd8\x01\x9a\x73\x6f\xa6\xb0\xda\x11\x61\xee\xbd\xd8\x99\x58\xd9\x94\x66\x14\xeb\x9a\x90\xd2\xb6\x87\xc6\x6b\xff\x50\x40\xc7\xcd\xf3\xa0\x4f\x36\xec\x2c\xc3\x8f\x7e\xb0\x2f\xf7\x80\x3b\x1b\x85\xdb\x39\x18\xb2\x14\x83\x4f\x91\xb6\x89\xd0\xcf\x34\x86\x01\xbf\x05\xe8\xbc\x18\x7f\x17\xa7\x9c\xc0\xc5\xd7\xde\x6f\x67\x8a\x38\xb5\xa3\x43\xce\x6e\x38\xcd\x61\xa3\xd4\x69\x64\xf2\xdd\x55\x68\x5f\x80\xf6\xd0\x51\x40\x56\x3f\xe9\x82\xad\x4e\x18\x7b\xa6\xe0\xd3\x98\x5c\xea\x7c\x78\xad\x1f\x3c\x10\x14\x48\x83\xdb\x09\x04\x8c\x32\xb8\xf0\x49\x62\xfe\x43\x89\x5c\xbc\xfd\x24\xc2\x76\xdf\x99\x6a\xc5\xe0\x39\x04\xde\xcd\xc5\xf9\xf5\xc5\xed\x57\x03\x0a\x3a\x94\xde\x68\xa4\xa0\xab\xe7\xdb\x8b\x77\x67\x77\xef\x6f\xe7\x6f\x2f\xaf\x9f\x03\x2a\x48\x3f\x1d\x80\x15\xbc\x21\xaa\xfe\x73\xad\x0a\xf1\xcb\x51\x67\x72\x5e\xaa\x39\x1f\x91\xb3\xe2\xc5\x3a\xfa\xcc\x1d\x2c\xb4\x29\x35\xe0\x75\x00\x88\x77\x12\x4f\x34\xaf\x2c\xb0\x0c\x4e\xc3\xa5\xcc\x32\x48\xe1\xf5\xee\x75\x4a\x0f\xb3\x9d\x0a\xfb\x8f\xa3\xda\xa4\x3d\x75\xa6\x16\x15\x25\x08\x70\xf9\xad\xed\x25\x18\x93\x77\xb7\xb6\x03\x72\x09\xa9\x91\x7d\x6a\x04\x2b\xa9\x44\xa8\x06\xca\xd9\x97\x8a\x75\x52\x48\xd3\x20\x3e\x27\x24\x8a\x0c\xaf\xa1\xb6\xa6\x9b\x71\x95\xf9\xe9\xcc\x4f\xf7\xa3\x6f\x21\x2e\x62\xa9\xd0\x30\xad\xac\xe6\x9b\xf6\xa9\x7b\x1a\x96\x00\xf4\xbb\x1d\x49\x0e\x31\x08\x50\x8c\x0f\x03\x49\x03\x81\x2a\x45\x21\x38\x71\x2f\x11\x3a\xa4\x97\xb5\x7e\xb6\x5b\xa1\xed\x6b\x09\x91\x0a\x4e\xac\x24\x49\x56\x9a\x42\xe4\xe4\x36\x39\xfb\xf9\x66\xa6\xde\xd8\xe3\xeb\x25\x9d\x42\xa4\x64\x83\x9f\x40\xe0\x8a\xae\x7c\xdf\x59\x28\xf1\x0e\xf6\x1d\xfa\xa8\x37\x82\x2b\xc3\x60\x69\x64\x99\xc8\xc3\xcc\xc0\xfa\x08\x91\x92\xa2\x2b\xd0\xb0\x86\xf7\x5f\x32\x42\x25\xda\xae\xb0\xf5\xa5\x5f\x73\xb1\xd1\x45\x73\x3e\x75\x65\x88\x03\x54\xf8\x39\x67\x4e\x4b\xc6\xca\xd0\x59\x44\x28\xeb\xd6\x49\x54\xcd\x1f\x19\x34\x97\x6e\xb1\xb8\xdf\xa6\xd2\x13\x4e\xa5\x01\xe7\x7a\x7c\x4a\xb0\xb5\xb6\x1b\xa8\x97\x79\x09\x61\x66\xcf\x50\x91\x01\xe8\xcb\x76\x63\xeb\xa9\x53\x93\x3a\x3c\x06\xfb\x01\x45\x1d\x07\xad\x3d\x6b\xa1\xc2\x09\x9a\x5a\x2e\xb6\xd3\xab\xa2\xf8\x3c\x94\x73\x67\x0e\x64\xa8\x74\xe1\xc8\x23\x3c\xae\x8f\x40\x8a\xf6\x01\xcf\x5a\xd2\x5b\x47\x62\x02\x71\x56\xca\xfc\x48\x25\xb2\xdb\x18\x0c\x59\x49\xa7\xc5\x5a\xc4\x89\xf8\x2e\xf9\xde\x93\x77\x8c\x99\x7c\x87\x6b\x5d\x56\xe7\x9c\x27\x82\x3c\x08\xec\x70\xf5\xf1\xea\x22\x86\x2a\x5c\x5e\xdd\x5e\xfc\xf1\xe2\xba\x92\x88\xfd\xfe\xe3\x59\x25\x99\xfa\xe6\xf6\xba\x96\x43\xfd\xe6\xe3\xc7\xf7\x17\x0d\xcc\xc3\xc5\xed\xe5\x87\x4a\xe1\x6f\xef\xae\xcf\x6e\x2f\x3f\x56\x9e\x7b\x73\x79\x75\x76\xfd\xaf\xf1\x5f\x2e\xae\xaf\x3f\x5e\xd7\xbe\x77\x77\xde\x8f\x9e\xa8\x34\xa3\xdd\xfd\x13\x82\xb3\x11\x27\x66\xeb\x32\xae\x6a\x81\x1e\xb1\x8a\x07\x22\xcf\xf6\x4d\x47\x97\x67\x9d\xc6\x54\xf9\xb8\x30\x6c\x55\x47\xcd\xba\xa7\x17\x2f\xad\x74\xdd\x96\x1f\xb7\xed\xd9\x53\x6d\xfe\x14\x48\xc0\x5e\x03\xd0\x7f\xa5\xe6\xb8\x25\xad\x60\xec\xda\x2d\x44\xb0\x56\xbc\x53\xba\x47\xa5\xcf\x5e\x53\xf7\x8d\x7d\xf5\x0c\x1c\x4c\x7b\xa8\x6c\x9e\x8a\xc6\xa2\xaf\xd2\xd1\xc7\x5c\x96\xb8\x4c\x9d\xa1\xe0\x7e\x8c\x0e\x6e\x68\x86\x9d\x39\xd1\x74\xec\x52\x99\x6c\xcf\x37\xe9\xa7\x4d\x1b\x5b\x7f\xfa\x48\xb3\xee\x35\x8e\x8d\x11\xf5\x06\xae\xa3\x31\xf5\xbe\xe5\xe6\x7e\x6c\xbd\xe9\x23\xcd\x7a\x83\xd9\x77\x50\xbd\xc1\xe1\x5d\xb4\xf3\x9f\x8c\xd8\xc4\xe2\x62\xaa\xd5\xf3\xc9\xd9\xfe\x91\x48\xcc\x75\x58\x1d\xed\x02\x78\xde\xeb\xe5\x96\x0f\x0f\x64\x40\x6d\xfc\x72\xe5\x35\x3a\xf0\x1b\xf8\x15\x5a\xb8\xc8\x05\xbf\x4f\xf5\x23\x8d\x47\x1d\x19\xca\x06\xed\xe6\xd5\x0e\xb2\x7b\xb8\x3b\x22\x8a\x9c\x22\x50\x88\x52\x0b\xc5\x03\x4c\x4e\x12\xa1\x35\xda\x60\x91\x0a\x69\x9d\x41\x06\x38\x7b\x54\x18\x9d\x99\x42\x6b\xbe\x4d\xc9\xd4\x8e\xaa\xad\x11\x71\x3e\x40\x53\xbd\x0d\x8d\xc1\x75\x13\x0d\x2c\x25\x70\x94\x39\x80\xe9\x16\x39\xdc\x99\xa0\x43\xa4\x02\x67\x72\x6e\x2f\x3c\xb9\x48\xa4\x11\x91\x9a\x53\xeb\x89\xfd\xe5\x38\xed\x87\x82\x17\xad\x6e\xd7\xc1\xfe\x70\x9e\x14\x25\xcf\xd8\x97\x52\xe4\x3b\xa2\xce\x43\x5f\x25\xfe\x25\xe1\x0a\x33\x45\x0a\xb1\xd9\x42\x3a\x76\x9c\xe2\x30\x53\x3f\x03\x50\x02\x87\xe0\x85\x61\x7f\x04\xc8\x83\x7b\x98\x0e\xe1\x0d\x2f\xe0\x2c\xfe\x0b\x7e\xc3\xff\x36\x9d\xa9\x8a\x3a\x4a\xf4\x56\x45\x28\x65\x3a\x53\x4e\x9e\x20\xd5\x89\x99\xc2\x8d\x6f\xaa\xf3\xd5\x29\x09\xfb\xda\xc9\xae\xef\x17\x5a\xdf\x9f\x0a\x75\x0a\x3e\xa9\xe2\x94\x97\x85\x3e\x05\xb8\x14\x8e\xbf\x39\x75\xfa\x9f\x4e\x40\xd5\x9c\xae\xe5\x83\x80\xff\x37\x5d\x17\x9b\xec\x1f\xcc\x76\xfd\xcb\xc9\x2a\xcb\x4f\xec\xbb\x27\xf1\xbb\x27\xee\xdd\x13\xf7\xee\x89\x7d\x0d\xff\xdf\x76\x87\xe1\x1d\xf1\x0b\xb7\x67\xd9\x64\xa6\xa4\x32\x22\x2f\xc0\xfa\x79\xcc\x65\x11\x64\x68\x76\xec\xc5\x7f\xfd\x17\x9b\xe6\xfc\x11\x53\x19\xdf\xf2\x82\x7f\x42\xff\xe2\x7f\xff\xf7\x0b\x08\xa8\x62\x52\xcf\x96\xe7\x5f\x4a\x51\xcc\x94\x11\x76\x11\xb2\xff\x6f\xa6\x20\x02\xbb\xd9\xcd\x0b\xf4\xbb\xa2\x0f\x32\x35\xec\x5f\xb0\xcc\x4b\xa4\x91\x4c\x8d\x2d\xa9\x23\x9d\x40\xf2\xac\x45\x32\xba\xc3\x45\xff\x25\x7b\x4b\xcf\x8f\x58\xd6\x5f\xb2\xea\xaa\x76\x42\x28\xe6\x4b\x06\x07\x68\xa6\xb9\x03\x6b\x31\x3f\x79\xe1\x9e\x4c\x95\x6b\x5b\x23\x0d\x68\xc0\xb3\x86\xe9\xdb\xd7\xca\x0d\x52\x59\x3b\xcf\x7d\x63\x1b\x81\x58\x41\x88\x43\x40\xf4\x5c\xda\x15\x72\x83\x9e\x50\xb0\xdc\xb0\xe5\x60\x93\x52\xe8\xdc\x97\x87\x8e\x0b\xf3\xfb\xd7\xa7\xa7\x13\xb6\x32\xf0\x3f\x8b\x2f\xf0\x3f\x80\x1e\x7a\x2a\x36\xd6\x46\x67\x7a\x20\x5c\x73\x94\xf7\x8f\xc4\x53\xa0\xe8\xbe\x06\x01\x78\x6d\x9a\xbe\x29\x55\x9a\x89\x90\x02\x59\x09\x89\x64\xda\x49\xd6\xa3\x63\xac\x2e\xb5\x02\x63\xbc\x10\x09\xb7\x1b\x5f\xe3\xdb\x08\x2e\xd5\xcb\x42\x28\xf4\x86\xe5\x41\x89\x8d\xa3\xe7\x0a\xcc\x62\x80\x42\xf2\x82\x20\xe7\x02\xfe\x08\x1f\x01\x46\xed\x49\xfd\x27\xb6\xd3\x25\x91\x43\x03\xe5\x69\x2a\x92\x0c\x18\xf8\x1d\xed\x0b\xcb\x45\x51\xe6\x8a\x71\xb6\xe5\x2a\xe5\x06\x66\xe0\x32\x87\x68\x67\xce\x78\xb3\xa2\x13\x84\xe3\xea\xb2\x00\x32\x23\x44\x16\xc4\x3d\x81\xec\xdd\x51\x9d\x27\x51\x25\xf0\x4c\x00\x12\xe1\xc6\x8b\xd3\x99\x72\x5a\x61\x84\x85\x43\x4f\x59\xa2\xb7\x3b\xa2\xaa\xa9\x77\xba\x74\x9e\x33\xea\xee\x49\xc0\x9b\xd4\x9f\x9d\x30\x59\x0d\xad\x01\x51\x78\x11\xa9\x1d\x3b\xbd\xe8\xef\x84\x4a\x74\x2a\x72\xf3\xd2\x2e\x43\xe9\xef\x1d\x68\x3f\x48\x13\x06\x03\x76\x29\x7b\xb8\x91\xb7\xd0\x16\xef\x15\x75\x6c\xef\x54\xa8\xa5\xdb\xec\x9c\xfd\x4b\xe5\xd7\x8e\x82\x69\xab\x2f\xfd\xe7\x57\x45\xc4\xc4\xb8\x4e\x77\xe7\x3c\xdc\x05\x81\x4b\x36\xde\x71\xb1\x50\xb4\x71\xc8\x38\x71\xd2\xb2\xb2\x00\xf5\xba\x5c\x98\x62\xa6\xe8\x04\x9e\xb0\xa5\xe0\xd6\xce\x9b\xb0\xc4\x3c\xe0\x66\x8c\xc7\x7d\xf1\xa8\x03\x06\xc7\xe9\x92\x00\x18\xb6\x52\x78\x70\x12\xe3\x63\x80\x28\xe0\x49\x81\x00\x83\x4e\x15\x72\x67\xaa\x40\x67\xb5\x6e\x88\x07\xf4\x83\x93\xb9\xa8\x4b\x4a\xc5\x2a\x2b\xd0\x13\x3b\x0c\x14\xb3\x7a\x3d\xf0\x07\xbb\xf1\x60\xeb\x10\x06\x12\x6d\x8e\x60\x71\x13\x96\x16\xd7\x59\x88\xe1\xc6\x5c\xe3\xe0\x9b\xe9\x5a\x54\x3d\x1d\x01\x15\x38\xcc\x6f\x61\x5f\xdd\xeb\xb0\x32\x22\x77\x1a\x1c\xd8\x56\x64\x06\x5c\xcb\x3c\x3d\xd9\xf2\xbc\xd8\xb9\xe9\x9b\xc9\x05\x50\xf7\x67\xf2\x5e\xb0\xb3\x3c\xd7\x8f\x4f\xdd\x0b\x9d\x5b\x4b\xd7\x0d\xfb\x18\x24\xfb\xd8\x5b\x7e\x2b\x2f\x68\xdd\xdd\x71\x18\x07\x69\x97\xe3\xa3\xf5\x3b\xb9\x28\xf2\xdd\xdc\x4e\xc4\xcd\xb6\x73\xa7\x18\x94\x34\x31\xdc\xc8\x1d\x47\x6f\x5a\x73\x61\x74\xd2\x9b\x56\x46\xf5\xd7\x43\x6f\xda\xc2\x5c\xda\xa4\x37\xbd\xbc\xba\xbc\xbd\x3c\x7b\x7f\xf9\x7f\x6b\x25\xfe\x7c\x76\x79\x7b\x79\xf5\xc7\xf9\xbb\x8f\xd7\xf3\xeb\x8b\x9b\x8f\x77\xd7\xe7\x17\xfd\x7c\x45\xcd\xda\x07\x13\xfc\x84\xc5\xdf\x79\xcd\x6e\x23\xa0\x06\x26\x1b\x90\xfd\x4d\xda\x95\x30\xab\xec\x62\x96\x6a\x35\x81\x85\xfa\x9a\x5d\xe4\xf9\xe5\x86\xaf\xc4\xa7\x32\xcb\x00\x4e\x85\x99\x3d\xe7\xb9\x80\x8b\xe7\x84\x7d\xd2\xe9\x65\xf4\x1e\xa4\x23\xb6\x36\x03\xbe\xcf\xd3\x34\x17\xc6\xe0\xe7\x27\xf4\xfd\x08\x3c\xe4\x53\x1d\x09\x3c\xc7\x1f\xb8\xcc\xec\xfd\xed\x35\x7b\xc3\x93\x7b\xbd\x5c\x62\xfa\xcc\xc4\x27\x4e\xb1\x2f\xa5\x2e\x38\x13\xbf\x24\xc0\xd1\xd5\x3e\x4f\xde\xeb\xd5\x37\x80\x2a\x0f\x08\x4f\x75\x5c\x52\x40\xa3\x6c\xde\x7e\x9c\xb7\x6f\x04\xd4\xca\x0f\xf8\xea\x3b\x7c\xb3\xdd\x41\x59\x64\x4f\x90\x1e\xff\x5e\xaf\xda\x15\x63\xc0\xba\x26\x99\x1b\x0a\x24\x24\x44\xb6\xa1\x57\xcc\x48\x75\x3f\x53\x3f\xaf\x85\x62\xba\xcc\xf1\x4f\x70\xcd\xb7\x66\x66\x56\x9a\xb5\x00\x09\xd9\x09\x7b\x14\x6c\xc3\x77\x68\x36\xc3\x9d\xc0\xcb\x5c\xc0\x94\x81\x53\xc4\xbe\x9d\x49\x65\x77\x8b\xad\x74\x79\x09\xf5\xa1\x7f\x8a\x1b\x97\x63\xa8\xe3\xc7\x13\xc8\xf6\x9d\xa7\x15\x7c\x1e\xb8\xca\x02\x6e\xd2\x01\x84\x68\xe7\x06\x15\x4d\xad\xef\xcb\x6d\xe0\xb2\x7c\xe1\x82\x93\xd0\xdd\x0f\x5a\xa6\x2c\x2d\xb7\x99\x4c\xfc\xbe\xfb\xa8\xf3\x4e\xc2\x5e\x4c\xa0\x19\x7e\xea\xd4\xd3\xc2\xfa\x1a\xd6\x92\x9d\x13\x21\xe9\x7a\xa8\x7b\x9f\x99\xbc\x98\x49\x95\x64\x25\xe8\x83\x95\x46\xe4\x27\x45\x2e\x57\x2b\x30\xc0\x5d\xae\xdf\xaf\x9f\xdd\x38\xb0\x27\x1e\x9f\xd6\x16\x27\x9d\x67\x7a\x25\x13\x9e\xc5\xe0\xe6\x80\x8a\xf0\xf4\xa9\x6e\xd9\x93\x7a\x2a\xe4\x41\xb8\x0a\x75\x32\x20\x6d\x73\x01\x0c\xbe\x73\xd8\xca\xe7\xb4\xdd\x1d\x53\xef\x25\xb3\x17\x74\xac\x57\x4c\x6e\xea\xc2\x0b\xee\x84\x0b\xdf\x76\x12\x5a\x60\x62\xa2\xbc\x36\xd3\x8f\x4a\xe4\x60\xc1\x02\xec\xc3\xb6\x54\x69\xb0\x4d\xbc\xac\x96\xc7\x27\x3b\x59\xb9\xa5\x07\x62\x63\xe6\xec\x4a\x3e\x08\xf5\xf5\xd9\xa8\xa3\x0f\x24\x3c\x59\x8b\xb9\xb3\xcb\x9f\x7a\xcb\xf2\x07\xc0\xc8\xcd\xca\xe9\x5b\xc4\x5b\xa9\x0f\x6f\xc2\xd5\x09\x6b\xdc\xdc\xbb\x30\x90\xd8\x93\x91\x65\x2b\x31\x4f\x45\x72\xff\xd5\xb7\xe6\x00\xb2\x72\x15\x61\x9c\xbd\x15\xc9\x3d\xbb\xbb\xbe\xc4\x6c\x60\x59\x30\xbb\x15\x98\x75\xd0\xeb\xe9\xbc\xbb\x15\x7c\xf5\x0c\x8c\x4e\x43\x05\x87\x02\xc7\xbc\x97\x59\xb3\x15\x22\x40\x14\xe4\x4b\xda\x4d\x92\x72\x69\x00\x08\xc6\x0b\x27\x43\x03\x8e\x78\x66\x36\xa0\x3a\x53\x16\x91\x54\x5b\xc6\x17\x22\xeb\x60\x5c\xdc\xea\x74\xee\xe2\x24\xc7\x82\x79\x1a\x65\x39\x3f\x06\x45\x1d\x5d\x1e\x03\xb7\x16\xeb\x2d\x3d\xc8\xee\xff\x60\x22\x7a\x0d\x1d\x13\x3f\xc3\xbd\x9e\x1b\x48\xef\x5e\xca\x95\x8b\xb6\xc9\x25\x69\xe3\x60\x42\x3f\xa8\xc0\xdb\xfd\xd2\x96\xf4\x49\xa7\x04\xd3\xf3\x24\x66\xd6\x0a\x12\xe4\x3d\x09\xb8\x8a\xb8\x0a\x5e\x29\xdf\x80\x6f\xc0\x14\x82\xa7\x4c\x2f\xc9\x9b\xb8\xdd\x66\x12\x28\x7d\x53\x64\x0f\x07\xf6\x0c\x53\x45\xc7\xc7\xa5\xb9\xca\x46\x24\x1f\x9f\x1c\x10\xaf\x37\xde\x18\x82\x5c\xb6\x5d\x55\x27\x77\xdd\xa6\x3a\x56\x05\xce\xe7\x23\x1d\x7a\x85\xee\xf7\xa6\xad\x32\xbd\x80\x8e\xea\x06\xc5\xf5\x6c\xd0\x76\x77\xca\x65\x3a\xe6\x78\x77\x7d\xf2\xd1\xbf\xda\x57\xc1\x8f\xce\xd3\xe1\xbf\xe4\x86\x99\x11\xe1\x7a\x1c\xc1\xaf\xa5\xb1\xef\xbb\x6b\x43\x80\xd0\xf8\x08\xa1\xb7\xc6\x0b\x92\x1b\x80\x55\xe1\xb7\xe3\x8e\x6b\x75\xb5\x2d\x47\x0d\x74\x93\x18\x65\x4f\x5f\x06\x2e\x95\xfe\x41\x3e\x82\xdd\x02\x57\xae\xa7\xb8\xe8\x76\xa4\xa9\x54\xa4\xf3\x03\xda\x70\x41\xef\x0e\x6b\x8b\xef\x69\xac\x1e\xb8\xbc\xd4\x89\x3d\x19\x53\x9e\xa7\xa1\x1d\x13\xb8\x11\x27\x7c\x0b\x5e\x67\xf0\xe2\x3f\xbc\x9a\xba\x6f\x5c\x87\x64\x1a\xbb\x3d\x60\x8a\x3b\xc2\x95\x75\x8b\x56\xc7\xbe\x79\xe4\x27\x29\xa2\x99\xed\xcc\x09\xd3\xb5\x92\x66\x32\x68\xee\xd6\x67\x98\xdb\xaf\x8e\x99\x5c\xcf\xb1\x77\x94\x85\x0e\xc1\x0d\x68\xcf\x25\xd0\xa3\xc6\x09\x6c\xb0\x41\x5e\xa6\x1d\xc0\x08\x67\x6d\xba\x4d\x68\x04\xdc\x76\x14\xe0\x77\x9b\x0b\x17\x26\xdb\x89\xc2\xd3\x18\x64\x4e\xff\x0c\xa2\x40\xbe\xd5\x55\x1e\x17\x47\xd5\xe0\xb9\xb7\x20\x66\x43\x96\x6d\xa2\x37\x5b\xad\x00\x85\x83\x49\x59\x33\x45\x85\x3b\x15\x6b\x1f\x48\xaa\x64\xf6\x4d\xc8\x7f\x87\x79\x22\xc2\xe8\xec\x81\x22\x86\x91\xd8\x02\xe8\xdf\xd9\x0a\x9e\xdb\xab\x90\xbd\xf8\x43\x28\x9b\x0e\x32\x00\xbe\xd7\xa4\x9c\x73\xb1\x92\xa6\x10\x71\x32\x64\xfc\xfe\x93\xa9\x6e\x56\x7c\x05\x7d\x5d\xdf\xa9\xba\xb9\xcf\xe8\xb7\xfb\xd3\x88\xfa\xec\xb6\x22\xbd\xf4\xef\xf5\x4f\x86\x5a\xbe\x7a\xd8\x0e\x2b\xe7\x1d\xce\x01\xbc\xec\x18\x64\xb6\x32\x5e\x26\xc1\x0f\x12\x71\x0e\xf1\x80\xdf\xb3\x43\xb4\x2a\x79\xce\x55\x21\x84\x99\x29\x8a\xb3\x22\x43\x5b\x4c\x42\x52\xc3\xfd\x79\x53\x3e\xd1\xa6\x40\xc2\x23\x78\x65\xc9\x65\x56\xe6\x9d\xb7\x6b\x9c\x95\x07\xb1\x2c\xf4\xf5\xd2\x39\x14\xcb\xda\x06\xcd\xe7\xeb\x46\xab\xc8\x93\x84\xd4\xa3\xa4\xd5\x74\xd6\x8e\x26\xb8\xc3\x65\xf8\x78\x7b\xd7\x6a\x47\x0a\xef\x1f\xcc\x7c\xab\x47\xec\x78\x7f\xfe\x83\xf9\xa4\x3b\x92\x9f\xcd\x97\x86\x0b\xb0\x07\x2d\xf0\xa5\x4b\x38\x82\x9b\x7b\x08\xb4\xed\xf3\x3c\x0c\x22\x9f\xdc\x1b\x8e\xeb\xdc\xbb\x60\xd6\xae\xb9\x4a\x33\x7b\x23\xe7\x45\xed\x04\x0a\xb0\x66\x7b\x03\x28\xdc\xe6\xd8\x9d\xc3\x06\x29\x21\xf3\xa4\x91\x4f\xb8\xaf\x9f\x6a\x89\x88\xbd\xd0\xc1\xda\x57\xaa\xe9\x81\x6d\x69\x29\xc1\x86\x21\xb9\x56\xbf\x60\xbf\xb9\xfd\x72\x11\xd7\xfd\x2b\x99\x2f\xd5\xb5\xb6\x94\xab\x5f\xc1\xbd\xf9\x43\xf3\x48\x48\x68\xcf\xa1\x83\xda\x83\xf9\x8f\xdc\x75\x20\x6f\xca\xee\xda\x31\xdf\xf4\x4c\x91\x6c\x35\x06\xd3\x21\x8a\x8a\xf4\x62\x86\xbd\xf2\xc9\xb4\xaf\xfe\xd1\x91\x4b\xed\xd8\x12\x26\x15\x30\xb8\xe9\x24\x29\x73\x88\x74\x93\x37\x8e\x09\x3c\x84\xcd\x28\xde\x14\x30\x3d\x3c\x3e\x09\xed\xc4\x36\x33\xc9\xbb\x5f\x2b\x8d\xba\x05\xaf\x1b\x0a\x70\xfb\x43\x9f\x74\x95\x72\x53\x30\x53\x88\x6d\xeb\xf6\x5b\xb1\x2e\xab\x1a\xf3\x47\xd8\x97\x41\xe1\x7e\xe0\xd2\x19\x71\x18\x9d\x45\x1e\x92\x3f\xdd\x7c\xbc\x62\x5b\xbe\x03\xa8\x5f\xa1\x19\x3e\x0a\xfc\x9a\xf5\x8d\x6a\xdf\x08\x54\x1b\x5f\xdd\x55\xb0\x4f\x1d\x66\xb8\xdd\x1d\x4f\x5f\x6c\x1a\x8b\x30\x67\x68\x4a\xda\x3d\x2b\xd7\xd9\xc9\x36\xe3\x2a\x42\x73\x9b\x29\xab\x7d\x3e\x0e\xdf\xfb\x40\x1e\x01\xa4\xa0\x02\xe0\x21\xa3\xb9\x90\x97\xad\x78\xdf\xaa\x6c\xfe\x51\x11\xfb\xce\x3d\xa2\x17\xc7\xf8\x01\xd5\x2a\x78\x62\x97\x09\x92\x45\x38\x14\x82\x07\xb2\x70\x03\x18\xd3\x4e\xc2\x6b\x9e\x64\xdc\x98\x5e\x50\xca\x73\x30\xb6\xc7\x49\x7a\xfb\xb7\xaf\x6a\x3d\x11\x35\x07\x54\x1e\x78\x2f\xf5\x3f\x03\x39\x80\xdb\xba\x82\x38\x55\x64\xef\x47\x22\x09\x14\xe9\x27\x7a\x24\x78\x1f\x89\x0f\xef\xc5\xce\x39\xe8\x68\xab\xe2\x1b\x31\xf1\xbe\x45\xef\x3c\x8b\x30\x6e\xcd\x82\x67\x0a\x40\xa0\xef\xe2\xea\xb1\x77\x5a\x4f\x10\x8e\x48\x1f\xe7\x58\x2c\x8f\x01\x3d\x33\xf5\x4e\xeb\x29\xf7\x97\x58\xaa\x3f\x6d\x37\xf5\x0f\x12\x08\x08\x20\x76\xb5\xe1\x1c\xbe\x36\x7f\x94\x0a\x65\xd4\xe4\xc6\x5e\xa0\xa8\x9f\x60\x46\x41\x85\x9c\x6a\xb7\x7e\x34\x2c\x45\x06\x95\x52\x9a\x35\x44\x19\x30\xac\x07\xdf\xa7\x23\x05\xf1\x47\x39\x57\xc6\xae\x61\x88\x4c\x88\x07\x41\xee\xc9\x4a\x48\xfd\xf2\xed\x7b\x8f\xd2\xc1\x75\x49\xc2\x8a\x1d\xab\x2d\xba\x74\x1c\x73\x39\x07\x74\xf5\x08\xfe\x36\xca\xc3\xfc\xc0\xb7\x7d\xb9\x9f\x47\x97\xb8\x6f\x94\x3c\x7f\x54\xfd\x46\x05\x8a\xcb\xa0\xb5\x56\x49\x00\x8d\x7b\xef\x4e\x1d\x79\xe2\xb4\x52\xb8\xef\x97\x06\x19\xec\x60\x18\xb9\x55\xec\x3f\x6e\x22\x2a\x47\x8f\x90\xf3\x77\x41\xbb\xb1\x83\x92\x15\x70\xd0\xe1\x92\x9e\xb2\x1b\x21\xd8\x67\xe8\x29\xfb\xb1\xcf\xa4\x94\x08\xa0\xdf\x82\xcb\x56\x21\x2b\x78\xfa\x52\x2d\xf5\x71\xfb\x7f\xbe\x6a\x80\x4a\x8f\xea\x95\xf6\x7a\x1e\x0b\x5b\x85\x84\x64\xf5\xbc\x2c\x1a\x83\x0e\x86\xda\x58\x7f\x0a\xfe\x26\xca\xad\x75\x35\xb5\x26\x19\x0c\xf1\x21\x3c\x6d\xb5\x49\x62\x5b\x39\x41\xee\xf1\x7b\xa5\x1f\x15\xee\xc7\xf4\x25\xf6\x9d\x5d\x7f\x60\xb3\x60\x18\x04\x2d\xc1\x12\x77\xc3\x97\x40\x86\x7e\xe6\xff\xcd\x6e\x30\xe2\x8b\x75\x06\x89\x23\x03\xf6\x2e\x89\x13\xc1\x01\xfe\xdd\xd9\x84\xbd\x99\xb0\xf3\x09\x9b\x4e\xa7\x2f\x27\xa8\xbf\x4e\x35\xc2\x57\x70\xeb\x2f\xf8\xca\x96\x4d\xa2\x2f\xcb\xe8\x03\x20\x63\x66\xed\x13\xc7\xf9\xc7\xc3\x53\x91\x57\xcd\x35\x01\x33\x91\x29\x6d\x8a\xd0\x31\xc9\x5a\xcb\x50\x29\x00\x5a\x8b\x44\xe7\x0e\xaa\x6d\x0a\x9d\x3b\xd8\xe9\x03\xcf\xb9\x54\x40\xd0\xc0\x9b\xa0\x7b\xfa\x72\x44\xd1\x2e\x7e\xe1\x1b\x68\xbf\x54\x9e\xa5\xd6\x76\xd3\xad\xaf\x7f\xb1\xdb\x52\x58\xe9\x31\x97\x45\x61\x0d\x32\x33\x53\x37\xec\xf5\xbf\xb0\xb3\xed\x36\x13\xec\x8c\xfd\x8d\xbd\xe1\x8a\x2b\xce\xde\xb0\xbf\xb1\x73\xae\x0a\x9e\xe9\x72\x2b\xd8\x39\xfb\x9b\xed\x36\x5b\xde\x95\xb6\x16\xd0\x6e\xc2\x38\x53\x65\x86\x86\xde\x77\x0e\xd2\xf9\xd2\xb7\x8b\x87\xd1\x59\x88\xe2\x51\x08\xc5\x8c\xde\xd0\x51\xf8\x57\x7f\xfa\x1b\xa9\x56\x99\x28\x68\x3e\x54\xc1\xb7\xf8\x81\x13\x68\xe9\xeb\x99\xf2\x7e\xea\xbf\xda\x1a\xff\x95\xfd\x8d\x5d\x95\x59\x66\xab\x64\x37\x1a\x3b\x91\x5e\x33\x97\x0c\x25\xd4\xf4\x51\xde\xcb\xad\x48\x25\x87\x74\x28\xfb\xaf\xd3\x5b\x18\xed\x79\x19\x98\x2f\xe3\x35\xed\x65\xa3\x8e\xd9\x7a\x9e\x85\x5a\xc1\x8b\x9a\xc5\xd6\x4a\x27\xe6\x22\x7e\x75\xbc\x11\x1c\xf8\x7e\x69\x3d\xd0\x1d\x05\x25\xbf\x62\xf1\xb4\x83\xb6\x80\xda\x61\xeb\xca\x6a\x39\x0a\xe2\x43\xfd\xd8\x4d\x16\x94\x00\xbf\xa2\x39\xfe\x53\xa3\x8b\x06\x53\xcd\x93\xda\x51\x85\xac\x02\x6c\xc9\x40\xd8\x35\x28\xb6\xeb\x75\x93\x7e\xaa\x4a\x21\x56\xba\x58\xcb\x41\x9a\x91\xb5\xca\xde\xd1\x4d\x00\xd3\x4c\xed\x32\x95\xd9\xa9\x5d\xaa\xa7\x57\x5a\x09\xc6\x8d\x91\x2b\x24\x19\x03\x87\x0e\x8a\x2d\x3a\xa3\xe0\xb6\x6a\xb2\x46\x4b\x00\xec\x03\x5b\x25\x04\xa8\x16\x76\x17\xb0\x43\x90\xed\x66\xca\xbe\x41\x27\x12\x24\xab\x48\xcf\x45\x8d\x5f\x23\xaa\x67\xf7\x2d\xda\x90\xa3\xc2\x5b\x26\x58\x5f\x26\xfc\x11\x13\x8e\x12\x2f\x8f\x88\xf8\x5c\x45\x3c\x8c\x54\x9a\x23\xe9\x41\xf4\xc2\x42\x64\x5a\xad\xec\xac\xe8\xda\x04\xf4\x86\xcb\x63\xe0\x61\x71\x15\xb0\xb0\xce\x1a\xd8\xc3\x92\x1e\xa1\x21\xb1\xe7\xa4\x4c\x83\x4b\xc7\x94\x0b\x6b\x47\xf8\x68\x83\x3f\x0d\xa9\x71\x5d\xb4\x00\xc7\xa1\x44\xee\x8c\xc8\x81\x2c\x1d\x71\x4a\x3e\x92\x85\x07\x67\xa0\xcc\xc1\x16\x0d\x5b\x54\xbd\xf0\xf6\x76\xef\x17\x45\xca\x1a\x04\x09\x03\xe6\xe3\xb7\x44\xba\x0f\xc1\xbf\xbf\x3b\xbb\x7c\x5f\x7b\xae\x89\x7f\x6f\x01\xc9\xdf\x5e\x7e\xb8\x78\x3b\xff\x78\x77\xdb\x78\xce\x96\x46\x7f\xda\x03\x81\xef\xec\xbd\xa7\x00\x01\x7f\x41\xd1\xa6\xb9\x5e\xba\x7c\xe8\xe1\x67\x7a\x43\x36\x6b\x18\xd6\x2c\xa6\xca\x8f\xe5\xa5\x9a\x13\xa7\x93\xd5\x41\xcd\x29\xda\x36\xac\xb2\xf5\x0e\xfb\xa8\xde\xe1\xeb\x9f\x74\x26\x93\x7e\xe8\xaa\x3b\xae\xd6\xfa\xb1\x05\x0b\xb8\x10\x80\xe5\x26\x97\x1f\x55\x0a\x2d\xf4\x42\x24\x45\x88\x26\x37\x1b\xf7\xbf\x1a\x2e\xb7\xff\x0e\x8e\x9e\x38\xdf\x6d\x20\xa3\xeb\xe3\xd3\x70\xb6\x02\x4d\x2e\xa8\x43\xa0\x7b\x1d\x7c\x7b\x80\xdb\x48\x38\x45\x1d\x2a\x3d\x0f\x1b\xf4\xe3\x5a\x67\xe4\x91\x43\xca\xe1\x99\xda\x8a\x3c\xd1\x00\x33\x43\x36\x0b\xcd\x92\xb5\xcc\xd2\x20\xc1\xf4\x1d\xe0\xf2\x01\x3d\xfb\x92\xc4\x35\x85\xc7\x4f\xb8\xe2\x7b\x4e\x5d\x37\xed\xde\xe2\xea\x3e\x0a\x7b\xf4\x94\x40\xdb\xbe\x69\xff\x33\x01\x42\xb1\x2b\x88\x24\xac\x16\x09\xb7\x9d\x5e\xa9\xcf\x28\xa7\xbe\x3d\x6e\x49\x5d\x27\x09\x17\xa7\xa2\x36\xae\x34\xcd\xea\x5d\x09\xd4\xd1\xe8\x49\x45\x18\x98\x11\x50\x9d\x8d\xe0\x68\x8b\x05\x22\x57\x1a\xd4\x99\x0a\xb1\xff\x17\x26\xb6\xcb\x5a\xc7\x19\xfd\xaf\x0e\xca\x3b\x61\x2f\x2a\x0d\x7d\x01\xd4\xc2\x4a\xc3\xf7\x28\x3e\x5b\xe9\x1a\x98\xae\x13\x26\x8b\x99\x92\x06\x67\x66\x2e\x32\xf1\x60\x6b\x17\xc7\x07\x08\xb1\xe6\xee\xce\xae\xd9\x90\x0d\xc2\x1d\x89\x00\x4d\x1b\x5a\x84\x79\x4c\x51\x8b\x81\xc9\x54\x18\x6b\x37\x82\xb8\x8e\xf8\xc5\x2e\x00\x09\xe1\x2f\x84\x36\xa5\x42\xb9\xfa\x01\xe2\x09\x15\xa9\x67\xea\x72\x09\x99\xdc\x90\x3f\x9e\xa6\x78\x0b\x75\x72\x2b\x9e\x2f\x50\x52\x3c\x40\xd3\x9d\xdc\x0d\x04\x69\xc3\xe2\x4a\x12\x0f\x22\xdf\x15\xe0\xd4\x85\x7e\x55\x82\x17\x6b\x26\x8b\x09\x10\x3d\xba\x9d\x72\xa6\x78\x9a\x52\x02\x2c\x16\x67\xbb\x06\xe6\x7d\xcf\x38\xd3\xef\x0b\xfd\xd0\x67\xd8\x1e\x8b\xdd\xc4\x55\xbd\xcd\xb8\x9a\xe3\x09\xf2\x0d\xd0\x9b\x91\x6c\x6f\x57\x18\xbf\x5c\xcc\x3d\x39\xd5\x93\xd4\x33\x52\x76\x8f\xc5\xb4\xad\x1d\xeb\x3e\x34\xc1\xc9\x10\xc8\xe9\xdd\xf5\xc4\xfb\x69\x08\x39\x93\x33\x87\x2e\x18\xbe\x0b\x04\x60\x27\xaf\xa1\x6c\xdc\x6c\xdd\x87\xec\x74\x33\xe0\xd7\x8a\xbd\x1b\x32\xf2\xb5\x33\xa4\x3e\xec\xe3\x61\x5f\x0d\x0b\xf1\x20\xe8\xd7\x9e\x6a\x3d\x2f\xfc\xab\xd3\x8f\xd2\x84\x81\xb9\xd6\x46\x11\x5e\x4c\x81\x12\xe8\x87\xf3\x6e\x9e\x76\x59\xe6\xf8\x1e\xa6\x5b\x10\xd2\x4f\xe9\xa3\x86\x7d\x6a\xa8\xa7\x24\x30\x28\x40\xbd\xa6\xec\x52\x31\x67\xee\x4d\xd8\x0b\x9c\x58\xe6\x05\xb9\x20\x49\xdb\x9b\xe0\x12\x29\xad\x1e\xca\x39\xaf\xc3\x8c\x30\xf3\x27\x2c\x37\x8c\x04\xf5\x12\x94\x3e\x6b\xbf\xbc\x91\x90\x79\x74\x08\xb9\x04\x46\x11\x17\x58\x00\x1d\x92\x78\xed\xde\xa1\xd1\xae\x83\x37\x3b\x34\xd8\xc5\xbb\xd8\x1b\xf7\xa2\xed\xa2\x6d\x49\xe7\xa9\xfb\x9d\xe9\x7c\xa6\x5c\x69\xe4\x92\x34\xa8\x88\x56\x2f\x2a\x4a\x84\x20\x9b\x3f\x9a\xa9\x10\x0c\x76\x22\x78\xa0\xad\x18\x58\x94\xeb\xbb\x00\xe0\x60\x16\x1e\x83\x08\xb4\xfb\xe1\x6b\xd6\xf0\xb0\x13\x7c\x83\xc7\x7c\x9d\x69\x35\xcb\x6c\xa7\xc8\xc2\x11\xbb\x46\x49\x4a\xa6\x04\x7a\xe2\x65\x69\x37\xa3\x88\xc3\x79\xa6\x6c\xe7\xb1\xa5\x04\xf4\x3e\xf5\xcb\x4c\x7d\xd0\xc6\x71\x62\x98\xd0\x1f\x2e\xb4\x4c\xdd\xf6\xc2\x6b\x01\xd2\x1f\xde\xc2\xa1\x4d\x3e\x7f\x64\xb7\xf2\x47\x0b\x64\xa7\x11\xb1\xcd\x4e\x97\x79\x68\x54\xc2\xd5\x4c\xfd\x87\xed\x1e\xd4\xa3\x57\x6e\x58\xf5\x12\x97\x30\x8c\x20\x04\x4b\x3e\x63\xa1\xdf\xfd\xe3\xcb\xcf\x2f\x31\x9b\xa4\x34\x20\xbf\x3a\xa9\x1e\x20\x9e\xce\xbf\xcc\x32\x88\x44\xbb\x16\x78\x4a\x99\xf0\x89\x5e\x24\x16\x5d\xea\xe6\xaa\x6a\x62\x0c\x59\xe8\x7d\x33\x38\x38\x9f\xcf\x58\xc2\x8b\x64\x7d\xe2\x6c\x39\xda\xc6\xdc\xe9\x47\xc3\x87\x3a\x8c\xd6\xd2\x6a\x67\xb4\xb7\x17\xce\x7c\xe3\x39\x36\x2b\xf3\xc5\x36\x01\xb0\x54\xb7\x75\x79\x27\x4f\x01\x8c\x93\x13\x91\x20\x55\x3b\xcf\x3f\xee\xc4\x15\xc3\x8d\x93\xbc\xe4\x8a\x6f\x44\xca\x5e\x40\xde\xe3\x0b\x37\xf8\x33\xb5\x5d\x4c\xb3\xdd\xb2\x20\xa2\x36\xdb\x29\x53\x90\x21\xdb\x73\xca\xcd\xd3\xe6\x35\x69\x4f\x67\x77\x5e\xb4\xda\x6d\x1d\xdf\x37\xfe\x4b\xc3\x0d\x16\xf4\x71\xf9\xde\xb9\xa9\xa2\xc2\xaa\x7a\x08\xdc\xdc\x4f\xd8\x22\xe7\x0a\x14\x64\xd2\xd8\xa8\x0a\xab\x13\x2e\xcf\xc8\x82\xe6\x12\xa1\x14\xcf\x76\x90\x01\x32\x99\x29\xa4\x8c\x03\x6e\xf1\x5d\x92\xc9\x84\xad\x72\xbe\x5d\xd7\xec\x20\xf1\x20\x54\x01\x42\xc4\xd7\x82\x9b\xe3\xa2\xf5\x79\xbd\x04\x36\x38\x9e\x72\xa6\xe0\xf6\xc1\x55\x8d\xe4\x17\xaa\xd7\x71\xb4\x00\x42\x4f\xa4\xf3\x71\x04\x3f\x7b\x69\x68\x2b\xe4\x86\xc4\xb4\x05\x11\x48\xdb\x38\xe6\xbe\xba\x2f\xfc\x8d\xfd\x4a\xdc\x33\x0e\xd3\x79\x6c\xc8\xde\x73\xd9\x1c\xc5\x48\x7a\x59\xb5\x22\x79\x20\xe9\x09\x9e\x6b\x4c\xe3\x23\x4f\x85\x03\xc2\xfb\x8d\x63\x42\x42\x91\xc0\x56\xc8\xfe\x52\x2e\x74\xe6\xe8\x1e\x2f\xdf\x32\x9d\x83\xd2\x4a\xa1\xe9\x4f\x32\xed\xb2\x0e\xa4\x4a\xc5\x2f\x47\x71\xae\xf4\x1f\xf4\xce\x6c\xb6\x9f\x89\x04\x3d\xea\x8d\x85\xdd\x29\x17\xf6\x10\x2e\xdc\xcd\xb8\xf1\x94\xa9\x83\x55\xcf\xb2\x62\x0d\x08\x52\x4c\xd2\x08\x9d\xba\xe1\x3b\x96\xac\xb9\x5a\x45\xae\x09\x00\xf4\x89\xad\xce\x51\x91\xf4\x01\xc8\x0d\x75\xee\x72\xda\x29\x53\x9b\x32\x45\x7c\x20\x01\x01\xda\xda\xa5\x63\xf3\xd5\x2a\x17\x2b\xa0\x19\x99\xa9\x0a\xd7\x04\x10\x3b\x3a\x31\x14\xfc\x4e\x5f\xaa\xfe\xd3\xf0\xdd\x74\xdd\x06\x8b\x7c\xe7\x13\x9d\x49\xce\x37\xac\xe7\x7a\xb7\x4e\x98\x14\xd3\x09\xfb\x21\x80\xd2\x45\xa2\x95\xcf\x94\xee\x48\x93\xad\xb9\xfc\xd9\x9e\xab\x43\x93\x18\xa7\xbd\xee\xf0\x5b\x43\x14\xb8\x75\xd2\xf4\xa6\x9a\x17\xbc\x28\x47\x9c\x41\x24\xfc\x7e\x6e\x5f\xbe\xc1\x77\xfb\xe6\xf5\x39\x22\xc6\x1d\x29\x99\x7d\xde\x9e\x9c\xf6\xdb\x81\xb4\xbc\xad\xaf\xf7\x3a\x90\x33\xdd\xed\x40\x7e\x0a\x53\xdd\x31\xcf\xec\xf7\x21\x67\x1d\x6c\x2a\x3d\x6d\x1a\xeb\x22\x76\xb8\x6e\x4a\x4d\x31\xf5\x6b\x6c\xcb\x0e\xb0\xcd\x75\x5a\x26\x22\xb5\x2b\x17\xee\x43\x88\x88\xf1\xa4\x2e\x95\x4d\xb2\xed\xa0\xad\x30\x53\xc1\xa9\xfb\xb5\x7c\x0e\x83\xc8\xc0\x7d\xf7\xdf\x75\xf8\x1b\x9c\xc5\xd7\xd6\xe9\xf1\xfa\xc4\x7e\xca\x47\x9e\x53\xfe\xf3\x55\x0a\x6f\x9d\xcb\x95\x54\xbc\xd0\x39\xfb\xce\xa7\x6e\xbf\xf4\xba\x5f\xdd\x16\xc2\xc8\x6d\xa2\xd2\x45\xb8\x4d\x7c\x55\xc3\xa3\x6d\x92\xda\xa7\x4c\xc1\x37\xdb\x98\x14\xd7\xab\xaa\x53\xcf\x64\xd8\x09\xde\x36\x01\xdf\xa9\x34\x21\x6f\x73\xa6\x28\xe2\x80\xe3\xa6\xf3\x98\xd5\xbd\xf3\x6c\xde\x96\xc5\xfc\x40\xa2\x27\x7c\x79\x9c\xe3\x89\x60\x08\x1f\xf8\xb6\x9f\x3a\x87\x93\xcb\x01\x13\xd7\xbc\xd4\xbc\xb3\x54\xaa\xf3\xb3\x5f\x37\x65\x24\x95\x6f\x3d\x74\x7e\xfd\xde\x05\x8a\xc2\x7d\xb0\x72\xc1\x82\x81\x40\x0e\x51\x4c\x04\xc2\xab\xbd\xdf\xd6\xec\x29\xee\xf8\x76\xce\x33\x5d\xa6\x8c\x36\x35\x0a\xc3\xe7\x53\x3c\x1d\x81\xd4\x77\x3a\xed\x4a\x6c\x1a\xa9\xe7\xec\xf7\x1f\x78\xaf\x7d\x05\xc2\x6f\x1d\x3b\x70\xef\xd2\xa7\x9e\x7d\xb6\xa1\xa7\x9e\x86\xb1\xf7\xdb\xf1\xa8\xb1\xf7\x5e\x70\x60\x18\x1c\xe7\x20\x85\xfb\xa8\x4c\x33\x58\x6f\x71\x00\xa1\x85\x03\xb9\x12\x98\x35\xf7\x47\x7f\xce\xf1\x10\xf4\x7f\x6a\xcb\x73\xa1\x8a\x39\x7c\x71\xdc\xc7\xe0\x23\x9f\xe0\xf5\x8a\xc1\x34\xc8\x11\xfc\x6f\xb7\x1a\xfd\xfb\x8e\x4e\xe8\xdf\xd9\x0d\xf9\xb4\xec\x7e\x25\x01\x44\x6a\xee\xd9\x77\x12\x30\x47\x51\x2c\xd4\x0f\x5c\xc7\x70\x51\x83\x0e\xe8\xbd\xa8\x41\x95\xad\x7d\x50\x83\x42\xed\x21\x54\x0d\xa5\x90\x7b\x8f\xb2\xc2\xed\x56\xeb\xfe\x16\x49\x0c\x5c\x55\xfe\x0d\x74\xb0\x76\xfc\x32\xf6\x9f\x22\xd7\x21\x03\x08\x9d\x55\x71\xc1\xbd\xf6\xfa\xe1\xea\xc8\x68\x8f\xa3\x2e\x6f\x2c\x4c\x09\x7f\x21\xc6\x26\xf4\x28\x2c\x76\xee\x3a\xd2\x11\x42\xda\x8a\x64\xde\xa1\x42\x32\xa8\x2a\xd1\xc5\x33\x56\x15\x91\xb5\xc3\xcc\x2d\xd0\x53\xf0\x57\x50\x6a\xcd\x86\x6f\x09\xdf\x47\x50\xe2\x7a\xf0\x66\x0a\x8d\xf8\xb7\xbf\xfe\xfb\xb4\x4b\xf7\x1e\xaa\x3e\x16\x2e\xe5\x2b\xff\x2e\x97\x42\xa5\x10\x8c\xe5\x69\x53\x20\x4b\x55\xbc\xf3\x95\xed\xd9\x4e\xc3\x27\xc9\x08\x6e\x3f\x6a\xcd\x1c\x27\xd1\x57\x88\xe8\x87\x4d\xd6\x2f\xdf\x4a\xbc\xaf\xcb\x94\x30\xf3\x74\xa7\xf8\x46\x26\x5f\xb5\x8e\x3b\x29\xb2\x14\xaa\x48\x5f\xdf\x17\x95\x4a\x45\x72\x3f\xd6\x26\x38\x98\xde\x5f\x24\xf7\xec\xc7\xdb\x0f\xef\x51\xcd\x55\x9a\x99\xba\xe2\x85\x7c\x10\x77\x79\xe6\xc3\x01\xc4\xd7\x94\x67\x6e\x8d\x54\xe9\xa6\x23\x6a\x23\xc7\x4d\xed\x0c\x87\x58\x0d\x60\xb3\x3b\x59\x94\xc9\xbd\x28\x4e\x73\xae\x52\xbd\xc1\x66\x9c\x9a\x72\xb9\x94\xbf\x4c\x0b\x9e\x77\x48\x03\xa0\x1f\xe1\x1b\xda\xb9\x41\xf0\xa9\x08\x36\x2f\x9a\xba\x8f\x90\xe8\x4b\x32\xe2\x15\xe3\x16\xf3\xd2\xf8\x46\x00\xb7\x23\xab\xca\x6a\x40\x29\x98\x3b\x0b\xea\x93\xc6\x10\x82\x5e\x93\xb6\xf5\xe7\xc8\xb8\xff\x1c\xd5\xaa\xaa\xaf\xee\x2a\x15\x14\x1d\x37\xfc\x1e\xef\x87\xab\x5c\x18\x33\x61\x46\x43\x8d\x67\xca\x61\xd1\x5d\xbe\x14\xe0\x5e\x80\x1d\x36\xdb\xb1\x44\x6f\x25\x08\x60\xfa\x76\xad\xf5\x23\xf8\xe9\xe3\x4c\x51\xd0\x2c\x2e\x55\x21\x33\xc6\x97\x05\x39\xf1\x81\x0a\xdf\x49\x5f\x99\xe9\x4c\x41\x28\x36\x81\xe6\x03\x44\xc2\x87\x5f\x7c\x23\x0c\x5b\xf2\x44\x66\xb2\x20\x82\x2e\x48\x32\xe2\xb6\xbd\xf6\x3c\xb0\x7d\x99\xf3\x1d\xcf\xc2\xc5\x8a\x67\x65\x48\x8e\x3d\x31\xa2\x87\x00\x52\x9a\x39\x3a\x08\xbe\x06\xe3\x9c\x8c\x83\x0f\x48\x96\x7d\x66\x3f\x7e\x55\x3b\x45\x7f\x17\xff\x6f\xe5\x1e\xde\x67\x15\x1c\x71\x21\x3f\xe6\x70\x6c\x5e\xb9\xbd\x5e\x74\xb0\x33\x64\xea\xf0\xc1\x15\x53\x3c\xa4\x9f\xfa\xe3\x11\x62\x26\x1d\x97\xfe\xa9\x53\xf9\x6a\x7e\x61\x44\xef\xb5\x1b\x89\x5f\xc9\x9d\xd1\xc5\x60\x3e\xa4\xfa\xce\x1b\xff\x49\xeb\xec\x58\x8f\x3c\x91\x32\x48\xad\xe6\x20\x7c\x7b\xcc\x75\x12\x27\x80\x77\x6c\x5d\xbe\xf5\x31\x77\x4f\x09\x5e\x95\xcb\x22\x38\x18\x55\x01\x36\x32\xa8\x44\x0f\x52\xdc\x6c\x5b\x40\x17\x23\x11\xef\x50\x06\xa2\xb5\x9c\x69\xdf\x0c\x11\x44\xfc\x1c\x3c\xd4\x11\x68\x53\x6b\x35\x1c\xe5\xac\x43\x99\xda\xda\xa7\xbc\xe3\x2e\xa6\x57\xf6\xfd\x18\x7d\xdb\xf5\x27\x8a\xe3\xdb\xf3\x93\xac\xf8\x99\x8a\x2c\x76\xe4\x44\x73\x29\x05\xbe\xd7\xda\xfc\x79\x95\x69\x78\xb4\x3f\xef\x18\x0e\xfd\xde\x9d\xf3\x6d\xac\x86\x07\x58\x90\x44\x6f\x16\x52\x39\x56\x02\x72\x72\xc3\x55\xe3\xcc\x51\x94\xfa\x80\x84\xbb\x32\xa0\x46\x4a\xad\xef\xbd\x99\x13\xb3\xbd\xc6\x5b\xd6\xbe\xeb\x78\x7c\xbf\x7b\x5a\xba\xff\x8e\x48\x63\xbd\x05\xf6\x00\xc9\x1e\xf9\xce\x80\x62\xb4\xb0\xbb\xe2\x12\x1d\xbb\xd5\xfa\x4f\x22\xf3\xc3\xd1\xdf\xce\x14\xf4\x50\x49\x42\xf2\xd4\x16\x49\x0c\x00\x99\xd3\xc6\x0e\x5c\x5f\x2f\x4c\x7b\xe7\x7c\x9b\x58\x4d\xde\x1b\xab\xc1\x20\xf4\xff\x8c\xf0\x4c\x8f\x13\xf8\x48\x5f\x74\x74\x4c\xa2\xc5\x48\x30\x21\x48\xdc\xf2\x21\xea\x09\xdb\x70\xa9\x68\x19\xa0\xfe\x60\x2a\x16\xe5\x6a\xd5\xe9\x22\xfd\xf5\xc7\x5a\xaa\xeb\xe4\xef\xde\x17\xde\xcb\x56\xf7\x14\xde\xe2\x4b\xf7\x25\x74\x5f\xdb\x7b\xdf\xd7\x71\x10\x7f\x43\x6f\x7c\x6b\x48\xac\x31\x89\x9e\xc6\x1b\x7f\x39\xc4\x1b\xef\xb0\x5d\x90\x62\x47\xd7\x69\x87\xbf\xf9\xcd\x4d\xff\x75\xdc\xf4\x83\x26\x05\xd2\xba\xcc\x65\xd5\x40\xef\xa9\xe1\x81\xcc\x87\x9e\x0c\x18\x6a\x85\xec\x62\x76\x77\x4f\x0d\x5b\xf0\xe4\x19\xa8\x10\xe1\x74\x3c\xde\x1f\xb8\x07\xfc\x72\xa3\x37\x82\xc1\xa7\x0c\x2a\xd7\x30\xca\x62\x9c\x00\x5a\xd5\x36\x30\x20\x46\x08\x8f\x02\xc7\x29\x22\x57\xd2\x60\x54\x7f\xa7\xc4\x23\xb3\xa7\xd5\x24\x86\xef\x45\xc3\x03\x92\x66\x2f\xad\x75\x58\xc1\xfa\x7b\xca\x86\x5c\xac\x78\x9e\x42\x86\x09\x2d\xc9\x8c\x27\xf7\xf6\xbf\xa1\x7e\xf4\x45\x82\x18\x3a\x75\x05\x84\xbd\x86\xd2\xa4\x4a\x90\x0c\x8f\xd0\x8c\xa1\x7e\xf8\xba\x61\x3c\xc9\xb5\x41\xa7\x91\x57\x02\x86\x0c\x67\x30\x60\x1f\x64\x5a\xf2\x0c\xbf\xd8\xe9\x69\x1f\x0b\x5f\xab\x03\x8e\x22\xd1\xae\x26\x9a\x8d\x86\x03\x39\x8a\xa0\x1b\xa7\x33\xf5\xd6\x07\x4c\x5e\xb3\x3b\x23\x08\x65\x66\x1c\xed\x79\x6f\x4d\x9f\xcd\x7c\x68\x60\x02\x3b\x6d\x88\x9e\x0e\x70\x20\xeb\xa8\x23\x4c\x77\x4f\xec\x21\xd4\x3c\x66\x50\x46\x13\x03\x5f\x46\xca\xe1\xa1\x5b\xf0\x9e\x90\x0b\x9e\xee\x62\x36\x3e\xa9\x18\x44\xe9\x18\x4f\x37\x52\xd9\x45\xe0\xd4\x29\xfd\x49\xe3\x88\xea\x11\x72\x0c\x22\x4e\x59\x56\xdb\x04\x0d\x53\xc2\x1a\x97\x3c\x97\xd9\x0e\xee\x13\xdb\x5c\x9c\x44\xdf\x89\xc6\x87\x32\x9e\x80\x72\x9f\x68\x44\x4a\x23\x96\x65\x86\xb7\x0e\xb8\x97\xfb\x06\xd0\x8e\x74\x77\x39\xb1\x06\x47\x41\xd2\x29\xd1\x87\x51\x90\xf0\x29\xb2\x47\x1a\xd1\xca\x71\x11\xb7\xc0\x16\x99\x03\xc8\x7d\xad\x1f\x5d\xaa\xdb\x23\x0f\x58\xe6\xae\xd3\xf5\xc9\xa2\x2c\xfd\x76\xa8\xbb\x01\xba\x7d\x2a\xa2\x7c\xf3\xa1\x35\xfa\x4d\xa4\x7e\x6f\x92\x0a\x9a\x43\x9a\xbe\xc1\x73\x5d\x1a\xcc\x98\xb3\x63\x09\xe7\x97\x73\x74\x54\x1d\xd7\xcc\xb7\x4e\x1a\xad\xd8\xac\xfc\xfe\xfb\xdf\x0b\xf6\x3d\xa4\x10\xd2\x7d\x04\xe3\x63\xc0\x17\x89\xa5\xc3\x96\xed\x3f\x20\x90\x4c\xb2\x31\x22\xac\x0d\xa2\xea\xf2\xf5\x01\xe4\xc9\x93\x35\x33\xe5\x02\x11\x8c\x9c\x42\x2c\x5c\x79\xde\xe9\xf7\x1a\xc0\x88\x78\xb2\xbb\xda\xff\x2f\x09\x28\xa0\xca\xc5\x4c\x6d\x35\x52\xa3\x03\xf4\x73\x21\xd8\x86\xe7\xf7\x20\x5a\x8a\xee\x79\xa0\x82\xff\x4e\x8a\x69\x35\xbc\xf0\xb2\x52\x1f\x0a\xe8\x20\xe5\x31\xcb\x4b\xa5\x9c\x0a\x13\xb3\x86\x69\xf0\xf5\x4f\x66\x6a\x51\xc6\x77\xcf\x4a\xb0\x20\x4c\x2d\x08\x18\xc0\x66\xab\x81\x2b\x84\x2a\xc5\x4d\xa8\xd7\x94\x0d\x88\x1a\xcc\xd4\x13\x87\x0d\xf6\x39\xfc\x3e\x91\x0d\xe6\x9c\x79\x51\xbe\x02\x34\x37\x16\x0a\x86\xe1\xc0\x69\x0f\x46\xce\x27\x50\x0b\x9e\xb0\x1f\xe5\x83\x98\xb0\x9b\x2d\xcf\xef\x27\xec\x2d\x86\xff\xfe\xa4\x17\x6d\x3e\xbc\x06\xa1\xc4\xd1\x7e\xbc\xc3\xdc\x58\x7d\x44\x2b\xed\xd6\xff\xcf\x0d\x62\x00\xd6\x15\xfb\xfe\x9f\x89\xc8\xeb\xe0\xfa\xf8\x7b\xf7\x44\xec\x09\x53\xff\x06\x5e\xfb\xbb\xbc\x15\xf7\xd3\x7c\xfc\x2e\xfe\x5f\xb7\x7f\x39\x8b\x0b\x6c\x4f\xda\xe5\x5a\x51\x69\xbf\xae\xc4\x66\x99\xd6\x0f\xe5\x66\x7e\xf3\xb0\xa5\x40\xe9\xe3\xa9\x4f\x6d\x1f\x01\xba\xa7\x57\x5d\x7f\x9d\x67\xda\x94\x79\xff\xe2\xbf\xae\xd6\xda\x7d\xbd\x85\xea\x13\x26\xdb\x66\x21\x80\xb5\x60\x28\xfc\x04\x1f\x9b\xff\x87\x5e\xcc\x01\x6b\x75\xdc\x0a\x6f\x2b\xce\x13\x08\xeb\xa4\x52\xd5\x70\x42\xde\x6c\x05\x30\x4e\x05\x53\x34\x04\x04\x6a\x33\xcc\xbb\x46\x66\xca\x71\xae\x63\xc6\x6c\x9e\x0b\x20\x87\xce\x05\x28\xdb\xb1\x2d\xcf\x3d\xe0\xc1\x59\x44\xd1\xcd\x27\x80\x62\xe2\x2c\x37\x48\x56\xa5\xfb\xd6\x42\x08\xe5\x7b\x7b\x8c\x29\x01\x44\xc8\xb5\xde\x27\xb4\xdb\xa3\x70\xd4\xfb\x1d\x2a\x9c\x8d\xf7\xa2\xbb\x20\x98\xdc\x2b\x51\x44\xbb\x79\xcd\xb4\xa8\x2c\xcd\x4a\x84\xea\x57\x85\xf8\x6f\x8d\x41\xd7\xc8\xb9\x2a\x0e\x94\x41\x31\xbd\xa7\xf0\x97\x7f\xe2\xc5\x1a\x2f\xb4\x1b\x5d\x08\xdc\x33\x91\x25\x08\xe7\x0b\x7a\x9d\x17\x99\x5e\x80\xa4\x9c\xfd\xa5\xeb\x6e\x98\xd0\xd2\x1e\xd4\x75\xcd\x01\x1b\xb2\x33\xd8\xdd\x04\x32\x6d\x73\x61\x80\x70\xa5\x19\xa5\x1a\x8a\x4f\x1e\x77\xe9\x6e\x56\xd7\x6e\xfa\x6f\x1b\x97\xed\xa6\x28\x83\x5d\xd6\x00\x56\xbd\x38\x20\x83\xa6\x21\x71\x41\x64\xc5\x14\x06\x46\xbe\xd2\x5a\x7b\x9d\x72\xf9\x4c\x9d\xe1\x2f\xd1\x21\xc0\x83\xca\x92\xc7\x83\x92\x48\xad\x5f\x7f\x98\xbe\xca\xce\x62\x04\x22\x79\x08\x26\xc1\x97\x09\x97\x81\x09\x64\x35\xaa\x42\xe6\x82\x29\x40\x21\xcc\x94\x29\x17\x27\x81\x98\xc4\xde\xe2\x1e\x80\x4c\xc7\x88\x2d\x87\xab\x0c\xf0\x15\x9d\xb4\x1c\xc3\xe8\x99\x0c\x6a\x29\x8e\xc0\x8f\x67\xb4\xf9\x43\xae\x24\x66\xc6\xfb\xb6\xfb\x72\xec\x65\x0d\x6e\xd1\x0e\xae\x84\x87\x5d\xdf\x7e\x01\x7a\x4e\x90\x81\x79\x8d\x28\x8a\x6f\x7d\x80\xc7\xd1\xd0\xa1\x47\x37\xc4\xd3\x66\xea\xff\x77\x67\x43\x37\xa8\x78\xc4\x4c\xb7\x3d\x63\x8f\xa8\x4e\xb0\x73\xa5\x6e\xee\x0a\x19\x19\x81\xdd\x95\x6a\x4c\xf9\xb6\x52\xb9\xc3\xb5\xc4\xa2\x1e\x9a\xd2\x65\xe1\xd7\x07\x69\x22\xba\x6f\xf8\xda\x8d\x10\xec\x75\x2e\x96\xaf\x3f\xe7\x62\x39\x77\x23\x3d\x85\x06\x4d\x6d\x8b\x9a\xa4\xdf\x03\x27\x87\xd9\x6a\xd5\x4e\x7e\xb8\x87\x9c\xb4\xd6\x24\x2c\x27\x6a\x93\x5c\xb2\x20\xe7\x69\xdb\x03\x0c\x10\x22\xad\xb3\x91\x37\x6a\xf6\xd5\x8f\xb9\x2e\x24\xd8\x00\xa8\x55\x87\x0c\xe6\xdf\xff\xf1\x56\xe9\xb3\x21\xc7\xdb\x6d\x15\x32\xe3\x36\x7b\xae\xfc\x81\xd7\x8d\x0b\xfd\xba\xe8\x74\x18\x40\xb3\xe5\x8f\x8a\x78\x6c\x46\xb9\x9e\x86\x1d\x6b\x35\x00\x51\x74\xac\x35\x30\x70\x61\x95\x29\xe7\xe9\x93\x5e\x49\x71\x12\xc9\xad\xf3\x2c\x8b\x35\x15\x42\xa4\x6d\xa6\x42\x5e\xaa\xb5\x5a\xb3\xcc\xb9\xf0\x2a\xf6\x06\xb1\x16\xa5\x90\x10\x2c\x26\x8e\x74\x85\xe8\x0a\x29\x1e\x76\xb2\xe0\xa0\xe5\xeb\x55\xb4\xf6\xad\xe6\xa7\xba\x44\xfe\xca\xf2\xa2\xf7\x44\x9e\xf1\xb3\xf3\x7b\xd1\x80\x33\xef\xad\x6b\x7b\xa4\x23\xa2\x94\x80\xc5\xec\x76\xd9\x84\xe7\xb9\x43\xf9\xd3\x57\x99\xbd\x2b\x2d\x79\x52\x71\x73\x76\xd4\x73\x2d\x92\xfb\xad\x96\x6a\xf4\x5e\x54\xa1\xb8\x80\xc9\x5e\xb0\x50\x9a\xbf\x1d\x0e\x3a\x1c\x2b\xf6\x24\x36\xc4\x00\xbc\xc2\x41\x43\x03\x19\x1b\x67\x5e\x2b\xb9\x7b\xda\x3d\xb5\xff\x42\x84\xb3\xe1\x19\x7c\xb1\x2d\xf1\xa1\xda\xa9\xc2\x5b\x1c\x3b\x15\x26\x50\xde\xc8\xfe\x1a\xd8\xd9\x9c\x55\x28\x0c\x5b\xbb\x14\x5c\x90\xbf\x79\x86\x7e\xf3\x0c\xfd\x0f\xf7\x0c\x7d\x4d\xb7\x10\x60\x63\x9e\xd3\x27\xd4\x13\x20\x3f\x62\x39\xfa\xaf\x8e\xce\x71\x6c\xb5\x8e\x27\x91\xec\x73\x94\xe9\xd8\x04\xfa\x3b\x22\x0c\xdb\x3f\x0b\x9e\xdc\x0b\xd5\x19\xa3\x77\xf4\x45\x9d\x0a\x9c\x4f\x8b\x60\x69\x63\x5f\x8a\xde\xee\x87\xb2\x04\xa8\x13\x91\x06\xb7\x11\x82\xd8\x75\x02\xb6\xa7\x6d\xf8\x09\x80\xc6\x74\xee\x89\xad\x0d\x65\xe1\x61\x30\x12\x69\x92\x10\x2c\x55\xa3\x82\x1e\x8a\x89\x73\x1f\x9e\x6f\xb5\xce\x5a\xa1\x71\x4f\xda\x81\x8d\x44\x99\xa1\x9d\x77\x89\xc6\xa8\x89\x01\x63\xae\x17\x43\xd2\x45\x48\xd1\xc0\x7c\x0c\xd0\xc2\x80\xd9\x94\x96\x90\x4b\x19\xba\x23\x12\xd8\xe3\xde\xe1\x42\x18\xb1\x85\x48\x38\x48\x7f\x3a\xf0\x5e\xc2\x7d\xf6\x49\x4c\x8a\xd4\x48\x07\x31\xcd\xef\x74\x44\x2d\xa1\xdc\xb9\x6c\x13\xbe\x18\xbb\xb8\x6a\x16\x82\x83\x96\x63\xcd\x1d\x92\xc4\xd1\x2e\xee\x93\xb4\x75\x1c\xd3\x73\xd0\xdf\x1b\x76\xc2\xb5\xee\x3b\x97\x54\xd0\x39\x94\x33\x7c\x23\xfd\x11\xd2\x71\x36\x03\x91\x3b\x33\x75\xe6\x95\x4e\x03\xf6\xcb\x23\xf7\x30\x5c\x8a\x98\xc5\xc6\xd0\x20\x97\x63\xb8\xb9\x4c\x98\x29\x93\x35\xb0\x55\x56\xf7\xa9\x78\xdf\x6a\xae\xd8\xc9\x4c\xd9\x0b\x11\xb8\x5a\x36\x1c\xf2\xe2\x1f\xad\xb1\x6a\xe4\x7f\x0a\x0f\xcf\x22\xf2\xae\x18\x91\x85\x17\x27\xad\x5a\xd1\x6b\x8e\x38\x14\x01\x16\x01\x53\x52\x6e\x53\x5e\x88\xe9\x2c\xa0\x6d\x24\x7a\x3a\x1d\xca\x83\x4c\x66\x13\x37\x2c\xc6\x31\xd6\x76\xda\x4c\x2e\x45\xb2\x4b\x1a\x3a\x40\xfd\x34\x11\xbf\x5d\xdb\x7e\x5d\xd7\x36\x64\xd9\xc5\x9c\xc1\x31\x5d\x4b\x55\xbd\x0e\xaf\x1f\xd7\xb9\x82\x45\x35\x31\x23\xfa\xf9\x2b\x5e\x3b\x5b\x6c\xe0\x71\xf6\xfc\xe0\x7b\x50\xff\x71\x16\x2e\xb6\xe1\xb0\x8e\x28\x10\x1a\x66\x61\x1c\x5c\x2c\xe2\xa9\x63\x0d\xda\xc1\x61\xfd\x6e\x96\x99\x5f\x15\x38\x69\xc8\xc5\xd5\x5a\xdc\x1e\xae\x74\xe5\x2c\x6d\x25\xf0\xbc\xeb\xb1\xb8\x23\x56\x77\x5e\xbc\x30\xbe\xd7\xab\x3b\xa0\xc3\xfe\xbf\x97\xa6\xf8\xa9\xa6\x19\x7a\x98\xe8\xe8\xb3\x99\xa6\xae\xaa\x58\xcd\xa1\x16\xd5\x75\xd5\xe6\xd1\x4b\x37\xe7\xe0\xf2\xe4\x54\xe2\x6c\xbd\xc7\xdc\x83\x3e\xfb\xfe\xfa\x8c\x47\xd3\x63\xce\xb7\x5b\x91\xbb\x83\xbc\x61\x6b\x81\xe4\x1a\x7c\x05\x34\x13\xd7\x02\xb5\xba\x6b\xb7\x5c\xbb\x95\xd4\x8a\x86\xc7\xa0\xeb\xa6\xed\x23\x77\x55\x66\x59\xe7\xc8\xed\x57\x72\xba\xba\x7b\xff\x7e\xfe\xd3\xd9\xfb\xbb\x0b\xd7\xfc\x56\x65\xa4\xe8\xb1\xce\x3e\xf1\x35\xa1\x3e\x09\xda\x8b\xf6\xb3\xc2\xe9\x85\xeb\xd0\x6a\x74\x72\x95\x59\x56\x55\xcd\x9a\xa9\xcf\x54\x0e\xc0\xb4\x51\x11\xd4\xf6\x1b\xeb\xed\xb8\xea\xf7\xe1\xb1\xcf\xb6\xf0\xcf\xf8\xee\x09\x0b\x8d\x78\x0d\xda\x8e\xa4\x19\xd7\xde\xaf\x94\x0d\x73\xc4\x72\x40\x30\x70\xd7\x72\x78\x6a\x5d\xc0\xc3\x96\xc7\x9d\x02\x46\x72\x91\x3a\x39\xbf\x27\x59\x1d\xd8\x77\x9f\xab\x71\x6a\xbf\x97\xa7\x78\xa5\x81\x72\x27\xa8\xe6\x06\x1a\xd5\x41\xf0\x6c\xa6\xd0\x07\x6a\xeb\x54\xe8\xee\x3a\xb1\x4b\x32\x6f\x33\xae\x56\x25\x5f\x59\xeb\xd6\x7d\x7c\xa6\x36\x72\xb5\x46\x1e\x90\x72\x1b\xf0\xc9\x9c\x29\xa0\x8b\xa9\x4d\xa1\x1a\x3e\x59\xaa\x99\xa2\x36\xa9\x55\x28\x1e\xb1\xb2\x7f\xba\xf1\xcd\x21\x50\x3a\x16\x44\x82\x74\x6a\xa6\x70\x70\x91\x9f\xc4\x45\x42\xe0\xc6\xc2\x8b\xfa\xd4\xe5\x10\xbb\x44\x9d\x7e\xbb\xa7\xaf\x20\x26\x33\x53\x3e\x45\x17\x3d\x47\xd4\x86\x48\xb8\x04\xab\xb4\x7f\x3f\x71\x83\xe1\xd6\x04\xd5\xad\x7d\xd6\x1f\x7d\x06\xd8\x05\x37\x1f\xa1\x3e\xdd\xdc\xc6\x06\x7a\x0b\x79\xb4\x71\x74\xf1\x36\x40\x5e\x76\x7b\x6d\x5c\xbb\xf0\x99\x4e\x68\xab\x2e\x17\xd9\x88\x2a\xe1\xf3\xbd\x95\xc2\x2d\xb9\xbf\x52\x03\xae\xc3\xd7\xb5\xa5\x65\xa7\x69\xdf\x67\x17\x5a\x77\x8c\xcb\x13\x06\x14\x2b\x95\xa2\x17\xf6\x75\x46\x99\x14\x87\xcc\x97\x01\xc9\x8a\xf5\x2e\x72\xbb\x4f\x5f\x85\x32\x69\x0e\xaa\x4e\xb0\x9f\x06\xd7\xc8\x5b\x08\x74\xd8\x8d\xda\x61\xe9\x9c\xab\x6c\xb0\x1d\xdb\x24\xc5\x93\x9c\x8c\xb3\xc4\xed\xc5\x2e\x1e\xd4\x58\xb6\xf3\x7f\xe2\x27\xd1\x24\x8c\xdc\x04\x2a\x99\x94\xb9\xb1\xdb\x25\xed\x77\xb4\x6b\xeb\x9c\xf1\x99\x72\xa9\x6a\x6e\x3b\x3e\x73\xe0\xdc\xdc\xff\x15\x13\x40\xb7\xc8\xa7\x0f\x16\x6b\xc1\xb4\x12\x6e\x37\x9c\x29\xa7\xfd\x3d\x61\x7c\x61\x9c\xa4\x36\x57\x3b\xaf\x73\x2d\x3d\x7d\x11\x57\x0c\x50\xcf\xfb\xf7\xbc\x9a\x19\x50\x39\xe7\x7f\x67\xff\xef\xbf\x7f\xf7\xff\x02\x00\x00\xff\xff\xd1\x4b\xbf\x0d\x7d\xb7\x04\x00") +var _adminSwaggerJson = []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\xff\xec\xfd\x7b\x73\xeb\xb8\x95\x2f\x0c\xff\x3f\x9f\x02\x67\xcf\xa9\xea\xee\x44\xb6\x3b\xc9\x4c\xde\x94\xa7\x4e\xbd\x8f\xda\xd6\xde\xad\xd3\xbe\xc5\x97\xee\xe9\x67\x94\x52\x43\x24\x24\x21\x26\x01\x06\x00\xed\xad\x4e\xe5\xbb\x3f\x85\x85\x0b\x41\x8a\x94\xa8\x8b\x6d\x79\x37\x67\xaa\xd2\xde\x22\x89\xeb\xc2\xc2\xba\xfe\xd6\x3f\xff\x0d\xa1\x0f\xf2\x19\xcf\x66\x44\x7c\x38\x45\x1f\xfe\x78\xfc\xed\x87\x9e\xfe\x8d\xb2\x29\xff\x70\x8a\xf4\x73\x84\x3e\x28\xaa\x12\xa2\x9f\x4f\x93\x85\x22\x34\x4e\x4e\x24\x11\x4f\x34\x22\x27\x38\x4e\x29\x3b\xce\x04\x57\x1c\x3e\x44\xe8\xc3\x13\x11\x92\x72\xa6\x5f\xb7\x7f\x22\xc6\x15\x92\x44\x7d\xf8\x37\x84\xfe\x05\xcd\xcb\x68\x4e\x52\x22\x3f\x9c\xa2\xff\x31\x1f\xcd\x95\xca\x5c\x03\xfa\x6f\xa9\xdf\xfd\x1b\xbc\x1b\x71\x26\xf3\xd2\xcb\x38\xcb\x12\x1a\x61\x45\x39\x3b\xf9\xbb\xe4\xac\x78\x37\x13\x3c\xce\xa3\x96\xef\x62\x35\x97\xc5\x1c\x4f\x70\x46\x4f\x9e\xfe\x70\x82\x23\x45\x9f\xc8\x38\xc1\x39\x8b\xe6\xe3\x2c\xc1\x4c\x9e\xfc\x93\xc6\x7a\x8e\x7f\x27\x91\xfa\x17\xfc\x23\xe6\x29\xa6\xcc\xfc\xcd\x70\x4a\xfe\xe5\xdb\x41\xe8\xc3\x8c\xa8\xe0\x9f\x7a\xb6\x79\x9a\x62\xb1\xd0\x2b\xf2\x91\xa8\x68\x8e\xd4\x9c\x20\xd3\x0f\x72\x4b\xc4\xa7\x08\xa3\x53\x41\xa6\xa7\xbf\x08\x32\x1d\xbb\x85\x3e\x36\x0b\x7c\x01\xa3\xb9\x49\x30\xfb\xe5\xd8\x2e\x13\xb4\xcc\x33\x22\x60\x6e\xc3\x58\xb7\xfe\x89\xa8\x3e\x34\x5b\xbc\x1f\xbe\x2d\x88\xcc\x38\x93\x44\x96\x86\x87\xd0\x87\x3f\x7e\xfb\x6d\xe5\x27\x84\x3e\xc4\x44\x46\x82\x66\xca\xee\x65\x1f\xc9\x3c\x8a\x88\x94\xd3\x3c\x41\xae\xa5\x70\x30\x66\xaa\x7a\x63\xf1\x52\x63\x08\x7d\xf8\xdf\x82\x4c\x75\x3b\xff\x7e\x12\x93\x29\x65\x54\xb7\x2b\x0d\xfd\x04\xa3\x2d\x7d\xf5\xaf\x7f\xab\xfb\xfb\x5f\xc1\x8c\x32\x2c\x70\x4a\x14\x11\xc5\x8e\x9b\xff\xab\xcc\x45\xef\x91\xee\xbc\xd8\xc7\xea\xc0\x2b\xb3\xbd\xc2\x29\xd1\x7b\xa2\x77\xca\x7e\x01\x7f\x0b\x22\x79\x2e\x22\x82\x26\x24\xe1\x6c\x26\x91\xe2\x4b\x6b\x40\xa1\x05\x4d\x5e\xd5\x27\x82\xfc\x23\xa7\x82\xe8\xbd\x52\x22\x27\x95\xa7\x6a\x91\xc1\x20\xa5\x12\x94\xcd\xc2\xa5\xf8\x57\xaf\xd5\xd4\x0c\x55\x6e\x30\x33\xf3\x41\xe3\xc4\x46\xac\xef\x5e\x89\x30\x43\x13\x82\xf4\x59\xa4\x31\x11\x24\x46\x58\x22\x8c\x64\x3e\x91\x44\xa1\x67\xaa\xe6\x94\xe9\x7f\x67\x24\xa2\x53\x1a\xb9\x35\x3b\x9c\xb5\x81\x3f\x57\xaf\xcc\x83\x24\x42\x0f\xfc\x89\xc6\x24\x46\x4f\x38\xc9\x09\x9a\x72\x51\x5a\x9e\xe3\x11\xbb\x9f\xeb\x75\x48\x27\x94\xc1\xc9\xd3\x6b\xe9\x28\xe4\xf7\x6e\xb9\x7e\x8f\x74\x7f\x28\x67\xf4\x1f\x39\x49\x16\x88\xc6\x84\x29\x3a\xa5\x44\x56\x5b\xfb\x3d\x87\xfe\x71\x82\x8e\x90\x5e\x67\x22\x14\xac\x37\x67\x8a\x7c\x56\x12\x1d\xa1\x84\x3e\x12\xf4\xd5\x05\x95\x0a\xf5\x6f\x86\x5f\xf5\xd0\x57\xe6\xbc\x20\xe0\x4d\x5f\xbd\xc2\x0a\xfb\xbf\xff\x16\x1c\x3d\x85\x67\xd5\x43\xf7\xa1\xaf\x4f\xf3\x9d\xb9\x1a\x8a\x16\xfe\xf6\x6f\x61\x3b\x76\xbf\x56\xf3\xdb\x82\xd9\x5a\x4e\xdb\x96\xbf\xc2\x32\x95\x59\xab\xd4\x3b\xb4\x2b\x67\xd5\xed\x56\x59\xab\x7c\x5f\xbc\x55\x4f\xe1\xa5\xf9\xeb\x2e\xcc\x15\x2b\xa0\x7a\x4c\x99\x39\x24\xfe\xcc\x08\xa9\xcf\x89\xa3\xde\x03\x61\x29\xbb\xf0\xda\x60\x66\x01\xbb\x75\x5c\x34\x58\x95\x03\x9c\x77\x42\x53\xba\x6e\x7f\x87\x2c\xd6\x22\x97\x65\x76\x2c\x4f\x27\x44\xe8\x65\x70\x6c\x0f\x66\x3b\xd1\x6c\x50\xe5\x82\x91\xb8\xc5\x34\xff\x91\x13\xb1\x58\x31\xcf\x29\x4e\x64\xd3\x44\x29\x53\x44\xcb\xb7\x95\xc7\x53\x2e\x52\xac\xec\x0b\x7f\xfe\x8f\x4d\x17\x42\xf1\x47\xb2\x6e\xff\x87\x66\x37\x23\x2c\x81\x0c\xd2\x3c\x51\x34\x4b\x08\xca\xf0\x8c\x48\xbb\x22\x79\xa2\x64\x0f\x5e\xd3\x32\x35\x11\x47\xfe\x06\x82\x1e\xdc\xcd\x9b\x4b\xf8\x05\x4d\xbd\x00\xc9\xc8\x67\x05\x2d\x8d\x18\xdc\xbd\xb0\x44\xe1\x8d\xf2\x02\x4b\xb9\x1d\xcd\x48\x2e\xd4\x78\xb2\x38\x7e\x24\x4b\xfd\x36\x52\x0e\x66\x08\x2b\x25\xe8\x24\x57\x44\xcf\x5b\xb7\xe1\xee\x4e\x60\x8f\xe6\x82\x6e\xc3\x1a\xde\x6e\xc2\x31\x15\x24\x82\xb9\x6d\x72\x60\xfc\x57\x7a\xde\x5a\x7f\x59\x98\xd9\x3f\x92\x05\xc8\x23\x35\x2b\xe0\xb7\x7c\xc4\x46\x0c\x1d\xa1\xf3\xc1\xdd\xd9\xe0\xea\x7c\x78\xf5\xe9\x14\x7d\xb7\x40\x31\x99\xe2\x3c\x51\x3d\x34\xa5\x24\x89\x25\xc2\x82\x40\x93\x24\xd6\x32\x87\x1e\x0c\x61\x31\x65\x33\xc4\x45\x4c\xc4\xcb\x2d\x63\xe5\x29\x61\x79\x5a\xb9\x57\xe0\xf7\x62\xf4\x95\x2f\xb4\x88\xe1\x1f\x95\x9e\xfc\x6d\x69\x81\x61\xc6\xba\xef\xa0\xb5\x57\x13\x6a\xa2\x39\x4d\x62\x41\xd8\x89\xc2\xf2\x71\x4c\x3e\x93\x28\x37\x77\xf2\x3f\xcb\x3f\x8c\xb5\x64\xca\x63\x52\xfe\xa5\xf4\x8f\x42\x14\xda\xf8\x53\xaf\xa5\x6e\xfc\x25\xe8\xb4\xed\xbe\x83\x5f\x68\x5c\xfb\x36\xfc\xb2\x66\x0e\xee\x9d\x15\x83\x75\xaf\x34\x8e\xca\xbd\x60\x25\xbe\xda\x77\x04\x51\x62\x31\xc6\x4a\x91\x34\x53\x1b\xea\xeb\x18\x25\x5a\xae\x5c\x25\x47\x5e\xf1\x98\x0c\x5c\x7f\xbf\x20\x23\xce\x92\x18\x4d\x16\x96\x6b\x4d\x89\x20\x2c\x22\xcd\x2d\xdc\x63\xf9\x58\xb4\xb0\x4e\x18\x2d\xf5\x27\x3f\x72\xa1\x3f\x7f\x0f\x02\x69\x69\xe0\xaf\x21\x93\x6e\x7b\xe2\xbe\x38\x0b\xc1\x96\xfc\xa3\xb3\x27\xec\xbe\x92\x6d\xad\x0f\x5c\x20\xb9\x90\x8a\xa4\x6b\xed\x10\xef\x67\x21\xec\x05\x71\xa8\x03\xae\xdc\x51\xbf\x81\x53\x5f\xbe\x71\xbb\xe3\xbd\xc1\x92\xed\xcb\x8a\x78\xe8\xf3\x74\x3e\x9c\xd5\x53\xbd\x73\xdb\x17\x38\x31\xde\xc5\x34\x4b\xb2\xe0\xbe\x07\xf9\x42\xe6\x86\xc6\xbd\x72\xab\x3d\x86\x01\xac\x51\x34\xcb\x76\x68\x7f\xfe\xf4\xa7\xa1\x85\xc6\x98\xe3\xd4\x9c\xca\xc0\x58\x85\x22\x2e\x8c\x2c\x18\xdb\xf3\x6e\x74\xcd\xfe\x7d\xff\x6e\x70\x7f\x8a\xfa\x28\xc6\x0a\xeb\x03\x2e\x48\x26\x88\x24\x4c\x81\x1e\xaf\xbf\x57\x0b\x94\xf2\x98\x24\x46\xe3\xfc\xa8\x25\x5f\x74\x8e\x15\x3e\xc3\x0a\x27\x7c\x76\x8c\xfa\xf0\x4f\xfd\x31\x95\x08\x27\x92\x23\xec\xc8\x8a\xc4\xae\x09\xcc\x62\xc7\x5a\x30\x8a\x78\x9a\xd1\xc4\xdb\xe0\xbd\x71\x85\xb2\x98\x3e\xd1\x38\xc7\x09\xe2\x13\xcd\x55\xb4\x86\x3c\x78\x22\x4c\xe5\x38\x49\x16\x08\x27\x09\xb2\xdd\xba\x17\x90\x9c\xf3\x3c\x89\x75\xbb\x6e\x94\x92\xa6\x34\xc1\x42\xab\xe0\x66\xb4\xd7\xb6\x2d\x74\x3f\x27\x7e\xac\x30\x2e\xbd\x9a\x29\x7e\x24\x12\x51\x85\x32\x2e\x25\x9d\x24\xc5\x99\x7f\x18\x22\x18\xf7\xd9\xc5\x10\xf4\xf9\x48\x21\x6e\x78\xa8\xeb\xdc\xda\x6f\x5c\x8f\x29\x66\x8c\x40\xc7\x5c\xcd\x89\xb0\xdd\xdb\x97\xdf\x5a\x35\x7f\xb8\xba\xbb\x19\x9c\x0d\x3f\x0e\x07\xe7\xcb\xba\xf9\x7d\xff\xee\x87\xe5\x5f\x7f\xba\xbe\xfd\xe1\xe3\xc5\xf5\x4f\xcb\x4f\x2e\xfa\x0f\x57\x67\xdf\x8f\x6f\x2e\xfa\x57\xcb\x0f\x2d\x59\xb5\x56\xf3\xc3\x91\x6d\x78\xb6\x3a\x9b\xe6\x4b\xd9\x34\x7b\x5f\xae\x51\x73\x4a\x13\xd0\x41\x5b\x1b\x34\xbd\x0d\xc1\x7e\x89\x32\x2c\xa5\x91\x8c\xcc\x08\x8e\x47\xec\x92\x0b\xcd\xc0\xa6\x5c\xf3\x08\x2d\x3d\x29\x91\x47\x8a\xb2\x99\xff\xe8\x14\x8d\xf2\x6f\xbf\xfd\x53\x74\x41\xd9\x23\xfc\x45\x0e\x71\x71\x3a\x8b\x6f\x67\xf1\xfd\x6d\x59\x7c\xb5\xe8\x73\x12\x1a\x7a\xf7\x1b\x32\xa4\x85\x0b\x96\xe5\x0a\x44\x09\x9e\x2b\xfd\xa7\xee\x12\xc8\x63\x45\xe0\x50\x3b\x83\xe2\x27\xa2\xfc\x8b\x5a\xb4\x79\x0f\x76\xc4\x9f\xb8\x78\x9c\x26\xfc\xd9\x0f\xfc\x13\x51\x7a\xec\xb7\xb6\x97\x2e\x94\xa8\x0b\x25\x7a\xdb\x50\xa2\x83\x32\xe6\xbd\x3c\xf3\x2b\x5b\xfe\x0c\x07\x6c\xf0\x64\x35\x3a\xaa\x1a\xfc\x50\x81\x9b\xe9\x55\xb8\x66\xd9\x99\xb3\x86\x73\x96\x5e\x7e\x2f\xdc\xb3\x34\xe8\xd7\xe7\x9c\xbf\x09\x7f\x4b\xe7\x4e\xd9\x72\xa1\xde\x25\x83\x6d\x79\x77\xbc\x9a\x33\xe4\xe5\x19\xfe\x52\x6c\xc3\x26\xc1\x0c\x1b\x44\x2f\xb4\x0e\x57\x58\x13\x9f\x50\x1b\x90\x50\x17\x81\xb0\x1c\x72\x50\x1b\x63\xb0\x5b\x50\xc1\xb6\x77\x53\xfb\x30\x81\x4f\x44\x95\x5e\x7e\x2f\x77\x53\x69\xd0\xaf\x7f\x37\xfd\x46\xa3\x03\xba\x70\x80\x17\x5c\xba\x2f\xfd\x46\x3b\x5c\x87\xff\x6f\xc0\xc3\xdf\xb9\xf4\x37\x5a\xa3\x2f\xcb\x87\xff\xa5\x3a\xed\xdf\xa7\x97\xbe\x73\xcb\x77\x6e\xf9\xb7\xf0\x9f\xbc\x3f\xb7\xfc\xcb\xaa\xa7\xc5\xf1\x1a\x3b\x5a\xb0\xfa\x5a\x70\x28\xff\xd5\xc2\x49\x03\x7f\x39\x95\x6f\xd3\xa0\xf1\x46\x1d\xee\xbc\x18\xdf\x00\x8e\xd0\x2f\x96\x90\xd6\xa8\x73\x4b\xdf\xbd\x07\x75\x6e\x79\xd0\x2f\xaf\xc3\xbd\x19\xf3\x7d\xa1\xcb\xf3\x9d\xb0\x81\xcd\x6f\xcb\x2f\x58\x26\xef\x64\xf1\x97\xcf\xc6\x3f\x98\x09\xbd\x1f\xd9\xfb\x0d\x2e\xde\x96\xb7\xee\xde\x73\xb2\x6a\xae\xd9\xe0\x76\x5a\x97\x61\x55\xfd\x9a\x12\xf9\xc7\x77\x79\xdf\xbe\x46\x92\x55\x77\xe1\x76\x17\xae\x6d\xaa\xbb\x70\xbf\xe0\x0b\xf7\xe0\xe0\x6f\x0e\x26\x02\xb4\x0b\x22\xef\x80\x31\xba\x18\xf2\x3d\x2e\x4e\x17\x43\xde\xc5\x90\xff\xc6\x62\xc8\x77\xd1\x9e\xb6\xc5\xa2\x7c\x0b\x3d\xaa\x53\xa3\x3a\x35\x2a\xfc\xbd\x53\xa3\x3a\x35\xaa\x53\xa3\xbe\x70\x14\xd1\x4e\x87\x6a\xbf\x10\x9d\x0e\xd5\x7a\xa9\x3a\x1d\x6a\xc5\xe2\x74\x3a\x54\xa7\x43\xfd\xb6\x74\x28\xf2\x44\x98\x92\x90\x8c\x16\x6a\x14\x1f\x32\x2e\x9b\x35\xa1\x90\x3b\xd4\x68\x41\xd0\x66\x39\x29\x0c\x02\x97\x7e\x41\x73\x2c\x11\x8f\xa2\x5c\x54\xce\x40\x55\x0f\x3a\x13\x04\x2b\x02\x2d\xe8\x0f\xdf\x83\xfe\xb3\x3c\xdd\xd7\x8a\xc1\x9f\xf0\x78\x89\xda\xcd\x41\xa8\x7b\xb2\x5a\x1e\xd9\xdb\xd4\xff\x91\x93\x76\xea\xdf\x0b\x12\xb5\xc2\xf2\x71\xcf\x44\x5d\xca\xb5\xd8\x8a\xa8\xa1\x85\xf7\x42\xd4\xcb\xd3\xfd\xcd\x10\x75\xdd\xd4\x0f\x81\xa8\x9f\x6d\x1e\xff\x9e\x09\x7b\x09\x1e\x60\x2b\xe2\xf6\xad\xbc\x17\x02\xaf\x9f\xf6\x6f\x86\xc8\x9b\xa6\xff\xb6\x84\xee\x53\x24\x5b\x93\xf8\xbd\xa0\xb3\x99\x56\x33\x40\xc3\xd3\xa4\xb8\xbe\x46\x50\x91\x14\xb8\x96\xac\xfd\xab\xef\x81\xa4\xfd\x60\xcd\xd8\x7f\x33\xb4\xbc\x34\xef\x03\x21\xe2\x13\x41\x22\xfe\x04\xf5\xc2\xda\x11\xf3\x2d\x01\x0a\x06\x7e\x9d\x09\xf2\x44\x79\x2e\x93\xc5\x91\xc8\x19\x72\xcc\x1f\xf9\xe6\x8d\xb5\xfa\x99\x26\x09\xe2\x4c\xeb\x5f\x0a\x0b\xe5\x1e\x6b\xfd\x5b\xf0\x14\x4e\x45\x82\xa5\x42\x8f\x8c\x3f\x33\x34\xc5\x34\xc9\x05\x41\x19\xa7\x4c\x1d\x8f\xd8\x90\xa1\x5b\x33\x46\xc8\x1b\xe8\xa1\x5c\xea\xb3\x14\x61\xc6\xb8\x42\xd1\x1c\xb3\x19\x41\x98\x2d\x6c\x02\x6e\x41\x19\x88\x0b\x94\x67\x31\xd6\x8a\xef\x9c\x54\xa3\xf4\xfc\x18\xc1\x7c\x47\x25\xa2\x12\x91\xcf\x4a\x90\x94\x24\x0b\xdd\x87\xa6\x7d\xc5\x91\x5d\x1f\x33\x54\x9b\xce\x47\x84\xe0\x42\x42\xc6\xc1\x64\xf1\x2b\x66\x8a\x32\x82\x40\x51\x92\xc6\x34\x77\x84\x2e\xb8\x04\xb3\xcd\x0f\x7f\x91\x28\x4a\x72\xa9\x88\xe8\xa1\x49\x3e\x93\x5a\x53\xcc\x12\xac\xa6\x5c\xa4\x7a\x84\x94\x49\x85\x27\x34\xa1\x6a\xd1\x43\x29\x8e\xe6\xa6\x2d\x58\x03\xd9\x1b\xb1\x98\x3f\x33\xa9\x04\xc1\xbe\x77\xf7\x10\x7d\x1d\x3e\x33\x04\x20\xbf\xe9\x41\xda\x21\x4d\xb5\xba\x1b\x0c\xbf\xd8\x71\xb3\x27\xba\x11\x12\xa3\x09\x89\x70\x2e\xad\x87\x41\x89\x05\x22\x9f\xe7\x38\x97\xb0\x77\x7a\x7a\x36\x67\x23\xe2\x69\x96\x10\x45\x10\x9d\x22\x25\x28\x89\x11\x9e\x61\xaa\x97\xee\x8e\xac\x00\x41\xf7\x44\x6f\x37\xd0\x52\xfd\x2f\xa0\x7e\xa7\x5c\x10\x14\x13\x85\x69\xb2\xd2\xeb\x64\xbf\xed\xb8\xdc\x7b\xe2\x72\xe5\x0d\x3f\x08\x36\x67\x40\xfc\xf7\x70\x69\x33\x6b\xba\x8f\x70\xb2\xe3\xfd\x7d\x6b\x07\xd5\xd1\xf6\xfb\xa2\x6d\xb3\x6b\x87\x43\xdc\xaf\x16\x83\xdd\xbe\xa2\x45\x51\xcd\xe2\x5d\xd1\xf4\x6b\x84\x05\x74\x0e\xe7\xce\xe1\xdc\xb8\x32\xef\xd3\xe1\x7c\x30\x1e\xa3\xce\xe7\xfc\x42\x3e\x67\x2a\x3b\xa7\x73\xe7\x74\x6e\xbb\x40\x9d\xd3\xb9\x73\x3a\xbf\x5f\xa7\xf3\x4b\xe2\x3e\xef\x15\xdd\xf9\x5d\x89\xd6\x9d\x58\xdd\x89\xd5\x1d\x84\xb3\x9f\xda\xbe\x58\x98\xfb\xfa\x43\x4c\x12\xa2\x48\xb3\x3d\x8b\x88\x54\x6b\x0b\xe6\x7a\xa6\x4c\xcb\x71\x33\x41\xa4\xdc\x95\x21\xf9\x86\xdf\x27\x5b\xf2\xc3\xef\xa0\xe6\x3b\x3e\xd5\xf1\xa9\x6d\xa6\x76\x38\xa6\xd9\xe0\x30\xbf\x96\x6d\xd6\xf3\xdf\x2c\x6f\x96\xfe\x1e\x8c\x1b\xb2\xf0\x8b\x1a\x0a\xd7\x52\xbb\xe2\xfe\x70\x5b\x3a\xdf\x91\x1f\x9b\xbe\xde\x27\x33\x36\x63\xef\x38\x71\xc7\x89\x3b\x4e\xfc\xbe\x39\xb1\x3b\xc9\x6f\xea\x22\x33\x7e\xba\x71\x96\x60\x36\xa6\xb1\x3c\xf9\x67\xa1\xcb\xbf\x94\x87\x4c\x1f\xa8\xd8\xa4\x98\xfa\x94\x4e\xf1\x8b\xfe\x24\x29\x0c\xe6\x1e\x33\x73\x8d\x13\xcd\xd8\xd8\x6f\x12\xcc\x86\xf1\xbb\xf0\xa3\xd5\xce\xfe\x35\x7c\x6a\xbb\xf0\x71\xac\xc0\xd3\x81\x29\x33\x26\xbc\x22\xaf\xb6\x64\xa0\x3c\x8c\x13\xbe\x0b\x57\x0f\x26\x16\x30\x76\xc7\xaf\x83\x45\x39\xbc\x69\x77\x7e\x9d\x2e\x97\xb0\xf3\x5c\xb4\x9c\x70\xe7\xb9\x38\x5c\xcf\xc5\x5b\xb9\x23\x5f\xf9\x78\xbe\x96\x58\xd7\x3e\x08\xdf\x44\xab\x41\x50\x6b\x9e\x25\x1c\xc7\xab\x5c\x31\x85\xe0\x15\x82\xa3\xac\x8d\xc4\x2f\x3e\x7b\x0f\xc2\x5a\x31\xda\xdf\x58\x24\xdf\xf2\xc4\x0f\x45\x4b\x79\xc5\x50\xbe\x7a\x12\xdf\x40\x25\x79\x1f\xf8\xa9\xc5\x78\xbb\xd0\xbe\xce\xa2\xf4\xf6\x16\xa5\x2e\xb4\xaf\x53\x01\x0f\x4c\x05\xec\x42\xfb\xba\xd0\xbe\x4e\x41\x5e\x3d\xed\x4e\x41\xfe\x22\x42\xfb\x5a\x89\xda\x2f\x88\xbd\xb9\xbb\xd0\xdd\xc9\xdc\xee\xbd\x4e\xe6\xee\x64\xee\x2f\x54\xe6\x3e\x8c\x15\xee\x04\xee\x4e\xe0\xee\x04\xee\x4e\xe0\xee\x04\xee\xbd\x2f\x63\x27\x70\xbf\x66\x81\xce\x7a\xa9\x7b\x4d\x92\xcd\x7b\xf5\xe5\x74\xe2\x76\x27\x6e\x1f\xb6\xb8\x7d\x30\x13\x7a\x3f\x65\x1e\xdb\xcd\xa7\x2b\x52\xde\x15\x29\xef\x8a\x94\xbf\x78\x91\x72\xf7\x75\x8b\x8c\x0f\x7b\xb8\x14\x56\xb9\x34\x80\x8f\x82\xcc\xa8\x54\xc0\xfe\xdb\xc8\x2b\xeb\x13\x3d\xde\xab\x9c\xd2\xa5\x7a\xf8\xa7\x9d\xd4\xd2\x49\x2d\xbf\x51\xa9\xe5\x80\x62\xc1\x0e\x22\x63\x25\xc5\x2a\x9a\xe3\x49\x42\xc6\xde\xe8\x23\xdb\xea\xc1\x17\x54\x2a\x89\xa2\x5c\x2a\x9e\x36\x5f\x2e\x97\xae\x87\xbe\xef\xe0\x8c\xb3\x29\x9d\xe5\xe6\x6e\x31\xe0\x9c\xc1\x89\x2e\x24\xc1\x45\x46\xd6\x79\xaa\x6a\x5a\x7f\x17\xd7\x52\xfd\xd0\x5f\xeb\x76\xda\x44\x70\x2f\x8c\x7c\x56\xea\xd6\xb2\xd6\xf8\x76\x70\x77\xfd\x70\x7b\x36\x38\x45\xfd\x2c\x4b\xa8\xb1\xbb\x1b\x52\xa0\xbf\xea\x49\x21\x85\xe5\x63\xb1\x97\xc2\x90\xb9\xc1\xb0\x05\x43\xbf\x96\x8d\xd1\x11\x3a\xbb\x78\xb8\xbb\x1f\xdc\x36\x34\x68\x09\x05\xf2\x56\x49\x9a\x25\x58\x91\x18\x3d\xe6\x13\x22\x18\xd1\xd2\x8e\x45\xba\x2d\xcc\xff\xa6\xd1\xc1\x7f\x0f\xce\x1e\xee\x87\xd7\x57\xe3\xbf\x3e\x0c\x1e\x06\xa7\xc8\x51\x9c\x6e\x56\x8f\x4b\x8f\x22\x5e\x30\x9c\x6a\x0d\x44\xff\x50\x64\xca\xfe\x23\x27\x39\x41\x58\x4a\x3a\x63\x29\x01\x44\xe0\x52\x8b\x6e\xc0\x17\xfd\xef\x06\x17\xe5\x96\xe7\x24\x84\xdf\x45\x09\x9e\x90\xc4\xfa\x23\xc0\xc4\xae\x09\x3d\x80\x2a\x36\x8e\x8a\xdc\xac\xea\x5f\x1f\xfa\x17\xc3\xfb\x9f\xc7\xd7\x1f\xc7\x77\x83\xdb\x1f\x87\x67\x83\xb1\x95\x2a\xcf\xfa\xba\xdf\x52\x4f\x56\xf8\x44\xff\xc8\x71\xa2\xb5\x13\x3e\x75\x78\xbc\xe8\x79\x4e\x18\xca\x19\x50\x9c\x51\x79\xb4\x1e\xe4\x3b\xd5\xa7\xcc\xcc\xe8\xe6\xe2\xe1\xd3\xf0\x6a\x7c\xfd\xe3\xe0\xf6\x76\x78\x3e\x38\x45\x77\x24\x01\xa5\xc0\x2d\x3a\xec\x62\x96\xe4\x33\xca\x10\x4d\xb3\x84\xe8\xd5\xc0\x36\x9b\x78\x8e\x9f\x28\x17\xf6\xe8\xce\xe8\x13\x61\x66\x1d\xe1\xcc\x42\xfb\x4e\xf8\x1e\x07\x4b\x77\x7d\xf5\x71\xf8\xe9\x14\xf5\xe3\xd8\xcf\x41\x42\x1b\x25\xca\x71\xb0\xce\x47\xe5\x61\x6b\xe6\x00\xdd\x1b\x22\xe2\x4f\x44\x08\x1a\x93\x0a\x1d\xf5\xef\xee\x86\x9f\xae\x2e\x07\x57\xf7\xb0\x62\x4a\xf0\x44\xa2\x39\x7f\x06\x53\x36\xcc\x10\x2c\xdc\x4f\x98\x26\xd0\x99\xdb\x2c\xce\xd0\xf3\x9c\x82\xfb\x03\x80\x99\x7d\xcf\x46\x3f\x13\x39\x7b\x73\xeb\x6c\xe9\xe0\x2d\xab\x2d\xd5\x93\xb4\xfc\x46\xe5\x58\xac\x7a\xa1\x44\xe5\xcb\x2f\xae\xa3\xd6\xe5\x2f\x2a\xe4\xd6\xac\xac\x2d\xd1\x4b\xf3\x4c\x8b\xbd\x6e\xad\xab\x95\xd7\xf0\xf5\xae\x59\xa2\x04\x8d\xe4\xcb\x42\x3d\x89\x9c\x29\x9a\x12\x64\x3b\xb3\x87\x73\x8f\xf0\x4f\x97\xa6\xe1\xf7\x70\xc1\x2e\x95\x72\xf8\x44\x94\x1d\x7e\xa7\x02\x76\x2a\xe0\x61\xa8\x80\xef\x2d\xdb\x3f\x26\xd9\x72\x87\x95\x89\xc1\x3b\xc6\xeb\xb5\x14\xa4\x61\xec\x89\xd6\xa2\x9a\x90\x27\x92\x80\x94\xa7\x04\xd6\x4a\xa3\x95\x5d\x26\x82\xe0\x47\x2d\xf0\xc5\xfc\x39\x94\x5c\x6a\x90\xfb\xd1\x7e\x6e\xe1\x36\x41\x1c\x7f\xfa\xe3\xeb\x5d\x16\x7a\xb9\xe3\xd7\x28\xe1\x7d\x0b\x41\x32\x2b\x31\x02\x83\x04\xfb\x5f\xac\x25\x78\xcd\x6d\x11\x7c\xf1\x1e\x2e\x8a\x70\xb8\x07\xa4\x75\xdd\x86\x4a\xb0\x63\xa1\x29\x51\x38\xc6\x0a\xeb\x43\x33\x23\xea\x18\x5d\x33\x78\x76\x8f\xe5\x63\x0f\xb9\x2b\x4f\xb3\x95\xc2\xca\xf0\x0a\xa9\xf5\xef\xc4\x80\xbf\x39\x1f\xef\xae\xef\xee\xfa\xae\x5f\x99\x2e\xcc\xb3\x61\x85\xf7\x75\x31\x6e\xe4\xf3\xda\xdf\xfd\x65\x5a\x7c\xbf\x57\xd8\xeb\x3a\xb9\xf6\x7a\xa1\x99\xca\x59\xdd\x6d\x65\xfe\xaf\xbb\xad\xba\xdb\xaa\xbb\xad\x0e\x60\x85\xdf\xdc\x61\x58\xc3\xdd\xdf\xd4\x63\xb8\x4e\x3b\xdd\x1a\xf2\xae\xd0\x46\x37\x01\xbd\xfb\xa5\x2d\xb6\x5d\xf1\x0d\x7d\x1f\x3e\xc2\x60\x92\xaf\x91\xd6\xb6\xd7\xcb\xdc\xe4\x8b\x74\xfa\xe9\x0b\xde\xf8\x1d\x02\xe1\x5e\x11\x08\x0f\x63\xae\x2f\x92\x02\xf7\x36\x16\xd3\xb7\x4f\x7b\xeb\xa0\x06\xbb\xc4\xae\x2e\xb1\x0b\x7e\xef\xa0\x06\xf7\x47\xad\x2f\x2b\x5d\xf3\x98\x8c\x2b\x51\x02\xfe\x9f\xe3\xaa\xe7\xa7\xf4\x24\x74\x03\x95\x1e\x14\x99\x6e\xd0\x3a\x8d\xf7\x59\x44\xea\x8a\xc7\xa4\x75\x24\x41\xe9\xe5\x03\x97\xc1\xdd\x3c\x8d\x2c\x5e\x1a\xf8\x0b\x4b\xe2\x0d\x5b\xfe\x25\x1a\x76\x6a\x08\xb8\xb3\xf2\xac\x5d\xa8\x2f\x35\xbe\xa0\xe0\x50\xef\xc8\x53\xd1\x8e\x8d\xbb\x98\xc6\x71\x03\x33\xaf\x7f\xee\x59\x7a\xfd\xe3\x97\xc1\x0c\x6a\xcf\xd1\xc1\xac\x12\xbe\xfd\x3e\xec\x2a\xe1\x88\x5f\xc3\xb2\xb2\x72\xef\xbf\x38\xae\xbe\x8a\x92\x3b\xde\xde\x72\xb9\xbe\x54\x0e\xdf\x41\xfc\xac\xb2\x75\x74\x18\x3a\x9d\xa9\xe5\x70\x26\xdc\x99\x5a\xde\xb5\xa9\xc5\xb8\x68\xc7\x19\x16\x84\xa9\x1a\x91\xba\x7a\x9d\xc0\xeb\x21\xe6\x82\x93\x3a\xa0\x01\xa4\x25\x5a\x64\x2f\x64\x7f\x55\x7d\x59\xb6\x17\x2b\x18\x04\x99\x90\x27\xff\x2c\xfe\xf6\xc2\x7a\xa9\x02\xc4\x8a\xe8\x24\x83\xf5\x2f\xf5\x1d\x9d\xdb\x40\xa5\xdd\x73\x25\xb1\x2a\x89\x82\x10\x44\xbd\x36\x9e\xe9\xc6\xbc\xfd\xbe\x52\x24\x97\x06\xfd\xba\xb1\x4d\xcb\x1b\xdf\xee\x00\xb9\x9d\xa1\x26\xdd\x2f\xc8\x29\xd3\xd2\x28\x9f\x16\x17\x83\x44\xcf\x34\x49\x00\x51\x04\x32\x1e\x9b\x6e\x80\xdf\x5c\xc4\x43\xe3\xce\xbf\x69\xdc\x43\x1d\x77\xa8\x63\x09\x6d\xec\xa9\xfb\xca\x99\x76\xc4\x06\xe9\xac\xa0\x0d\xad\x31\xc0\x7e\x19\x9c\xe0\x13\x51\xaf\xc5\x06\xb6\x3d\xfb\x2b\xcf\xbd\x20\x53\x22\x08\x8b\xc8\x01\x7a\xdb\x37\x09\x03\xf9\xc9\x4c\xd2\xc6\x80\x78\x28\x81\x70\xaa\x8a\x5b\x3d\xad\x24\xea\x76\x99\xe4\x5d\x26\x79\x97\x49\x5e\x3d\xea\x5d\x26\x79\x97\x49\x5e\x9b\x03\x11\x93\x84\x28\xd2\x28\x55\x9c\xc3\xe3\xb7\x92\x2a\x4c\xef\x5f\x86\x60\x61\xe6\xd2\xc9\x16\xbf\x19\xcd\xc2\x6d\xf8\x41\x68\x16\xe6\xac\xad\x33\x3f\x94\x7e\xac\x09\xb1\x7e\x75\x93\xc4\x36\x4c\xa3\x64\x97\x38\x87\xd7\xdf\x25\xeb\xa8\x0e\xbd\xb3\x51\xa0\x60\xeb\x5e\x8e\x93\x2c\x1d\x81\x76\x13\xb7\x1e\xc3\xf7\x3b\xef\x43\xe1\xa0\x4d\x74\x7f\xa8\x7c\x74\xeb\xa4\x94\x43\xb1\xd8\x7c\x41\x3c\xb2\xb3\xde\xbc\x71\xae\xc4\x12\x33\x7c\xb7\xd3\xed\x8c\x55\x9d\xb1\xaa\x33\x56\x75\xc6\xaa\xce\x58\x85\x3a\x63\xd5\xc6\xc6\xaa\x2f\x48\xa6\xea\x0c\x57\x9d\x58\xb5\xbf\xe9\x1e\xaa\x96\x79\x48\xd6\xba\xd6\x28\xe9\x45\x0e\xd5\xda\xc8\x7b\x3b\xed\x5f\xd6\x84\xdc\xdf\xb8\x11\xbc\x1f\x7e\x25\x5f\x9a\x25\xed\x12\x58\xec\x76\xf4\x8b\x8d\x2b\xee\x4a\x87\xd6\xae\x55\x17\xf6\xbc\x62\x71\xba\xb0\xe7\x2e\xec\xf9\xe0\xc2\x9e\xf7\xae\xac\x64\x5c\xae\x02\x24\x32\xa5\xb3\x56\xe6\x3f\xbb\x3b\x1b\x12\x8d\x80\x14\x0c\xca\x71\x4c\xb2\x84\x2f\xc0\x92\xb2\xe2\x3a\x77\x5d\xdc\x2c\x49\xd4\x87\x7e\xa3\xbb\x91\xbf\x96\xce\x71\x28\x32\x69\x31\xef\x83\x90\x42\x4f\xfe\x59\x49\xe7\x6f\x85\x97\xc9\x10\xf9\x4c\x25\xdc\x4a\xeb\x09\x7b\xc4\xea\x9f\x04\xa5\x0b\xed\x3d\x38\xc9\x55\x90\xbb\x27\xb5\x60\x95\x11\xa1\x16\xc1\x9b\x24\xcd\xd4\xe2\xbf\x46\x8c\x2a\xef\x61\xa3\x33\xc6\x85\xe1\x6a\xfa\xe3\x39\x66\x71\x42\x84\xbe\x54\x5d\x3b\x11\x66\x8c\x2b\x10\x37\x60\x06\x31\x7a\xa2\xd8\x08\x27\xfd\x9b\x61\x6b\x3f\xf3\x3b\x3a\x5d\xaf\x5d\xac\x6e\xcd\x5d\xf7\x29\xe1\x13\xa8\x60\x99\x97\x75\x7a\xdd\x40\xe7\x19\x2d\xed\xdc\x5b\x31\x04\x85\xe5\x63\x15\x38\xa4\x9c\x85\x3e\x5e\x09\x25\xb2\xe6\xdd\x12\xc6\xfc\xea\x57\x2b\x70\x23\xe5\x67\x16\x80\x04\x1e\xc3\x90\xab\xe3\x70\x3f\x86\x1d\xba\xdf\x8a\x96\xdd\x2f\xae\x74\x37\xfc\x28\x88\x12\x8b\x31\x56\x4a\x33\x99\x7d\x62\x9c\xdc\x63\xf9\xd8\x1a\xe3\xa4\xf4\xf2\x81\xb3\x9c\x12\xc6\x49\x79\xe0\x2f\xce\x72\x5a\x52\xe7\x1a\xce\xf4\xfe\xf2\xe3\xdb\x9e\xb5\x0d\x26\xfe\x5b\xc9\x95\x6f\xc7\x7b\xd6\x99\x69\xdf\x63\xde\xfc\x2a\x66\x7a\x30\x23\xac\xf0\xf3\x2f\xf1\xe4\x96\x6f\xa7\xee\x88\xae\x5a\xa3\x2f\xae\x10\x6e\x45\xe8\x58\x33\xb7\x77\x52\x10\xb7\x2a\x37\xed\x7b\x54\x2f\x63\xe6\x0e\x76\x63\x93\x18\xa0\x61\x19\xad\xdc\x9f\x21\x17\x15\x54\x94\x9e\x9d\x43\xa2\x35\x95\x61\x42\x7c\xc4\x85\x91\xbc\x62\x7b\x66\x8d\xd9\xce\x80\xf9\x9e\xa2\x3e\x8a\x6d\x6d\x7e\x41\x32\x41\x24\x61\xca\xa8\xda\xa6\xde\x95\x2b\xef\x4f\x99\xb5\x10\x9d\x63\x85\xcf\xb0\xc2\x09\x9f\x1d\xa3\xbe\x2f\xec\x4f\x25\xc2\x89\xe4\x08\x3b\xc2\x21\xb1\x6b\x02\xb3\xd8\xb1\x07\x8c\x22\x9e\x66\x34\xf1\x48\xed\xde\x8a\x4f\x59\x4c\x9f\x68\x9c\xe3\xc4\x23\x63\x8f\xd8\xe0\x89\x30\x95\x83\x0a\x87\x93\x04\xd9\x6e\xdd\x0b\x81\x7e\xee\x46\x29\x69\x4a\x13\x2c\x90\xe2\x76\xb4\xd7\xb6\x2d\x74\x3f\x27\x7e\xac\x0e\x05\x1c\xa5\xf8\x91\x48\x44\x15\xca\xb8\x94\x74\x92\x14\xc7\xf8\x61\x88\x60\xdc\x67\x17\x43\x30\x8d\x46\x0a\x71\xc3\x07\x5d\xe7\xd6\x4f\xe0\x7a\x4c\x31\x63\x04\x3a\xe6\x6a\x4e\x84\xed\xde\xbe\xfc\xd6\x56\xce\xb7\xc6\x88\x6e\xb6\x98\x86\x23\x7b\x3b\xa5\xb3\xb5\xc6\xd9\x56\xdd\x6c\xa7\x6b\x36\x2b\x9a\x2f\xe0\xa5\x6d\xaf\x0d\x5e\x50\x59\x56\x07\xdf\x85\xcb\xb6\x34\xe2\xd7\xc0\x47\xfb\x8d\x2a\x82\x9d\x16\xf8\x22\xeb\xf6\xa5\xaa\x80\x07\xae\xff\x75\xc8\x6e\x1d\x8a\x7d\x17\x80\xb1\xc7\xc5\xe9\x02\x30\xba\x00\x8c\x2f\x36\x00\xa3\x59\x9b\xa0\xf1\xce\xe9\x7a\x1b\x56\x90\xf2\x46\x01\xf1\x0b\x88\x52\x58\x3e\xb6\xad\x29\xa5\x45\xe5\x61\xfc\x2e\xa4\xfa\xda\x09\xbf\x86\x74\xdf\xd5\x29\xda\x6b\x9d\xa2\x83\x9b\x76\x27\xf8\x75\x82\x5f\x27\xdb\xb4\x9c\x70\x27\xdb\x1c\xae\x6c\xf3\x56\x0a\xcb\x97\x04\xa1\xab\x85\xa7\x52\x66\xcc\xca\x00\x5b\x03\x47\x03\xee\x81\x3c\x4b\x38\x8e\xd7\x05\xe1\xfc\x82\x0a\xb9\x66\x85\x68\x66\xda\xd5\x1f\x1c\xb8\x64\xb6\x14\x7f\x63\x46\xfe\x5b\x88\xa9\x6d\x9c\xfa\x9b\x86\xd5\x02\xfd\x42\x30\x59\x29\x28\xed\xa5\xb4\x90\x2a\x4d\xb7\x52\x38\xe4\x1f\x0f\x9c\xaa\xfd\x96\xbe\x86\x7a\xf1\x05\x3b\x08\x3a\x27\xc0\x6f\xb3\xf0\xf9\xc1\x48\xad\x9d\x6a\xd7\x65\x55\x76\x46\xfd\x4e\xf1\xed\x14\xdf\xbd\x2f\xe3\x21\x29\xbe\x6f\x28\x51\x9b\x34\x91\x17\x29\x63\xb8\x9d\x6c\xdd\x89\xd6\x9d\x68\xdd\x89\xd6\x5f\xac\x68\x7d\x18\x2b\xdc\xc9\xd5\x9d\x5c\xdd\xc9\xd5\x9d\x5c\xdd\xc9\xd5\x7b\x5f\xc6\x4e\xae\xae\xc8\xd5\xf0\x97\x4b\x93\xde\x54\xc8\x6e\x2d\x5c\xb7\xc8\x89\x7e\x2f\x92\x75\x27\x55\x77\x52\xf5\x61\x4b\xd5\x07\x33\xa1\x2f\x2f\x11\xb2\x4b\x25\xec\x52\x09\xbb\x54\xc2\xb7\x48\x25\x74\xbc\x64\x95\x84\xb2\x2c\x58\xfc\xb8\xc4\x81\x0e\x56\xb6\x28\x46\xbb\x6d\x78\xc7\xbe\x96\xda\x01\xcd\x6f\x53\x69\xaa\xf4\x9b\x6b\xe8\x80\xea\x4f\xf5\x9c\xb4\xa0\x19\x85\x1b\xdf\x7a\x84\xb0\x9f\xec\x9b\xef\x0b\x0c\x7c\x79\xd4\x5d\xfd\x29\x14\xec\x5a\x57\x7f\xea\x05\xe7\xed\x0e\xd7\x9a\x99\x3b\x1a\x35\x36\xde\x77\x3a\xed\x37\x07\x97\x6b\x3e\xe9\x6f\x1a\x2e\x57\x7b\x93\x2c\x25\xef\x9c\xfc\xb3\xf6\xa2\x78\x83\xb2\x5b\x1b\xdf\x0e\x9f\x88\xfa\x52\xae\x86\xae\xec\x56\x57\x1f\x62\x4f\xd3\xdd\x8a\xf5\xbf\xdb\xd9\x76\x45\xc6\xba\x22\x63\x5d\x91\xb1\xae\xc8\x58\x57\x64\x0c\xfd\xc6\x8b\x8c\x6d\x2c\x3e\x9a\x71\x7c\x29\x12\x64\x57\x64\xac\x13\x22\xf7\x37\xdd\xdf\x96\x10\x79\x80\x16\x84\x83\xa8\xa6\xe6\x2d\x08\x6f\x8e\xfb\xe1\x46\xd2\x16\xfb\xc3\x2d\x68\x87\xff\x61\xff\xaf\xc3\xff\xe8\xf0\x3f\x1a\x66\xdd\x05\xb3\x76\xf8\x1f\xa8\x0b\xd7\xec\xc2\x35\x0f\x39\x5c\xb3\xc5\x36\x76\xf8\x1f\x2d\xc5\xb9\x17\xc2\x00\x71\x32\xd7\x46\x38\x20\x3f\x2d\x2b\x1a\x07\x2b\xa5\xb9\xb1\xfe\x76\x70\x40\x6a\xa7\x7d\x10\x2a\xc9\x2b\xe2\x80\xd4\xd1\x75\x6b\x05\xe4\x7d\xe0\x81\xb8\xd1\x76\x89\x8b\x5d\x88\xf5\xe1\x87\x58\x1f\x5c\xe2\xe2\xc1\x48\xb2\x9d\xba\xd7\xe5\x2e\x76\xb9\x8b\x9d\x32\xdc\x29\xc3\x7b\x5f\xc6\x43\x52\x86\xdf\x58\xc2\x7e\x41\x5c\x90\xdd\x64\xed\x4e\xd4\x36\xef\x75\xa2\x76\x27\x6a\x7f\xa1\xa2\xf6\x61\xac\x70\x27\x67\x77\x72\x76\x27\x67\x77\x72\x76\x27\x67\xef\x7d\x19\x3b\x39\xfb\xd5\x70\x42\xea\x84\xed\x96\xf9\x36\xef\x49\xd2\xee\xa4\xec\x4e\xca\x3e\x6c\x29\xfb\x60\x26\xd4\x61\x86\x74\x98\x21\x1d\x66\x48\x87\x19\xb2\x95\x7c\xf3\x6f\xf6\x58\x7e\x08\x6e\x62\x7f\x65\x7f\xf8\x2e\xe1\x93\xfb\x45\x46\xf4\x7f\xcf\x69\x4a\x98\x04\x69\x94\xaa\x45\x28\xcf\x34\xac\xfc\xf2\x9a\x7f\xb8\x1b\x5e\x7d\xba\x08\xb3\x69\x3e\x5c\x3e\x5c\xdc\x0f\x6f\xfa\xb7\x7e\x5d\xfc\xac\xc2\xb5\xb0\xdf\x95\x44\x32\x4b\xf2\xb7\x44\xeb\x9e\x70\x6a\xee\x14\x56\xb9\xdc\x6e\x64\xb7\x83\xbb\xc1\xed\x8f\x90\x0d\x34\x3e\x1f\xde\xf5\xbf\xbb\x28\x11\x44\xe9\x79\xff\xec\xaf\x0f\xc3\xdb\xe6\xe7\x83\xff\x1e\xde\xdd\xdf\x35\x3d\xbd\x1d\x5c\x0c\xfa\x77\xcd\x5f\x7f\xec\x0f\x2f\x1e\x6e\x07\x2b\xd7\x63\xe5\x68\x57\x2b\x21\x12\x16\x09\xe2\xfc\x51\x64\xb9\x86\x28\xd6\x10\x79\xf1\xd1\xb1\xc3\xba\xbe\x4e\xd1\x83\xd5\xe9\xa9\x6d\xdc\x30\xd8\xa0\x21\xa3\x8c\xc4\x54\xe2\x49\x42\xe2\xa5\x96\xdc\x1a\x36\xb5\x84\x4b\x83\x7a\xd6\xda\xb3\x17\x39\x35\xcf\x8b\x0c\x2f\x40\x90\xa3\xa8\x08\x8b\x6b\xfa\x30\xfb\xd0\xd8\x03\xd3\xbc\x8b\x3e\x91\x52\x4f\x51\x2e\x04\x61\x2a\x59\x20\xf2\x99\x4a\x25\x97\x1a\x75\xdb\xd7\xd4\xac\xbd\x53\x7d\x83\x73\x2c\xd1\x84\x10\x56\x1e\xbf\x20\x09\xc1\xb2\x66\xcc\x76\xf7\xdb\x2d\x8b\xdf\x2b\x6b\x8d\x31\x97\xd1\x14\xd3\x24\x17\xa4\x72\x5a\x78\x9a\x61\x41\x25\x67\x83\xcf\xfa\x2e\xd3\x07\xf9\x1a\x3e\xe7\x62\xbb\x13\x33\xf8\x6b\x48\xc1\x57\xe5\x7f\x7e\xba\x2f\xff\xab\x74\xe6\x2f\xee\xcb\xff\x5a\x4d\xeb\x41\xc3\x55\xca\x3e\x42\x9f\xee\x4f\xd1\x27\x08\x71\x12\xe8\x7e\x8e\x0d\xc5\x5e\xdc\x9f\xa2\x0b\x22\x25\xfc\x52\x7c\xac\xa8\x4a\x60\x6e\xdf\x51\x86\xc5\x02\xb9\xe9\x9b\x44\x57\x1c\xcd\x11\xf1\x4b\x53\x5d\x3c\xf6\xf7\x9c\x81\xea\x5e\xac\xde\x05\x9f\xd1\x08\x27\xbb\x2d\x62\xff\xaa\xc4\x07\xae\x6f\x57\x2e\x45\xf8\xf6\xf2\x5a\xf4\xaf\xce\x21\x89\xd4\x0d\xb5\x66\xe6\x57\x44\x6a\x22\x89\x38\x8b\xad\x97\x46\xdf\xfe\x8b\x40\xa8\xff\x3b\x87\x44\xdc\x5c\x52\x36\xd3\x2d\xa2\x13\x74\x7d\x3b\x62\xd7\x22\x36\x86\x50\xa2\xa5\x61\x43\x73\x54\x22\xc6\x15\xa2\x69\xc6\x85\xc2\x4c\x69\x45\x00\xc4\x00\xbb\x22\x86\x03\x9c\xf1\x34\xcd\x15\xd6\x07\x6d\x69\x51\x99\x31\x87\xdc\x11\x35\x8c\xc1\xb5\x52\xb3\x86\x46\x4e\x28\xe6\x92\x09\xdd\xbe\x96\x51\xca\x3a\x34\x8d\x97\x54\x59\xd7\x04\x16\x02\x97\xa5\x89\x0f\x54\x91\xb4\xfa\x7e\xcb\x20\xcf\x7f\xd5\x1a\x08\xce\x4c\x52\x05\x11\x7d\x11\xcd\xa9\x22\x91\xd2\x47\x70\x2b\x9a\x78\xb8\xfa\xe1\xea\xfa\xa7\x50\x82\xf8\xd0\xbf\x3c\xff\xf3\x7f\x94\x7e\xb8\xbd\x5c\xfa\x61\xfc\xe3\x9f\x97\x7e\xf9\xff\xad\xa4\xa7\x6a\x4f\x4b\x7a\x7e\x30\x97\x23\x10\xa9\xc1\x26\xec\xa6\x8a\x68\x8a\x67\x04\xc9\x3c\xd3\x14\x20\x8f\xcb\xfb\xab\x45\xca\x0b\x8e\x63\xca\x66\x26\x03\xf4\x82\x2a\x22\x70\x72\x89\xb3\x8f\xce\x7e\xbd\xc5\xea\xfc\xdf\xbb\x52\xbe\xee\x87\x9f\xfb\x97\x61\xc6\xef\x87\x9b\xdb\xeb\xfb\xeb\x95\xb3\x2e\xb5\xb0\x7c\x8c\xf4\xe3\x53\xf8\x5f\x74\x82\x74\xeb\x5e\xf2\x4d\x89\xc2\x5a\x23\x40\x5f\x9b\xa4\x39\x9f\x48\x43\x59\x02\xa7\x26\x13\x34\xa5\x70\xa5\x18\x0b\xde\x37\x46\xb8\xf6\xda\x83\x3f\x37\xe6\x03\xd0\x96\xdd\xa5\xcc\x62\x2c\x62\xf4\x77\x59\x4d\x1f\x07\xc3\xb1\xf9\x81\xc4\xe8\x08\xcd\x95\xca\xe4\xe9\xc9\xc9\xf3\xf3\xf3\xb1\x7e\xfb\x98\x8b\xd9\x89\xfe\xe3\x88\xb0\xe3\xb9\x4a\x13\x93\x2e\xaf\x57\xe1\x14\xdd\x08\xae\xaf\x10\x50\xd0\x89\xa0\x38\xa1\xbf\x92\x18\x4d\x0c\xff\xe3\x53\xf4\x4b\xc4\x05\x39\x2e\x36\xc6\x1a\x95\xec\x3d\x62\x0d\x4f\x27\xfa\xa5\x1a\x66\x52\xdd\x4f\x14\x93\x88\xc6\x56\xcc\x20\x2c\xe2\x60\x79\x34\xbe\x0a\xdd\x9e\xcb\x34\xd4\x1a\x4d\x96\xab\x62\x39\x03\x65\x05\xc7\x24\xc8\x76\x57\xbc\x4c\x70\x5a\xf1\x19\x1a\xb5\x35\xd7\x2a\xba\xbe\x5b\x31\xdc\xaa\xee\xd5\x4c\x4f\x38\xe2\x09\x9a\xe4\xd3\x29\x11\xa1\x43\xba\xa7\xb5\x19\x2a\x91\x20\x11\x4f\x53\x90\x18\xf4\x57\xb9\x34\x54\x0d\x2b\x66\x47\x7b\x3c\x62\xb0\xff\x5a\xcd\x01\x0a\x88\x39\xb0\x3a\x46\x48\x8c\x30\x5b\x98\x6e\x26\xf9\x34\x6c\xdf\xc0\x50\xe0\x18\x51\x35\x62\xfd\x24\x41\x82\xa4\x5c\x91\x20\x87\x12\x9c\x67\xe5\x05\x07\x16\x29\x48\x96\xe0\x88\xc4\x86\x1e\x12\x1e\xe1\x04\x4d\x69\x42\xe4\x42\x2a\x92\x86\x0d\x7c\x0d\xb6\x1a\xbd\x66\x54\xa2\x98\x3f\xb3\x84\x63\x3b\x8f\xea\x67\xdf\x94\x4f\xe3\xc0\x41\x04\x0c\x84\xe0\x02\xfe\xe7\x07\xca\xe2\xbd\x71\xa8\x87\xbb\xc1\x6d\xf8\xef\xbb\x9f\xef\xee\x07\x97\x9b\x71\x1f\x4f\x59\x30\x3c\xd0\xe1\x4f\xd1\x9d\x59\x04\x2e\xb4\x44\x24\x1a\x26\x75\x69\x49\xa9\xf8\x81\xc7\x5b\x72\xdf\xcb\xfe\xd5\x43\xbf\xc4\x51\xee\xce\xbe\x1f\x9c\x3f\x54\xf4\x01\x3b\xbf\x92\x0c\x6f\xd4\xbf\xf0\xb7\xb3\xef\x87\x17\xe7\xe3\x1a\x85\xf1\xc3\xed\xe0\xec\xfa\xc7\xc1\x6d\xa1\xdb\xd5\x2e\x51\x65\x30\x55\x66\x75\x6f\x98\xd2\x9c\xc7\x68\xb2\xa8\x07\x84\xd0\x92\x73\x02\xbe\xd8\x02\x12\xc5\xb4\x7a\x0a\xbc\xc9\x61\x73\x14\x5f\xa4\x3c\x26\x3d\xfb\x0e\x20\x69\x18\xe3\x8a\x91\x98\xeb\x1b\xd6\xbd\x63\x16\x18\x2a\x0c\xc8\x85\x5f\xb8\x53\xd4\x47\x52\xbf\x98\xeb\x43\x2d\xe8\x6c\x06\x86\xc3\xca\x50\x4d\x6b\xf6\x53\x58\x5e\xf8\xce\xec\x7f\x26\x38\x9c\x73\xdd\xad\xb5\x38\x7b\xab\x84\xf9\x10\x50\x57\xca\x2d\x0a\x0c\x06\x87\x9a\xa1\xb9\xcd\xd2\x8b\xd0\xb8\x5e\xe6\x3c\x1a\x7b\x91\x3e\x5c\xc0\xb6\xa4\xb1\x77\x66\x82\x3c\x51\x9e\x07\x9f\x5a\x60\x8f\xd2\x8e\xd7\x36\x5f\x2c\x00\x2c\x9b\x31\x8a\x54\x9a\xf1\xe4\x51\xdb\x82\x66\x61\x4f\xd0\xc2\x54\xf0\xb4\xa6\x8d\xf2\x31\x19\x5e\xdf\x29\x81\x15\x99\x2d\xce\x2d\xcb\xd8\xfe\x78\x9c\x5f\xff\x74\x75\x71\xdd\x3f\x1f\x0f\xfa\x9f\xca\x27\xde\x3f\xb9\xbb\xbf\x1d\xf4\x2f\xcb\x8f\xc6\x57\xd7\xf7\x63\xf7\xc6\x4a\x92\x6f\xe8\x60\xf9\x9e\x2e\xbf\x78\x8a\x34\xcb\x05\xd6\xe8\x00\xef\x02\xfe\x38\x21\x53\x2e\x0c\x9f\x4f\x5d\xe8\x82\x15\x61\xdc\xda\x5a\x5d\xac\x32\x8b\x53\xb0\x8c\xd5\x35\x69\xac\xde\x4a\x10\x9c\xc2\x3d\x81\x19\x1a\xb0\xf8\xe8\x7a\x7a\x74\x67\x7e\x4c\xb1\x78\x24\xc2\x7f\xfa\x2c\xa8\x52\x84\x95\x54\x3a\xec\x86\xec\x95\xc4\xa2\x83\x63\x74\xab\xf9\xbe\x7e\xdf\x5f\x6a\x9a\xd8\x63\xa2\x30\x4d\xa4\x1d\x6c\x69\x5d\x4f\xd1\x05\x16\xb3\xc2\x0e\xf7\x35\x9f\x4e\x4d\x63\xdf\x98\x61\xe8\x3b\xac\x34\x8b\x1a\xde\xab\x49\xc3\xdd\x8b\xd0\x9f\x7d\xd9\xcb\xc3\xcb\x54\xf5\x90\xed\x46\x53\x0f\x37\xb0\xe2\x46\x63\x2f\xe9\x86\xf6\x49\x0d\xad\xc1\xc4\xcd\xe3\xd5\x97\x4c\x7d\xdb\xcb\xe4\x54\x7e\xb1\x86\x9c\x4c\x2e\x95\xde\xf9\xa9\xd6\x36\x6b\x68\x89\x7c\xa6\xd6\x60\x10\x8e\xbb\x42\x42\x45\x33\x60\x5e\xc5\x59\x46\xb0\x90\x75\xbb\x5d\x16\x03\x1b\xf6\xde\xf4\x14\xf6\x61\x37\xd9\xf5\xd3\x43\x9c\x81\xc1\xc1\x0b\x11\x15\x8a\x6c\x41\x03\xa6\xad\x25\x0a\xb8\x01\xb4\xa5\x6b\x8b\x6c\x74\x49\xa5\x56\x1a\xcd\x8f\xdf\x59\xc8\xa5\xed\x08\xe2\x63\x7f\x78\x51\x11\x2e\xc6\xe7\x83\x8f\xfd\x87\x8b\xd5\x66\xc2\xd2\x77\xd5\x2d\x46\x47\x48\x3f\x2f\xfb\xcd\xe9\xd4\xdc\x19\x0e\x38\xca\xa8\xb4\x84\x81\xd1\xca\x42\xd5\x18\x7b\x75\x4c\xb2\x84\x2f\x52\xc2\xc0\xc4\x53\xba\x09\xf5\x7a\x4e\x31\xb5\x57\x4b\x30\x58\xb0\xe2\x58\xb3\x1b\x5c\x63\x47\x0e\xad\x8a\xc4\xfe\xe6\x2d\x83\x55\x55\x58\xf7\x8d\xf1\x9e\xd9\xff\xdc\x29\xac\xb6\x3c\x63\xfd\xb3\xfb\xe1\x8f\x83\xb2\x7e\x78\xf6\xfd\xf0\xc7\x3a\xa9\x66\xfc\x69\x70\x35\xb8\xed\xdf\xaf\x11\x4e\x2a\x4d\xd6\x09\x27\x52\x0f\xb8\xea\x3d\xa5\xd2\x47\x04\x45\x06\xf2\x0a\x51\x25\xd1\x13\x95\x74\x42\x01\x20\xcc\x7a\x22\x1f\x86\xc0\x59\x9f\x70\x42\x63\xaa\x16\x4e\x7c\x31\xfd\x96\xf7\x51\x73\x52\xdb\xbe\x31\x3b\x84\xfe\x49\xb0\xf2\x99\xcd\x71\x93\x3e\x45\xa0\xdb\x3e\x81\xd2\x16\x7c\xc6\xb4\x20\xcd\x66\x44\x98\xe1\x80\xf7\x25\x1c\x4b\xf0\x5c\x8f\x2a\x14\x56\x8a\x55\xf3\x42\xeb\x8c\x30\x22\x00\x04\xce\x77\x62\x04\x29\x41\xd8\x57\x5a\xe6\xca\x12\x1a\x51\x95\x2c\x50\x04\x36\x2c\x30\x67\xa6\x98\xe1\x99\x15\x0e\x40\xcd\xa9\x90\xc4\x5f\x0d\x8a\xda\xf5\xd4\x9a\xf6\xef\x29\xd9\xf2\x98\x3d\x5c\x9d\x0f\x3e\x0e\xaf\xca\x24\xf0\xfd\xf0\x53\x49\x84\xbd\x1c\x9c\x0f\x1f\x4a\xb7\xb9\x96\x64\x57\xcb\xf5\xd5\x66\x6b\x8e\xa2\x7f\xe9\x14\x9d\x9b\x4f\x4f\xf5\xe2\xd6\x40\xc4\x79\xe5\xb7\xb2\x0e\xb7\x2e\x24\xcf\xfd\x31\x60\x4a\xd4\xfa\x25\xda\x9a\x90\xac\x0f\xb2\x64\x43\xaa\x0f\x55\x58\xea\xfb\xaa\xea\x54\xae\x4e\xd9\xbd\x08\x41\x97\xc7\x85\x65\x29\x8c\x61\x00\xa3\x41\x93\x11\xab\xc6\xad\x55\x30\xec\x1f\xc1\x45\x9d\xe6\x52\x19\x57\x22\x10\x27\x7a\xfc\x8b\xd4\x0b\x0a\xae\xc6\x63\x74\x47\xc8\x88\x39\xeb\xc1\x8c\xaa\x79\x3e\x39\x8e\x78\x7a\x52\xe0\x13\x9e\xe0\x8c\xa6\x58\x4b\xd2\x44\x2c\x4e\x26\x09\x9f\x9c\xa4\x58\x2a\x22\x4e\xb2\xc7\x19\x44\xc0\x38\x77\xea\x89\x6f\x76\xc6\xff\xfd\xe2\x4f\xdf\x1e\x5d\xfc\xe5\xdb\x0f\xcb\x16\xb2\xa6\xfd\x1f\xb0\x08\x67\x32\x4f\x6c\xc4\x9c\x08\xd7\xc6\x1d\xf9\x9c\xac\xdb\xef\xab\xf2\x76\xed\xa6\xbf\x9e\xdd\x3c\x94\x2c\xd6\xe5\x7f\x5e\x0e\x2e\xaf\x6f\x7f\x2e\x71\xca\xfb\xeb\xdb\xfe\xa7\x12\x43\x1d\xdc\x7c\x3f\xb8\x1c\xdc\xf6\x2f\xc6\xee\xe1\x2e\xb6\xb7\x1f\x18\x7f\x66\xe5\xa5\x91\x8e\x03\x2e\xf5\x74\x8a\x3e\x72\x81\x7e\xf0\x3b\x79\x34\xc1\x12\xae\x18\x77\x67\xc9\x1e\xca\x78\x0c\x8c\x17\x91\x6c\x4e\x52\x22\x70\x62\x6d\x06\x52\x71\x81\x67\xe6\xa6\x97\x91\xc0\x2a\x9a\x23\x99\xe1\x88\xf4\x50\x04\xd4\x30\xeb\xc1\xa6\x80\xaa\xc5\x67\x55\x3b\xdf\x6d\xce\x14\x4d\x89\x53\xc1\xed\x3f\xef\xcd\x66\x6c\xb1\x39\xd7\xf7\xdf\x97\x85\xbd\x8f\x17\x3f\xdf\x0f\xc6\x77\xe7\x3f\xac\x5c\x4f\xf3\x59\x69\x64\x77\x10\x80\x74\xc6\x93\x3c\x65\xe1\xdf\xdb\x8f\x6d\x78\x75\x3f\xf8\x54\x1d\xdd\x75\xff\xbe\x4c\x19\xb7\xe5\x00\xb7\x0f\xdf\x5d\x5f\x5f\x0c\x4a\x2e\xe1\x0f\xe7\xfd\xfb\xc1\xfd\xf0\xb2\x44\x3f\xe7\x0f\xb7\x06\x8d\x70\xd5\x34\xdd\x08\x6a\x26\xaa\xa7\x15\x4e\x73\xdf\xac\xb0\x15\x27\xea\xdb\x80\x72\x73\x96\x8f\x02\xb8\x1d\x13\x0e\x06\x56\x9d\x23\x6f\x52\x8d\xcc\x48\x6b\xd9\xa1\x2a\x6f\x13\x6a\x66\xc7\x2b\x37\x7a\x15\x57\xbe\xf7\x43\x30\x50\xa0\x46\xd9\xc6\x49\xc2\x9f\x4d\x28\x6f\x4a\xf5\xad\x6c\x81\xd1\xf4\x2b\xb2\xf0\x10\x1e\xd7\x70\xbc\xf2\xb6\x90\x48\x10\x75\xc9\x73\xa6\xb6\x27\xb9\xfe\x55\x89\xef\x0c\xae\x7e\x1c\xff\xd8\x2f\x53\xe0\xf0\x62\x35\xab\x09\x9b\xa8\xb9\x8a\xfb\x57\x3f\xfb\x4b\x18\x02\xbe\x7b\x5e\x43\x35\xb2\x6b\x94\x50\x2d\xf6\x46\x58\x6b\xaf\x09\x48\x34\x88\x50\x30\x39\xa4\x7a\x72\x10\x60\x9a\x19\x7f\x92\xe1\x4f\x66\x90\xa7\xee\x8f\x4a\x7b\x12\xd6\x05\xac\xa9\x2e\x9e\x1e\xda\xb1\x5a\x35\x43\x84\x3d\x51\xc1\x01\xcf\x16\x3d\x61\x41\xb5\x34\x6e\x5a\xd6\x73\x3d\x85\xff\xdd\xac\x4d\x30\x8c\x56\x18\xd7\x1d\x17\xea\xdc\x07\xf2\x6e\x67\x0d\xa9\x0b\x68\x5d\x0e\x65\xad\x37\x74\x2c\x7f\x5b\xb3\x39\x3b\x06\xfc\x96\x27\xfc\x8f\xe4\x9c\xe2\x44\x33\x80\xfd\xc9\x8b\xfd\xab\xbb\x61\x59\x7e\x2c\xab\x19\x01\x5f\xde\x5a\x5e\x04\x43\xa5\x19\xb9\x53\x26\xee\xfe\x7a\x61\xb4\x0b\x00\x3d\x36\xe7\x36\x50\x2c\x40\x00\x72\x28\x28\x19\x16\xb2\xf2\x85\x44\x00\x84\x56\x04\x5c\xe9\x3b\x0b\xc2\x99\x9e\x38\x8d\x47\x8c\x7c\xce\x08\x93\x10\x1c\x60\xee\xb3\xc2\xd7\x2e\x8f\xd1\x70\x0a\x2c\x41\xbf\xce\x50\xce\xac\x03\x4c\x5f\xb8\x66\x90\x3d\x2d\xca\xda\x21\x78\x0d\x11\x0c\x2f\x8c\xb8\x60\xa9\x62\xf0\x23\xf6\x93\x77\xa2\xc1\xa3\x29\xd7\x0c\x48\xef\xa2\x6d\xef\x14\x61\x26\x69\x0f\x69\x85\xa5\xba\xa7\x90\x3a\xa0\x15\x4a\x1b\xc2\xa5\x39\x8d\xfd\xf3\xf5\xaf\x81\xa5\x38\xe1\xf0\x32\xa8\xbf\x0b\x2a\x57\x41\x83\x68\x9c\x18\x8f\xc9\xb8\xfd\x9d\x10\x71\x41\xac\x9f\x65\xe3\x6b\x60\x1d\x63\xbf\xc7\xf2\x71\xc9\xf7\x30\x64\x52\x61\x16\x91\xb3\x04\xcb\x2d\x83\x90\x9c\x8d\xa3\x57\x96\x38\x6e\x6f\x1f\x6e\xee\x87\xdf\xad\xe1\xf2\xd5\x8f\x97\xc3\x80\xa2\x24\x77\xee\xb9\x89\xe0\x38\x46\x9a\x7d\xce\xb8\x71\x05\x5a\xc1\xbf\x80\xfe\x36\x79\x3d\x3e\xa0\xb2\x04\x3b\x5e\xa4\x23\x58\x3b\x47\xe8\x4a\xa0\x76\x21\x50\xa4\x57\x02\x05\x26\x0f\xb7\xd5\xe0\x59\x34\x05\x49\xac\x75\x2b\x4b\xb0\x9a\x72\x91\x1a\x2e\x5f\x9a\xb4\x69\x7c\x75\xa3\x94\x29\x22\x44\x9e\x29\xea\xb0\xdc\xab\x52\x2a\x54\x78\xe7\xb3\x4b\x22\x25\x9e\x91\x5d\x1c\xd0\x75\xca\xc3\xdd\x8f\xe1\x3f\xc1\xc1\xdc\x46\xf6\x2f\x8d\xd0\x45\xbe\x3b\x7a\xba\x66\x1f\x4d\x20\xcf\x0d\x4f\x68\xb4\x65\xc0\xdd\xc7\xfe\xf0\x62\x3c\xbc\xd4\x4a\x7c\xff\x7e\x70\x51\x12\x25\xe0\x59\xff\xe3\xfd\xe0\xd6\x82\x58\xf7\xbf\xbb\x18\x8c\xaf\xae\xcf\x07\x77\xe3\xb3\xeb\xcb\x9b\x8b\xc1\x9a\xc8\x9c\xc6\xc6\x97\xad\xab\xd5\x57\x4f\x97\x7e\x81\x1d\xd6\xbc\x2c\xb4\x97\x41\xd6\x18\xa6\x09\x38\xc1\xb9\x71\x86\x63\xc4\x78\x4c\xe0\x67\xe9\xac\x33\x1e\x39\x1a\x0d\xd5\x57\x49\x82\x70\xae\x78\x8a\xc1\x6b\x93\x2c\x46\x0c\x4f\x34\x6b\xc5\x49\x12\x84\x77\x89\x9c\x31\xcd\x62\x75\x63\x06\xa2\x3d\x4a\x88\x66\xe7\x59\x90\xec\x67\xfd\x06\x53\xca\x20\xd2\x36\xc5\xe2\xd1\xb8\x99\x8a\x2e\x8b\x43\x21\x11\x96\x23\xa6\xc7\x45\xac\x61\xa8\xcd\x0a\x9f\xb6\x7a\xab\x71\x75\x52\xfc\x48\xf4\xaa\xa4\x79\x34\x47\x99\xe0\x33\x41\xa4\xb4\xb6\xe5\x08\x33\x13\x80\x60\x5f\xd7\xd7\xd0\x88\x31\xae\x97\xc2\x99\xb0\x63\x92\x11\x16\x13\x16\x51\x93\xd6\x07\xbe\x7b\x6f\xda\x9c\x09\x9c\xcd\x91\xe4\xe0\xf4\x86\x65\x07\xfb\x95\xf9\xc8\xdd\x64\x66\xc6\xe6\x71\x68\x81\x16\xb9\xe6\x13\xd7\x20\x27\x9a\x55\x86\x8f\xdd\x65\xe8\xdc\x2e\xc6\x0e\x98\x66\x09\x51\x06\xac\x1f\x96\x1c\x36\x43\xaf\x75\x69\x3f\xf4\x36\xd5\x6d\x82\xbe\xb0\xdd\x98\xb1\xb4\x23\x3a\xae\xb1\x6c\xdb\x23\x85\xbe\xc7\x2c\x4e\x74\x2b\xce\x87\x51\x3e\x8b\x90\x8a\xd2\xd7\x54\xe3\x4e\xe3\x2e\xb7\x68\x84\x73\xb9\xcb\x35\x5a\xc9\xc5\x34\x56\xc1\xa3\x22\x28\x04\xc8\xdb\x26\x62\xc2\xea\x66\x9a\x45\xe2\x84\xdb\x55\x32\xaf\xe7\xa6\xfe\x13\x82\xd1\x34\x5c\xb3\x99\xa0\x2c\xa2\x19\x4e\xb6\xd2\xfd\x2a\xc1\xf8\x36\xc6\xfd\x6b\x3a\xd5\xe4\xf3\xcd\x92\xdb\x56\x11\x91\x42\x82\xb2\x1d\xa6\xdf\xc2\x0d\x2c\x49\x36\xab\x81\xc8\x22\x9a\x04\x0b\x9e\x1b\x7f\x1c\xac\x0b\x89\x6b\x8e\xea\x71\xdd\x76\xeb\x93\x81\xcb\x01\xd0\x5b\x6c\xb6\x89\xfc\x69\x5a\xbf\x4a\x2b\xb6\x77\x13\x8c\x87\x93\x9b\xfa\x36\xeb\x76\x20\x78\xf8\xaf\x55\xb4\x73\x89\x33\x4d\x33\x16\xb6\x1f\x17\x73\xb4\x4a\x92\xad\x0a\xe6\xe2\x67\x02\xdf\xb9\xcf\x0b\x69\xbf\x1b\xc5\x12\xda\x00\xa8\xe5\x4e\x4a\x31\x04\x41\x8e\xb9\xa5\xf1\x69\xae\x65\x59\x84\x21\x0a\x01\x7d\x4d\x8e\x67\xc7\xc8\x15\x61\xe8\xa1\xfe\xcd\xcd\xe0\xea\xbc\x87\x88\x8a\xbe\x71\x31\x8b\x36\x60\x69\xc4\x14\xb7\xd2\xca\xc2\x15\xd0\x48\x89\x98\x91\xd2\x9c\x5d\x74\x13\x84\x2a\xcf\xa8\x54\x36\x7c\x56\xf3\x95\xa0\xd4\x09\x4d\xab\x62\xb6\xa1\x90\x5c\xcd\x77\x21\x0d\x2c\x65\x9e\x6a\x5d\x76\x4c\x71\x3a\x16\x3c\xd9\x85\x29\x9c\xc3\x54\x40\x5d\xf6\xe9\xf9\x14\xa7\x48\x37\x6b\x43\x41\xbc\xcb\xd1\x8b\x74\x5a\x30\xd2\x7c\x59\xdf\x9b\xc1\xbd\xe5\xbc\x0f\x36\x1e\x8d\xba\x10\x08\x48\xdf\x6f\x60\x15\x85\xd9\x78\x6c\x2d\xf5\x63\x1c\x45\x5a\xe5\xde\xf3\xa4\x82\xfa\x39\xce\x25\x60\x3b\x7a\xb1\x69\xae\xa3\x73\x37\xcc\x4c\x73\x30\x08\x06\xd6\x57\xae\xe4\x11\x2d\xda\xaf\xe9\x77\xb2\x58\xea\xd5\x55\xb8\x79\x90\xde\xa4\x62\x2e\x61\x49\x60\x27\xa5\xa9\x90\xa3\xe6\x64\x81\xe6\xf8\x89\x94\xba\x74\x09\x31\xba\xe1\x05\xcf\x45\x1d\xa3\x1b\xb1\x73\x92\x09\xa2\x25\xfd\xaa\x03\xc5\xd3\xf4\x6d\x99\x12\x3b\xba\xee\xe8\xfa\xdd\xd3\xf5\x99\x29\x94\xd4\xf7\x85\xb1\x76\x12\xe0\x4c\x63\xe3\x8c\xf3\x64\xdc\xc2\x26\xd2\x7e\xc5\x4b\x9e\xb0\x4a\xd9\x28\x80\x04\xe0\x39\xc8\x47\xa5\x6b\x93\xeb\xbb\x2e\x48\xb1\xb5\xc3\x5b\xb1\x0c\xce\x65\x16\xd4\xcb\xd9\xe5\xbc\xd7\xb5\xb2\xaa\x25\xf4\xe2\x62\xce\x99\x91\x6f\xbc\xbb\x2c\xac\x7f\x5a\x3a\x4c\x4e\x14\xa1\x6c\xa9\x1a\x9b\xa1\x67\xbd\xc0\x46\xee\xf8\x47\xce\x15\x96\xdf\x1c\x8f\x98\x16\xa2\x1e\xc9\xc2\x98\x5b\xb5\x98\xf2\x3b\x2d\x8b\x1f\x49\xc2\x24\x84\x7b\xff\xce\xb8\xe7\x34\x89\x3b\x73\xb5\x51\x4d\x4d\x11\x38\x08\xba\xf6\xbd\x40\x88\xae\x6d\xd4\x4a\x49\x45\x00\x34\xc8\xf9\x66\x2e\xf6\x99\x19\xfe\x8c\x28\x48\xb1\x56\x54\x81\xce\x14\x9b\x2a\x73\x4b\x43\x5f\x6b\xba\x32\x54\x21\x38\xf8\x49\xe2\x7c\x37\xc6\x2f\x97\xdb\x58\xcb\x19\xbd\xb6\x70\x67\x63\xde\x4f\x9c\xdd\x28\x12\x7c\xa9\x74\x1b\x96\xc8\xec\xf4\xc4\xb0\x03\xe7\xbf\x26\xec\xf8\x99\x3e\xd2\x8c\xc4\x14\x43\x04\xbc\xfe\xd7\x89\x9e\xd7\xbf\x9f\xdd\x5e\x5f\x8d\x8b\x4c\x9e\xff\x1a\xb1\x7e\x22\xb9\xcf\x52\x40\x8c\x33\x1f\x6e\x9f\x09\xe2\x44\x42\x3b\x17\xb0\xba\x16\x66\xc4\x11\x6b\x1a\x41\xcc\x23\x79\x8c\x9f\xe5\x31\x4e\xf1\xaf\x9c\x81\x2b\xbd\x0f\x7f\x9e\x25\x3c\x8f\x7f\xc2\x2a\x9a\x9f\xc0\xb9\x56\x27\xe4\x89\x30\x65\xdc\x54\x7a\xb9\x62\x48\xde\x95\x10\xad\xff\xef\x7a\xcc\x45\x52\x91\xd4\x9a\x6c\x44\x32\x85\xfe\x1f\x41\x26\x9c\xab\xfa\x4b\x8a\x4f\xa7\x92\x6c\x74\x21\x15\x4a\xda\xdd\x35\xfa\xcb\x9f\xbf\xfd\x83\x26\xa1\x6d\xd6\x78\x78\x77\x3d\xd6\xdf\xff\xfb\xb9\xfd\x5e\x6e\xc0\xee\xae\xb3\x82\xb5\x39\xe2\x31\x81\xf3\x39\x83\xdb\x4f\x80\xf3\x02\xd8\x1b\x90\x43\xb1\x8f\x75\xdc\xed\xbc\xd4\xfa\x6e\x2a\xdb\x56\x8b\x09\x2a\x76\x30\x47\x74\x84\x18\x47\xa9\x89\x35\xc5\x0c\xfd\xc7\x0f\xdf\xd5\x6f\x60\x2e\xe8\x56\x1d\x52\x0b\xd7\x10\x74\x29\xe9\xaf\x44\x22\x4d\x35\x9a\x8a\x79\xaa\xbb\x16\x44\xce\x79\x12\xa3\x67\x02\x6a\x92\x8d\x03\xf5\x5a\xb9\x20\x23\x16\x36\x01\x21\x87\x08\x27\x8a\xcf\x08\xdc\xd5\x4e\x51\x53\x44\x68\x51\xc5\x64\x69\x28\x2e\x48\xcf\x40\x7d\xdd\xfd\xc9\xc5\x56\xc3\x34\xe1\x91\x4b\x6a\xb1\x26\xb9\x78\x52\x3f\xf3\x69\xd5\xf4\x8a\x9a\x6d\xf8\xd5\x4d\xb6\x66\xdb\xfa\xa5\xb1\x49\x28\xd6\x86\x55\xdd\x99\xfa\xc1\xd0\x88\xb3\x71\x42\xd9\xe3\x56\x9b\x71\xed\x44\x39\xdd\x82\x5d\x33\xdd\xa2\xb7\x73\x1b\x0b\xc8\x06\xe7\xe3\x63\x9e\x24\x26\xb5\x25\xdc\x1e\x90\xbb\xcc\xba\x81\x30\x90\x99\x1c\x50\x12\x5b\xbf\x97\xd5\x84\x05\x61\x10\xf0\x36\x62\x93\x85\xf5\xd9\xca\x1e\x92\x79\x34\x77\x99\x79\x11\x67\x52\x8b\xd1\x5c\xa0\x88\xa7\xa9\x29\x6e\xca\x08\x52\x9c\x27\xd2\x46\xbb\xb3\x23\x85\x23\x35\x62\x45\x7f\x6b\x4e\x9e\xa9\x80\xb4\x5b\xea\x5e\x7b\x97\x4e\x51\x69\x69\xa5\xc0\x4d\xe3\x10\xb3\x01\x8c\x60\xc6\x13\x15\xa0\x3f\xf0\xe5\xb3\x64\x36\xac\x41\x33\x90\x73\x2e\xd4\x38\xae\xe5\x39\x6b\x89\xa6\xca\x08\x19\x39\x4a\x20\x68\x98\x3f\x69\xe1\x9f\x3c\x7b\xe3\xeb\xaa\x21\x68\xaa\x5e\x35\x82\x76\xc7\x68\xe5\xc8\x36\x25\xc1\x86\xb5\x32\x08\x1e\x51\x39\x26\x7c\xdd\x18\xef\xe0\xab\x33\xfd\xd1\xca\xc5\xab\x9e\x3b\x27\x04\xf1\xb8\x00\x9b\x33\xf7\xba\xcd\x08\x59\xb5\xa6\x16\x3a\xe1\xe5\x32\x47\x57\x4d\xe5\xa1\x6c\xc9\xd5\x63\x01\x93\xbd\x24\x20\x6b\x62\x31\xa1\x4a\x60\x51\x42\x0a\xf1\xfa\xa0\x24\x58\x40\x7c\xd6\x88\x19\xdc\x38\xa3\x29\xc4\x28\xa6\x12\x12\x44\xe0\x2e\x0d\x9c\x61\xa8\x9d\x12\x58\x39\xda\x45\x9e\xa3\x89\x3f\x87\xc0\xb2\x82\x34\x1c\xb3\xd3\x1d\x79\x7c\x2c\xad\x9f\xf1\x28\x2f\x04\xb9\x08\x24\x5c\x8b\xa9\x83\x28\x93\x74\x36\x57\x88\x32\x6b\x77\xc4\xc9\x8c\x0b\xaa\xe6\xa9\xec\xa1\x49\x2e\xb5\x16\x6a\x82\xd5\x4c\x3c\x0a\x51\x51\x2b\x2e\xb4\x6b\x12\x71\x5c\x69\x70\x59\x45\xd9\x82\x34\xda\x1d\xca\x41\xe5\xae\x58\x43\x38\x7d\x8f\x33\x58\x6d\x83\x42\xdd\x46\x03\x4f\x89\x4c\x1c\x20\x77\xc8\x4e\x50\x05\xa4\xe9\x1c\x00\x2a\xe4\xde\xbc\x14\xaf\x51\x88\x0b\x99\x64\x50\x41\x5c\xec\x36\x48\x5e\x65\x64\x4a\x83\xde\xe4\x9d\x4e\x69\xa6\x6a\x03\xb7\x96\x5d\x45\xb7\x01\xe6\x4f\xbb\xc5\x86\x64\x2c\xa0\x66\x40\x6a\x1b\xb1\x3b\x42\x9a\x81\xdc\x96\xf6\xde\x94\xc6\x85\x29\xd8\x44\x8f\xd5\x24\xbf\x8b\x13\xfb\x7c\x70\x77\x76\x3b\xbc\x31\x90\x13\xd7\xb7\x97\xfd\xfb\x71\x8d\x5f\xbb\xe6\xad\xcb\xfe\xed\x0f\xe7\xeb\x5f\xfb\xfe\xbe\x9c\x95\x5d\xf3\xca\xed\xdd\xea\x64\x8e\x16\x43\xac\x49\x0a\xab\xed\xe7\x14\x65\x0b\x35\xe7\xcc\x87\x28\xc4\x25\xde\x74\x84\x4c\x46\xb0\x82\x10\x22\x21\x55\x8d\xe3\xf0\x1e\xe2\x72\xd6\x4b\x98\xe5\xcd\x32\x30\x6c\x7b\x15\x8d\x36\x38\x91\x9f\x12\x3e\x01\xbf\x75\x5e\x2a\x71\xbb\x22\x02\x7d\xc7\x78\x9f\x73\x2a\xb3\x04\x2f\x96\x7a\x58\x77\xe5\x5c\xe1\x94\x40\xc4\x71\x81\x1f\xe7\x92\x45\xf4\xce\x40\x02\x93\xbf\xd7\xe9\x14\x32\x99\x14\xc5\x8a\xa0\x09\x51\xcf\x90\x37\xe7\x7e\xf5\xb6\x54\x17\x30\x22\x8f\x47\x0c\xcc\x39\x23\xbd\xc8\x71\x0e\xd1\x7e\xa3\x0f\x3d\x34\xfa\x10\x93\x27\x92\xf0\x4c\xef\xbc\xfe\xa1\xe1\x92\x19\xa4\x98\x26\x57\x5c\x79\xcb\xdc\x2e\xfb\x29\x48\x44\x33\x90\xcc\xc7\x44\xb7\xfb\x7a\x82\x47\x89\x92\x1d\x3b\x83\x31\x20\x1c\xc7\x5a\xc9\x06\x56\xe6\x86\x57\x84\x00\xb1\x60\xea\xa5\x5a\x99\x9b\x88\x14\xde\xfc\x6d\x7a\x0c\xdb\x2c\x9b\x3d\x6b\x77\x80\x3d\xbd\xa0\x4b\x76\xd7\x8b\x5c\x6b\x25\x3f\x90\x05\xa4\x60\xdc\x60\x2a\xb6\x74\xcd\xd6\xc5\xbc\xbe\x88\x93\x76\x50\xd3\xd1\x01\xb9\x6b\xeb\xd7\x61\x37\xc7\xad\x8f\xd5\x7b\x2d\x2d\xd5\xc5\x72\xf9\x8e\x5b\xaa\xad\x0f\x4d\x4a\x6a\x63\x08\x03\xaa\x2a\x5e\x19\x89\x36\xd0\xb8\xfc\x00\xef\xf4\x77\x6b\x35\x15\x2f\xae\x45\x61\x4d\x7f\xd8\x05\x9b\x1c\x5f\xcd\xc7\x27\x6b\x47\x1c\x25\x5c\x96\xb1\x72\x5a\x0f\xfa\xcc\x7e\xba\x6a\xdc\x83\x90\x7c\xb5\x5c\xb8\x51\x40\x43\xcd\xc2\x57\xc0\x20\xcd\x3d\xa3\xac\x87\xcc\xbe\xdd\x43\x14\xa2\x2d\x41\x21\x4b\x0a\xe4\x00\x16\xa3\xc2\x0d\x32\x62\x45\xcc\x8a\x44\xcf\x24\x81\x30\xb7\x88\xa7\x19\x98\xf8\xed\x70\x6d\x4b\x24\x36\x11\xc3\x3d\xc4\x73\xa5\x1b\x33\x39\x39\xce\x88\x6b\x13\x7e\x0a\xb7\x87\xf1\xbd\xd9\xe0\x77\x0f\x2c\x6d\x68\xdd\xdc\xa5\x94\xa1\x4f\x44\x41\x2b\x00\xdc\x1f\x4e\x10\xf4\x84\x6a\x08\x65\xfd\xda\xef\x70\xa2\xec\x4c\x36\xd8\xf9\x02\x38\xe5\xbb\x84\x4f\x56\x1b\x09\xa0\x71\xf4\x70\x3b\x74\x16\xc9\x22\x7e\x2a\x40\x2f\x2e\x79\x14\x07\x37\xb7\x83\xb3\xfe\xfd\xe0\xfc\x18\x3d\x48\xa2\x97\xc7\x4f\x17\xf2\xab\xbd\x4a\x62\x46\x6e\x91\x58\x98\x54\x04\x37\x19\x42\x88\x10\xa5\x2c\xe8\x35\x8c\xa3\x0c\xd3\xb2\x9a\xb0\x01\x24\x85\x5a\x43\x1d\x00\x0b\x55\xe7\x69\x23\xf3\xd6\x9d\x40\x88\x93\x1a\xbf\x9f\x28\x35\x33\xde\x74\x39\x32\x6f\x1d\xf9\x94\x23\xfa\x5e\x7a\x32\x70\xb4\xd4\x9c\x50\x81\x5a\x4d\xcb\x10\xd5\xb8\xfd\x9c\x82\x10\xf7\x4b\x9c\xad\x4e\x3f\xc5\xcf\x25\xa2\x35\xa2\x70\xe0\xbb\x7f\xe9\x73\xe0\xd8\xda\xd8\xb0\xc2\xdd\x27\x58\x38\xb4\x0c\x6f\xf5\x7c\xd3\x64\x7c\x48\x67\x24\x0b\x27\x56\x19\x84\x8d\x63\x95\x08\xce\x0e\xfc\x42\x19\x2a\x5d\x89\x3d\x34\xa5\x9f\x6d\xa3\x45\x7c\xbb\x7b\x35\x08\x78\x68\x88\xa7\x9c\xe3\xe5\x33\xb5\x81\xd8\x70\x03\xdf\xaf\x14\x22\xb9\xd4\x22\x51\xa4\xc5\x25\x41\x22\x2e\xf4\x4d\x01\xdd\x16\x5e\x88\x75\x22\x83\xc2\x42\x2f\xca\xb2\x57\x66\xd5\xe9\x2f\x6a\x90\xc4\x58\x91\x23\x2d\x7a\xad\x49\x80\xb6\x39\x32\x90\x4d\x83\x55\x00\x07\x56\xdc\x3c\x13\x32\xc3\xcc\x85\x66\x37\x0c\xd7\x5d\x79\x3b\xb0\x2a\xad\x02\x61\x48\x0f\x03\xf9\x0a\x52\x7f\x4a\xe3\x90\x19\xac\xe7\xca\x71\xd8\xe8\x97\x43\x58\xb6\x67\xec\x83\x71\x1a\x06\x9b\x67\xf1\x21\x0d\x36\xc1\x52\x21\x3b\xa6\x26\x53\x44\xa0\x22\xbe\xac\x11\xb6\xa4\xdb\xb7\x55\xde\x34\x09\x95\xb5\x58\x02\x9e\x11\xe9\x70\x53\x0c\x4a\x8c\xd6\x69\x9c\x20\x6c\x4a\x31\xfb\xb3\x6d\x6b\x32\xbb\x5b\x22\x64\x26\x10\xa4\xbf\xdc\xf4\x31\xea\xb3\x25\xbc\x2c\x17\x97\x55\x5a\x2f\x73\x27\xe1\xe4\x19\x2f\x24\xca\x84\x81\x96\x31\x91\xfb\x6e\xf2\xa0\x81\x95\x3f\xf2\xa1\x10\xca\xa5\x4e\x20\xb0\xc5\xac\x0f\x9a\x73\x72\xef\xf8\x05\x5c\x79\x95\xa8\x72\x2f\x90\x17\xcd\x15\xb6\x8a\x16\xac\x4e\x91\x71\x34\xc7\x6c\x46\xc6\xce\xc8\xba\x8d\xb6\xa4\xdb\x39\x83\x66\xce\x6d\x2b\xf5\x97\xd3\x8d\x51\x98\x6c\xfd\x17\xf3\xaa\x37\x20\xea\x43\x20\x15\x9e\x11\x64\x46\xd4\xca\x2c\x5d\x8a\x18\xb3\x60\xc3\xa0\x27\xd8\x56\x07\xe5\x28\xfa\x26\xe1\x1d\x42\x9f\x2e\xf0\x84\x24\x6f\x13\x39\x01\x5d\x5b\xe3\x3c\x78\xeb\x4c\x36\x00\x41\xcf\x60\xcf\xaf\xb0\x0c\x6b\xbd\x17\x79\x5d\x6e\xc0\xaa\x79\x96\xaa\x9f\xef\x30\x51\x57\x2b\x64\x9b\xa9\x36\x55\x10\x09\xaf\xbd\xa0\xd2\x46\x9d\x81\x2d\xbc\xfe\xaa\x36\xe5\xed\x06\x12\x14\xfc\x68\x18\xc7\xce\x15\x3f\xd6\x4e\x65\x6b\x90\x81\x96\x55\xf0\x86\x53\xc4\x38\x23\x88\xca\xe2\x65\x55\x4e\x87\xf2\x10\x3d\x5a\xc4\x37\xc6\x17\x5f\xa5\xcb\x17\x5f\x7a\x69\x4b\x4b\x01\x9e\xe0\x6d\x03\x2e\xbf\x9b\x11\xad\xa8\x62\xb1\x00\x88\x4f\xc3\x87\xcb\x32\xdd\xda\x71\xee\x5d\xe0\xbe\x77\x08\xae\x41\xa4\xae\xe2\x08\xc4\xc8\xca\xe0\x90\xc1\x41\xb5\x2f\xd9\x8f\x2c\x4c\xcd\x88\x79\xcb\x06\x10\x22\x95\x28\xc5\x19\xf8\xf4\x18\x57\xc5\x57\x06\x76\x49\xf9\x2d\xec\x39\x41\x5c\x9a\x1a\x5a\x0d\x2b\xb0\xce\xb4\xe3\xae\xdf\x62\x5d\xcb\xf0\x96\x0e\x9a\x77\x46\x9f\x08\x73\x34\xdd\x73\x67\x42\x0f\xca\x75\x9a\x2c\x8e\x30\x84\x19\x93\x38\xf4\x7c\xac\xe6\x48\xc6\x20\x73\x08\xf6\xc8\xf6\x4b\x76\x5f\x1b\x46\x63\x40\xd2\x4a\xe8\xf6\x2e\x30\x3c\xa4\x52\x8b\xdb\x6b\x32\xc1\xb1\x44\xbf\x63\x5c\xfd\x2e\x40\x36\x76\xc6\x0b\xf8\xd4\x99\xa0\x7a\x4b\x25\x5b\xe0\xd0\x5a\xc2\x41\x38\x40\xd8\x5a\xbb\xf2\xbb\xc6\x06\x14\x81\xef\x2f\x2a\x8d\x0e\x96\xb3\xe0\x9a\x6a\x5e\x75\x1e\x7b\x54\xbd\x16\xaa\x06\x4f\x53\x56\xaf\x38\xe9\x25\x43\xa7\x5c\xe7\xa2\xf7\x7b\xd1\xca\x35\xbf\x84\x08\xb0\x0b\xb5\xa5\xad\x23\xa7\xd6\x80\x20\xd7\xdb\x25\xb6\xc9\xf3\x6c\x92\xcb\x45\x39\x74\xcd\x96\xc1\x68\x40\xf9\x3d\x1e\xb1\x8f\x5c\xd8\x2b\x58\xda\x3a\x03\x13\x1c\x3d\x1e\x11\x16\x23\x9c\xab\xb9\x41\xdb\xb5\x7e\x85\x85\xa5\x06\x2d\x69\x00\xd9\x78\x28\x0d\x2a\x23\x2c\x62\x57\xf1\xe2\x89\xbb\x51\x8c\x58\xd0\x08\x54\x32\x80\x42\x4f\x50\xaa\xb6\x49\xd5\x24\x52\xeb\x57\x4d\x6b\x51\x57\x84\x75\xa9\x04\xeb\xea\x73\x56\x2a\x2a\x0b\x35\x18\x20\xc0\x89\x4f\x97\x57\x67\xe8\xac\x8d\x4e\xbf\xd3\xf4\xbc\xec\x85\xe8\x59\x8d\xc2\x98\xa4\xec\x0c\xb4\xa4\xf3\xad\xe3\xb5\x25\xd4\xe0\x69\x2e\x20\x5c\xb7\xae\xcd\xaf\xa3\x39\x4d\x0a\xdf\xc5\x37\x3d\x3f\x4c\xdd\x64\x42\x9e\x48\x62\x30\xeb\x23\x01\x91\xf9\xc6\x6a\xf8\x2d\xfa\x3f\xa6\x30\x29\xfa\xc3\x88\x7d\x02\x36\x9c\x24\x0b\x40\xd4\xf4\x2d\x63\x55\x69\xe6\xb1\x76\x00\xca\xa6\x02\xa1\xf2\x40\xcc\x5e\xcf\xf1\x13\x19\x31\xd7\xcc\xff\x41\x8f\xe8\xf7\xe8\x0f\x4d\xea\x9d\x0b\xb0\x7f\x61\x3b\xc7\xc7\x20\x7c\x3d\xb8\xe5\x2c\xa3\xb4\xfc\xc6\x99\x41\x4a\x46\xc8\x1a\x64\x0d\x0f\x8c\x4d\xd9\x13\x8f\x96\xb2\x38\xc2\x53\x8b\x05\x61\x6a\xcc\x78\x4c\xc6\xa4\xc6\xa5\xb9\x82\x49\x68\x21\xe0\x8a\xc7\x64\xad\x43\xd2\x33\xd3\x9f\xc0\x74\x23\xf3\x89\xdf\x0e\x48\xf0\xf7\xd9\xdc\xde\xfa\x50\xa6\xb4\xfa\x91\x7b\xf4\xd9\x6d\xc6\xbd\xad\x33\xd5\x85\x89\xf6\xe0\x42\xb0\x03\xa8\x77\xe8\x25\x58\x39\xf7\x7a\xf5\x38\x56\x1d\x01\xfa\x65\x3d\x73\x7b\x59\x05\xb8\xba\x50\xfb\x44\xd0\x19\xd5\xf2\x7b\x7b\x87\x2d\x70\xc2\x6d\xbc\x19\x06\x64\xb4\x95\x3b\xa3\x58\x0a\x07\xb4\x72\xe4\xe9\xaf\x70\x42\x4e\x78\x5e\x15\xe0\xed\x02\x50\x19\xba\xfb\xad\xac\xbe\xd0\x7c\x78\x66\x32\x00\xc9\x9c\x9a\x9c\xfb\xfe\xd9\x05\xd2\xa7\x83\xa7\x06\x98\x0a\x16\x2d\x57\x73\x2e\xe8\xaf\x8d\x19\x4a\xcd\x32\x7a\xe1\x69\x2d\x12\xba\xcc\x38\xcb\xd2\x3a\x10\xab\x11\x29\x54\x49\x2b\xa9\xd3\x99\xd0\x24\x07\x0c\x56\xcd\x66\xa7\x79\x62\x0a\x37\x44\x5c\xc4\xa6\x72\xba\x2c\xa5\x8f\x41\x18\xae\x13\xef\xb1\xf2\x0d\x52\x0b\x55\x69\x4b\x43\x18\x0b\xce\x4a\x01\xf4\xaf\x39\xc9\xf7\x94\x81\xf7\xa6\x31\xcb\xf7\x78\x26\x8b\x20\x64\xb3\x36\x9a\x37\x17\xeb\xfb\x0f\x3d\x53\x19\xe4\xac\x3a\xcb\xa2\x87\x80\x32\x2a\xb9\x29\x0c\xba\x91\x45\xe7\xd6\x40\xdf\xef\xc1\xa4\xf3\x1a\xf1\x1c\xcb\x32\x52\x0d\xfb\xb1\xe4\xf7\xe4\x33\x38\xab\x2c\xe2\x85\xec\x24\xae\x86\x40\x45\xfa\x78\x41\x93\xc9\x16\x4c\x6e\x59\xa8\x5e\x19\x15\x5d\x18\x50\x3c\x5b\xab\x49\xa6\x56\x1c\xd2\x2e\x9e\x05\x05\x84\xb8\x45\xf1\xb2\xaf\x81\xeb\xae\x8b\x90\xc7\x68\x29\xc5\x88\xb5\x10\xd7\xe1\x96\x70\x51\xcf\xe3\x37\x30\x40\xd8\x86\xca\x5d\x2f\xfb\xed\x9b\x4e\x84\x61\x49\x87\x7a\x24\x96\xe1\x61\xd6\x1e\x06\x5f\x09\xe4\x6d\x0c\x88\x5e\xb4\x79\xbd\x93\xe1\xc9\x71\x1c\xe1\x68\xde\x38\xa9\x09\xe7\x09\xc1\xac\x49\x7a\xad\x7d\x5c\x3d\x22\x06\xdc\x14\x58\x77\x92\x00\xc2\xaf\x5b\x02\x5b\x15\xb2\x10\xdf\x59\x0c\xc8\xec\x86\x87\x9b\xd8\x40\x37\x50\x45\x98\xb3\xfc\x50\x36\x4b\x48\x75\xad\x2c\x84\x7e\xcf\x76\x92\x44\x79\x12\x94\x85\xcc\x88\xd0\xa3\xd6\x4b\xfc\x44\x98\xd6\x19\xec\x38\x9c\x33\xe3\xd9\x25\x44\xfb\x62\x50\x3d\xdf\xb5\xf3\xa7\x41\xd6\x61\x3c\x62\x70\x70\x79\xf9\xb0\x6a\x5a\x95\x5a\xcd\x08\xed\x52\x5b\x9f\xce\x40\x88\xd8\xf8\x78\xde\x95\xcd\xc4\x1b\x9f\x49\xd3\xf7\x18\x62\x0c\x76\x76\xad\x05\xee\x97\x02\xaa\xc1\x6c\xac\x83\xe3\x7a\x25\x23\x32\x44\x6d\x94\xc3\x4e\x83\xa0\x8d\x26\x38\xa8\x17\xbd\x4b\x8a\xf2\x17\xee\x36\x68\x39\x94\x95\xae\xea\x96\x8e\x67\xb0\x4e\xae\x3a\xb7\x17\x36\x64\xbb\xec\xb2\xf5\xf9\x3d\x45\x98\xa3\x2d\xf0\xaa\x04\x06\x74\x02\xc8\x29\xff\xc9\x68\xd8\x54\x1a\x0b\x98\x2b\x73\x91\x66\x6a\x61\xab\xa2\xc1\xbd\x18\xe6\xf4\x1a\xc4\xb7\x3a\xf7\x70\xf5\x8e\x8c\x4b\x0e\xe2\xba\xce\xa0\x23\x6b\x56\xa8\x6d\xd2\x2d\x74\x88\x20\x52\x41\x6c\x68\x8a\x06\x31\x05\x66\xc7\x38\x69\xb4\x65\xed\x81\x69\x42\x9a\x6d\x81\xd2\x60\xc1\x5f\x95\xc8\x89\xe6\x5d\x38\x49\x2a\xf3\xc2\x90\x0e\xad\x7c\x91\xb9\x49\x51\x09\xb7\xbd\xb3\x3a\xc1\x13\xb2\x91\x7b\xfa\xc2\x7c\xb0\x92\x8a\xe0\x15\x88\xec\xce\xb2\x64\xd1\x2e\xa2\x3c\x0c\xbd\xab\x05\x49\x5b\x37\xb0\x10\x5a\x6d\xe5\xdd\x54\x86\x27\xdb\x6e\x88\x92\x44\xb9\xa0\x6a\x31\xb6\x46\xbf\xf6\x4c\xeb\xce\x7e\x79\x66\x3f\x6c\xa3\x51\x9f\x22\xd7\x9f\x33\x32\xc2\x3d\x25\xa8\xa9\xa0\x63\xa7\xd0\x66\xbb\xb5\x96\x5c\x0b\x9e\xb4\x6a\x61\x1d\x7a\x53\xbb\xa1\xea\x2e\xb6\x1d\x9e\xad\xcc\x31\xe6\x53\x87\x8b\xd4\x7e\x61\xab\x25\x4b\x36\xb0\x96\x3a\xf8\xe5\x4c\x50\x2e\x6c\x65\x90\x36\x41\x6d\x29\xfe\x3c\xce\xb0\xc0\x49\x42\x12\x2a\xd3\xed\x6d\xbb\x7f\xfa\xe3\xca\xd1\x9e\x99\x0a\x36\xd2\xd6\x83\xfa\x4c\xd3\x3c\x45\x2c\x4f\x27\x56\xca\xc5\xf2\x31\x04\xbf\x74\xa9\xfa\x06\xc3\xc9\x0d\xb0\x04\x18\x20\x02\x38\xd3\x11\x0b\x80\xad\xad\xa9\x02\x47\x73\x4a\x9e\x00\x76\x53\x30\x22\xe5\x31\xba\xe2\x8a\x9c\xa2\x4b\x9c\xdd\x83\xa0\x66\x4a\x4a\xce\x8c\x75\x1c\x4b\xa4\xa5\xd6\x9c\x51\xd5\x1b\x31\x8b\x86\xed\x56\xe5\x24\xe2\xcc\x20\xa2\x46\xb0\xb0\xbe\x09\x30\xf7\x3a\x68\x50\xe5\x12\x1b\xa9\x6c\x58\x6c\x81\x9f\xc7\x41\xf4\xea\xd8\x64\x07\x6c\x40\xc7\xb7\xf8\xd9\xc4\x6b\x9f\x63\x85\x4d\xb5\xd8\x55\x92\xbb\x0d\x88\xb2\x15\x84\x0c\x10\xb0\x0b\x1c\xe1\x16\x8d\xc2\xd7\x3e\x33\xd1\xa9\x5f\xd3\x63\x72\x8c\xbe\x4b\xf8\x44\xf6\x90\xf4\xa0\xd9\xf0\x50\x12\x25\x7b\xc6\x41\x05\xff\x36\xa9\x60\xdf\xb8\xd5\x2f\xf8\x3e\x94\xfd\x9b\xd2\xcf\x06\x04\x43\xfe\xe9\xf4\xe4\x24\x5d\x1c\x4d\xf2\xe8\x91\x28\xfd\x17\xc8\x14\xb5\x2b\xe4\x10\xa4\x70\x1d\x1e\xd5\xba\xd5\x59\xc6\xb2\x6a\x45\x91\x36\xad\x46\x12\xc0\x4d\xd7\x57\xba\x2f\xac\xea\xa0\x8f\x38\xab\xaf\x1a\x69\xa7\x2c\xf2\xa6\xe3\x55\x02\x5c\x7e\x1d\x6d\xc5\x14\x8e\x0d\x71\x9e\xa7\x09\x9e\x55\x54\x96\x0d\x94\x94\xeb\x94\x5a\x2a\xd2\x73\x87\x78\x0b\x7d\xca\xca\x51\x66\x5f\x39\x77\x24\xb8\x15\xad\xbb\xe5\x78\xc4\xfa\x12\x3d\x13\x53\x0f\x16\x72\x12\xc1\x3b\x91\x53\x39\xf7\x19\x89\x60\x2f\x85\x46\x0d\x1c\xae\x41\x4d\xb0\x8a\xa3\xd3\xac\x9c\xff\xc6\x6a\xa0\x38\x91\xa4\xa7\x1b\x06\x48\x34\x17\x48\x88\x9e\x05\xce\x32\x22\x46\xcc\x42\x9b\x02\x80\x37\xe7\x36\x48\xa4\x29\x9a\xbc\xd3\x28\x5f\x57\xa3\x0c\x93\x3e\xca\x09\x8b\xeb\xce\x37\xe4\x37\xae\x4c\xf5\x58\x91\x1b\xa8\x65\xd1\xb6\x91\xde\x6f\x6f\x36\x6e\x39\xe6\x75\xda\x79\xbf\x12\xa6\x0f\xe5\xa6\x53\x50\x20\x65\x51\x55\xd3\xd9\xfa\xbc\xfa\x5e\x12\x73\x00\x19\x1b\x3e\x8e\x39\x91\x81\x11\x1f\x79\x5b\x5c\x42\xa7\x44\x4b\x1f\x23\xa6\xc9\x38\x74\x38\x18\x80\x6d\x87\xb7\xad\x3b\x8d\x04\x97\xd2\x46\xde\x9b\x76\x56\xe7\x4f\xed\x50\xcb\xcf\xa0\x84\x0f\xaf\xaf\xc6\xcb\x55\xfd\x82\x67\xae\xbe\x9f\x7d\x58\x9b\x64\xdf\xd8\xd4\xda\x6a\x7e\xc5\x5a\x6c\x50\xcf\xef\xe4\xec\x62\xe8\x8b\x58\x55\xba\x5e\x2e\xe8\x17\x22\xab\x37\x97\xf4\x5b\x9e\x71\x50\xdc\xaf\xd2\xc4\x8a\xf2\x7e\xeb\x37\xab\x1c\xef\xbb\x0b\x6c\x5e\x65\xeb\xd7\xf2\x87\x32\xcd\xac\x0b\x4b\xdf\xd3\x36\x35\x5c\x2b\x11\x08\x8c\x2f\xed\x61\x07\xc1\x4b\xbf\x25\x15\x4e\xb3\x30\xe5\xd2\xe1\x86\xda\x69\x9a\xa3\xd6\x74\x09\xbe\x2a\x9e\x79\x84\x4d\x34\x4b\x75\x70\x4b\x5b\xb1\x99\xc7\xeb\xde\xc2\xa4\xef\x23\x8c\xf9\xf5\x72\x98\x93\x45\x11\xb5\x27\xad\xec\xe6\x4a\x70\x37\xd8\xfd\x27\xc4\x43\xc2\x37\x6e\xe8\xae\x49\x8a\x1e\x3a\x4a\x10\x2c\x6d\x38\x06\xe4\xf2\x55\xf2\x7c\x36\x30\x0f\xfb\x31\x9b\x6c\xe0\x23\x5f\x84\x21\xb8\x6a\x6c\x5d\xb1\xc8\x1d\x44\x2a\x04\x79\x22\x02\x68\xc7\xc6\xfc\xb0\xf2\x51\xc5\x89\x20\x38\x5e\x04\x2b\xe2\x03\x0e\x4c\xcf\x60\x1e\x93\x34\xd5\x0a\x3c\xa8\x26\x8c\x1f\xf1\xcc\xe9\x2c\xa5\xb7\xa0\x82\x06\x9d\xea\x1b\x2b\x08\x57\xd0\x5f\xb0\x23\xf2\x99\x4a\xa5\xe5\x8a\x9a\x58\x4d\xd7\x08\x48\x3c\x50\x57\x6b\x4e\xec\x0d\x37\xfa\xd0\xff\xee\xfa\xf6\x7e\x70\x3e\xfa\x50\x44\xe7\xbb\xf4\x33\x8f\x08\xe5\x00\xfe\x39\x1b\x31\x1f\x50\xeb\x01\x90\x61\x2f\x11\x8e\xe3\x02\xd9\xc0\x2a\x91\x46\x66\x5b\xc9\x91\x83\x53\xb1\x36\x94\x76\x45\x33\x0f\x90\x83\x74\xa8\x27\x6b\x85\xeb\xac\x74\x72\x4c\x26\xd5\x8a\x94\x97\x3d\x5d\x36\x21\x76\xab\x32\xba\x36\x51\x0e\x5c\x90\x91\x67\xa7\x2b\xc1\xed\x7c\x82\xcd\x25\xbc\x19\xb7\x73\x1b\xb2\xc5\xa6\x7e\xa4\x9f\x49\x7c\xdb\x20\x55\xed\x25\xa3\xa5\x55\x24\x60\xed\x2e\xe4\x8c\x6e\xa2\xf1\xfb\xa9\x3c\xe8\xef\xda\xb3\xa5\xeb\x02\x92\xad\x80\x57\x05\x6c\x55\x85\x30\x8a\x88\x50\x98\x32\x34\x85\x83\xcd\xa2\x05\x02\xc0\x0e\x02\x3e\xec\x3f\xa2\x94\x32\x40\x0e\x58\xb5\xb4\x0f\xe5\x79\x6c\x20\xb4\x5e\x0e\xaf\x1e\xee\x4b\xa2\xea\xf7\xd7\x0f\xe5\xa2\xee\xfd\x9f\x57\xca\xaa\x95\x16\x56\x05\x0b\x05\x53\x2c\xb2\x10\x2d\xca\xac\x5f\x99\xda\x89\x26\x0b\x45\x1e\x6e\x2f\x76\x92\xef\xea\x9d\x65\x8d\x18\xe1\xa1\x74\x55\x8f\x88\xd0\xe6\xd3\x98\x44\xeb\x50\x4c\xdb\xd3\x91\x89\x82\xd2\xeb\x60\xad\x89\x16\xe1\x0c\x4b\x94\x61\x61\xfd\x50\xb1\x09\x80\x2a\x57\x06\x33\x9a\xd7\x2a\x04\x89\x4f\x44\xfd\xa8\xaf\x3e\xce\xf6\x91\x05\x61\x45\x59\xf0\x8f\x92\xf1\x93\x69\x78\x83\x93\x66\x87\xb2\x22\xd5\xc5\x09\xcb\xd0\x03\xb2\x3d\x84\xb8\x0b\xc7\xa6\x42\x7c\x5f\x37\x07\x2b\xe2\xe2\x09\xb5\x4a\xca\x99\xa6\x48\x03\xa7\xea\x30\x58\x83\xe6\xf8\xd4\x7c\xdc\x12\x91\x2e\x88\x6a\xd7\x6d\x15\x4b\x89\xfa\x37\xc3\x9a\xb5\xbe\xa8\xba\x90\xbe\xac\x72\x36\x89\xf7\x66\xed\x1b\x24\x29\x48\x4f\x3c\x08\x54\x24\x3b\xd3\xdd\x60\x90\x8c\xd3\xff\xa6\x1c\x49\x70\x08\x68\xbd\x75\x2a\x43\x29\xed\x78\x0d\x30\xef\x66\x99\x78\xc5\x32\x6c\x08\x7a\x14\x0e\xc8\xa6\x81\x84\x40\x3f\xcb\x31\xc6\xbd\x10\xf8\x87\x9b\x82\xb9\x36\xb6\x60\x6f\x60\x48\xc5\x6c\xda\xa0\x21\xfd\x68\x28\xda\x83\x65\x00\xfc\x87\x2b\xc8\xe8\x62\x83\x6d\xee\x7a\x38\xdd\x90\xda\x36\x03\x50\x2a\xc6\xe7\xcc\xdf\x16\x8b\x1a\x67\xd8\xda\x1d\x40\x89\x72\x95\x12\xea\x0a\xeb\x1d\x8f\x58\x10\xb0\x22\x8d\xda\xa3\xcf\x88\x2b\x4e\x02\x15\x6f\x19\x00\x5b\x43\x92\x8e\x17\x7e\x4a\x3b\x50\x4d\x91\x57\xf3\x72\x79\x91\xa5\x7e\xec\xe9\x94\x73\xec\x12\x11\x9d\x05\xc5\xc6\x01\x86\xf6\x25\x68\x2f\x28\x28\x60\x3b\x06\x73\x34\x18\x2d\x70\x50\xae\x2e\x48\x5e\x8f\x39\x91\xec\x2b\xe5\x53\x3d\x69\x62\x4b\xa2\xe0\xaa\x7b\x40\x4b\x75\x98\xda\x96\x57\x1f\xf0\x3d\xa0\x33\x6d\xaa\x38\x04\xc7\x6a\xad\x99\xca\xf9\x78\x81\x12\xc2\x58\x24\xe8\xb4\xc9\xaa\xfe\x39\x23\xd1\x36\x10\x32\x37\x58\xe0\x94\x28\x22\x56\x85\x23\x95\x8b\x49\x83\x88\xe3\x76\xd0\xf6\x6b\x76\xd1\x54\xda\xa8\x96\x64\xf1\xda\xed\xc5\x3a\x48\x18\x3f\x8b\x8d\xd0\xaf\xf4\x34\x7e\xb4\x96\xff\x0d\x67\x61\xfb\x29\xa6\x61\xa3\xad\x02\x04\xa0\x5d\xe7\xf4\x3a\x50\x28\xf7\x4b\xa0\x22\xa5\x70\xa1\x03\xc1\x40\x59\x3f\xca\x26\xf0\x93\x75\xbc\x74\x2f\xbc\xdb\x65\x38\xb8\x14\xda\xca\xa1\x2a\xe5\x4e\x00\x95\x80\x4a\x65\x70\x40\xea\x01\x4c\x40\x68\xa9\x8b\x90\x0c\xdc\x7e\x16\xde\xae\x30\xe8\x5a\xc9\xaa\x5a\x5c\xaa\xb2\x5c\x6b\x78\xdc\xbe\xc0\x1d\x3a\x89\x66\xdf\x12\xcd\x3a\x52\x2e\x45\xd7\x6a\xea\x24\xa2\x82\x33\x63\x8b\x3e\x5b\x80\x80\xf2\x04\x21\xf7\xc8\x5e\x91\xb6\x72\x2c\x5c\xfd\x94\xf9\x7f\x95\x39\xb8\x23\xea\x90\x54\xeb\x92\x2a\x8f\x03\x17\x14\x78\xa0\x92\x50\x1a\xb0\x71\x35\x30\x5a\x13\x06\x69\xac\xfc\xc3\x2b\xe3\xc0\x82\xe4\xe6\x05\xcf\xd1\x33\x95\x73\xa4\xf8\x88\x41\x9c\xa0\xf7\x06\x28\x8e\xcc\x8b\x3d\x78\x0b\x60\x10\x64\x3e\x49\xa9\x42\x38\x98\x61\xc9\x24\xd9\xb3\xe7\x59\x7f\x00\x33\xae\xcd\xb3\xaf\x83\xe8\x59\x73\x68\xb6\xb0\xaf\x15\x8d\xec\x9a\x4a\x1f\xc4\x34\xbf\x6c\x32\x7d\xa0\xf1\x84\x1a\x66\xed\x99\xeb\xb2\xe9\x51\xbd\xb5\xc1\x82\x86\x02\xb2\x2b\x95\xaa\x72\xb7\x58\x43\xcf\x9a\x4c\xfa\x62\x23\x5a\xa5\xd2\x17\xaf\xef\x23\x97\xbe\xa9\x4c\xd9\xaa\xdc\x4a\xf7\x49\x83\xfd\xdb\xe5\xec\x2a\xee\x02\xe7\x43\x49\xe9\xa6\x51\x52\x3a\x34\x54\xb3\x22\x21\x60\xfb\xf0\xf2\x4d\xd4\xc1\x22\x3f\x2b\xa4\xa2\x20\xdd\xb2\x8c\x09\x43\xaa\x9c\x9f\x71\x05\x39\x35\x11\x94\x70\x5f\xca\xf3\x1c\xb1\x7a\x09\x64\x35\x4f\xdc\x35\x45\x63\xaf\xe8\x67\xc1\xf9\x73\xb3\xb0\x16\xad\x9f\x7c\x90\x9b\x51\x96\x6d\x31\xf6\xaa\x88\x59\xb8\xf8\x9a\x82\x93\xb4\xe0\xb1\x4d\xc2\x71\xcd\xa9\xac\x1f\xfa\x52\x02\xc5\xda\x73\x61\x2f\xdd\x3d\xaa\x76\x4b\xdc\xb9\x75\xbe\x89\x97\x91\x2d\x37\xb6\x01\xd3\xb1\xd7\xe3\x2b\xae\xda\x6d\xaa\xcc\x02\xaa\xe8\xde\xb0\x50\xab\xf0\x04\xba\xf1\x1e\xb8\x77\xed\xd8\xb1\x09\x75\xf1\x08\xdd\x95\x3d\x29\xcd\xd8\x56\xef\x7f\x89\x59\x6f\x5a\x1a\x38\xf0\x37\x0a\x1b\xef\x4b\x43\xcb\x01\xd4\x04\xb6\x61\x92\x15\x4e\xec\x85\xbb\x9c\xc5\x44\x30\x82\xd5\xfc\xf5\xb2\x2c\xce\x76\x35\x4f\x07\xe3\x7b\xd9\x8c\x8b\xb3\xbd\xd4\x85\x0f\x87\x5b\xae\x91\xbe\x76\x9c\xfa\xf5\x36\x96\x22\x1b\x7c\xe0\xab\x04\x2f\xa9\x8e\x35\x66\xc3\x00\x84\x66\x13\x2a\xdd\x29\x11\xa3\x5e\x9d\x7b\x99\x94\x94\x1a\xbb\xcf\x52\x32\x8a\x3e\xed\x61\x6d\xe5\x35\x4b\xf2\x45\xe4\x7e\xbc\x7c\x3a\xc2\xaa\x2a\xce\x79\x90\xa1\x00\xa5\xb4\x15\xa6\xcc\x72\xaf\x55\x49\x09\x5a\xa6\x4c\x71\x5d\x1e\xc2\xc1\x67\xb8\x7c\xf1\x09\x2e\x5d\xba\x43\x97\xee\x50\xb3\x47\x5d\xba\x03\x42\x87\x96\xee\xb0\x4e\x05\x5d\x65\x00\xf5\x3e\x39\xa8\xb6\x59\x2a\x71\x63\xf6\x77\x8d\x1e\xb9\x7d\x48\xbf\xb3\x21\x86\xf1\x50\xf6\x17\xfb\x43\x6d\x48\xd4\xd2\x67\xd5\xd9\x86\xf6\x4c\xb6\xa8\xba\x05\xb0\x88\x13\x8b\x43\x67\x03\x96\xcb\xf6\xa7\x55\xa6\xd2\x11\xfb\x9e\x3f\x93\x27\x22\x7a\x08\x2b\x94\x72\xa9\x80\x0f\xbb\xf8\x18\x38\x08\x25\x48\x73\x13\x07\x81\xd1\x15\x4e\x49\x6c\x2a\x1e\x06\x61\x8d\xd6\x60\x6b\x5d\xad\x75\x70\xab\x80\x1c\x6a\xb6\xc1\xc5\x4d\x8c\x98\x09\x35\x34\xe1\x6d\x20\x2b\x50\x37\x31\x20\x98\xdf\x79\x47\xf0\xef\x8e\xd1\xbd\xbe\x9f\xa8\x2c\x8f\x37\x40\x5f\x6b\x1a\xdb\x88\xcd\x04\xcf\x33\x6f\x43\xe3\x13\x53\xfa\xd6\x44\x3f\x2d\x3b\x82\x61\x30\xce\x0b\x1c\xe1\x58\xeb\xe2\xab\x09\xe7\x4d\xa2\x50\xb7\x82\x30\x0a\x09\x48\x1f\x43\x1f\x5a\x67\x43\xdd\x8d\xff\x36\x00\x6e\x59\x05\xc4\xfe\x42\xce\xe5\x73\x22\xc1\x2a\xe4\xad\xee\xa5\x3c\xf2\x32\x56\x41\xed\x38\x57\xd9\x44\xbd\xdf\xc2\xd9\xf6\xeb\x61\x10\x8a\xce\x6d\xcc\x97\x49\x52\xb5\xf7\xc4\x8b\x59\x4b\x5b\x47\xcf\x36\xf1\x8b\x9b\x5c\x64\x1c\x24\xb1\x64\xe1\x60\x1b\x2c\xd2\x5b\xc6\xb3\xdc\xc4\xb5\xd1\x30\xcc\xa9\x96\xb2\xa9\x54\x97\x58\x45\x73\xcd\xb9\x0b\xc4\xb3\x3d\xc5\xfb\x15\x5c\xf9\x65\x2d\xa8\x35\x33\x38\x0b\x7b\x6f\x70\x29\xb4\xb0\xa8\x9b\x7b\xdf\x85\xd7\x3b\x49\x22\xd5\xfd\x19\xb7\x9b\x2d\x68\x1d\xd8\x45\xdd\x27\xf6\x89\x9e\xe8\x3a\x2a\x5a\x37\xfe\x76\xb4\x55\xae\xb8\xb5\xf7\x48\xc2\x1d\x20\x64\xce\x2d\x60\x57\xf1\xa2\xad\xd0\xda\xe0\xfe\x17\x74\xbb\x2c\x20\x8b\x92\xff\xa4\xc5\x11\x6f\x71\x4d\x71\xa6\x95\x08\xc5\xf5\x2d\x29\x66\x46\x8e\x35\x71\xb2\x08\xa3\x5c\x50\x77\xf6\x2b\x39\xe1\xcd\xd4\x01\x16\xca\x93\xb0\xa2\x52\x84\x83\x62\x73\xc6\xe1\x8f\x23\x95\x63\x1f\x98\x08\x34\xe1\x8a\xa0\x9b\xfc\x77\xe7\x58\x17\x4e\xbc\xab\xd9\xd3\xb5\x84\xbd\xc3\x2e\xe3\x3a\x7c\xc3\x56\x27\x8d\xb2\x59\x00\x8e\x58\x6f\x25\x6e\x53\xfb\xa0\xf6\xcb\x76\xf5\x1b\x6a\x3f\x75\xb2\xcf\x36\xdf\xae\x00\x6f\xda\x3a\x36\xbb\x14\xe7\x6e\x03\x61\xad\xf4\x14\xc2\x56\x5a\xfb\x1d\xa0\xcf\x52\x70\xd4\x63\x2b\x4d\xfd\x97\xff\xcb\xd4\xca\x32\x4b\xf3\x5f\x88\x8b\x11\x33\xbf\xf7\x7c\x9d\x0a\xfd\x42\x01\x00\x8b\x53\x52\x40\x64\x8a\x32\x98\x1e\x40\x8a\x58\x30\x34\x03\xf6\xeb\x61\xfa\xf5\x18\x1e\xf3\x09\x11\x8c\xe8\xa1\x39\xf0\x01\xcf\xcc\x52\xcc\xf0\x0c\xa0\x85\x7b\x10\x19\x07\xe2\x6a\xa1\x8a\x18\x92\x36\xf5\x0e\x81\x5b\x69\x66\x69\xf3\x6d\x8b\xba\xbf\xd0\xa7\x11\x65\x2d\xb2\x69\x11\x5e\x51\x4f\xfd\xb7\xb6\xff\xed\x24\xf6\xfb\xfe\xdd\x0f\xe3\xdb\xc1\xdd\xf5\xc3\xed\x59\x49\x6c\x3f\xbb\x78\xb8\xbb\x1f\xdc\xd6\x3e\x2b\x72\x55\xff\xfa\x30\x78\x68\x78\xe4\x1a\xb8\xe8\x7f\x37\x28\x15\xd1\xfe\xeb\x43\xff\x62\x78\xff\xf3\xf8\xfa\xe3\xf8\x6e\x70\xfb\xe3\xf0\x6c\x30\xbe\xbb\x19\x9c\x0d\x3f\x0e\xcf\xfa\xfa\xcb\xf0\xdd\x9b\x8b\x87\x4f\xc3\xab\xb1\x0b\x3b\x0e\x1f\xfd\x74\x7d\xfb\xc3\xc7\x8b\xeb\x9f\xc6\x41\x97\xd7\x57\x1f\x87\x9f\xea\x66\xd1\xbf\xbb\x1b\x7e\xba\xba\x1c\x5c\xad\x2e\xd6\x5d\xbf\x1a\x8d\x75\x80\x83\x8b\x2c\x30\x1a\x05\x62\xd2\x64\x61\x49\x9b\xfe\x0a\xbe\x8b\x1b\x43\x8f\x47\x3d\xf7\x97\x29\xad\x7d\xa4\x59\xa0\xf3\x8b\x15\xdc\x63\xc4\xbc\xe3\xd2\x5f\xaa\x0a\xcf\xa4\x4b\x3d\x2e\x8d\xf6\x14\xf5\xe1\xac\x80\xc2\x50\xea\x14\x32\x1b\xfc\x48\x9d\xab\x1b\xe8\x30\xa1\x29\x05\xaf\x37\x3a\x42\xd5\x0d\x2f\x37\x68\xe7\x04\x43\xb0\x7e\xbb\x78\xd5\x69\x90\xd5\xac\x66\xa0\x94\x53\xe4\x38\x34\x31\xe6\x04\x83\x3d\xbb\x60\x38\xa5\x51\x35\x05\x03\xe0\x57\x51\x01\x35\x52\x6d\xb1\x44\x60\xe5\x96\xe7\x04\xfd\xf0\x97\x62\x50\xe0\xc1\xb0\x9a\x77\xbe\x54\x51\xcf\x3e\x10\xb9\x59\xd5\x75\xe4\x59\xea\xc9\x1d\x73\x6b\x5a\x86\x73\x6b\x2b\x77\x83\xbb\x29\x67\x01\xdc\x58\xc9\xf7\xa4\x8f\xb7\x99\x51\x85\xc6\x4f\xd1\x1d\x40\x9d\xc8\x42\x75\xd7\xbb\x98\x25\xf9\x8c\x32\x44\xd3\x2c\x21\x45\xcd\xf7\x09\x99\xe3\x27\xca\x5d\xf9\x0a\x53\xe5\x03\xd6\xd1\x8a\x56\xe8\x08\x35\x1e\x94\x53\xd4\x8f\x63\x59\x66\x70\x25\xca\x71\x2c\xf3\xa8\x3c\xec\x10\x21\x8c\xc5\x9e\x6d\x56\xe8\xa8\x38\x72\xb0\x62\xfb\x07\x73\x59\x66\x87\xe5\xbb\x77\x87\xeb\x5f\xaf\xe0\xd8\x91\xf2\x78\x2b\x61\xe0\x1e\xcb\x47\xc7\x9a\xd7\x09\x04\x0e\x56\x67\xb7\x1e\x2d\xbe\x4e\xdb\x4e\xfd\xca\x8e\xe1\xa0\x6d\xd7\x67\x23\x2a\xf4\x9a\x2e\xdd\x8c\x93\x4a\xe9\xae\xd6\xfd\x95\x4a\x7f\xd5\x76\xb6\x57\x6f\x4f\xbd\x34\x06\x47\x72\xec\xe9\x7f\x83\x79\xdc\xc0\xa7\xd7\xfe\xcb\x95\x22\xdb\x38\x58\xb7\x4d\x7d\x40\x4b\x49\xba\xd6\x0f\xb4\x92\x0e\xf7\x04\xef\xd4\x5e\x18\x84\xc2\x0b\x34\x02\x77\x1f\xa6\xcc\x96\xe3\x21\xde\x1f\xe5\x0a\x50\xeb\x73\xec\x4b\xc4\xe1\x09\x7f\x2a\x29\x97\x29\x91\x12\x37\x00\x96\x04\x26\xb1\x5d\x18\x83\x3f\xa1\xf6\xc3\x96\xf4\xe4\xce\xe4\xbd\xfe\x6a\x95\xd1\xe7\x36\xd4\x8c\xdd\x44\xb5\xc0\x1a\xbb\x48\x5b\x74\x6d\xf2\xed\x34\x7f\xe9\x15\xc1\x34\x5c\x04\x31\x46\x4d\xee\x9f\x96\x66\xb5\xea\x82\xd5\x56\x59\x0a\x5d\x78\x9b\xc7\xe0\x04\xad\x6f\x8d\x88\x6d\xfd\x2a\xb8\xbc\x3e\x1b\x50\x5d\xc9\xdf\x19\x56\xa0\x8e\x78\x9a\x1a\xb9\xa0\x64\x4b\xed\x21\x6c\xd2\x1c\x0b\x69\x4a\xe6\xd1\xdc\x78\x99\xf4\x95\xd1\x1b\xb1\xe7\x60\x43\x4a\x81\xc0\xfd\xb0\x25\x40\x13\xfd\xac\x8f\x1b\x7d\x2a\x85\x57\x83\xc8\x48\x21\xd6\x37\x20\x04\xe3\x10\x2c\xca\x47\xad\x21\xf0\x60\xbf\x76\x20\xf5\x2d\x6a\x05\x56\xd6\xb7\xa9\x62\xa0\x9f\x5b\x50\xa8\x6f\x07\x4d\xb9\xed\x10\x82\x5a\x81\x75\x23\xd8\x43\xa9\xc0\x57\x85\xf7\xf6\xe9\x9a\x26\xbb\x37\x9d\x58\x8c\x0a\x3d\x5d\xb7\xda\xbf\x77\x33\xfa\xbd\xf1\x3b\xe4\x0d\xa0\x26\x41\x6b\x1e\xe1\x1b\x1d\x69\x99\xd5\x25\xdb\xdb\x40\x0c\x89\x8e\x0c\x6a\xe0\x57\x10\x69\xd9\xbf\x19\x7e\xd5\x43\x5f\x85\xd9\x66\x5f\x6d\x75\x00\xed\xb8\x6d\xb9\x40\xd0\xa6\x4a\x29\x07\xe5\x63\x07\x7b\x55\x39\x89\x76\xcf\xec\x41\x44\x4d\xe7\x50\x7f\x59\xfa\x06\x9c\xd3\x50\xfe\xce\xf8\x6f\x7d\xc0\xb3\x75\x01\x19\x19\x97\xca\x9a\xb5\x8b\x47\x6c\xb2\xa8\x3a\x79\x7a\xde\xcb\xd3\xfa\x94\xee\x5c\xd2\x4d\xb7\xb7\x9c\x9e\xbc\xe7\x40\xdc\xd5\xf7\xc1\x9a\x84\xe7\xbe\x89\xb9\xe6\xd3\x80\x8b\x35\x45\x29\x74\x11\xec\x75\xb3\x2a\xd9\xcb\xdc\x62\xd6\x6e\xca\x3a\xf9\xe7\xbd\x91\x5b\x8b\xb0\xef\x7e\xdd\x8a\xd8\x88\xff\x06\xe1\xba\xa3\xb2\x97\xa5\xb2\x7d\x64\x3c\x94\x07\xb7\xf9\x05\x7a\x66\xe4\xb8\xa0\x19\x67\x70\xd5\xca\x84\x67\xf0\xa5\xba\x7f\xeb\x0b\xe6\x6e\xe8\xf3\x0d\xd6\x64\xbd\xd3\xf7\xce\x04\x0e\x18\xb7\xeb\xf2\x58\xab\x43\xed\x2b\x5b\x84\x88\x53\x93\xdd\xa8\x68\x4a\x7a\x88\xb3\x64\x11\x04\x3b\xd8\xf3\x0a\xe4\x66\x62\x94\xe6\x84\x0a\xd7\x89\xc5\x18\xdc\x28\x1d\x7e\x43\x69\xbc\x89\x46\x76\x88\x34\xb9\xea\x5f\x0e\xce\xc7\x83\xab\xfb\xe1\xfd\xcf\x35\xf8\x91\xe5\xc7\x0e\x42\x32\x78\xe1\xee\xe7\xbb\xfb\xc1\xe5\xf8\xd3\xe0\x6a\x70\xdb\xbf\x5f\x03\x2f\xb9\xaa\xb3\x26\xe8\xc2\x5c\xd6\xa9\x6f\x9b\xc0\x17\x3a\x33\x6f\x4d\xef\xcb\x20\x93\x41\x27\x94\x34\x00\x4d\x9a\xd4\x7f\x16\x13\x81\x62\xf2\x44\x12\x9e\x15\x66\xd5\xda\x05\x0b\x10\x28\x6b\xda\x5f\x85\x42\x09\x6d\x56\xd7\xf8\x14\x99\x5a\x6f\x41\xb9\x5b\xdf\x20\x88\x7c\x58\x10\xf6\x95\x42\xe4\x73\x96\xd0\x88\xaa\x20\x35\x90\x0b\xeb\x5e\x31\xee\x43\x88\x4e\x5d\x43\x5c\x7b\x8b\x46\xd9\xbb\xce\x1f\x7a\xd2\x97\xb5\x7d\x7f\xa2\x3c\x22\xda\xda\x02\x42\x7b\x50\xec\x1b\x9c\xc6\x4b\x80\x6d\x5b\x8c\xee\x25\xcc\x03\xcb\x39\x3a\x36\xbd\xaf\x01\xcc\xad\x7e\x90\xeb\x6f\xc3\x55\x71\x32\xa5\x73\xbd\x3a\x50\xa6\x1d\xa5\xbe\x71\xb8\x4b\xa9\xb0\xe6\x1e\x90\x37\x6c\xec\xfa\x86\x01\x0b\x4b\xf5\x62\x98\x89\x39\xc5\x48\x90\x94\x2b\xad\x80\x99\x88\x80\x9e\x16\xaa\x28\x4e\xe8\xaf\x80\x51\x25\xc8\x71\x10\x41\xe1\x90\xbd\x0a\xf7\x81\xc5\x8f\x38\x1e\xb1\xf3\xc1\xcd\xed\xe0\x4c\x33\xa4\x63\xf4\x20\x01\x7e\xaa\x34\xf5\x73\x4b\xde\x46\x1c\x0b\x23\x19\x28\x93\x8a\xe0\xa6\x60\x30\x22\x04\x17\xed\xf9\x83\xef\x6f\x00\xdf\xd5\x93\x37\x3c\x2b\xd9\xa6\x9c\x01\xe0\xaa\xb1\x2a\x72\x90\x33\xb0\xf7\x9c\xac\x5b\xfc\x5c\x5a\x91\x10\x7e\x03\x24\x91\xf2\xaa\xbf\xe0\x6a\x03\x80\x67\xfb\xf9\x95\xfa\xbc\x81\x6f\x57\xcd\xf3\x1e\x42\xec\xa4\x2a\xd0\x40\x0d\x60\xa8\xaf\x7a\x53\x99\x67\xa3\xa8\x28\xde\x02\xaa\xa3\x42\xfa\x13\x32\xc3\x0c\x89\x9c\xb1\x0a\x3c\x6c\x68\x69\x5b\x0e\x9a\xd9\xf4\xa8\xea\x35\xc3\x29\xcf\x19\x28\x0d\x10\xc6\x5a\x33\x18\x99\x11\xa6\xd6\x0c\xe6\xad\x80\x58\x2a\x43\x3d\x5c\x2c\x96\x9a\x81\x36\xc1\xb1\xd4\xf9\x93\xa0\xf4\xf2\x66\xd7\xb2\x0b\xca\x2b\x39\x95\xf4\xa1\xf2\xf7\x73\xbd\x96\x8d\xe5\xe3\xce\xdd\xdd\x63\xf9\xb8\xbe\xab\x98\x44\x8f\x9b\x5e\x36\xd5\xcc\xcc\xc4\x56\xae\x5e\x32\xf6\x2d\xf4\x53\x5b\x9a\x05\x0a\x96\x47\x8f\xe8\xfb\xfb\xcb\x0b\x34\xa5\x5a\xee\xd5\xd7\xca\x15\xd6\x32\xf6\x83\x48\x9c\x5d\xd8\xda\x56\x73\x91\xf8\xbb\x17\x36\xde\x89\x52\x81\x94\xa0\x6f\x34\x3c\x23\xce\xd8\x2b\x2c\xda\x5e\xa5\x34\x8b\xc0\x2c\xe6\xa9\x99\xc7\x89\xcc\xa7\x53\xfa\xf9\x58\x61\xf1\x4d\xc3\x7a\x98\xa8\x8a\xf1\xdf\xf9\x64\xac\x47\xb4\xe3\x45\x5c\xd7\x1c\xb2\x05\x95\xfd\xb2\xd9\x99\x9d\x9b\x77\xff\x2f\x9f\x40\xb6\x7b\x26\x38\x20\x00\x82\x77\xce\x46\x2a\xd8\x57\x1c\x25\x1d\x23\x97\x40\x55\x02\x39\x89\xb8\x10\xc4\x26\xc9\x9b\xda\xa2\x19\x16\x8a\x82\xb5\xd6\x81\xa4\x94\xd0\xf1\x8b\x2d\x0a\x4b\x7e\xcf\x71\x81\x44\x3d\x21\x04\x1c\x3c\x19\x4d\x36\x53\x7a\xcf\x4a\xbe\xc9\xca\x09\xb4\x91\xa7\x16\x37\x13\x0c\x32\x6b\x45\xac\xc1\x13\x61\x6a\x2f\xfa\x09\x34\x51\x93\xb6\xdf\xce\xcb\x60\x4a\x7c\x0e\xcf\x8b\xcb\xcd\x85\xf4\x86\x51\x4d\x4a\x60\xb8\xe7\x6d\xa2\x94\x75\xa9\x37\x39\xfa\x9f\x5a\xfb\x8e\xe1\xd5\xe5\x75\x59\x13\x1a\x6f\x57\xbb\x28\xf5\x5d\x84\xb5\x3a\x68\xff\x2d\x81\x7c\x24\x31\x56\x8c\x00\x40\xc2\x2a\xa7\xd5\x3d\x37\x7d\x6a\xda\xaa\x74\xb9\x76\xcb\xb7\x40\xad\x29\x35\xf3\x89\x40\x4a\xe7\x3e\x02\xd1\x37\xc9\xdd\x87\x81\x3c\x88\x04\x42\xa8\x57\x5a\xb1\x4c\x99\x71\xcd\xf9\xbc\x64\x87\x5b\xc8\xe8\x66\x30\x5a\x68\x24\x99\x20\x91\xbe\xca\x4e\xd1\x4d\x42\xb4\xe4\x95\x6b\xe9\x2b\x4f\x12\x87\xf0\xb5\x5a\x3a\xdc\x08\x95\xee\xc5\xe7\x15\xe8\x1e\x2b\x26\xe6\x10\xee\x56\xcf\x2c\x58\x83\xfd\x23\x2e\x04\xeb\x0b\x26\x64\x30\x24\x96\xb5\x48\xe0\xf0\x0b\x13\x37\x0b\xa6\x24\x5c\xba\xc8\xe8\xaf\x9a\xfd\x0a\x22\xe7\xbc\x31\xc9\x31\x9c\xed\xcb\xcc\xc1\x2d\xe5\x0b\x4e\xc2\xdd\x87\x4d\x71\xd5\x2d\xe4\x9a\xca\x1d\x58\x12\x71\x56\x4d\xd1\x57\x7f\xf0\xd1\x1f\x16\x6f\xd5\xde\xad\x76\x68\x70\x4b\x16\xa6\xb6\x10\xfb\xac\x70\x5d\x14\xca\xcc\xc2\xf8\x5e\xfd\xe7\x85\x01\xb9\x48\x09\xa0\x4a\x16\x55\xe7\x90\xbe\x6b\x9b\xb6\x58\xcf\x73\x9c\x8b\x8d\x20\x29\x0a\xd4\xf2\x4d\x38\xb7\x4d\x46\x29\x86\xa5\x17\xa1\x9e\x5d\xda\x62\x12\x20\x46\xdb\x50\x23\x59\x42\x82\xb3\x64\x63\x96\xb1\x56\xc5\x6b\x66\xca\xbb\xba\xd5\x40\x4a\x2e\x44\x99\x97\xf2\xae\x95\x28\xb0\x34\x81\x0e\x5b\x6c\x73\x6c\x31\x5b\x59\xc4\xd3\x1e\x20\x01\x2a\x01\x89\xff\x85\x03\xad\x2a\x38\x58\xa3\xf7\xba\xcc\xa7\xd2\xee\xb4\x4a\x73\x2a\x7d\xa1\x79\xc9\xf9\x8e\x1e\x38\x3d\x99\xc5\x18\x12\x47\x77\x89\xc2\x29\xcd\xdf\x78\x0f\xa0\x4d\x12\x23\x83\x5e\x60\x90\x8f\xed\xda\x79\xcf\x49\x86\x05\x61\x6a\xc4\x6e\xf5\x28\xcc\x17\x45\x24\x86\x8b\xc3\x71\x68\xf4\x50\xb3\x76\x8a\xb0\xfd\x0a\x16\xbd\x29\x10\x4e\x8e\xcd\x4b\xa0\x9a\xbe\x60\x92\xfd\x77\xe6\x1d\x83\x79\x60\x31\x7f\xf4\x54\xe9\xb4\x50\xe3\xb5\x00\x19\xcd\x29\x40\x0e\xc4\x44\xda\x0b\x89\x2a\x8b\x29\xe1\xc5\xef\x9c\x38\xfc\x65\xf8\xcc\xf3\xaf\x3a\x86\xed\x0c\x05\xcc\x19\xe8\xe4\x88\x05\x7d\xac\x80\xeb\x34\xca\xfa\x96\xaa\x04\xec\x33\x8d\xbd\xe3\x0b\xfe\x69\x76\x88\x0b\x3a\xa3\x2c\x28\x9a\x64\xa7\x97\xe2\x0c\xcc\xbb\xe6\x0c\xf2\xa9\xbf\xd3\xee\x6d\x96\xc1\x31\x8c\xf8\x7f\xfe\xfb\x6f\xc7\xb4\xc9\xfb\x21\xc7\x76\x05\x0e\x61\x27\x37\xdb\x96\x70\xe7\x03\x14\x91\x06\x74\x8a\x40\xa7\x95\xa5\xcc\x89\xe2\x57\x7b\xb9\x69\xa2\xe1\x6a\x6e\xdc\xbd\x65\x72\x07\xdf\x88\xc8\x57\x9c\x0d\x73\xc5\xbc\xed\x5a\x52\x09\xd9\x01\x7a\x24\xe6\x24\x7b\x03\x41\x58\x90\x7c\xc9\x4c\x33\x62\xc5\x27\xd2\xe0\xa1\x18\x78\x57\xf3\x43\xb1\x3a\x2d\x17\x66\x15\xef\x2f\x22\x25\x0a\x77\x78\x10\x8d\xec\xca\x67\x98\x28\x52\xdd\x7e\xe5\xa6\xad\x70\xee\x00\xe7\x70\x97\xa8\xcd\x39\x96\x2f\x17\x9a\x53\x5b\xf6\xc9\x58\xd3\x43\xe1\x61\x5d\x90\x8e\x19\xa4\xc9\xf6\xd4\x1b\x92\x4b\x22\x0c\xa7\xf3\x70\x58\x96\x12\x42\x14\x47\x88\xd1\x5c\xe3\x6b\x24\x29\xa6\x1b\xe5\x13\xe8\xf7\xeb\x31\x26\x4b\xce\x06\x3c\x23\x62\x1c\xe7\x6a\xe9\x58\xac\x8a\xf1\xd7\x1f\x9d\xe7\x6a\xb1\xbe\x7d\x99\xe0\xe5\xb2\x37\xab\x70\x3d\xf5\xfb\x0d\xcd\xae\x97\x98\x83\x10\x9f\xb2\xd4\xdc\x80\x9a\x49\x2a\xa8\x99\x36\xe6\xb4\x64\x22\x81\x1b\x98\x29\x80\xd4\x2b\x34\x29\x7b\x45\x1b\x6c\x6f\x18\x39\x9a\xe4\x85\x49\xc9\x57\x4b\x88\x8f\x47\xec\xa3\x29\x37\x02\x5a\x9e\x19\x40\x04\x09\x3f\xe4\x73\xc6\x25\x29\x65\xa0\xd5\x54\x40\xb0\x19\xa4\x76\x18\xf5\xc2\x7a\xf1\xd1\xee\xb2\xfa\x9b\xe3\x9f\x2e\x6f\xf8\xf2\x94\xeb\x29\x70\x27\x71\x30\xa2\x19\xd5\xb4\x33\xae\x3d\x69\x2f\x57\x85\xb7\x88\xe9\x02\x1c\x2c\x95\x2c\x7a\xc8\x4f\xaf\x42\x10\x09\x79\x22\x60\x4e\x87\x31\x86\x75\x2e\xca\x76\xbd\x06\x76\xb2\xee\x00\x15\xe9\x9f\xc0\x16\x50\x5c\x1d\x41\x39\x49\xae\x8e\x16\xcb\xe9\x3f\x3b\x67\xaa\xd5\x05\xa6\x6c\x20\x9e\xf7\xc3\x7a\x1f\x0b\xa2\x10\xf9\xac\x88\xad\x08\x7a\xef\x72\x09\x97\xd3\x0f\x50\x7d\x3a\x54\xb3\xec\xf8\xe2\xb5\x99\xfb\x2e\x83\xdc\x25\x4b\xc6\xee\xca\xb7\xc9\x83\x73\xcc\x62\x9b\x11\x6b\x95\x0c\x2d\x6c\xc1\xec\x8c\xd1\xcd\xe7\x0a\xd8\xbc\xce\x00\x28\xdd\xb4\x69\x10\xdd\xe1\x22\x73\x0a\xa3\x56\x59\x20\xbc\x82\x0b\x2d\xb9\xe7\x4c\xd1\x44\x13\x87\x1d\x83\x44\x53\x88\x8c\xb3\x40\x85\x10\xd9\xde\x84\x85\x47\xa5\xa4\x6c\x36\xb6\x2b\xe9\x92\x3b\xdb\x5d\x0c\x65\x9a\xba\x34\x4d\x99\x1f\xbf\x73\x0d\xad\x36\xaa\x1b\xb2\x06\x9c\x32\x97\x56\x0a\x1a\x07\xe3\x6e\x32\x16\x60\xce\x65\xa3\x8e\x69\x6c\x96\x82\x9a\xc2\xd3\x30\xd1\x4d\xec\xee\x20\xd3\x2d\xe3\x38\x14\x57\x88\xb4\xa9\xa2\x26\x01\x0c\x22\xf5\x55\x43\x2e\xac\x6c\xcc\x81\x1d\x32\x2f\xa2\xd9\xb2\x57\x3e\xd3\xbf\x92\x4e\x8b\x5d\x77\x36\x1d\x01\x27\xc9\x04\x47\x8f\x5e\x0b\xf3\xb6\x08\x2e\x5c\xd9\x00\x2d\x57\x42\x5d\x34\x43\x5c\x7a\xa0\x11\x48\x37\xa1\xb7\xd0\x20\xf9\xd8\x61\x17\x9d\x9b\x55\xb3\x10\x69\x06\xba\xc9\x8c\xde\xe4\x36\xc4\x24\x4b\xf8\x22\x6d\xb8\xcf\xaa\x29\x84\xbb\x44\xea\x34\x65\x30\xee\xf5\x2a\xab\x30\xbd\x8d\x2f\xb3\xa5\x7c\xa4\x3d\xe0\x4a\x6d\xc0\x25\x3f\x25\x7c\x02\x26\x55\x6b\x7e\x70\x39\x36\x41\xaa\x47\xf5\x3c\x6f\x9a\xf9\x53\x3d\x91\x54\x66\x89\x56\x66\x9a\x7b\x30\x39\x27\x2f\xbb\x6f\x06\xa3\x60\xbd\x75\xb0\x7d\xb4\x76\xed\xe7\x2f\x81\x60\x7c\xe1\x24\x01\xf3\xae\xe1\x5f\x15\x2b\x9b\x49\xf6\x3b\x36\x4e\x6a\xc5\x47\x4c\xe1\x99\xdb\x5c\x2b\x5c\xf2\x67\x46\x84\x9c\xd3\xac\x54\x2f\x71\xe7\xf0\x70\x4b\xd1\xf6\x3f\x26\x18\x7a\x03\xde\xc9\xb3\x23\x83\x50\xa2\xe9\x43\x66\x38\x2a\xac\xa2\x51\x82\xa5\xa4\xd3\x45\x00\x2c\xe2\x23\x6d\x21\x7d\xab\x6c\x46\x08\x4a\x94\xd5\x31\x1a\x33\xbe\xfd\x64\xd6\xef\x9e\x55\xf8\x50\x3e\x7e\x34\x0e\x11\xdc\xf4\x7d\xb2\x8c\x22\xe3\x6e\x6a\x8b\x26\xd3\x88\x44\x6b\x20\x04\xb6\xcb\x84\x5f\x09\xfe\xd3\x6c\x46\x28\x84\x49\x3b\x6c\xab\xc8\x78\xc0\x8f\x10\x0c\x47\x95\x52\x29\x61\xf3\xb5\xe2\xe4\xec\xc2\x9a\x38\x3d\x58\x08\x60\x2a\x14\x1f\xf7\x90\xdc\x09\x64\xab\x0d\x5d\x9c\x93\x84\xec\x25\xe2\x7a\x0b\x22\xa9\x86\x33\x04\xe4\xb1\x92\x34\x8a\x32\x03\xeb\x8d\x0b\x5b\x04\x82\x37\x40\xf5\xd4\x0f\xfd\x27\x33\x50\x1b\x0b\x5e\xb7\x8b\x60\x18\x84\x55\x6e\xab\xbb\xd4\x61\xfe\x99\x16\x2c\xc9\x15\xdd\x94\xe8\xaa\xe8\xd4\xcb\x2b\x87\x48\x6a\x6f\x1c\x32\xbd\x34\xae\x4f\xa4\x4d\x78\xc7\xda\x03\xb0\x15\x07\x5a\xe6\xd3\xed\xe8\xc2\x3a\x50\x15\x47\x33\xa2\x4c\xf5\xff\x98\x3e\xd1\x38\xc7\xc9\xbb\xa2\x89\xbd\x25\x7c\xec\x69\xf5\xeb\x0f\xf9\x66\xa7\xf6\x8e\x28\xe9\xae\x84\x25\x18\x45\xbb\x39\x07\xb8\x05\x87\x71\x2c\x8d\xe0\xfa\xc5\xcb\x2d\x3b\x83\x24\xd8\x91\x59\xa8\x80\xdf\x90\x40\x65\xe6\x18\xdb\x2f\x3c\x2c\x40\x09\x10\x0b\x97\x40\x04\xcd\x1a\xbd\x3d\xd7\xab\x92\xf6\x97\x2e\x7a\x6d\x4e\xe3\xd5\x51\x15\xd4\xdd\xc9\x83\x9b\xc9\x83\x0e\x64\xf3\x00\x2f\xff\xa6\x63\x70\x98\xf7\xcf\x01\x08\x87\x4b\x57\xe2\xfe\x44\xc4\x77\x44\x26\x07\x21\x29\x2e\x6d\xc5\x6b\xc9\x8b\x47\x0e\xe5\xa8\xc0\x0c\x3a\xdc\x2d\x3a\x8c\x93\x7c\x6b\xdd\x40\x2f\x77\xc1\xae\xa7\x97\xbd\xd0\x07\x00\x7e\x62\xc8\x8b\xce\x6d\x05\x11\x38\xbc\x41\x2c\xdd\x92\xef\x61\x4d\x94\xa2\x1d\x5e\xab\xf8\xc4\xa5\xe5\x7c\x89\xed\xb5\x49\x70\xad\x37\xf7\x25\x49\x6d\xd3\xb1\xec\x43\x47\x79\x61\x2f\x8e\xa5\xc6\xe0\x83\x2e\x58\xb8\xdd\x2d\x5a\x03\xad\xe3\xb6\x6c\x9f\x87\xac\xae\xec\xdb\xee\x69\xfc\x2e\xc7\x6f\x9c\x09\x32\xa5\x9f\xb7\x12\xc5\x6f\xe0\x53\xab\x5e\xea\x65\xae\x14\x92\x03\xf7\x0c\x14\x9e\x0b\x02\x1a\xed\x4a\xdb\x62\x53\x23\x56\x64\x46\xda\xb4\xc8\x47\xb2\x40\x5c\x94\x7e\xda\x16\x04\x72\xff\x45\xef\xcc\xbe\xce\x95\xca\xe4\xe9\xc9\xc9\x8c\xaa\x79\x3e\x39\x8e\x78\x6a\xe2\xf0\xb9\x98\x99\x3f\x4e\xa8\x94\x39\x91\x27\x7f\xfc\xc3\x1f\x8a\x2d\x9e\xe0\xe8\x71\x66\x60\x75\x96\xfd\x4e\xe5\x2d\x27\x58\xee\x16\xd9\xe3\x52\xd8\x5e\x38\x95\x39\xe8\xc6\x25\x8f\xea\x6f\xa4\xc2\x69\x16\x86\x82\x9a\xb2\x71\x52\xe1\xa2\x58\x05\xe4\x25\xea\x69\xa2\x39\xce\x32\xc2\x9a\xcd\x0e\x26\xd1\x74\x07\xd6\xe3\x52\x55\xed\x08\xc9\xe7\x2c\xc1\xac\x0c\xbf\x00\x95\x97\x04\x89\x08\x53\x16\x1a\xa0\x28\x25\x0d\xd4\x68\x20\x80\x0c\xff\xdf\x2c\x15\x11\xe6\x48\x65\x51\x52\xcd\x0d\xc7\x96\x37\x75\x45\x2f\x71\xb0\x74\xd5\x92\xb2\xc5\xda\x11\xb7\x6a\xab\x92\x14\xef\x96\x4b\x8b\x6f\x5e\xd2\x46\x70\x36\x26\x9f\x35\x93\x93\xdb\x02\x76\x3d\x48\x22\x51\xff\xa7\x3b\x24\x17\x4c\xe1\xcf\xa7\xe8\x92\x32\x10\x60\xbf\xe7\xb9\x90\xe8\x1c\x2f\x8e\xf8\xf4\x28\xe5\x4c\xcd\xd1\x25\xfc\xaf\xfd\xe9\x99\x90\x47\xf4\x33\xc1\xc2\xf2\x07\x5b\x92\xce\xd7\x37\xd7\x24\x24\x72\x26\x11\x79\xd2\x27\xf4\x0f\xff\x89\x52\xd3\xf2\x29\xfa\xf6\xe4\x0f\xff\x89\x7e\x07\xff\xff\xff\x47\xbf\x6b\xd0\xf4\x37\x83\xfc\x82\xca\xc5\xb7\x65\x77\x6e\xaf\xb2\x52\x5b\x54\x73\x3f\x13\xbc\xd8\xa9\xda\x96\x1f\x69\xf4\xc8\xa7\xd3\xb1\x26\x0c\x93\xc8\x37\xc6\x62\x09\x2e\x7a\x4b\xfc\x54\x6a\x6b\x4f\x9b\x4a\x76\x45\x0d\x19\xdb\xa9\x41\x7c\x70\xec\x5a\xe6\x45\xe5\x5d\x08\x22\x2a\x55\x33\xa6\x12\xbe\x22\xb1\xe6\xaa\x9b\x9c\x0e\x67\xdd\x73\xc9\xdf\xce\x82\x13\x22\xa4\x84\xf5\xd4\x7d\xe0\x5f\x18\xc5\x6a\x02\x7d\xec\x42\xd6\x1e\x87\xa5\xf0\xda\x2f\x26\x66\x12\xa6\xf6\x56\xf1\x92\x72\xa9\xf3\xf5\xa1\x92\x77\x5c\xec\xa4\x6f\x3d\x92\xc6\x54\x86\x35\xf5\x92\x5c\x0d\xdf\xb0\xb2\x3f\x64\x88\x73\xe1\x71\x8c\x8d\x5d\xc4\x56\x55\x5c\x6f\xc5\xa4\xc2\x04\x97\xb5\x3b\xf4\x7a\xea\xe7\xfe\x93\x75\xc3\x84\x48\x33\xf7\x76\x51\x2f\x0e\x46\xab\x45\x24\xcd\x12\x6b\x46\x5c\x03\x76\xb8\x6e\x43\xef\x3c\xbe\x05\x34\x0e\x61\x8f\x90\xbf\xc1\x9c\x64\x6b\x01\x04\xea\xf7\x33\x17\x11\x39\xe3\xbb\x85\xbd\x26\x94\x2d\xc5\xcb\xb7\x2f\x45\xe4\x57\xef\xc2\x16\x9d\x72\x78\xc0\x3c\x2e\x94\x05\xe3\x16\xb0\x55\x28\x02\x20\xd2\xf2\x6c\x00\xd0\x6e\x1f\x58\x97\x4b\xb5\x11\x76\xe0\xda\xc6\x70\x5c\x30\x3c\x57\x5a\xa3\x52\x51\x43\x60\xcd\x0b\x57\xc4\xae\x41\x50\xd1\xce\xe3\x08\xaa\xc4\x14\x91\x4a\x95\x6a\xec\xd8\x94\x4a\x11\x5b\x62\x95\x9a\x82\x4d\x3d\x24\x30\x04\x65\xaa\xb9\x6e\x4f\x12\x71\x34\xc5\x11\x65\xb3\x5e\x00\x53\x09\x90\x11\xe1\x75\x50\x47\xa4\xf7\x58\x3e\xee\x37\xd0\x70\xe7\x02\x96\x34\x2e\x8a\xa8\x59\x60\x19\xe3\xd8\xa0\x4b\x18\x7d\x0a\xcb\xc7\x26\x64\xa5\x25\x58\xb7\x15\xa3\xf3\x4b\xe1\xc0\xe0\x56\x8d\xcf\xa5\xa0\x93\x50\x9f\x82\x9a\x0d\xae\xa4\xb2\x05\x79\x74\x19\x7f\xd8\xa3\xb0\x54\xd1\x4d\x57\x8c\x5f\xce\xb9\x50\xe3\x2d\x71\x61\xab\x69\xf4\x8c\x1c\x25\x00\xe8\xc2\x9f\x88\x78\xa2\xe4\xb9\x0c\xaf\xba\x09\x2d\x1a\xa3\x59\x10\x55\x07\xf8\x9b\x69\xc6\x21\x85\x66\x8a\x52\xcc\x16\x86\x51\x6a\xe6\x82\xe5\xa3\xf4\x85\x5c\x91\x4c\x71\x92\xf4\x90\x20\xb9\x34\x05\x8e\x25\x49\xa6\x47\xae\x14\x46\x8c\x12\x3e\xa3\x11\x4e\xd0\x24\xe1\xd1\xa3\x34\x19\x6e\x6c\x66\x98\x54\x26\x78\x44\xa4\x0c\x24\xab\x22\x9b\xdd\xe6\x18\x42\x15\x57\x45\x44\x4a\x19\x95\x8a\x46\x4e\x64\x2a\x40\x29\x4c\x2d\xf1\x08\x83\x49\x18\x32\x36\x61\xb8\x5a\xd2\x23\x06\x9c\x33\x67\xb6\x68\x12\x5c\xd7\x16\x73\xcf\x05\x89\x37\x1d\xa0\x3d\x40\x08\x3a\x0a\x19\xab\xf2\x81\x5c\x73\xa4\xce\xec\x67\x70\x8c\x57\x91\xc0\x6d\xf9\x44\x79\x82\xf4\x27\xad\x04\x6b\x04\x31\xe5\x3e\x04\xbe\x24\xb9\xf8\xc8\xf0\x03\x43\x34\x83\x21\x37\xe0\x98\xad\xa3\x69\xbd\x8a\x20\xf2\x40\x9d\xae\xaa\xd7\x9c\xb2\x28\xc9\x63\x5f\xa9\x51\x8b\x00\x4f\x9a\x48\xdc\xf2\xe8\xb5\xd7\x82\x42\x0f\x61\x89\x9e\x49\x92\xe8\xff\x9a\x08\xf8\x23\x5f\x38\x41\xb3\x64\x53\xdc\x02\x3a\x71\x5c\xba\x89\xa2\x0e\x0e\x9d\xf2\x06\xab\xb9\xc9\xf9\x4f\xb9\x32\x45\x32\x0d\x3a\xa5\xb3\x6f\x19\x38\xc3\x49\xc2\x27\x70\xd2\x01\xb8\xd2\xe5\xb9\x06\x69\x75\x79\x14\x11\x12\x93\x18\x7d\x1d\x1c\x5c\x8f\x47\xf1\x4d\x3d\x8c\x62\x69\x45\x0e\x00\xb4\xb2\x6a\x58\x6b\x84\xae\x2c\xd7\x79\x3b\x46\x37\x15\x60\x96\xb0\x7e\x3b\xae\xc2\x74\xf5\x96\xb6\xf0\x6d\x80\x2e\x2b\x93\x78\xb9\x1d\xda\x10\xe8\xb2\xd4\xe7\x1e\x80\x2e\x2b\xf3\x6c\x88\xdd\xe7\xb3\x17\xcd\x39\xd6\x93\xba\xe0\xed\x13\xc1\x0c\x40\x98\xb9\x3b\x4b\x24\xe8\x0e\xe4\xa2\x8e\x10\x0f\x0b\xc4\xb3\x52\x0d\xf1\x6d\x41\x3c\x2b\x83\x39\x64\x10\xcf\xca\x50\x0f\x17\xc4\xb3\x66\xa0\x2d\x40\x3c\x8d\x73\x7f\xac\x89\xba\x1d\x53\x80\xc4\x96\x49\x3e\xbd\x83\x54\xef\x95\x63\x3c\x33\x81\x03\xe6\x1a\x73\x77\xb4\xc5\xb4\x86\xd1\xda\x1c\xc8\xa6\x70\xa8\x8a\x13\x62\x53\xda\xf3\xde\x37\x03\xfe\xb0\xa9\xd9\xbd\x17\x5a\xbb\xc1\x0e\x19\xe1\xcc\xe6\x94\x37\x95\x9a\x39\x9c\xec\xd9\xed\xf0\x51\x01\x83\xb0\xc4\xf2\x5b\x21\x88\x5d\x56\xaa\x36\xcc\xf9\xb3\xad\x9c\x04\x64\x68\x88\xb2\x91\x04\xa1\xd3\xb1\x55\xda\x9a\x56\x8e\x32\x45\x66\x55\x9d\xb6\x38\x34\x94\xa9\x3f\xfd\x71\x2d\x27\x32\x10\x8b\x4e\x3d\x0c\x6a\x27\x78\x67\x87\x7d\x46\x62\x14\xcd\xb5\x56\x24\xb5\xfa\xa2\xa7\x63\x6e\x56\x89\x52\x4c\x9d\x22\x95\x4b\xe3\x5a\xa2\x72\xc4\x4a\x98\xa4\xc7\xe8\x23\x14\x84\xc5\x69\xa6\xf5\x2f\x3f\x3f\xaa\x29\x69\x94\x7f\xfb\xed\x9f\x08\xfa\x16\xa5\x04\xb3\x92\x0e\x0b\x6a\x93\xbe\xfa\x00\xc3\x4f\xcd\xc9\x88\xd5\x6e\x05\x1a\x7c\x36\x35\xa6\x5c\xbc\xdf\x90\x4d\xb9\xd3\x89\xa1\xd0\x21\x8e\xe6\x48\xe6\x13\x53\xa9\x37\xb0\x61\x38\x41\xfa\x82\xcf\xc0\x51\x0d\x37\xb2\x1b\xf4\xaa\x53\xf8\xb2\x31\x00\xd6\xdd\xd8\xf6\x36\xee\xc3\x3d\x72\x24\x49\x09\xdb\xa9\xc6\x69\x66\x38\x5f\x78\xf0\xa5\xc1\x7d\xe9\x19\x1f\x82\xd6\xcf\xb0\xb5\xec\x6b\x59\x1a\xc2\x79\xc1\x4b\x96\x27\x58\xd8\xa3\x3f\x62\x5a\xd1\x10\xe4\x89\xf2\x5c\x26\x0b\x14\x73\x46\x7a\x40\x09\x79\x34\x37\x8e\x55\xad\xb3\x60\x5b\xb0\xe2\x89\xca\x5c\x2b\xb4\xd0\x96\xab\x8f\x21\x15\x36\x98\x54\x73\x0a\xfd\x68\xf5\x9b\xc0\x57\x61\x96\x1c\x6a\xa7\x45\x85\xb0\xb1\x15\x9e\xdf\x12\x36\xb6\x44\x55\x1d\x6c\xac\x87\x8d\x5d\x5e\x97\x43\x84\x8d\xad\xec\x79\x3b\xd8\xd8\xba\x2d\xdf\x02\x36\xb6\xd4\xcc\x17\x03\x1b\x5b\x59\xd1\x2f\x06\x36\xb6\x32\xaf\x0e\x36\xf6\xcb\x83\x8d\xdd\x11\x18\xb5\x9e\x17\x1b\x7c\x25\x45\xd9\x62\x63\x22\xfb\x4a\xa2\xe1\xb5\x26\xb0\xe8\xb1\x1c\xd4\xe6\xaf\xab\xdd\xc1\x58\xeb\x99\xd0\x66\x60\xac\xb5\xaa\x7a\x33\xab\xdb\x15\xe0\x09\x14\x83\x57\x06\x63\x2d\x4d\xa0\x8b\xaf\xdc\x3c\xbe\xb2\x96\xf8\x6c\xdf\x7a\x78\x2e\xe8\xb2\x7a\x21\xb7\x84\x63\x2d\xed\x4f\xab\x48\x4c\x10\xdd\xf7\x40\x89\x2f\x2b\xcd\xdf\x97\x0e\xf9\x5a\x59\x3e\x5c\x45\x69\x81\xa1\xb5\x84\xe7\xd0\xe2\x8c\x12\x1e\xfa\xff\x3b\xca\xdd\x22\x32\xb8\xb2\xbc\xde\xaf\x62\x68\xb1\x05\xa9\xb6\xa6\x50\xa7\x95\xee\x27\x51\xd6\x25\x4f\x6e\xe8\x62\x76\x83\xb8\xcb\x48\xd4\x60\x63\xa6\x29\xdd\x57\xb3\xeb\x2e\x32\x8f\x85\x05\x0a\xf9\x52\x5e\xa8\xbe\x9e\xcc\x70\x8c\x8c\x5f\x49\x87\x05\xa0\x0e\xf3\xe5\x8c\x4a\x25\x1a\x63\x9b\x96\x46\xb8\x8b\xab\x34\xcb\x5b\x07\xc4\x04\xab\x3a\xdb\xee\xb3\x94\xa4\x5c\xac\x0b\xac\xaa\xfd\xd2\x96\xba\xd9\xe6\x53\x92\xcd\x49\xaa\x25\x99\xf1\xa6\x8d\xb4\xdd\x6f\x9f\x34\x6c\x73\xd7\x4c\xa0\x63\x89\x08\x02\x47\xa8\x7e\x37\x36\x88\x94\xad\xb7\x7b\xd7\x6d\xb6\x98\x99\x1b\x3a\x84\x1c\x98\xf2\x6a\x83\x9b\x7d\xa9\xe4\xee\x06\xfa\xae\x8d\xe9\xf0\x21\x35\xeb\xa3\x36\x56\xc4\x6b\xac\xc2\x9d\x2a\xbe\xb2\x85\xa0\x37\x70\xe5\x97\xbd\xf3\x9a\x13\x86\x55\x80\x37\x0f\xf0\x68\x40\x4d\x5d\x5e\x1e\x88\xcc\x91\x44\x1c\x85\x9a\x41\x69\x30\xcb\xeb\x55\xa2\x12\xa7\x51\xee\x40\x24\xb9\x68\x8c\x32\x6d\x63\xd0\x8e\x54\x8e\x13\xd0\x24\xc2\xea\x95\xd5\x4d\x9d\x2c\x6a\xd2\x1e\xdb\x79\x4c\x28\x53\x7f\xfe\x8f\x8d\x76\x53\xab\x56\x76\xdd\xa0\xe2\x16\x8e\x22\x22\x8d\x8d\xdd\x46\x21\xe3\x09\x7f\x82\x62\x5b\xbb\xec\xaa\x3e\xca\x7a\xde\x9a\xc1\x7b\x28\xe2\xb8\x20\x75\x23\x2e\xcc\x05\xcf\x67\x73\x67\x43\xd2\x67\x46\x4f\xad\x6e\x2f\x7f\x5c\xb2\x91\x6f\xbc\x97\xdf\xe5\x34\xd9\xce\x42\x77\x57\x2a\x43\xf6\x69\x78\x8f\xe4\xdc\x9f\xd6\x09\x34\x5b\xbb\xb1\xcb\x83\x6e\xdf\xa7\xfd\xd6\xfb\x6b\xa0\x9b\x9e\x83\xdf\x9c\xf2\x24\x01\x4f\x83\x24\xe9\x13\x11\xf5\xdd\xc3\x84\xef\xe9\x66\xc8\x79\x7e\x00\xf0\x75\x91\x18\xd1\x4a\xfe\xba\x31\xa2\xa1\x44\x6e\xf4\xd5\xa0\x05\x13\xaa\xc6\x19\x61\x75\x36\xb6\x9f\x96\x2b\xc0\xbc\xb3\x80\x41\x17\x3d\xb6\xb7\xa0\x41\xb7\x24\xaf\x1c\x38\xb8\x66\x1e\x87\x1a\x3c\x58\x61\x76\x3e\x96\xaf\xb8\x66\x5c\xe0\x90\x51\x7c\xfa\x7a\x89\x47\xac\x5f\xca\xa7\x70\x95\xb2\x27\x8b\x22\x20\xdb\xe8\x10\x21\x33\x83\x3a\x1b\xd6\xb0\x02\x6e\x34\xfd\x17\x68\x3a\x06\xbc\xd6\x84\x14\xba\xb0\x41\x88\x26\x27\xf1\x11\x8e\x16\x51\x42\xa3\x40\x67\x9e\x09\x9c\xcd\xeb\x38\x9e\xdb\xf9\x0e\x75\xe7\xad\x50\x77\x9a\x0a\x52\x6d\x12\xb7\xed\xe8\x8a\xe1\x94\x74\x68\x40\x75\x68\x40\x3d\x8f\x77\xc1\x8a\xd2\x5a\x6f\x08\xa3\xb0\x7c\xee\x3a\x48\xa0\x37\x80\x04\xda\xe6\xf0\x15\x78\x3f\xa5\x63\xd7\xc1\x14\x7d\x68\x05\x53\xe4\x2f\xc1\x83\x42\x9e\x69\x3e\x8f\x6f\x8c\x68\xb2\x3c\xb0\xb7\x84\x25\xaa\x11\x17\x36\x91\x9b\x56\xe1\x12\xad\xa2\x8b\x56\xeb\xf2\xb6\x28\x41\x9b\xad\xcc\x46\x00\x40\xb5\x77\xd7\x81\xc0\x01\x35\x6f\xc3\x81\x9c\x9b\x7d\x66\xb5\x6c\x56\x3b\x34\xcc\x6c\xd9\x44\xc1\xda\x2c\xc9\xc5\xd3\xc3\xfb\x4a\x74\x29\x8a\xac\x6d\x97\xec\xd2\x77\x3e\x68\x22\xd0\x9c\x27\xb1\x03\xa1\xf0\xab\xe5\x3b\xf0\x99\x00\x7e\x81\xdc\x66\x40\xb1\x73\xd0\xb6\x8a\x82\x60\xab\x52\x5a\xfc\x26\xc2\x70\xf7\xc0\x68\xf6\x61\x45\xf0\x9c\x64\x1b\xfb\xc1\x5a\x59\x44\x96\xcd\xdf\x2b\xc6\x58\x5a\x21\xb0\x9a\xd7\x0f\x73\xad\xdd\x77\xcd\xe0\x56\x89\x1e\x81\x71\x50\xd4\x95\xfa\x34\x74\x06\x4f\x9f\xa8\x33\x44\xe0\xb0\xc7\x95\x5e\x3a\x37\xbb\x56\x9e\xba\x2a\xb1\x6c\x11\x0c\xb6\x54\xb9\x6d\x77\x70\xa0\x14\x7f\x1e\x67\x58\xe0\x24\x21\x09\x95\xe9\x8b\x05\x03\x9f\x95\xdd\xb5\xfa\xac\x0a\x6e\x4c\x44\x2c\x4f\x27\x86\x14\xdd\x40\x6c\xb1\x3f\xc5\x91\xc8\x59\x08\x6d\xe6\x37\xc6\x17\x13\xcc\xe1\x5e\x00\xab\x52\x34\x87\xaa\xad\x53\x4c\x05\x23\xb2\xb1\x46\x26\x89\x72\x41\xd5\x62\x6c\x4b\x8e\xb6\x3f\x70\x77\xf6\xcb\x33\xfb\xe1\x6a\x0f\xb7\xcb\xea\x77\xfd\xf9\x12\xa7\x19\x11\x50\x26\xc8\x15\xbc\x09\xca\xaa\x5a\xd4\x06\xe2\x6b\x0d\x41\xf8\xf3\xd2\xb5\xdd\x14\x38\x8c\x9f\xc7\x41\x46\xd5\x38\xaa\x12\xc7\xba\xc3\x5a\x87\x3b\xb5\x6a\x92\x2f\x8c\xbc\xd4\xe0\x45\x7e\x81\x2a\x23\x36\x6d\xc2\x34\xad\x07\x1c\xb8\x82\xc1\x5e\x59\x6c\x4c\x90\xf2\x6e\x95\xaa\x86\x71\x5a\xac\x9f\xba\xe0\xa3\x15\x83\xed\x07\x5f\xb5\x18\x71\xd0\xc9\x9e\x86\xad\x0f\xba\x10\x79\xa6\xe8\x64\x19\xda\x46\xed\xaf\x84\x68\x3f\x81\x34\x6b\xe7\x66\x28\x75\x6b\xea\x8a\x96\x38\xb1\x9d\x9d\x96\xff\x2d\x8e\x98\x43\x08\x32\x08\x4b\x61\x1e\xdf\x75\x4a\x95\x72\x89\x02\xc6\x00\xad\xa9\xb3\x6c\x9b\xfd\xca\x85\x7b\x60\xa8\xf4\x6a\x4c\x44\xc7\x23\xd6\x97\xe8\x99\x20\x46\x2c\x84\x44\x4d\x0d\x57\x6f\xd5\x86\xda\x4f\x13\xa2\x7b\xf2\xb1\x29\x5a\x78\xa0\x4a\xfa\xf2\x63\xa6\x8f\x29\x4e\x24\xe9\xe9\x86\xa1\x6a\xa9\xe2\x10\xfc\x89\xd1\xb3\xc0\x59\x46\xc4\x88\xd9\x2c\x0e\x70\xb8\x70\x9e\x98\xf6\x9b\x42\x5c\xed\x1a\x90\x71\x84\xa3\xf9\x2b\xed\x11\x86\x64\x9c\x68\x4e\x62\x97\x2f\x5c\xde\x1e\x37\x6f\x63\xb0\xde\x60\xb3\x86\x53\x57\x3e\xab\x67\x3b\x49\x22\xcd\x51\x7c\x99\xe9\x8c\x08\x3d\x6a\x4d\xc3\x4f\x84\x21\x3a\x75\xe3\xb0\xb1\x3b\xe8\x19\x3c\x53\x9a\xf4\x9f\x30\x4d\x4c\x02\xbe\xeb\xda\x09\x81\xc6\xfc\x3e\x62\xc6\xdd\xcd\xa2\x52\x86\x2a\x65\x54\xce\x35\xa7\xce\xc1\x27\x09\x6a\x46\x53\xe2\x0c\x7b\xda\xe4\x34\x0f\xf4\xeb\xab\x39\xe8\x13\x15\x9c\xa5\x90\x24\x63\x71\x99\xdc\xf2\x49\xa2\xfc\xf1\xa8\x4d\x71\x5c\x2b\x11\xc7\xb1\x2c\x1b\x3f\x8d\x5a\x49\x7f\x2d\x99\x5d\x8e\x4a\x59\x81\x51\x00\x2b\x04\x41\x9c\xae\xb2\xd8\x2a\xf9\xb7\x4b\x6d\x58\x4e\x6d\xa8\x5f\x9b\x43\x4c\x6f\xf0\x87\x78\xd3\x14\x87\xa6\xed\xdf\x87\x64\xbb\xc7\x54\x87\x37\xce\x09\x78\x99\x74\x80\xb7\xcd\xdf\x78\x89\xd4\x8d\x2e\xc1\xe1\x0d\x13\x1c\x5a\x5b\x6a\xcb\xb1\xd9\xcd\xc7\x76\xa3\xe4\x80\x35\x60\x4e\x75\xbd\x5c\x12\x25\x68\x24\xf7\xc1\x1f\x64\x86\x5b\x46\xb5\x81\x16\x98\xad\x91\x9a\xf4\x0b\xde\x09\x09\x71\x62\xbe\xce\xdf\x44\x10\xfc\x18\xf3\xe7\x25\x5b\x9d\x0c\xd1\x34\x2e\xb9\x16\x7b\x04\x89\xa8\x24\xa5\x48\x16\x2a\x11\x23\xd2\x1a\x3b\xf1\x88\xcd\x29\x11\x58\x44\x73\xc8\x6e\x2c\x36\xc6\x64\xc9\x1a\x40\x23\x13\xcb\x10\x7a\x9b\x36\xd8\xf4\x16\xeb\x5e\xb5\x30\x79\x7c\x3a\xbb\xe7\x7a\x24\xa9\xf9\xc4\x0b\x33\x56\xca\x08\x4d\x72\xad\xb6\x7f\xd7\x40\x7c\xbf\xd8\x2f\x1a\x8c\xef\x83\x89\x82\x2f\x5a\x06\xe4\x17\xd4\xd0\x05\xe5\xbf\x50\x50\x7e\xcd\x12\x6f\x16\x98\xbf\x95\xc9\xef\xf5\x63\x86\x5d\xcf\xaf\x11\x37\xbc\x2e\x68\x2b\x9f\x8c\x5f\xfc\xe8\xd5\xce\xb9\xed\x09\xfc\xc9\x13\x85\x91\x88\x85\xa6\xb3\x09\x89\x63\xe0\xb4\x8a\xdb\x4a\xd1\x05\xed\x38\xf3\x80\xbe\x7b\xb1\xd4\xc4\x8e\x13\xce\x66\x92\xc6\x06\x6c\x25\xc3\x50\xb1\x35\x34\x5e\x00\xb8\x00\xec\x6f\x92\x10\xe1\xbc\x12\x02\x7d\x2d\x29\xb3\x68\x8a\xfe\xb7\x98\x13\xc9\xbe\x52\xc6\x58\x80\xd9\x02\x3d\x32\xfe\x9c\x90\x78\x06\x3b\x54\x1d\xcc\x11\xa2\xa4\x87\xa8\xf2\x9f\x09\x40\x23\xe0\xb9\x1a\xe9\xb1\x43\xac\x99\xd1\x00\x88\xfd\x36\xa8\x89\xee\x9b\xf9\xe6\x18\xa1\x21\x43\x53\x1c\xa9\x1e\x92\xf9\xa4\x68\x3f\xe6\xa6\xc8\xb5\xd6\xbe\x83\x89\x17\x8d\x74\x31\xe3\x35\x9d\xd7\x9f\x0d\xc7\x1d\x34\xb9\xf6\x13\x8a\x77\x8a\xad\x7b\xc2\xbb\x40\x8c\x5e\xe6\xd2\x06\x61\x20\xce\xfc\xd1\xb7\xf0\x4a\x1e\x23\x1a\xf0\x3e\x0d\xde\x32\xe3\x71\xa3\xad\xb3\x32\x95\x4d\xc7\x52\x04\x42\x5a\x41\xc9\x3a\xaa\xa0\x5d\xb3\xdc\x5a\x6a\x92\x4a\x10\x9c\x5a\xe7\x80\xbe\x6a\x40\xac\x31\x61\x90\x7a\xf4\x54\x18\x09\x73\x93\x2d\xbe\xa0\xec\x51\xef\x6e\x81\x8a\x0d\xf5\xe5\xa1\xe7\xba\x4d\xcb\xf4\x8d\x47\xce\x38\x33\x0e\xc2\x9d\xe4\x4e\x3a\x63\x38\xd9\xd0\xc6\xb1\xb4\x72\xcb\x3e\x3d\x27\x67\x59\x71\x41\x4b\x11\xc6\xd8\x87\x4c\x8f\x1b\xd9\x90\x2a\xf3\x0d\xe5\x3d\x8c\x62\x92\x11\x16\x13\x16\x2d\x80\x44\x18\x20\xe7\x08\x86\x13\x84\xe1\x3b\x9c\x1c\xa3\x73\x93\x5f\xe3\x25\x3c\x7b\xad\xc3\x85\x9e\x62\x46\xa7\x5a\x4f\x00\x23\xac\x1d\xe5\x88\x99\x61\x3a\x1f\x48\x50\xb4\xdf\xaf\x58\xdd\xce\xe8\x1b\xe4\x6a\x47\x54\x62\x56\xfe\x1e\xad\xbe\x70\xa0\xb7\x55\xbb\xa3\x9b\x73\x35\x08\x64\x3e\x39\x82\x7f\x97\x12\xce\x1c\x50\x4f\x81\x22\x43\x12\x02\xe6\x40\xeb\xf1\x82\x8b\xb1\x09\x58\x6e\x1f\x7e\xbb\x35\x79\x1c\x41\x1f\x25\xa5\x26\xa5\x8c\xa6\x79\x1a\x38\xef\x4c\xc5\x82\xc8\xda\x2f\x4d\x26\x46\xa6\xf5\x80\xc8\x81\x97\x23\x7d\xb9\xb2\x05\x9a\xd1\x27\xc2\x46\x2c\xe3\x94\xa9\x63\x74\xc5\x15\x09\x4a\x44\x18\xe8\x28\x9e\x29\x9a\x1a\xb4\x53\x41\xf4\x39\x30\xa0\xd8\x00\x34\x39\xc7\xaa\x87\xe2\x1c\x8e\x2a\x23\x4a\xb3\x0e\x7d\xe3\x2a\xd8\x19\x88\x8f\x16\x23\x66\x6e\xba\x29\xa6\x49\x2e\x88\x95\x59\xb1\xc9\x8b\x29\x86\x5c\x8c\xcc\x22\xa1\x05\x93\x48\xe9\x6c\xae\xf4\x16\x69\x19\xcf\xfa\x1b\xe7\x9a\x1b\xf1\x11\x9b\x10\x84\x51\xc6\x25\x55\xf4\xc9\xfb\x2f\xe9\x14\x61\x29\xc1\x82\x72\x8c\xce\x4b\xf6\x7f\x2a\x41\xf5\x6e\x8a\xab\xa5\x6c\x6c\x6d\xcf\xcd\xf9\x38\x3b\x6f\x64\xa9\x17\xbb\xca\x78\x22\x79\x92\xab\xd0\x05\x5b\xbf\xb7\x85\x69\xdc\x01\xf7\x83\x81\x98\x4f\x47\xcc\xd1\xb5\x3c\x46\x7d\x89\x24\xd7\xbb\x24\xcd\x56\x46\x82\x2a\x22\xa8\x41\x71\x22\xca\x6c\x82\x3f\xa7\xfe\x0c\xa4\x58\x3c\x6a\x11\x2a\xb4\xc0\x1b\x4c\xd1\x92\xb5\x63\x62\x24\x24\x80\xb5\x0a\xb7\x03\x4c\xff\x88\x71\x76\xc4\xc8\x0c\xaf\xdb\x91\x11\x2b\x6d\x09\xfa\x9a\x4e\x0b\x85\xb4\xc9\xe7\x18\xac\xdd\x18\x22\x9f\x9a\x76\xc9\x74\xdc\xb4\x49\xd3\x84\xe3\x35\x6e\xe3\x69\x71\xe8\xd1\xdf\xf9\xc4\x8c\x51\xeb\xfd\x5c\x81\x14\xa8\xd5\xab\x29\x17\x64\x8e\x59\xdc\x73\x9b\x55\x1e\x1b\xdc\x8c\xd6\xd4\xe6\x94\x31\x90\x04\x1d\x88\x30\x31\x58\x4c\x98\x05\x7b\x61\x15\x37\xbb\x15\xc5\x3e\x6c\x74\x57\xf8\xd6\xa0\xf6\x89\x31\x40\x18\x96\xb7\xc8\xec\x11\x97\x34\xcd\x92\x22\xa7\x29\xb0\x8d\x4e\xb5\x88\xe5\x78\x24\x7f\x02\xd3\x95\xd3\xda\xe0\x56\xb7\x3b\xa7\xe9\xac\x66\xe4\x9e\x91\xc2\xad\xe1\x6c\x5e\xa6\x0c\x66\xc0\xc2\xbe\x96\x44\xff\x53\x91\x42\xed\x33\xc2\xfa\x88\x39\x11\xe4\x1b\xe0\x32\xb6\xd9\xc0\x78\xa6\x45\x68\x03\xf3\x6a\xd7\x0f\x45\xc6\xc9\x5d\x3a\x27\xf6\x30\xb8\x57\x6b\x2e\xaa\xef\x28\xc3\xa5\xcc\xdb\x2d\x04\xbf\x24\xdf\x28\xb9\x2a\x70\xfb\x2d\x9a\x6a\x9a\x28\xbc\xae\xcc\xc8\x06\x94\x60\xf6\x99\x20\xdd\x9d\xa5\x66\x57\xf1\x06\x43\x44\xc0\x9c\x24\x19\x8a\xe9\x14\xcc\x52\x0a\xd8\xb7\x07\x16\x33\x58\xf0\xfa\xb0\xa7\x39\x33\x20\x71\xc6\x23\xf2\x6c\xf1\xb6\xed\xd5\x58\x34\x7e\x3c\x62\x43\xf5\x95\xd4\x22\x3a\x67\x33\x7d\xd1\xc4\x4f\x54\x16\x45\x4e\x22\xce\x64\x9e\x12\x61\xbb\xd0\x37\xb2\xa6\x48\x5b\x20\x00\x3b\x19\x4a\x8f\x4d\xef\xfd\x13\x4e\x68\xec\x0a\xf1\xe8\x1f\xcd\x99\xd3\xa3\x94\xce\xa3\x58\x13\x12\x66\x37\x37\xd6\x6b\xf5\x66\x62\xfd\x8f\xa1\xe4\x8e\xd2\x42\xc8\xc7\xd6\x56\x7f\x52\x15\xf1\xed\xaa\xaf\x10\xef\x27\x4b\x93\x42\xab\x05\x23\xbb\x0a\xe7\xeb\x50\x0c\x1d\xa2\x6e\x6e\x42\x80\x75\x3f\xce\xe8\x63\x06\xb7\x11\xfb\xa9\x4c\xd0\x8e\xda\x70\x96\x50\xbc\x27\x14\x64\x03\xa9\xb0\x16\x2f\xcc\x75\xc0\x85\xd5\x70\xec\x9d\xd3\xbc\xb5\xe7\x3b\x96\x89\x90\x11\x4e\x96\x77\x78\x85\xbd\xd9\xbc\xbf\x5a\x09\xb0\xc7\xcd\xb4\xbd\x32\xe9\x37\xe2\x49\xb2\x49\x09\x93\xca\xcc\xcf\x8a\xcf\x57\x8f\xa8\xe8\x47\x6f\x80\xdb\x0b\x38\x35\xe6\xf2\xc6\x89\x35\xa5\x48\x65\x77\x29\x7c\xc9\xa8\x61\x0b\xcb\x5a\x47\x8c\x4f\xa1\xc8\x4d\xd2\x14\xd5\x95\x09\x9e\xd2\x4d\x50\x96\x4d\xa0\xd3\xad\xb3\x8b\xaf\xb1\x32\x38\xeb\x39\x88\xa6\x86\xbc\x6c\x8f\x90\xaf\x87\xad\xb8\xb9\xe2\x0c\xa5\x38\xdb\x6a\xc1\xd7\x79\x85\xfa\x28\x35\x2e\x39\xbb\x7a\x80\xb7\x48\xa0\x5e\x0c\x2c\xf2\x33\x5e\x14\xa9\xd1\x4d\xf8\xb9\x6c\x23\x72\x78\xd0\xaf\x0f\xd9\x94\x6f\x70\x38\x8b\x54\x66\x7b\xfa\xb0\xa3\xd9\xe0\xfc\x79\x2f\x85\xd9\x7d\xb3\xa6\x6d\xce\xe3\x59\x1d\x51\x6f\x7c\x32\xdd\x0a\xbe\xa4\x8d\x32\x64\x22\xa1\x79\x72\x93\xbb\xb5\x7c\xb4\x82\x16\x11\x0c\x67\xf5\x52\x5d\x96\xe8\x70\xef\x6b\x54\x69\x07\x19\x53\xb8\x0b\xa6\xbe\xa9\x6f\xf5\x15\xd6\xcc\x1e\x92\x56\x8b\xb5\x23\x76\xc3\x66\x38\xc0\xae\x47\x8f\xfa\x5b\x7f\x42\xd7\x16\x39\x68\xbf\x18\xc0\xcd\xa4\xb5\x73\x15\x91\x99\x36\x45\x6d\x4a\x13\x2d\x62\x0f\x6b\x0c\x9c\x2e\x41\xcc\x07\x54\x99\x50\x79\x27\x3d\xe5\x82\x06\x85\x41\x9d\x8c\x84\x28\x14\x28\x09\x9d\x3c\x81\x42\x0f\xa6\xc5\x39\x7f\x36\xd1\xe9\x82\x6a\x9e\x65\x84\x55\x05\xe6\x1e\xcd\x0b\xa8\xb5\x96\x18\x63\x93\xff\x80\x9b\x98\x41\x6c\x6b\x1f\x17\xa3\x6a\xd8\xd2\x7d\x94\x78\x6a\x9f\x7f\xe7\x7a\xbd\xd7\x5f\x2c\xef\x4d\xed\x08\xef\xcb\xad\x6f\x3c\x3a\x2f\xe5\x6f\x1e\x30\xf5\x11\x3e\x75\x4a\x0f\x46\x53\x41\xc0\xc1\x9f\x7a\x4c\x0d\x03\xaa\xcb\x39\xdc\x77\x77\xe7\x3f\x9c\x3c\x0c\x11\x51\x11\x4a\xe8\x23\x19\xb1\x48\x3e\xf5\xb4\x78\xfc\x8f\x9c\x28\xfd\x73\x83\x47\x80\xa6\x84\x49\xe0\x04\x54\x2d\x61\x0f\xd5\x2f\xa4\x5b\x18\xfd\xdf\xf3\xf2\xf7\x2b\x48\x7e\x29\x7d\x18\x68\xd7\xd5\xbb\x01\x32\x85\x92\x1e\x66\x69\x65\x0d\xc5\x18\x5b\xe4\xa0\xae\x1a\xe6\x16\xe9\x42\xec\xef\x39\xdb\x50\xe8\x3a\x2b\x3e\x0a\x46\xd1\x20\xd3\xa5\x19\x06\xac\xeb\xcd\xf2\x90\xcc\x37\xb5\xad\xaf\x63\x22\x45\x5a\xb6\xb3\x2d\x17\x85\x43\x91\x12\x84\x00\x0b\xf1\xf4\x64\xef\x7a\x8b\xc4\xe1\x27\x16\x7c\x74\x3c\x62\x97\xce\xe3\x5c\xfc\x2a\x0b\x3d\x3c\x9d\x04\x10\xe0\xe5\x56\xa0\xd9\x98\x4a\xff\x03\x14\x74\x91\x79\xa2\x4c\x45\xbb\x29\x65\x38\xf1\x03\x35\x4f\xea\xb8\x84\xc0\x2c\x9a\xef\x6a\x42\xa6\xd3\x31\x49\x36\x91\x44\x87\xd3\x41\x22\x35\x7d\x47\x8f\x0d\xa7\x73\x9b\x9a\x8d\xc5\x64\x6c\x25\x5a\x53\xf7\x09\x15\x26\x68\x9c\x98\x8a\x72\x04\x81\x8f\xb2\x9a\x3d\x66\x00\x22\xf4\x2e\x5a\x49\xdd\xb8\x28\x4d\xda\x86\x0f\xc9\x86\x5e\x10\x56\x23\x26\x72\x06\xc5\x26\x7c\xc4\x02\x46\x05\x5e\x78\xe4\xfc\x07\xd6\x9b\x33\xd3\x6c\xc2\xc0\x71\x9b\x97\xb5\x7e\xc6\x73\x09\xb6\x9a\x94\x28\x7d\x41\x7d\x0d\x75\x60\x4d\xc8\x50\x0f\x65\x82\xa6\x60\x6e\x95\xdf\xd4\x6c\xdd\x19\x56\x38\xe1\xb3\xbe\x50\x74\x8a\x23\x75\x8f\x77\xd2\xc0\xb1\x6d\x66\xdb\xf0\x53\x37\x0c\x34\x3c\xd7\x8b\x3f\x23\x8c\x08\x98\xa8\xd6\xc9\xeb\x8f\x30\x3c\xd9\x8a\x73\x83\x95\xcd\x1a\x46\xa5\xb7\x58\xe0\x5c\xf1\x54\xeb\xb7\x38\x49\x16\x3d\x63\x91\x25\x68\x8e\xe5\xdc\x6d\xb4\x31\xa6\xb5\xb9\x9b\xec\xe2\x9e\xe1\x68\x4e\xee\xa0\x2a\x72\xdd\xe2\x56\x46\xf9\x81\xb0\x3c\xfd\x70\x8a\xfe\xa7\x98\xe3\x59\xff\xec\xfb\xc1\xf8\x7c\x78\xd7\xff\xee\x62\x70\x1e\xcc\xc7\x3e\xb9\x1c\xde\xdd\x2d\xff\xfa\xfd\xf0\x7e\xf9\xc7\x9b\xeb\x9b\x87\x8b\xfe\x7d\x5d\x2b\x17\xd7\xd7\x3f\x3c\xdc\x8c\x3f\xf6\x87\x17\x0f\xb7\x83\x9a\x4f\x1f\xee\x9b\x1f\xde\xfd\x30\xbc\xb9\x19\x9c\xbb\x55\xf9\x5b\x70\xba\xc0\x7a\x0c\xa9\x17\xf5\xd3\xa8\x1e\xc0\x23\x54\x7e\xf1\x14\x3d\x54\x4b\x1f\xd8\x58\x64\x83\x63\xf1\x8c\xa5\xe6\x61\x10\x0a\x3f\x62\xc8\x7d\xae\x17\xa5\xe9\x53\x13\xae\x13\xcd\x09\x4a\x38\x7f\xcc\x33\xcb\xda\x4c\x7c\x18\xe3\xc6\xf0\x43\x64\xd0\xda\xf7\xc3\xfb\xd3\xe5\x12\x0c\xbe\xb1\x00\x31\xcb\x9d\x01\x18\x17\x76\xec\x14\x6c\x29\x0e\x9a\xbf\xb0\xde\x06\x3d\xf8\x9d\x59\xd5\x8f\x69\x0d\x33\x55\xe9\x26\x8e\x6d\xd1\x5f\x37\xb1\xa0\xe1\xf2\xbe\xae\x5a\x4d\xbf\x1c\xa6\xf6\x14\x9a\x90\x08\xe7\x26\xa8\x49\xdf\x53\x42\x70\x11\x0e\xb8\xa0\x87\xfd\x35\x6a\xe9\xa8\xb6\xc1\xca\x9e\xe9\x89\xcb\x47\x9a\x65\x24\xfe\xb0\x2c\xbf\x94\xab\xc3\xda\x9a\xe4\x7c\x8a\x82\x33\xa9\xf5\x7a\xd0\xf9\x5d\xe1\x94\xf9\xc2\x7b\xd2\x20\x70\xa3\x08\x65\x01\x20\x67\x7d\x27\xf8\xc2\x16\x14\x5c\x63\x58\xa1\x67\x02\x29\xd5\xb9\xad\x1c\x65\x74\x6f\x7d\xb6\xa1\x3b\x63\xd3\x76\x75\xe0\x4a\xa9\xd6\x8d\xcc\x78\x1f\x02\xb7\xfe\x5e\x92\x3a\x46\xbc\x43\x5e\xec\xb9\x69\x14\xb8\xb3\x8b\x79\x83\x11\x37\x04\x37\xb8\xdb\xa0\xc6\x42\xbe\x42\xbe\x5a\xbe\x91\xd6\x5c\x16\x9a\x6d\xb7\x19\x8f\xc3\x02\x29\x01\x5c\xb7\x1f\x58\x09\x04\x79\xed\x5a\xdd\xf3\x18\x2f\x34\x71\x40\xac\xb1\xcc\xb3\x8c\x0b\x85\x1a\xda\x30\x6e\x7c\x33\x3e\xb8\x73\xec\x3c\x3c\x8f\x83\x46\xb4\x84\x21\x6b\x6a\x69\xb4\x83\x47\xb0\xeb\x5a\x30\x8e\x30\x40\x16\x14\x41\x5f\xf7\x28\x2d\xa9\xd4\x25\x0a\xad\x13\x7e\x77\xc9\x30\xc8\xf4\x05\xdf\xb6\x0c\x5f\x5d\xef\xd7\xae\x85\xda\x2d\x4f\xc8\x54\x8d\x6b\xbd\x3e\x2b\x0c\x9c\xba\x45\xd6\x84\x28\x43\x67\xf3\x3d\xb4\xd8\x5e\x4b\xf8\xa3\x0d\xec\xd1\xaa\x41\x60\x21\x10\x9c\x2b\x23\x9f\x16\x3a\x0c\x72\xab\x09\xe6\x05\xdb\xa9\xcd\x05\xf3\x42\xa0\x96\xf9\x8d\x3f\xd4\xa7\x4d\x1d\x8f\xd8\x00\x02\x28\x0a\x45\xc4\xa5\x88\x81\x16\xb0\x56\xfe\x2f\x15\x1d\x7d\xd5\x68\xcd\x66\x84\xd7\x82\xee\x6d\xbd\xfc\x64\x81\x8a\xc2\xb2\xa5\xef\xda\x9c\x1e\x63\xf5\x76\x22\xa0\x99\xb0\x2d\xe3\xae\x48\x66\x2d\xf3\x66\x9e\x45\xa4\x0f\xc4\x87\xe9\xae\x8e\xd1\x4f\xce\xf2\x03\x81\xaf\x45\x4d\x66\x1b\xbb\x91\xe0\x85\x03\x85\xac\x5b\xd8\x7d\xe0\x2c\xee\x3b\x14\x76\xf5\x02\x7b\x40\xa7\x9a\x55\x2e\x29\xe0\x8c\x19\x8b\xec\x06\x69\x1f\x67\xfe\xa3\x3b\xb2\x3a\x2a\xe0\x23\x94\xe1\xb4\x91\x55\x20\x74\xb0\x64\xf1\xbf\xcc\x66\x99\x4c\x54\x57\x58\xcb\x96\x45\xb4\x1e\x54\x7d\x7e\xc0\x03\x68\x12\x55\xd1\x94\x26\x09\xc8\x01\xc7\xa8\x0f\xe5\x81\x21\x91\x53\x5f\x85\x2e\xc0\x82\xce\x18\x5f\x97\x63\xd6\x40\x4c\x51\x40\x4c\x77\xcd\xc4\x24\x81\x9a\x8a\x3c\xfe\xfd\x50\xd4\x1e\x30\x5d\x34\x6f\xc1\xcb\x88\xd8\xed\x91\x5c\x36\x50\xde\xdf\x22\x3a\x7a\x69\xb8\xc1\x87\xff\xaa\x1f\xfa\xa7\x1c\x0b\xcc\x14\xc4\xfc\x5a\xd1\x5d\x90\x20\xf5\x88\x7c\x86\xf8\x0c\x66\x0c\xc1\xf0\x53\xb8\xb9\xce\xe5\x0f\xe1\x5e\x88\xc6\x3d\x44\x8f\xc9\x31\x54\x67\x13\x5a\x96\x98\x14\x6f\xce\xb5\xe4\x30\x62\x4b\xb1\x8c\xc7\xa8\x9f\x48\x6e\xbf\x20\x2c\x4a\xa0\x1c\x77\x10\x9e\xec\x29\xdf\xba\x95\x26\x0b\x50\x50\x60\x2b\x8b\xe6\xb9\x7d\x10\x7c\x08\x45\xc6\xc0\x27\x9e\xc0\x49\x2f\x7e\xff\x3d\xcf\x8c\xb7\xa2\x29\x4e\xe2\x05\xcb\x39\x2c\x5d\x43\x2f\xb6\x49\xa6\x54\xe0\xaa\x0d\x82\x37\x60\x63\x8a\x18\xd3\x00\x81\x05\x7d\x8d\x15\x4a\x08\x96\x0a\xfd\xe1\x9b\x8d\x62\x43\xdc\x04\x0b\xee\x6a\x8f\x6f\x91\x28\xe6\x52\x0d\x42\xe1\xce\x77\x0c\xb5\xe3\xb0\x50\x08\x23\x46\x9e\xc3\xc8\x52\x0e\xc1\xc0\xae\x20\x1c\x09\x72\x5b\x4d\x3c\x99\xc9\xcc\x87\x6c\x0d\xa3\x32\x35\xf0\x11\x07\x77\x6c\xdd\xa7\x76\x58\x35\x94\x65\x95\x27\x1b\xe2\x09\x90\x5c\x45\xd0\xff\x1c\xab\x11\xb3\x9c\xd5\x85\x8d\x04\x69\x5e\xfd\x24\x29\x07\xda\x63\xc8\x25\x61\x7a\xc2\x50\x9f\xfd\xd8\x2f\xd0\x15\xa8\x5f\x3e\xda\xb9\x64\xa7\x2b\x0e\x8b\x89\xc7\xf3\x78\x47\x61\xdb\xb5\xd2\x4e\x9d\x7d\xf9\x15\x85\xe0\x9a\xee\x2f\x4c\xa1\xfc\x16\xc2\x30\xa9\x1b\xf2\x9a\x83\xb5\x6c\xd3\x5f\x21\x1b\xef\xbb\x83\xf6\xa2\x72\xbd\x7d\x1c\xae\xd9\x67\x5e\x63\x6e\x6f\xd8\xdc\x40\xb6\xd8\x45\x01\xf7\x61\xf7\xaf\xe5\xf1\x2d\x0d\x7d\x18\x43\xd2\xdf\x7a\x2e\x58\x24\xd1\x39\xd6\x61\x62\xaf\xe3\x20\xa7\x27\x48\x21\x80\xe0\x3f\xc7\xf8\xec\x9b\x0d\x9e\xd7\xec\x7d\x4f\xbf\x57\xcc\xdf\x4d\xc5\x07\xc1\x2d\x4f\xbc\x59\xd8\xeb\xc7\x7f\xc7\x11\x44\xfa\x43\x4f\x2e\xc7\x60\x19\x90\xc9\xc1\x58\x63\x30\xe6\xd7\x8a\x87\x99\xe0\x11\x91\xf2\x18\x0d\xe0\xa2\xb1\xff\x44\x78\xea\x1c\x12\xc1\xcb\x23\xa6\x35\x13\x87\xdf\x12\xb4\x5f\x26\xf1\xba\x13\x60\xc0\xe0\x76\xf2\xe5\xa4\xeb\x6b\x94\x34\x69\x13\x0e\x8b\x0e\xda\x80\xb2\x06\x68\x30\x3b\x45\x31\x8f\x1e\x89\x38\x11\x24\xa6\xf2\x14\x7c\xeb\xaa\xd1\xa9\x97\x6a\x6d\x7b\x67\x49\xa3\x29\x50\x60\x4d\x52\xdc\x99\xe9\xdf\x06\x58\xbb\xf0\xda\x1e\xa2\x53\x50\x27\x5c\x4e\x86\x09\x42\x76\x70\x37\x84\x29\xb1\x80\xb8\x7e\x6f\xca\xaa\x2c\x84\xd3\x34\xb4\xd0\xd6\x94\x4d\x24\xf6\x11\x83\xb3\xe5\xb4\xef\xe7\x44\x12\x17\x70\x60\x26\xa5\xb8\x8d\x65\x36\xec\x22\xc3\x6a\x2e\x21\x75\xb5\xbc\x06\x56\xe9\x82\x4f\xf5\x0a\xe1\x0c\xe2\x15\x8c\x95\xa2\xf8\xc8\x27\x58\x4a\x45\x93\x64\xc4\x18\x21\xb1\x44\x90\x65\xfa\x55\x6d\x86\xbc\xfe\xb4\x87\x70\x1c\xa3\xff\xfd\xf5\xc7\x8b\x9f\xef\x07\xe3\xe1\x15\x18\xad\x87\x17\x83\x6f\x7a\xfe\xc7\xeb\x87\x7b\xff\xab\xb1\xb0\x3c\x11\x81\x52\xfc\x08\x2a\x1e\x93\xc4\x26\x4f\x90\x11\x0b\x47\xea\xb0\x03\xf4\x13\x49\x5c\xa4\xab\x15\x53\x3c\x84\xa2\xdd\xc3\xc6\x8a\xc5\xc6\xe6\xb7\x81\xf2\x7b\xeb\x3f\x59\x4d\x83\x8e\x78\x7c\x17\x4e\x0c\x84\x1c\x19\x2c\x83\x64\x72\xab\xfb\x16\x04\x47\xd8\x8c\xb2\xa6\x78\x3c\xc2\x9e\x5e\x52\x88\xff\x81\x2c\x7e\xd4\xea\xf5\x0d\xa6\xa2\x35\xed\xd5\xa3\x01\xb9\x13\xa3\xf5\x74\x2c\xab\x87\x4a\x1a\x59\xd8\x64\xdb\x34\xc6\x7c\xd6\x01\xc1\xbd\xf9\x74\x2d\xbc\x14\xf9\xac\x84\x43\xa9\xf0\xf9\x1c\x0e\xca\xc9\x5f\x34\x05\x0d\x8e\xd8\xfd\xf5\xf9\xf5\x29\x22\x09\x9e\x70\x08\xe5\xb7\x21\x41\xae\x09\xbb\x60\x11\x4f\x83\x86\x4a\x08\x25\x3d\x94\x15\x08\x25\xa1\x11\xed\xd8\xb4\xb1\x06\xa9\x24\xe3\x62\x19\xdf\x63\xbf\x2a\xa0\x9d\xec\x0d\x17\x6d\xae\x7f\xfd\x1a\x2c\x1d\xcf\xb4\x22\x57\xe1\xbc\xf6\x6e\x9e\x12\x6c\x6a\xe9\x1b\xb7\x90\xb5\xe5\xdb\x00\xd6\x24\x29\xd5\x53\xd4\x07\x47\x1e\x5b\x17\x7c\xf1\x26\x67\xe8\x87\xbf\x48\x34\xc9\xd5\x88\x95\xdb\xe0\x0c\xf5\x7f\xba\x43\xdf\x61\x15\xcd\xbf\x19\xb1\x6b\xad\x66\xfe\xf0\x97\x06\x28\xa5\x8d\xd1\x09\xf5\x9a\x9c\x63\x85\x2f\x38\x8e\x29\x9b\xd5\x41\x13\x16\xf5\x63\x06\xf7\xfd\x53\x74\x6d\x75\xf8\x22\x13\xc4\xa7\x04\x07\x0d\x01\x43\x86\x89\x38\x2e\x02\xac\x9c\x95\xe1\xdb\x8c\x66\x06\x17\xd6\x88\xdd\x1b\x4c\x46\xcd\x55\xa9\x42\x19\xb7\x35\x8c\xb4\x56\x66\xd0\x2a\xb1\xcb\x90\x22\xc9\x02\xe9\xd5\x01\x32\xf6\x9b\x61\xe5\x31\x90\x67\x96\x99\xfd\x88\x81\x82\xee\x73\x53\x12\x1e\xe1\x04\x62\xf2\x8e\x02\x9b\x9e\x56\xdb\x79\x0e\xf9\xe1\xa6\xe8\xf9\xa2\x1c\x3a\xeb\x21\x0b\xbc\x50\x16\x6e\x14\x18\x00\x60\x1f\xad\x37\x36\xe5\x9a\xe3\x18\x2c\x36\x30\xbe\x25\x66\x75\xf4\x87\x1e\x9b\xcd\x2c\x8b\x7e\xea\xd3\xb6\x78\xce\x1c\x16\x49\x04\xe6\x7b\xb6\x80\xf0\x6d\x28\x3a\xc2\x21\xf4\xa3\xe0\xce\x96\x28\x97\x76\xd1\xdf\x89\xc1\x67\x23\x66\x22\x05\x4b\xfb\x12\xa2\xf7\x04\xbd\x73\x06\x81\x8c\xcb\xb9\x62\x79\x66\x03\x1b\xad\xac\x9f\x09\x72\xe4\x33\xa0\xe2\xd2\x9a\xea\x1b\xf6\x18\xdd\x86\xea\x75\xcc\xa3\x3c\x75\xc8\xca\x90\x3d\x55\x94\x95\x2f\x49\x3c\xe6\x62\x5f\x47\xf1\x80\xd2\xa2\x08\xa4\x8f\xb7\xd6\x8f\x0d\xc1\xf4\xc3\x4f\x97\x25\xf5\x66\xc1\x17\x78\xc7\x6e\x51\x6b\xa6\xa1\x71\x56\x6e\xa9\xd4\xda\xce\x79\x89\x57\x05\xfa\x2b\x17\x20\x6c\x91\xcf\x19\x07\x23\xb7\x49\xcf\xe2\xf1\x57\x12\x0d\x6f\xb4\x04\xa4\x35\x5e\x7f\x06\x73\xa9\x4c\x70\x19\xa4\xeb\x98\xaf\x4d\xba\x40\x0f\x7d\x8b\x46\xf9\xb7\xdf\xfe\x29\x42\x9f\xdd\x1f\x7f\xfe\xcf\xff\xfc\xd3\x9f\x37\x49\x27\x71\x0a\x39\xb4\x5b\xac\x91\x2f\x27\x55\x16\x89\xc2\x1d\x58\xe6\x54\x3b\xec\x82\x3d\x80\x4d\xcb\xbf\x0d\xca\x63\x10\x3b\x84\x67\xf6\x84\xcb\xf0\x64\xa2\xd2\xd1\x2c\x22\x09\x24\x51\xbd\x32\x87\xf0\xc2\xae\x95\xe8\xff\xd7\x0a\xb0\xb2\xb1\x3e\x2a\xdb\xc5\x38\xd1\xc4\x8b\xd7\xba\x11\xf4\xb5\xb5\xff\x29\x70\x20\x7e\xe3\x2e\x38\x9e\xc4\x44\x98\x31\x79\x93\x9d\x37\x24\x02\x73\x20\x9f\xb3\x84\xc7\x0e\x1e\xb5\xc8\x05\xa4\x20\x20\x0c\x3e\x63\xcd\xb9\x7b\x16\x46\xcb\x7c\x64\x3c\x2f\x53\x1c\x19\x54\x50\x89\xbe\xfe\x7c\xaa\x7f\xeb\xa1\xc5\x29\x04\x91\xf6\xd0\xaf\xa7\x16\x2d\x07\x0b\x35\xd6\x3f\x7d\xe3\x64\x6d\xdb\x04\x0c\x9a\x4a\xf4\xd5\xc9\x13\x16\xa6\x66\xf4\x89\x19\xd1\x57\x96\xb3\xfa\xba\x78\xa1\x6c\x9e\x70\xfe\x68\x03\x6c\x97\x3e\x3c\x71\xc0\x6b\x40\xde\xde\x6f\x62\xb6\xde\x27\xe6\x2b\x74\x04\x2f\x10\x74\x9c\x4d\xd0\xf1\xdf\x25\x67\xe8\x78\x81\xd3\xc4\xfe\xea\x9e\xda\xf8\x5f\x2c\x6d\x4e\x5c\xec\x83\x7c\x92\x85\xb1\x94\x7e\x97\xf0\x09\xcc\xea\xd2\xcd\xd4\x44\xd0\xc2\x40\x8b\xdb\xa7\xb8\xb0\xec\x44\x5c\x22\x2a\xe0\x07\xa5\x5c\x99\x57\x80\xc7\xd5\xcd\xea\xb3\x1f\xd2\x7f\x1b\xbf\x30\x2c\x8a\x4b\xe2\x33\xc6\x61\x1f\xbd\xa6\x1b\xfd\x8c\xbe\xb6\x2c\xe8\x1b\x7d\xc7\xd8\x70\x65\xb3\x0c\x75\x1d\x2c\x7c\x07\x3f\x07\x1d\x50\x86\x4c\x5a\xe6\x8a\x2f\x7f\x3d\x39\x3e\x3e\xf6\x5f\x43\xd6\xfa\xff\x8b\xa8\x92\x24\x99\x9a\x96\xdc\x0d\xb6\x18\xb1\x4b\x57\x78\xc1\x19\xaf\x0b\x48\xc7\x4c\x70\xc5\x23\x9e\xa0\xa3\xc2\xa0\x1b\xf3\x48\xa2\x7f\xd7\x62\x6d\xb0\x94\xf0\xa3\xd6\xe3\x1a\x60\x60\x0d\xd2\xf3\x2b\x1d\x2a\x6b\x10\xaf\x1e\xab\x10\xc5\xcd\x2b\xb6\x58\x86\x55\x3c\x80\x16\x34\xe5\x9c\x58\xa4\x37\x21\xf4\xcb\xe4\xb3\x82\x47\x0d\x40\x7a\xb5\xa1\xec\xf5\x37\xe5\x12\xbb\x2d\xf0\xf4\x0c\x59\x37\x2c\x80\xc5\xbb\xb2\x9c\xc1\xcc\xb3\x17\xba\x4f\xf4\xe5\xc2\xc2\x52\x00\x32\x4f\x53\x2c\x16\x27\xc5\x69\x5b\x26\xce\x02\x69\x0d\x78\x4c\xe2\x16\x00\x5c\xb8\x89\x3d\x5a\x36\x8a\xc1\x8a\x97\xee\x46\xf3\x67\x37\x82\x5a\x86\x01\x62\x01\x61\x11\x8f\x2d\x5d\x17\xd9\xa7\x65\x89\xc5\xbf\xb3\x2c\xab\xb8\x88\x18\x59\x18\xe3\x98\x32\x10\x1e\xf6\x0d\xf7\x71\x03\xfb\xe6\x63\xa8\x8a\x4b\x66\x1b\xb8\x47\x87\xd7\x77\xee\x9b\xf6\x97\x2e\xac\x43\x59\x64\xc7\x49\x88\x8f\xc7\x66\x48\xe0\xe7\xe2\xfa\x85\xd8\x0e\x63\x9d\xc9\x7d\x6e\xae\xf9\xf7\x19\xbf\xa1\x89\xbe\xb5\x80\xc6\x8f\x47\xac\xf4\x73\x0f\x91\x84\xa6\x94\xf9\xd8\x3a\xc3\xdc\xf9\xd4\x48\xcf\x8f\x54\xe9\x2d\x93\xf1\xa3\xe6\x60\x0e\xd7\x29\x50\xa9\xfa\x6c\xe1\x48\xc7\x3b\xa6\xac\x05\x22\x97\x7a\x5c\x85\x8e\xae\x85\x59\xdd\xc4\x91\x15\x48\x69\x40\x78\x70\x7e\x47\x4c\xb7\xe6\xce\x52\x11\x2e\x1c\xb4\x17\x34\x77\xe4\x00\xf1\x03\x0e\x00\x7d\x94\x62\x7e\xbd\xfc\x5b\x23\xa0\x0c\x58\x9e\xee\x9a\x6c\x62\xc3\x87\xdf\xca\x4c\x77\x23\x88\xbb\xa9\x6c\xe2\x12\x61\x79\xea\x0e\xd4\x06\x14\x37\xb0\xe2\x4f\x4c\xa2\x04\x1b\xa4\x1a\xdd\x10\x44\x3e\xf6\x8c\x83\x34\x0b\xfa\x32\xd7\x8b\xe9\xc6\xd4\xd8\x49\x08\xfb\xda\xfc\xfb\x1b\x64\xef\x86\x6f\x7b\xf6\x3e\x17\xd2\x23\x80\x98\x3d\x87\x1a\x8d\x24\x36\x36\x74\x40\x25\x9e\x61\x11\x1b\x6b\x79\xa8\x55\x98\x0c\x5e\x2d\x7f\x2d\x78\x8e\x9e\xa9\x9c\x8f\xd8\x3d\x77\x06\x47\xc4\xb8\xc7\x75\xee\x81\x32\xba\xd4\x1f\x96\xc0\x04\x60\xd4\x75\x14\xa0\x99\xf0\x4e\xb9\x46\x10\x05\x3b\x66\x3c\x26\xbb\x01\x18\xdd\x17\xbe\x0a\xe7\xbf\x16\xc4\xe4\x83\xc1\x4d\xd1\x94\x4e\x4b\xa4\xdc\xd0\x36\x5f\xdd\x78\xb8\x87\x6c\x3b\x50\x12\xf8\x79\x23\x74\xed\x10\x1b\xcc\xdf\x6a\xd0\x8a\xd3\x38\x83\x6c\xe0\xd2\xda\x7b\xb4\xe4\x5d\x37\x21\xaa\x41\x2b\x6a\x75\xf7\x9b\xb9\x47\xb0\xec\x3e\xc0\x18\xa3\x99\xe0\x79\xe6\x53\xe6\x5d\xba\x9f\xd9\x06\x2b\xd3\x0c\xd9\x94\x9f\x5a\x9d\xea\x82\xb2\x47\x43\xf1\x2f\xb5\x47\x06\x10\x9b\xc4\x25\x18\x37\x57\xa5\x15\xe6\x70\x84\x28\x8b\x92\x1c\x2e\x3e\xa9\x70\xf4\x68\x40\xbd\x9b\x8c\xbe\xfa\x9b\xf1\xfa\x64\xca\x06\x89\x29\x4f\x12\xdb\x6d\x71\x81\x16\x65\xac\x9f\x28\x46\x18\x3d\xdc\x0e\xeb\xfb\x7e\xa4\xcb\xce\x9c\xfa\xdb\xb3\x4c\x20\xf0\x3f\x3f\xd0\x8d\xe2\x2e\x2b\xb0\x78\xa4\x44\xea\xde\xb8\xd4\x04\xba\x6a\x88\x54\x69\x05\x22\xbe\xad\x31\xed\x6f\x4c\xa7\xb3\x2c\x1f\xeb\x85\x4a\x36\x09\x10\xd0\xa3\xf8\x74\xf3\xd0\x0f\xbe\x5b\x45\x2a\x9f\x6e\x1e\x50\xd0\x87\x01\x3c\x4c\x48\xa4\x7c\xa4\xf1\x31\x3a\x2b\x70\x88\xab\x92\x79\x4c\x9e\x68\x64\x52\x5c\x7b\x5a\x2a\x1a\x31\x80\xf7\xd4\xba\xce\x91\xc3\x84\x42\x9f\x6e\x1e\x2c\x92\x94\x87\x9b\xb2\x90\xca\x00\x61\xb1\xd9\xb5\x53\x01\xd6\x64\x9c\x1d\x81\xc4\x86\x45\x5c\x78\x3b\x7a\xa0\x5c\xff\x7f\xec\xbd\x5b\x73\x1b\x49\x72\x36\x7c\xbf\xbf\xa2\x22\x7c\xa1\xd1\xf7\x81\xe0\x68\xf6\xb5\x63\xad\x08\x5f\x50\x14\xb5\xc3\x5d\x89\xd2\xf2\x30\xb3\x7e\x0d\x07\x54\xe8\x2e\x00\x65\x36\xaa\xa0\xae\x6e\x72\x60\xaf\xff\xfb\x1b\x95\x99\x75\xe8\x23\xba\x01\x52\x1a\xaf\xe7\xc2\xde\x11\xd1\x5d\x5d\xe7\xca\xca\x7c\xf2\x79\x12\xbe\x2d\x4a\x32\x30\x1e\x5e\x4d\xdd\x98\x5c\x87\x48\x88\xad\x96\x9e\x29\x6b\x2b\x61\x96\x01\xa8\x7f\x34\xf5\xe9\x5b\x3a\xf5\x18\x70\x00\x74\xda\x51\x9b\xbf\xf4\x19\x7e\x5c\xed\x18\xcf\x17\xb2\xc8\xed\x35\x0c\x5f\x86\xa1\x70\x77\x8f\x85\xbb\x51\x05\xcb\x88\x04\x5b\x60\x80\xa5\x2a\xcc\x4c\x45\x19\x2c\x3e\x2b\x18\x93\x17\xa4\x62\x40\x87\x07\xd8\x1b\x47\xcf\x95\x64\xba\x4c\xdd\xb1\x9a\x7b\x01\x98\xdd\x16\x8d\xa8\x99\x02\x66\x12\x7b\xb6\x82\xf0\x79\x38\xfb\x5f\xb3\xcf\xea\x41\xa6\x92\x9f\x14\xc2\x64\xfc\xa4\xf8\x3f\x9f\x27\xb5\x3f\xf1\x57\xdf\x7f\xff\x19\xb5\x6c\xba\x68\x17\xfc\x34\x3a\xda\xc1\xd3\x1e\xa7\x70\xc5\xcf\xed\x2c\x3d\x62\x9c\xde\xcb\x7b\xc1\x3e\xe3\x70\x7f\x26\x02\xbf\xc3\x86\x6d\xa6\xda\xc6\x8d\x1d\x32\x6c\x40\xa7\xda\x3e\x6e\xac\x67\xd8\x5e\xad\xa6\xff\xb8\x5a\xd8\xd1\xfa\x61\x35\x7d\xf5\x3d\xfc\x67\x6d\x8c\xf6\x2d\x5e\x9f\x3d\xd3\x56\xed\x96\x8d\xa8\x65\x59\xfa\xbd\x68\xa6\xf6\x6f\x46\x6c\xdc\x5e\x04\xb3\xb6\x6d\xe1\xf3\x42\x1c\x9b\xdd\x8a\xbc\x8e\x23\xd0\xd7\x0d\xc2\xcc\xde\x88\xe0\x91\x6c\x93\x81\x29\x12\xe0\x9e\xdd\xb4\x97\x31\x00\x17\x7e\x1c\xc1\xc7\x03\xcf\x0f\x6b\x4f\xed\xd9\x3d\xcd\xe9\xaf\x66\x26\xc4\x08\x06\x99\x1b\xfb\xf8\xc0\x4a\x56\x1e\xed\xab\xe3\x23\x47\x45\x9d\x26\x91\x7b\x4a\xb7\xf5\x31\xab\xc8\x4d\x47\x74\x99\x18\x9f\xf7\xe7\x6b\xe2\xa0\x95\xfe\x7e\xed\xbe\xbb\xa2\xb5\x14\x0b\xf6\xf8\xa8\x5b\xcb\xc4\x8f\x5c\x11\x47\x42\xe1\xec\x95\x7a\xbe\x19\x4c\x12\x1a\x3e\xfc\x96\x5e\xfe\xd0\xa0\x0c\xf5\xe6\xe5\x07\xc8\xcc\xf6\x64\x58\x1b\xae\xac\xb5\xe6\xbe\xda\x11\x58\xc2\x5b\xfe\x41\x55\xba\xdb\x1e\x54\x21\xfc\xe2\x40\x2d\x5b\xfa\x94\x2b\xe5\x11\x63\xab\x3c\xc3\xd8\x41\xb1\x06\xb7\x72\xd0\x80\x73\xdb\x5c\x70\x2f\xa3\x5e\x5c\xc6\xf3\x15\x3a\xbd\x8c\x28\xcc\xcb\x96\x11\x0e\x79\x6c\x47\x8c\xf0\x01\x3a\xdb\x31\x96\x05\x5c\x2a\x7d\x2b\xcd\xd7\xb2\x4a\x18\xed\x6f\x5a\x5e\xb1\x3e\x62\x43\x0d\xc9\x75\x89\xce\x51\x5d\x21\xb5\x6b\xa5\x9b\x07\x6b\xac\xd4\x7b\x3d\x1e\xc7\x37\x9e\xe5\xc5\xa9\xbe\x53\xce\x2e\x56\x6e\x21\x80\xeb\xbc\xbb\x0e\xe3\x75\xdd\x7b\xaa\x40\x42\xc7\x5d\x35\x98\xa9\x33\xf7\x48\x60\x6c\x34\x12\xbd\x2c\x98\x8e\x58\x2e\x30\xc3\x05\x7c\x66\x3c\xf4\x3a\x35\xae\xa3\x11\x63\x13\xf2\x6b\x4d\xb8\x33\x22\x0f\xa7\x11\xa9\xc0\x79\x5e\xe6\x5e\x05\xbe\x07\x91\xb7\xc1\x8e\x47\x7c\xfc\xc6\x35\x91\x8a\x72\x7d\xd9\xf6\xe1\xe1\x17\x15\x2a\x08\x12\x8e\x08\x55\x8b\x79\x01\xd9\x2e\x4c\xd3\x40\xfc\x59\xfb\x58\x73\xb5\x16\x47\xed\xc6\x92\x6f\xe6\xb9\xee\x96\x28\x1c\xd0\x4d\xae\x88\x8a\xcf\x7e\x8d\x92\x45\x3b\xf6\xa5\xe4\x19\x1e\x6e\x8a\xa6\xa3\xab\x36\xb8\x3f\x7e\xf8\x27\x76\x06\xa7\x0f\xfb\x00\xfb\x22\x80\xb6\xa0\xb4\x42\x33\xb9\xd9\x8a\xdc\x68\xc5\x3b\xb5\x3a\xef\xff\x60\xe6\xa4\x37\x66\xaf\xc6\xba\x6c\x6a\x8b\x8d\x68\x49\x4b\x69\x71\xa3\x38\xbb\x2f\x17\x22\x57\x02\xf5\x48\xe1\x39\xe6\x9e\x1b\x54\x5d\xcd\xcb\x62\xfd\xc3\x3c\xc9\xe4\x60\x11\x34\xc8\x18\x3d\xb3\xaf\x9d\xe3\x5b\x7d\x0d\xa8\x94\x5f\xa9\xba\x62\xf8\x1b\xc3\xdf\xa6\xec\x0d\x4f\xee\x85\x4a\xd9\x36\x2b\x57\x92\x08\x62\xd0\xdc\x97\xd5\x8b\x7d\xb5\x61\x68\x5b\x60\xf9\xf6\x18\x9a\xa9\x0d\xbf\x47\x62\x72\x32\x22\xed\xcd\xa1\x8b\x5e\xd0\xbb\x4a\xe6\xb2\x39\x77\xf7\x8e\x96\x3f\x0f\x9b\xc5\xd4\xe7\x9e\x29\x31\x5f\xee\x71\xad\x09\x65\x54\xf1\xd4\x8c\x58\xb8\x7e\xb6\x36\x78\xbc\x1c\xd7\x8a\x57\xa6\xa5\xca\xe0\xea\x85\x10\x1e\x90\xeb\x97\x8a\x71\xa0\x02\x7b\x61\x58\xb9\x75\xf6\x19\xc4\x96\x32\x40\xfa\xe0\x10\xd8\x1f\xb6\x32\xb9\x47\x6c\x29\x64\x4f\x30\xdf\xbc\x86\x80\x21\x13\x01\xe4\xd8\xb6\x35\x2c\x91\x08\xe7\x38\xdc\x4a\x83\x9b\x7f\xcf\x3c\x1d\x98\x19\x52\xac\x85\x9a\x1f\x40\x11\x3f\x7c\xd0\x2a\x59\x20\x64\x06\xfb\x18\x9d\xef\xc2\x52\x49\x12\x05\x0c\x77\x6c\xcf\x7f\x2c\x97\x35\x33\x5a\x1a\x66\x78\x21\x8d\xdd\xcb\x5a\x7b\x3c\xd0\x0f\x1d\xd3\xeb\x7c\x1c\xe7\x51\x0b\xdf\x51\xad\x2f\x7c\xa6\xd9\x94\xbd\x83\xc8\x46\x74\x33\xd0\x9e\x3d\xa8\x6b\xc3\x2a\xd6\xa2\x93\x46\xf7\x29\x20\x9a\xae\x05\xd1\xf3\xbd\x01\x2b\x9f\x55\x38\x65\x67\x21\xa2\x8c\xfc\x49\x18\x2b\xde\xd3\x22\x91\x19\x71\xc8\xe4\x1b\x14\x7c\x01\xd4\x15\x4c\x20\x06\x96\x94\xb1\x7f\x0f\xaa\x20\xbe\x9a\x8f\x90\xb8\xcf\xef\x85\xea\xf3\xb0\x0f\xaf\x21\x86\x40\x7a\x5d\x02\x3e\xb6\xa2\x31\xbc\x72\x48\x05\x87\x2f\xbb\x40\x59\x25\x97\xa7\xb6\xcb\xed\x35\x24\xb9\xa7\x74\x41\x8c\xb0\x11\xe9\xd5\xe3\x5a\x9b\x78\x9d\xb9\xf1\xc3\x9b\x6c\x5e\x7a\xe5\x07\x48\xb7\xf4\x1d\x8c\x38\x4b\xa5\x63\x4e\x2c\xa8\xb5\x5f\xa4\xe8\xd6\xf1\xe3\xcd\xdc\x16\x0a\xdd\x00\xc8\x04\x57\x54\x73\x35\xff\xf9\x0f\xe6\x23\xac\xd8\xa7\x60\x5f\x69\x97\xda\x3e\x3e\xf3\xe9\xc0\x98\xaf\xc7\xf4\x06\x9d\x6e\x9e\x7a\xbe\xa0\xad\x4e\x59\x98\x5e\xe3\x45\xb9\xbf\x7d\xb3\x6a\x62\xde\x83\xda\xb6\x6f\x66\x7f\x88\x80\x61\x6c\x51\xca\x2c\x45\xfa\xbc\xc8\x20\xd4\xce\xe2\x00\x4e\x7b\x38\xfe\xa5\xf1\xe7\x49\xfb\x1c\xfb\xa4\xd3\x63\x26\xd6\x78\x8a\xd4\xe6\xbc\x1e\x90\x37\x62\x62\xf0\xce\x66\x7f\x4f\x6c\x75\x37\xe2\x3f\x9d\x9b\xaa\x88\x5b\x4f\x85\x01\xe2\xb5\x28\x97\x37\xa0\x18\xd5\xc5\x42\x14\x89\xa9\xb8\xb4\x62\x3b\xce\xf6\x33\x3e\xc9\xad\x6b\x50\x08\x31\x14\x8e\x7f\xce\xfe\x74\xf3\xf1\xea\x64\xc3\x73\xb3\xe6\xc0\xf2\xe0\xca\x9a\x38\x11\x4e\xbc\x1e\x3b\x24\x83\x54\x33\x75\xc2\x56\x7a\x82\xb8\x99\xd7\x6c\x5d\x14\x5b\xf3\xfa\xf4\x74\x25\x8b\x75\xb9\x98\x26\x7a\x73\x1a\xba\xe6\x94\x6f\xe5\xe9\x22\xd3\x8b\xd3\x5c\x40\xe6\xc4\xc9\xab\xe9\x0f\xaf\x60\x64\x4e\x1f\x5e\x9d\x02\x5a\x62\xba\xd2\xff\xf0\xfe\x87\x7f\xfe\xfd\x3f\xd9\x82\xb7\xbb\x62\xad\xd5\x6b\x02\xe5\xf4\x96\x7d\x82\x56\xf9\x29\xbe\x52\xfb\xca\x3f\x4f\xbf\x8f\xab\x41\x8f\x6e\x74\x2a\x32\x73\xfa\xf0\x6a\xee\x06\x66\xba\xdd\xfd\x96\x6b\xf0\xcd\x72\x0d\xee\x65\xf1\x5b\xae\xc1\x37\xcd\x35\x18\x6e\xe1\xf8\x3d\x06\xc8\x9b\xc3\xfe\x68\xff\xee\xf7\x48\xe7\x7a\xdf\xb7\x0f\xb5\x1c\x0e\x71\x26\xd8\x11\x47\xc4\xbd\x18\x75\xc5\xae\x35\xd7\x5f\x1d\x3a\x5c\x6c\x63\x05\x54\x3a\x8d\xf9\x51\xc4\x17\x80\xec\x93\x09\x90\xf3\xa3\x4b\x70\xcb\x65\x5b\x06\x01\x21\x58\x8f\xe9\xbf\xe7\x94\x99\x78\x6a\x7d\x09\x6a\xee\x81\xda\x12\x19\xbe\xed\xf0\xb6\xfa\xd1\x69\x4a\x3c\x85\x12\xc3\x40\x6d\x6e\x4f\x30\x8f\x93\x07\xea\xe2\xea\xd5\x51\x8d\x35\x37\x87\x01\xb7\xcf\x90\xc6\xd5\xc7\xe9\x10\xf5\x2a\x8d\xfb\xa0\x3b\x38\x1c\x33\x8e\x3d\x87\x1c\x01\xdf\xb6\xcc\xb7\xda\x08\x33\x65\xef\x6a\xea\xb5\x01\x8c\x7e\xfd\xee\x9c\xbd\xfa\xc3\x3f\xff\x7e\xa6\xbe\x6b\x39\xb7\x61\xbf\xd7\xf9\x8a\xb0\xf1\x70\x5a\x6f\xb8\x29\x44\x7e\x9a\x2f\x93\x53\xdc\xe5\x4e\xed\xfb\x27\xf4\xd1\x13\xbd\x3c\xf1\x34\xf3\x27\xc4\xb8\x3d\xdd\xa4\xe3\x48\x63\x2a\x53\x0f\xcf\x1a\x3a\x68\x0c\x1c\x4a\x48\x2f\xa7\x97\x5e\x50\x04\x73\x17\x51\x7b\x48\x2f\x5b\xfe\xe3\x4d\xa6\x17\xe6\xa5\x27\xb5\xe4\xc6\x7d\x23\xb0\xcc\x75\x2f\xcd\xa7\x51\x9c\x70\x53\xe4\x39\x1d\x15\x6e\x2f\x89\xaf\x23\x63\x3a\xbe\x7d\xb1\x85\xe3\x1e\x39\x76\x78\xae\x4b\xe5\x18\xfb\xb5\x12\x7a\x09\xd0\x0d\xb0\x84\x1d\xf2\x0c\x7c\xb5\x80\x67\xf2\x7c\x3a\xb9\xd8\xe2\x01\x03\x51\x85\xee\xee\x3e\x52\xb5\x62\x5f\x3f\x3f\x87\x6a\xc5\xb1\xfd\x4e\x1b\xca\x37\xea\xf0\x63\xe1\xe1\xb8\x94\xc6\xa0\x2a\xec\xf3\x7b\x23\xa8\x7e\x1f\x08\x8a\x72\x81\x20\x7e\xcb\x73\x30\xd2\xc4\x49\xa1\x4f\x80\x88\x0c\xe8\xad\x50\x47\xa6\x0b\x56\x01\x91\xe7\x31\xc7\xa4\x7d\x7e\x40\x3d\xd1\x30\xff\x25\xaa\x28\xd9\x24\x06\x69\x99\x09\x66\x2b\x95\x12\x39\xc5\xd4\xf6\x9e\xa8\x23\xe3\xd2\xf1\x50\xf6\xa3\x6c\xc3\x4d\x34\xd6\xf8\xf0\x39\x56\x3c\xda\x04\xa6\x0c\xac\xcf\xb5\xde\x68\x6b\xce\xe8\xd2\x44\x3f\xe2\xed\x05\x0e\xe1\x4e\xdb\x6b\xc3\xb7\x48\x3c\xfa\xed\x5a\x63\x97\x96\xfd\x09\x9d\x7a\xf1\x43\xa3\x64\x93\x16\x55\xa1\x98\x3d\xf5\xf7\x0a\x1f\xfd\xf3\x06\x50\x0f\xa8\x3d\x0a\xf2\xdf\xc4\xdb\x2f\xff\xd3\xde\x6b\xec\x94\xf2\x37\x05\x7f\x72\x23\x48\x07\xf9\x75\x63\x48\x9a\xb3\xe6\x3b\x19\x30\xca\xcd\xc8\x31\xf0\x89\x23\x43\x06\x80\x2b\x4c\xa5\x70\x39\x14\x27\xad\x49\x14\x5d\xeb\xd2\x89\x6d\xa7\x73\xc7\x01\x3d\xae\xaa\x37\xbe\x00\xa2\x7b\x6e\xd6\x3b\x50\xe8\x41\xc6\x0d\xf6\x31\x6e\x08\xce\xb6\xe8\x02\x6e\x8e\x5f\x8c\x20\x9a\x35\xa6\xef\xe0\x23\x38\x39\x1b\x3d\x18\xad\x85\xae\x0e\x1c\xe7\x62\xeb\xf3\x58\xb5\x61\x76\x91\x75\x34\x64\x64\xda\x5a\x36\x2e\x8f\xfe\xc5\x07\xbf\xbe\x10\xd2\xb8\x28\xe1\xf7\xab\x8f\xb7\x31\x5a\x43\x62\x6b\x4f\x92\xb5\x48\xee\xc1\x61\x82\x47\x9e\x17\xe2\x25\x86\xd3\x99\x0a\x72\x8e\x85\x76\xd0\x83\x9d\x57\xb8\xf0\x2a\x2f\x3a\x67\xa9\x34\xdb\x8c\xef\x20\xc8\xab\x30\xf7\x2a\x04\x88\x7d\xd2\xa2\xdd\x0a\xf6\xf9\x8b\x87\x8f\xb4\x1d\x95\xb3\xf0\xde\xd8\xbe\x0c\x60\xda\xd0\x99\xcd\xfd\x80\x19\xb1\xe1\xaa\x90\xc9\x4c\x6d\x04\x57\x31\x2a\x8f\x82\xdc\xb6\x93\x53\x2d\x88\x03\x7e\xb9\x14\x49\x11\x48\x64\xc1\x78\xf7\x3d\xb5\x6f\x0d\x8e\x6b\xbb\x5f\x79\xbd\x4d\xff\x11\x70\xbf\x18\xa3\xcf\xf5\x03\x6d\xc3\xee\x68\x3c\x30\x78\x03\xf2\x9f\x74\xe4\xba\xcb\x20\xfc\xcb\xcd\x29\xb6\x10\xc5\xa3\x00\x8e\x14\x4a\xea\x6e\xb3\xf1\x8f\x96\x80\x39\x4e\xd1\xbd\x5d\x0b\x3f\x42\x82\xe1\x02\x8b\xc1\x64\x9e\xcc\x4d\xd5\x58\xd9\x5e\x50\x9a\x39\x78\x7b\x5e\x90\xdf\xea\x05\x1c\xd3\xf6\xf6\x98\x3f\x88\x74\xa6\xaa\x54\x79\x64\x33\x86\x05\xc7\x82\xb8\xe1\xd3\xec\x36\xae\x8f\x07\xf9\xf2\x2f\x80\x1e\x28\x10\x03\xfb\x44\xea\x1e\xb1\x45\x6c\xf4\x73\xde\xaa\x9c\xce\x6b\x6c\xdd\x0f\x80\x64\x09\xe3\xc4\xcb\x48\xeb\xb4\x82\xa7\xf0\x93\xd2\x13\x81\x21\x4b\xa8\x07\xc0\x92\x5f\xb2\xe1\xe9\x6c\x2b\x63\xa6\x1c\x43\xc6\xb2\xcc\x90\xf9\xb9\x2b\x0f\x81\x78\x01\x5d\x36\xdf\xb7\xcb\xea\xf4\x7e\x35\x16\xe9\x45\x7a\xd8\x43\x04\x46\xc6\xbd\xce\xcd\x7a\xa1\x4c\x09\x26\x85\x93\x8a\x03\xc7\xf3\x4a\x14\x70\x9a\xa7\x65\x86\x84\x0f\xe0\x31\x07\x8e\x41\x9e\x65\x4c\x16\x66\xa6\x3c\x25\x22\x26\x1b\xc0\x0e\xeb\x5c\xea\x4e\x65\x5c\x79\xad\x72\xf8\x99\x2b\xb0\xc3\x64\x22\x8b\x06\x84\x7b\x17\xcb\x2b\x6d\xb7\x82\x63\x7e\x32\x0e\xdb\x4c\xc5\x77\xae\xfa\x20\x50\x32\x2f\xcf\x24\xef\x51\x81\x7f\x8a\xa9\x7b\x66\x3f\x71\x10\x6e\x01\x5b\x67\x2f\x5c\x4e\x39\x19\x6b\x4b\x9c\x28\x84\xb4\xb4\xb7\x9a\xc2\x38\x1f\x79\xb8\xb7\x42\x9e\x42\x52\x66\x3c\xc7\x04\x8d\x65\x99\x31\xb9\x8c\x44\xa0\x61\x0c\x90\x10\xcf\x0e\x57\xa2\xe1\xac\x76\x5e\x72\xc3\x37\x22\xe2\xe2\x20\xf7\x4e\x16\x61\x28\x90\xe5\x1f\x83\xf3\xb6\xac\x97\x53\xf6\x36\x50\x7e\xe2\x08\xc3\x9a\x88\x88\x74\xa5\xc1\xed\xcf\xd7\x37\x4a\x23\x87\xd6\xd9\x2a\x6a\x65\x57\xa4\x5f\x75\x1d\x23\x08\x82\x1c\xe3\x00\x1a\x4e\x8e\xa5\x1f\x35\xdc\x4a\x23\x61\x5f\xad\xc1\x36\xfc\x82\xe8\xa8\xa0\x3b\x15\x46\x56\x32\x26\x21\x3e\xa0\xa2\x9e\xe4\xb9\xa5\xb2\x9b\x1e\xcd\x69\x18\xc7\x91\x55\x8d\x14\xdc\xc6\x57\x34\x9a\x39\x31\x1c\x67\x48\xcf\xae\x78\x31\x16\x9b\xe3\x93\x71\xc6\x57\xb4\x15\x07\x35\xa4\x9a\xb0\x7b\x8c\xac\xa7\x17\xda\x3f\xa0\xa2\x5e\xce\x3f\x68\xbc\xc0\x56\x21\x78\xb2\xae\xe6\xc5\x3b\xf6\x5a\xdf\x02\xc8\x8b\x82\xf5\x38\x3e\xa5\xff\x2c\xcc\x39\x10\xb1\x63\xb6\xfa\x53\xf6\x51\x09\x44\xce\xe9\x65\x74\xa8\x50\x05\x48\xed\x0e\x04\x44\xfc\x2e\xb7\xb0\x15\x53\xf7\x8e\x2e\xc8\x2e\xb9\x09\xe3\xa1\x74\xd8\xf5\x70\xda\xe0\x2e\xd2\x61\x4b\xb6\xc9\xed\x1c\x61\x5e\x0e\x4b\xba\x6f\xbf\xf3\x47\x00\xd4\xf1\x3b\x40\x5b\x3b\x86\x0f\x4b\x2f\x92\xdc\xdf\xe2\x1c\x7c\xbc\x3a\x6f\x18\xc2\x49\xf7\xf5\xef\xa7\x75\x15\x85\x38\x42\x9c\xee\xee\xea\xed\xc5\xbb\xcb\xab\xaa\xa2\xdc\x5f\xee\x2e\xee\xaa\x7f\xb9\xbe\xbb\xba\xba\xbc\xfa\x63\xfc\xa7\x9b\xbb\xf3\xf3\x8b\x8b\xb7\xd5\xe7\xde\x9d\x5d\xbe\xaf\x3d\x67\xff\x54\x7d\xe8\xec\xcd\xc7\xeb\x9a\x86\x9d\x13\xa0\x8b\xfe\x74\x7b\xf9\xe1\xe2\xed\xfc\xe3\x5d\x45\x06\xef\xed\xbf\x5e\x9d\x7d\xb8\x3c\x9f\xb7\xd4\xe7\xfa\xe2\xfc\xe3\x4f\x17\xd7\x7b\x54\xec\x42\x7b\x5b\xbb\xf4\x29\xe0\x63\x07\x6b\x1a\x9e\xb1\x65\x2e\x85\x4a\xb3\x1d\x62\xef\xdd\xcd\xb6\x06\xa6\x8d\xcf\x5e\xb9\x11\xba\x3c\x06\x42\x7f\xbb\x16\x4c\x3f\x88\x1c\x98\x8d\xb0\x34\xa2\x41\x08\x59\xd4\xf5\xaf\xe6\xa2\xc8\x9b\x51\x81\xde\x4c\xa1\x22\xdf\xf9\x5c\xb4\xbe\xea\x04\x56\x3c\xfa\x08\xdb\x8a\xbc\xaf\x2e\x60\x19\xe5\xe5\xb6\x90\x8b\xee\xa4\x88\xd1\xc9\xc4\x43\xef\xde\xc8\xe1\xda\x4e\x78\x75\xd5\xbe\x31\x56\x72\x03\x8e\x01\x1e\x43\x09\x87\x4a\x75\xfa\xb7\x1d\x58\x73\x5b\x2e\x32\x99\x30\x99\xd6\xfd\x29\x94\xe3\x0f\x2e\xe3\x3a\xd5\xf3\x56\xe4\x60\xaa\xda\x1b\xc0\x36\x17\x27\xbc\x2c\xd6\x48\x4b\x48\xa9\x08\x24\xcc\x31\x53\x46\x24\xb9\xc0\x58\x80\x30\xe0\xa4\x45\x8d\xc6\xe8\x4b\x50\x19\x62\xe5\x48\x81\x00\x6c\x1a\xc9\x6e\x74\xc4\x08\xf0\x4d\x2c\x7d\x84\x93\x14\x9f\xef\xed\x1a\xaa\xb1\x34\x75\x81\x7e\x38\xe1\xf1\x47\xa7\xf4\x68\xdb\x6d\x77\x6a\xaf\x74\x88\x83\xec\x72\x37\xda\x9b\xb1\x6f\x8e\xc5\x13\xa5\x9a\xcc\x40\xa5\xd3\x4f\xe7\xb9\x80\x43\x84\xa0\x00\xce\x7f\x01\xd0\x15\xca\xf5\x80\x14\x0f\x7b\x55\x5b\x88\x35\xcf\x96\x68\x71\xd8\xa1\x69\x67\x4a\xc0\xf2\x6f\xf5\xbd\x50\xd7\x38\x60\xdf\x64\x3b\x54\x78\xf3\x09\x3c\x2d\xde\x23\x14\x5c\x98\xb6\x8e\x6e\x56\xb9\x5c\x37\x30\xa6\x0a\xbc\x27\x44\x3f\x63\x4a\x47\x60\x61\x77\x69\x72\xcb\xa5\xfc\xc5\x16\x38\x53\xa2\x95\x87\x1a\xf0\x42\x8e\x31\xcf\xef\xcb\x80\x8d\x42\xda\xb1\x7b\xa1\x40\x23\x12\x25\xe4\xf7\xce\xd9\x71\xfe\xf3\xe6\x58\xf4\x38\xf4\xc1\xe7\x27\x2b\xd2\x99\x71\x94\xc7\xf5\x53\x81\x39\x36\x9e\x57\x00\xe6\xcd\xf9\xfb\xcb\x8b\xab\xdb\xf9\xf9\xf5\xc5\xdb\x8b\xab\xdb\xcb\xb3\xf7\x37\x43\x97\xdf\x53\xe4\x45\xd5\x56\x5f\x3d\x3d\xc8\xef\x10\xa7\xb4\xf2\x42\x7a\xae\x6f\x54\x58\x76\x30\x24\xfb\x6b\x2f\xd3\xed\x3c\x95\x26\xb1\xc7\xdf\x6e\x2e\x54\x0a\x04\xfe\x07\x4d\xd5\xf6\xa2\xea\xad\xf0\x4f\x30\xff\x84\xdb\x41\xf0\xb4\x7b\x70\x33\xda\xff\x0e\xa8\x3b\x70\x43\xe6\xc2\x2e\xfe\xb4\xc2\x9b\x30\xdd\xaf\xda\x64\x8b\x3b\xae\x6d\xd5\x22\xea\x6d\xc2\xfa\x4a\x63\x4a\xa0\x67\x70\x8f\x01\xe4\xb0\xa3\x57\x88\x55\x35\x56\x11\x90\x91\x02\x36\x93\x66\xa6\x36\x5c\xa5\xbc\xd0\xf9\xae\xa3\x89\xc3\x36\xcf\x78\xd9\x54\xb7\xd0\xf8\xc8\x56\x42\xa4\x6e\x14\xf0\x51\xae\xea\x53\x09\xb5\x06\x6e\x3f\xfe\xf9\xe2\xea\x66\x7e\x71\xf5\xd3\xfc\xd3\xf5\xc5\xbb\xcb\xbf\x7a\x24\xe4\x96\x9b\x36\xc5\xdb\x6d\x2e\xec\xee\xe2\xa8\x9b\x5a\xf7\x17\x94\xa1\x75\xe5\x90\xf4\xa0\x5c\xce\x94\xdb\x59\xf2\x50\xfc\x3a\xd7\xe5\x6a\xdd\x5e\x50\xbd\x96\x9f\xce\x6e\x7f\x3c\xa8\x9a\x40\xac\x87\x5a\x95\xb8\xda\x9a\x88\x50\xb9\xa4\x7d\x0f\x61\xa4\xb5\xea\x01\x3d\x24\x3c\xda\x16\x65\xe8\xd8\xd1\x0e\xba\xbd\x34\x37\xad\x5e\xe3\xbf\xe5\xf1\xae\x09\x74\x1b\xed\x9b\x95\x63\x04\x10\xca\x28\x79\xdc\x28\xed\x75\xcb\xdf\x2a\x27\xd8\x0f\x27\x99\x58\xad\x44\x8a\xd3\xab\x5e\x30\xf9\xe0\x68\x0b\x4c\xc2\xb9\xde\xd6\x8b\x24\x4a\x7a\xc4\xc1\xec\xf1\x5e\xc3\x37\xf0\x4f\xfe\x95\xf6\xbd\xe2\x9c\xc8\x71\x20\xbe\x59\x70\xd5\x11\x48\x7e\x68\x22\x34\x07\x6d\x45\x1f\x73\xe6\x93\x9f\xc8\x61\xe2\x42\x06\x61\x1d\x74\x01\x5e\x8e\xc7\x85\xfa\x7a\x5c\x8b\x6d\xc6\x13\xe1\x73\x18\x90\xd5\x14\xee\xf5\x87\x04\xf0\x48\xfa\x55\x91\xbf\x25\x92\x84\x0d\x6a\x57\x6d\x53\x00\x3c\xb7\xd7\x6e\x3f\x7e\x7e\xd7\x4a\xef\xc5\x8d\xb8\x0c\xc1\xd1\x8c\xda\x7b\x04\x7d\x47\x5f\x14\x08\x5a\x76\xc2\x92\x47\x4d\x87\xda\x97\x7f\xa2\x81\xc7\x3b\x73\xd5\xd1\xcd\x1d\x5b\xa8\x9f\x1e\xde\x74\xec\xf3\x17\x16\x45\xde\x4b\x30\xfc\x14\xe1\x88\x4f\xb9\xde\x48\x23\xce\x8a\x22\x97\x8b\x32\x56\x58\x1d\x09\x98\xab\x5c\x4e\x42\x83\xb7\xb9\x4e\xcb\xc4\x51\x02\x41\x6b\x03\xec\x87\xbc\x7c\xce\xea\x48\xd9\x89\x9d\x7d\x74\x73\x13\xe9\x09\x00\xfa\x91\xb3\xaa\x2d\xc6\xe6\x36\xc6\x0e\xdf\xdf\x27\x77\x94\x1f\x33\x25\x5b\x26\x45\x77\x67\xba\x39\x30\x2c\xb1\x96\xb9\xc7\xc1\x02\xee\x40\x4d\xd1\x74\x59\x70\x0c\xa0\x57\x6d\x94\x2e\x06\x10\x7f\xd4\x8c\x03\x77\x0d\xc3\xc6\x54\x33\x66\xd0\x6e\x58\x73\x83\xe6\x7c\x91\xac\xab\x15\x87\xd6\x54\x99\x50\xeb\xd5\xf5\xe6\xf1\x71\x6e\x93\x41\x61\xb4\x09\x3a\x1a\x24\x39\xb6\x2b\xaa\x96\x5e\xa2\x77\x9c\xb7\x3b\xb6\x18\xfd\x8d\x0e\x0f\x03\xd8\x47\x33\x5e\xaa\x64\xcd\xb6\x19\xc7\x64\xf2\x35\x37\x38\xa5\x1d\x96\x84\x2f\x64\x26\x0b\x60\xe9\xc1\x10\x67\xad\x87\xed\x35\x8f\xe7\xf7\x8e\xec\x9c\x07\x4a\xa6\xbe\x49\x7f\x24\x66\xd7\xb7\xea\xab\xa2\x76\xc3\x92\x8d\xb7\xa1\x61\xd3\x92\x10\xbb\x61\x38\xec\x46\x0c\xd3\x32\xb4\x65\xdc\xc8\x52\x89\x9f\xea\xaf\x57\xfa\xbb\xc5\x7a\x19\x8f\x58\x21\x15\x8f\x11\xa7\x4f\x5d\xe3\xa3\x75\x65\x2d\x33\xcd\x3b\x74\xe6\x5d\xd9\x28\xd9\xd1\x55\x76\xaa\xcb\x45\x17\x49\x3c\xd6\xaa\xbf\xf4\xbe\x60\x88\x5b\xb7\x4f\xe5\x2c\x8d\x37\x40\x5e\x88\x42\x8e\xf3\xf7\x44\x8d\xe6\x85\x38\x81\xd7\xdb\x0b\xa7\x0c\xc3\xc1\x6d\x6e\x4c\xb4\x20\x1c\xe5\x8d\x36\xc0\x12\xb6\xcd\xae\xda\xe9\x7c\x0c\x26\xfc\xc8\xf1\x92\x6a\xcf\x54\xda\xaf\x45\xf3\xfb\x1f\x5a\xba\xa5\xd1\xe8\xbf\x94\xdc\xee\x87\x1f\x97\x37\xc8\x95\x73\x4c\xa3\x0b\xd9\x5c\x56\xed\xdb\x4f\xfd\xab\xb7\xd5\xf0\x5a\x3c\xf1\x07\x67\x22\xb7\xb5\xe6\xc6\xbe\x3d\x7c\x17\xba\xac\xb8\xd1\xb6\xb9\xd4\xc0\x19\xa3\x97\xc8\xc0\xd8\x4d\x21\xdc\xfa\xdd\x23\x7a\xf2\x4b\x29\x4a\x61\x27\xd0\xa2\x4c\x57\x4d\x2f\xf7\x08\x4b\x39\x34\x69\xad\x1f\xd9\xa6\x4c\xd6\xcc\x15\xce\x52\x91\xf1\x5d\xa5\x69\x60\x24\x16\x1a\xf8\x3c\x47\x51\x67\x45\x2c\xcc\x49\x69\x0a\xbd\x01\x80\x71\x28\x37\x2f\x15\xac\x72\xc6\xdd\xea\x6a\xdb\xdf\x2b\xec\x72\x07\x86\x36\x6f\x3e\x5d\x9c\x5f\xbe\xbb\xac\xc5\x15\xcf\x6e\xfe\x1c\xff\xfb\xe7\x8f\xd7\x7f\x7e\xf7\xfe\xe3\xcf\xf1\xdf\xde\x9f\xdd\x5d\x9d\xff\x38\xff\xf4\xfe\xec\xaa\x12\x7d\x3c\xbb\x3d\xbb\xb9\xb8\xdd\x13\x60\x6c\x7e\xb5\x7b\x20\x78\x44\x7e\xe7\x20\xcf\x4e\xd9\xc1\xf9\x19\xe8\xab\xaf\xd9\x99\xa3\x02\xac\x90\x55\xba\x20\x31\xa0\x4a\x32\x04\xc7\x61\x2c\xf9\x2d\x2f\xf8\x39\x2f\x78\xa6\x57\x53\x76\xc6\x08\x10\x8e\x40\x7f\x63\x2d\x24\xe2\x49\xb3\xa3\x83\x45\x58\x33\x29\x09\x77\xf8\x20\x5d\xab\x97\xc4\x50\x98\x89\x58\xe4\xc4\x65\xb5\xcd\xd4\xc5\x83\x50\x45\x09\x24\xb4\x3c\xcb\x18\x7d\xd6\x3d\x10\x65\xec\xbb\x5a\x1a\xb9\x91\x19\xcf\x83\xca\xe8\x47\x2a\x0b\x6e\x29\xae\xae\x9e\xa0\xa9\x99\x0e\xee\x2e\x72\x77\x97\x0c\xea\x7d\xfe\xfe\x12\xec\xbe\xa4\x70\x12\x5a\xee\xe3\x33\x85\x0c\x78\xf4\xc5\x0d\x87\xe4\x93\x42\x93\x67\x15\x3f\x4f\x0f\x77\x4f\xc4\xa3\xa8\xc0\x5d\x0c\xe2\xb9\x6e\x94\xbe\x92\xee\x3f\x2e\x54\x91\xef\x06\x1b\x73\xb7\x90\x6d\x6d\xc0\x20\x27\x2c\x5b\x55\x79\x14\x1d\x5f\xcc\x95\x7e\x05\x16\x9e\x03\x5a\x52\x5c\xc6\x87\x5f\x10\xd7\xd2\x71\xe9\xc8\xec\xc9\xfb\x6b\xed\x87\x98\x10\x07\x7a\x61\xa1\x4b\x95\x1a\x42\xdd\x6d\xa4\x3a\xdd\xf0\x5f\x5e\xba\x96\x22\xc1\x84\xd7\xff\x01\xf2\x30\x91\xd9\xeb\xd7\xce\x6e\x72\xfd\xdd\x35\x53\x3d\xfd\xb5\xdf\x44\x76\x3b\x2b\xdc\xf5\xc2\xc5\x1c\xf1\x83\x0f\x62\xd7\x36\x7e\x0d\x0d\x37\x16\x13\x91\x43\x21\xdb\x5c\xd8\x07\x3d\x38\x31\x43\xcc\xa9\xff\x37\x24\x21\x54\x74\x66\xdb\xf7\xee\x38\xde\x7f\xd4\xb2\x69\x45\x1a\x0c\x37\x7c\x06\x8b\xf0\xd1\x97\xec\x98\x21\xee\xc0\xb9\xbc\x29\xe9\x82\x02\xaa\x76\xb0\xfe\x43\x2f\xd8\x12\x32\x90\x30\xd1\x8e\xe5\x02\x42\x1c\x30\x14\x4e\x35\x02\x28\xa6\x1a\x60\x06\x37\x05\x32\x61\xc0\xf1\xaf\xec\x1d\x53\x7c\x29\x29\x76\xfb\xea\xfb\x71\xe7\x6c\x81\xd4\xe3\xc8\x35\x5b\x27\xe5\xf6\x67\x39\xd4\xab\x54\xb2\x8d\x77\xee\xba\x54\xf6\x28\x7e\x0a\xd8\xcb\xf0\xb8\x66\xed\xa3\xf4\xcf\xbd\x49\x42\xce\x25\x9f\xe3\xf3\xcf\x46\x23\xfa\x53\x8d\x3d\x94\x3e\x07\x90\x74\x2a\x3d\x3e\xd0\x16\x3c\xb9\x7f\xe4\x79\x8a\x7e\x5b\xc0\xa1\x4c\xd9\x8f\xfa\x51\x3c\x88\x7c\xc2\x12\x91\x17\x9c\xa8\xbb\x0c\x04\xe2\x61\x41\x51\x39\x33\x05\x19\x1a\xc8\x83\xa6\x4c\x99\x0b\x56\xc8\xd5\xda\x5e\xa2\x23\x18\x85\xce\xed\x76\x54\x20\x6b\xe3\x56\x24\x44\x96\xd4\xd1\x01\xcb\x8c\x3f\x34\xb9\xc8\x0e\x61\x79\x60\x97\x3e\xcd\xd4\xc5\x29\x9d\x12\x4f\x1f\xf0\x85\x3a\x8c\x36\x4d\xa4\xb7\x99\xb0\x95\xce\xb8\x5a\x4d\xa7\x53\x60\x9d\x7f\x39\x6a\xa2\x53\x81\x71\xe4\xd3\xc3\xab\x33\xad\x8d\xc8\x76\x9e\xe0\xc7\x27\xc0\x00\xe2\xf2\x97\x42\x28\x23\xd1\xcf\xd3\x32\xfd\x6f\xea\x51\x81\xaf\x1b\x44\x69\xbf\x9e\x8f\x4e\xaf\xec\x28\x07\x84\xfd\x46\x94\x84\xcf\xb7\xdf\xbc\x0e\x4a\x17\x6e\x2f\x4b\x69\x35\x36\x07\xf6\x27\x2d\x3b\x62\xf8\x07\xf1\xee\xb5\x96\x44\x24\x25\x07\xe5\x0d\xb6\xf7\x59\x23\x95\xf3\x88\x2c\xce\x9e\x84\xcc\x91\xb9\x98\x43\x1c\x01\x37\xf5\xe1\x1e\xbd\x2c\xf6\x6b\x0d\xb5\x36\x68\x64\xae\x6b\x48\x4a\x1f\x63\x3a\x61\xba\x5c\xb6\x83\x1b\x97\xcf\x7c\x05\x77\x7a\x1a\x85\x03\x2a\xd1\x0e\xc8\xc1\x0a\xe1\x12\x4f\x1e\x15\x45\x47\x4c\xa1\x73\xbe\x12\x6c\x23\x52\x59\x6e\x5a\x37\x1b\x5f\xdd\x63\x70\x7f\x3a\x2b\x37\xdd\x34\x7e\xc7\x1a\xd0\xa1\x92\xf8\x5f\xe7\xf0\xb9\xc1\x06\xf4\x99\x87\xb4\x3b\xc9\x37\xaa\x2f\xfa\xfe\xa9\xaf\xed\x49\x99\x4b\x03\x84\x93\x87\xa4\x3c\xfa\x62\xb0\x68\x88\x9c\xee\xb6\xe8\x73\xae\x8c\xee\x89\x0b\x69\xd1\x2b\x06\x47\x15\xc2\xad\xdd\x87\x42\x1d\x4d\x38\x5e\xf8\x29\xd7\x65\x83\x6c\x67\x50\x84\x1b\xcc\xc6\x88\x06\x9e\xe0\x4e\x50\x20\x61\x32\x0a\xcd\x96\x2e\x89\xee\x5e\x44\xb4\x64\x29\x10\xc4\x3f\x22\xc7\xcd\x9f\xff\x60\x1c\x7a\x83\x00\x36\xc1\x62\x29\xc2\x47\x30\x20\xf2\xf0\xca\xe1\xaa\xb0\x85\x58\x04\x90\x87\xa5\x5c\x15\xad\x05\x04\xd8\x21\x94\x85\xaf\xfc\xc4\xcb\xac\xfd\x71\x2a\x1f\x1e\x45\x01\xc1\xb3\x9f\x6f\x18\x76\x35\x51\x89\xe7\x7d\x15\x8d\x0a\xd9\x8f\xec\x82\xee\x9a\x1f\x60\x09\x56\xc6\x01\x3b\xdd\x71\xc9\xdb\x6e\x17\x45\xb2\x0e\x96\x07\x90\xa7\x79\xd2\x37\x52\x87\xa5\x76\x6e\x02\x39\x3a\x82\x66\x63\xf4\xa1\x5c\x29\x1d\xeb\x7a\x68\x25\x20\x32\x65\x37\x20\x1d\x17\xcb\x64\xb1\x1f\xe2\x35\x92\x31\x6c\xdf\x54\x2b\x34\x42\x77\xa8\x9d\x95\x00\x23\x5c\x29\x24\xf2\x0c\x39\x7c\x2c\xde\x89\x48\x6c\xb4\x4e\x9a\x5d\x65\x6e\x98\xa9\xea\xa7\x1a\x9d\xe4\x30\x58\x32\x17\xc8\x75\x6b\xac\xf5\x56\xc8\x07\xbb\x50\x9b\xd3\xda\x4f\x50\xd8\x01\x9a\x73\x6f\xa6\xb0\xda\x11\x61\xee\xbd\xd8\x99\x58\xd9\x94\x66\x14\xeb\x9a\x90\xd2\xb6\x87\xc6\x6b\xff\x50\x40\xc7\xcd\xf3\xa0\x4f\x36\xec\x2c\xc3\x8f\x7e\xb0\x2f\xf7\x80\x3b\x1b\x85\xdb\x39\x18\xb2\x14\x83\x4f\x91\xb6\x89\xd0\xcf\x34\x86\x01\xbf\x05\xe8\xbc\x18\x7f\x17\xa7\x9c\xc0\xc5\xd7\xde\x6f\x67\x8a\x38\xb5\xa3\x43\xce\x6e\x38\xcd\x61\xa3\xd4\x69\x64\xf2\xdd\x55\x68\x5f\x80\xf6\xd0\x51\x40\x56\x3f\xe9\x82\xad\x4e\x18\x7b\xa6\xe0\xd3\x98\x5c\xea\x7c\x78\xad\x1f\x3c\x10\x14\x48\x83\xdb\x09\x04\x8c\x32\xb8\xf0\x49\x62\xfe\x43\x89\x5c\xbc\xfd\x24\xc2\x76\xdf\x99\x6a\xc5\xe0\x39\x04\xde\xcd\xc5\xf9\xf5\xc5\xed\x57\x03\x0a\x3a\x94\xde\x68\xa4\xa0\xab\xe7\xdb\x8b\x77\x67\x77\xef\x6f\xe7\x6f\x2f\xaf\x9f\x03\x2a\x48\x3f\x1d\x80\x15\xbc\x21\xaa\xfe\x73\xad\x0a\xf1\xcb\x51\x67\x72\x5e\xaa\x39\x1f\x91\xb3\xe2\xc5\x3a\xfa\xcc\x1d\x2c\xb4\x29\x35\xe0\x75\x00\x88\x77\x12\x4f\x34\xaf\x2c\xb0\x0c\x4e\xc3\xa5\xcc\x32\x48\xe1\xf5\xee\x75\x4a\x0f\xb3\x9d\x0a\xfb\x8f\xa3\xda\xa4\x3d\x75\xa6\x16\x15\x25\x08\x70\xf9\xad\xed\x25\x18\x93\x77\xb7\xb6\x03\x72\x09\xa9\x91\x7d\x6a\x04\x2b\xa9\x44\xa8\x06\xca\xd9\x97\x8a\x75\x52\x48\xd3\x20\x3e\x27\x24\x8a\x0c\xaf\xa1\xb6\xa6\x9b\x71\x95\xf9\xe9\xcc\x4f\xf7\xa3\x6f\x21\x2e\x62\xa9\xd0\x30\xad\xac\xe6\x9b\xf6\xa9\x7b\x1a\x96\x00\xf4\xbb\x1d\x49\x0e\x31\x08\x50\x8c\x0f\x03\x49\x03\x81\x2a\x45\x21\x38\x71\x2f\x11\x3a\xa4\x97\xb5\x7e\xb6\x5b\xa1\xed\x6b\x09\x91\x0a\x4e\xac\x24\x49\x56\x9a\x42\xe4\xe4\x36\x39\xfb\xf9\x66\xa6\xde\xd8\xe3\xeb\x25\x9d\x42\xa4\x64\x83\x9f\x40\xe0\x8a\xae\x7c\xdf\x59\x28\xf1\x0e\xf6\x1d\xfa\xa8\x37\x82\x2b\xc3\x60\x69\x64\x99\xc8\xc3\xcc\xc0\xfa\x08\x91\x92\xa2\x2b\xd0\xb0\x86\xf7\x5f\x32\x42\x25\xda\xae\xb0\xf5\xa5\x5f\x73\xb1\xd1\x45\x73\x3e\x75\x65\x88\x03\x54\xf8\x39\x67\x4e\x4b\xc6\xca\xd0\x59\x44\x28\xeb\xd6\x49\x54\xcd\x1f\x19\x34\x97\x6e\xb1\xb8\xdf\xa6\xd2\x13\x4e\xa5\x01\xe7\x7a\x7c\x4a\xb0\xb5\xb6\x1b\xa8\x97\x79\x09\x61\x66\xcf\x50\x91\x01\xe8\xcb\x76\x63\xeb\xa9\x53\x93\x3a\x3c\x06\xfb\x01\x45\x1d\x07\xad\x3d\x6b\xa1\xc2\x09\x9a\x5a\x2e\xb6\xd3\xab\xa2\xf8\x3c\x94\x73\x67\x0e\x64\xa8\x74\xe1\xc8\x23\x3c\xae\x8f\x40\x8a\xf6\x01\xcf\x5a\xd2\x5b\x47\x62\x02\x71\x56\xca\xfc\x48\x25\xb2\xdb\x18\x0c\x59\x49\xa7\xc5\x5a\xc4\x89\xf8\x2e\xf9\xde\x93\x77\x8c\x99\x7c\x87\x6b\x5d\x56\xe7\x9c\x27\x82\x3c\x08\xec\x70\xf5\xf1\xea\x22\x86\x2a\x5c\x5e\xdd\x5e\xfc\xf1\xe2\xba\x92\x88\xfd\xfe\xe3\x59\x25\x99\xfa\xe6\xf6\xba\x96\x43\xfd\xe6\xe3\xc7\xf7\x17\x0d\xcc\xc3\xc5\xed\xe5\x87\x4a\xe1\x6f\xef\xae\xcf\x6e\x2f\x3f\x56\x9e\x7b\x73\x79\x75\x76\xfd\xaf\xf1\x5f\x2e\xae\xaf\x3f\x5e\xd7\xbe\x77\x77\xde\x8f\x9e\xa8\x34\xa3\xdd\xfd\x13\x82\xb3\x11\x27\x66\xeb\x32\xae\x6a\x81\x1e\xb1\x8a\x07\x22\xcf\xf6\x4d\x47\x97\x67\x9d\xc6\x54\xf9\xb8\x30\x6c\x55\x47\xcd\xba\xa7\x17\x2f\xad\x74\xdd\x96\x1f\xb7\xed\xd9\x53\x6d\xfe\x14\x48\xc0\x5e\x03\xd0\x7f\xa5\xe6\xb8\x25\xad\x60\xec\xda\x2d\x44\xb0\x56\xbc\x53\xba\x47\xa5\xcf\x5e\x53\xf7\x8d\x7d\xf5\x0c\x1c\x4c\x7b\xa8\x6c\x9e\x8a\xc6\xa2\xaf\xd2\xd1\xc7\x5c\x96\xb8\x4c\x9d\xa1\xe0\x7e\x8c\x0e\x6e\x68\x86\x9d\x39\xd1\x74\xec\x52\x99\x6c\xcf\x37\xe9\xa7\x4d\x1b\x5b\x7f\xfa\x48\xb3\xee\x35\x8e\x8d\x11\xf5\x06\xae\xa3\x31\xf5\xbe\xe5\xe6\x7e\x6c\xbd\xe9\x23\xcd\x7a\x83\xd9\x77\x50\xbd\xc1\xe1\x5d\xb4\xf3\x9f\x8c\xd8\xc4\xe2\x62\xaa\xd5\xf3\xc9\xd9\xfe\x91\x48\xcc\x75\x58\x1d\xed\x02\x78\xde\xeb\xe5\x96\x0f\x0f\x64\x40\x6d\xfc\x72\xe5\x35\x3a\xf0\x1b\xf8\x15\x5a\xb8\xc8\x05\xbf\x4f\xf5\x23\x8d\x47\x1d\x19\xca\x06\xed\xe6\xd5\x0e\xb2\x7b\xb8\x3b\x22\x8a\x9c\x22\x50\x88\x52\x0b\xc5\x03\x4c\x4e\x12\xa1\x35\xda\x60\x91\x0a\x69\x9d\x41\x06\x38\x7b\x54\x18\x9d\x99\x42\x6b\xbe\x4d\xc9\xd4\x8e\xaa\xad\x11\x71\x3e\x40\x53\xbd\x0d\x8d\xc1\x75\x13\x0d\x2c\x25\x70\x94\x39\x80\xe9\x16\x39\xdc\x99\xa0\x43\xa4\x02\x67\x72\x6e\x2f\x3c\xb9\x48\xa4\x11\x91\x9a\x53\xeb\x89\xfd\xe5\x38\xed\x87\x82\x17\xad\x6e\xd7\xc1\xfe\x70\x9e\x14\x25\xcf\xd8\x97\x52\xe4\x3b\xa2\xce\x43\x5f\x25\xfe\x25\xe1\x0a\x33\x45\x0a\xb1\xd9\x42\x3a\x76\x9c\xe2\x30\x53\x3f\x03\x50\x02\x87\xe0\x85\x61\x7f\x04\xc8\x83\x7b\x98\x0e\xe1\x0d\x2f\xe0\x2c\xfe\x0b\x7e\xc3\xff\x36\x9d\xa9\x8a\x3a\x4a\xf4\x56\x45\x28\x65\x3a\x53\x4e\x9e\x20\xd5\x89\x99\xc2\x8d\x6f\xaa\xf3\xd5\x29\x09\xfb\xda\xc9\xae\xef\x17\x5a\xdf\x9f\x0a\x75\x0a\x3e\xa9\xe2\x94\x97\x85\x3e\x05\xb8\x14\x8e\xbf\x39\x75\xfa\x9f\x4e\x40\xd5\x9c\xae\xe5\x83\x80\xff\x37\x5d\x17\x9b\xec\x1f\xcc\x76\xfd\xcb\xc9\x2a\xcb\x4f\xec\xbb\x27\xf1\xbb\x27\xee\xdd\x13\xf7\xee\x89\x7d\x0d\xff\xdf\x76\x87\xe1\x1d\xf1\x0b\xb7\x67\xd9\x64\xa6\xa4\x32\x22\x2f\xc0\xfa\x79\xcc\x65\x11\x64\x68\x76\xec\xc5\x7f\xfd\x17\x9b\xe6\xfc\x11\x53\x19\xdf\xf2\x82\x7f\x42\xff\xe2\x7f\xff\xf7\x0b\x08\xa8\x62\x52\xcf\x96\xe7\x5f\x4a\x51\xcc\x94\x11\x76\x11\xb2\xff\x6f\xa6\x20\x02\xbb\xd9\xcd\x0b\xf4\xbb\xa2\x0f\x32\x35\xec\x5f\xb0\xcc\x4b\xa4\x91\x4c\x8d\x2d\xa9\x23\x9d\x40\xf2\xac\x45\x32\xba\xc3\x45\xff\x25\x7b\x4b\xcf\x8f\x58\xd6\x5f\xb2\xea\xaa\x76\x42\x28\xe6\x4b\x06\x07\x68\xa6\xb9\x03\x6b\x31\x3f\x79\xe1\x9e\x4c\x95\x6b\x5b\x23\x0d\x68\xc0\xb3\x86\xe9\xdb\xd7\xca\x0d\x52\x59\x3b\xcf\x7d\x63\x1b\x81\x58\x41\x88\x43\x40\xf4\x5c\xda\x15\x72\x83\x9e\x50\xb0\xdc\xb0\xe5\x60\x93\x52\xe8\xdc\x97\x87\x8e\x0b\xf3\xfb\xd7\xa7\xa7\x13\xb6\x32\xf0\x3f\x8b\x2f\xf0\x3f\x80\x1e\x7a\x2a\x36\xd6\x46\x67\x7a\x20\x5c\x73\x94\xf7\x8f\xc4\x53\xa0\xe8\xbe\x06\x01\x78\x6d\x9a\xbe\x29\x55\x9a\x89\x90\x02\x59\x09\x89\x64\xda\x49\xd6\xa3\x63\xac\x2e\xb5\x02\x63\xbc\x10\x09\xb7\x1b\x5f\xe3\xdb\x08\x2e\xd5\xcb\x42\x28\xf4\x86\xe5\x41\x89\x8d\xa3\xe7\x0a\xcc\x62\x80\x42\xf2\x82\x20\xe7\x02\xfe\x08\x1f\x01\x46\xed\x49\xfd\x27\xb6\xd3\x25\x91\x43\x03\xe5\x69\x2a\x92\x0c\x18\xf8\x1d\xed\x0b\xcb\x45\x51\xe6\x8a\x71\xb6\xe5\x2a\xe5\x06\x66\xe0\x32\x87\x68\x67\xce\x78\xb3\xa2\x13\x84\xe3\xea\xb2\x00\x32\x23\x44\x16\xc4\x3d\x81\xec\xdd\x51\x9d\x27\x51\x25\xf0\x4c\x00\x12\xe1\xc6\x8b\xd3\x99\x72\x5a\x61\x84\x85\x43\x4f\x59\xa2\xb7\x3b\xa2\xaa\xa9\x77\xba\x74\x9e\x33\xea\xee\x49\xc0\x9b\xd4\x9f\x9d\x30\x59\x0d\xad\x01\x51\x78\x11\xa9\x1d\x3b\xbd\xe8\xef\x84\x4a\x74\x2a\x72\xf3\xd2\x2e\x43\xe9\xef\x1d\x68\x3f\x48\x13\x06\x03\x76\x29\x7b\xb8\x91\xb7\xd0\x16\xef\x15\x75\x6c\xef\x54\xa8\xa5\xdb\xec\x9c\xfd\x4b\xe5\xd7\x8e\x82\x69\xab\x2f\xfd\xe7\x57\x45\xc4\xc4\xb8\x4e\x77\xe7\x3c\xdc\x05\x81\x4b\x36\xde\x71\xb1\x50\xb4\x71\xc8\x38\x71\xd2\xb2\xb2\x00\xf5\xba\x5c\x98\x62\xa6\xe8\x04\x9e\xb0\xa5\xe0\xd6\xce\x9b\xb0\xc4\x3c\xe0\x66\x8c\xc7\x7d\xf1\xa8\x03\x06\xc7\xe9\x92\x00\x18\xb6\x52\x78\x70\x12\xe3\x63\x80\x28\xe0\x49\x81\x00\x83\x4e\x15\x72\x67\xaa\x40\x67\xb5\x6e\x88\x07\xf4\x83\x93\xb9\xa8\x4b\x4a\xc5\x2a\x2b\xd0\x13\x3b\x0c\x14\xb3\x7a\x3d\xf0\x07\xbb\xf1\x60\xeb\x10\x06\x12\x6d\x8e\x60\x71\x13\x96\x16\xd7\x59\x88\xe1\xc6\x5c\xe3\xe0\x9b\xe9\x5a\x54\x3d\x1d\x01\x15\x38\xcc\x6f\x61\x5f\xdd\xeb\xb0\x32\x22\x77\x1a\x1c\xd8\x56\x64\x06\x5c\xcb\x3c\x3d\xd9\xf2\xbc\xd8\xb9\xe9\x9b\xc9\x05\x50\xf7\x67\xf2\x5e\xb0\xb3\x3c\xd7\x8f\x4f\xdd\x0b\x9d\x5b\x4b\xd7\x0d\xfb\x18\x24\xfb\xd8\x5b\x7e\x2b\x2f\x68\xdd\xdd\x71\x18\x07\x69\x97\xe3\xa3\xf5\x3b\xb9\x28\xf2\xdd\xdc\x4e\xc4\xcd\xb6\x73\xa7\x18\x94\x34\x31\xdc\xc8\x1d\x47\x6f\x5a\x73\x61\x74\xd2\x9b\x56\x46\xf5\xd7\x43\x6f\xda\xc2\x5c\xda\xa4\x37\xbd\xbc\xba\xbc\xbd\x3c\x7b\x7f\xf9\x7f\x6b\x25\xfe\x7c\x76\x79\x7b\x79\xf5\xc7\xf9\xbb\x8f\xd7\xf3\xeb\x8b\x9b\x8f\x77\xd7\xe7\x17\xfd\x7c\x45\xcd\xda\x07\x13\xfc\x84\xc5\xdf\x79\xcd\x6e\x23\xa0\x06\x26\x1b\x90\xfd\x4d\xda\x95\x30\xab\xec\x62\x96\x6a\x35\x81\x85\xfa\x9a\x5d\xe4\xf9\xe5\x86\xaf\xc4\xa7\x32\xcb\x00\x4e\x85\x99\x3d\xe7\xb9\x80\x8b\xe7\x84\x7d\xd2\xe9\x65\xf4\x1e\xa4\x23\xb6\x36\x03\xbe\xcf\xd3\x34\x17\xc6\xe0\xe7\x27\xf4\xfd\x08\x3c\xe4\x53\x1d\x09\x3c\xc7\x1f\xb8\xcc\xec\xfd\xed\x35\x7b\xc3\x93\x7b\xbd\x5c\x62\xfa\xcc\xc4\x27\x4e\xb1\x2f\xa5\x2e\x38\x13\xbf\x24\xc0\xd1\xd5\x3e\x4f\xde\xeb\xd5\x37\x80\x2a\x0f\x08\x4f\x75\x5c\x52\x40\xa3\x6c\xde\x7e\x9c\xb7\x6f\x04\xd4\xca\x0f\xf8\xea\x3b\x7c\xb3\xdd\x41\x59\x64\x4f\x90\x1e\xff\x5e\xaf\xda\x15\x63\xc0\xba\x26\x99\x1b\x0a\x24\x24\x44\xb6\xa1\x57\xcc\x48\x75\x3f\x53\x3f\xaf\x85\x62\xba\xcc\xf1\x4f\x70\xcd\xb7\x66\x66\x56\x9a\xb5\x00\x09\xd9\x09\x7b\x14\x6c\xc3\x77\x68\x36\xc3\x9d\xc0\xcb\x5c\xc0\x94\x81\x53\xc4\xbe\x9d\x49\x65\x77\x8b\xad\x74\x79\x09\xf5\xa1\x7f\x8a\x1b\x97\x63\xa8\xe3\xc7\x13\xc8\xf6\x9d\xa7\x15\x7c\x1e\xb8\xca\x02\x6e\xd2\x01\x84\x68\xe7\x06\x15\x4d\xad\xef\xcb\x6d\xe0\xb2\x7c\xe1\x82\x93\xd0\xdd\x0f\x5a\xa6\x2c\x2d\xb7\x99\x4c\xfc\xbe\xfb\xa8\xf3\x4e\xc2\x5e\x4c\xa0\x19\x7e\xea\xd4\xd3\xc2\xfa\x1a\xd6\x92\x9d\x13\x21\xe9\x7a\xa8\x7b\x9f\x99\xbc\x98\x49\x95\x64\x25\xe8\x83\x95\x46\xe4\x27\x45\x2e\x57\x2b\x30\xc0\x5d\xae\xdf\xaf\x9f\xdd\x38\xb0\x27\x1e\x9f\xd6\x16\x27\x9d\x67\x7a\x25\x13\x9e\xc5\xe0\xe6\x80\x8a\xf0\xf4\xa9\x6e\xd9\x93\x7a\x2a\xe4\x41\xb8\x0a\x75\x32\x20\x6d\x73\x01\x0c\xbe\x73\xd8\xca\xe7\xb4\xdd\x1d\x53\xef\x25\xb3\x17\x74\xac\x57\x4c\x6e\xea\xc2\x0b\xee\x84\x0b\xdf\x76\x12\x5a\x60\x62\xa2\xbc\x36\xd3\x8f\x4a\xe4\x60\xc1\x02\xec\xc3\xb6\x54\x69\xb0\x4d\xbc\xac\x96\xc7\x27\x3b\x59\xb9\xa5\x07\x62\x63\xe6\xec\x4a\x3e\x08\xf5\xf5\xd9\xa8\xa3\x0f\x24\x3c\x59\x8b\xb9\xb3\xcb\x9f\x7a\xcb\xf2\x07\xc0\xc8\xcd\xca\xe9\x5b\xc4\x5b\xa9\x0f\x6f\xc2\xd5\x09\x6b\xdc\xdc\xbb\x30\x90\xd8\x93\x91\x65\x2b\x31\x4f\x45\x72\xff\xd5\xb7\xe6\x00\xb2\x72\x15\x61\x9c\xbd\x15\xc9\x3d\xbb\xbb\xbe\xc4\x6c\x60\x59\x30\xbb\x15\x98\x75\xd0\xeb\xe9\xbc\xbb\x15\x7c\xf5\x0c\x8c\x4e\x43\x05\x87\x02\xc7\xbc\x97\x59\xb3\x15\x22\x40\x14\xe4\x4b\xda\x4d\x92\x72\x69\x00\x08\xc6\x0b\x27\x43\x03\x8e\x78\x66\x36\xa0\x3a\x53\x16\x91\x54\x5b\xc6\x17\x22\xeb\x60\x5c\xdc\xea\x74\xee\xe2\x24\xc7\x82\x79\x1a\x65\x39\x3f\x06\x45\x1d\x5d\x1e\x03\xb7\x16\xeb\x2d\x3d\xc8\xee\xff\x60\x22\x7a\x0d\x1d\x13\x3f\xc3\xbd\x9e\x1b\x48\xef\x5e\xca\x95\x8b\xb6\xc9\x25\x69\xe3\x60\x42\x3f\xa8\xc0\xdb\xfd\xd2\x96\xf4\x49\xa7\x04\xd3\xf3\x24\x66\xd6\x0a\x12\xe4\x3d\x09\xb8\x8a\xb8\x0a\x5e\x29\xdf\x80\x6f\xc0\x14\x82\xa7\x4c\x2f\xc9\x9b\xb8\xdd\x66\x12\x28\x7d\x53\x64\x0f\x07\xf6\x0c\x53\x45\xc7\xc7\xa5\xb9\xca\x46\x24\x1f\x9f\x1c\x10\xaf\x4b\x45\x15\x36\x0c\xcc\x60\x98\x03\x39\xda\xfc\x81\x77\x73\x8b\x3d\xbb\xd4\x55\x47\x7d\x7c\x34\xb9\xca\xe5\x89\xf3\x93\x36\x1c\xf2\x15\xe0\xb1\xee\x12\xf2\x13\x9e\x25\x25\xc5\xc9\x40\x1f\xdc\xc9\x7e\xf7\x23\x08\x43\xd4\xcf\x0e\x74\xd5\xeb\x5f\x37\x32\x8f\x95\xc5\xf3\x09\x5a\x87\xfa\x14\xfa\xdd\x8b\xab\x4c\x2f\x60\xe6\x74\xa3\x04\x7b\x4e\x2c\xbb\x5d\xe7\x32\x1d\x63\xef\xb8\x3e\xf9\xe8\x5f\xed\xab\xe0\x47\xe7\xfa\xf1\x5f\x72\xf3\x9e\x11\x03\x7d\x0c\x69\xa8\xe5\xf5\xef\x73\x3e\x40\xc4\xd4\xf8\x90\xa9\xbf\x9e\x14\xa4\xbf\x00\xd3\xca\x9f\x4f\x1d\x7e\x86\x6a\x5b\x8e\x1a\xe8\x26\x53\xcc\x9e\xbe\x0c\xe4\x32\xfd\x83\x7c\x04\xdd\x07\x6e\x65\x9e\xf3\xa3\xdb\xb3\xa8\x52\x91\xce\x0f\x68\xc3\x05\xbd\x3b\xac\x2d\xbe\xa7\xb1\x7a\xe0\x03\x54\x27\xd6\x54\x48\x79\x9e\x86\x76\x4c\x60\xbd\x27\x7c\x0b\x6e\x78\x08\x6b\x3c\xbc\x9a\xba\x6f\x5c\x87\xec\x22\xbb\x5f\x62\xce\x3f\xe2\xb7\x75\x8b\x78\xc9\xbe\x79\xe4\x27\x29\xc2\xbb\xed\xcc\x09\xd3\xb5\x92\x77\x33\x68\xee\xd6\x67\x98\xdb\xc0\x8f\x99\x5c\xcf\xb1\x77\x94\x85\x0e\xd1\x1e\x68\xcf\x25\xf0\xc5\xc6\x19\x7d\xb0\x41\x5e\xa6\x1d\x48\x11\x67\x7e\xbb\x4d\x68\x04\xfe\x78\x14\x02\x7a\x9b\x0b\x17\x37\xdc\x89\xc2\xf3\x3a\x64\x4e\x10\x0e\xc2\x62\xbe\xd5\x55\x62\x1b\xc7\x5d\xe1\xc9\xc8\x20\x88\x45\xa6\x7e\xa2\x37\x5b\xad\x00\x96\x84\x59\x6a\x33\x45\x85\x3b\x59\x6f\x1f\x59\xab\xa4\x3a\x4e\xc8\xa1\x89\x89\x33\xc2\xe8\xec\x81\x42\xa8\x91\xfa\x04\x08\x02\xda\x0a\x9e\xdb\xbb\xa1\xce\x91\x60\xcb\x9d\xec\x90\x09\x50\xd3\xb6\xce\xc5\x4a\x9a\x42\xc4\xd9\xa1\xf1\xfb\x4f\x26\x43\x5a\x71\x9e\xf4\x75\x7d\xa7\x0c\xe9\xbe\x5b\x90\xdd\x9f\x46\xd4\x67\xb7\x15\xe9\xa5\x7f\xaf\x7f\x32\xd4\x12\xf8\xc3\x76\x58\x39\xef\x70\x0e\xe0\xed\xcf\x20\xd5\x97\xf1\xba\x11\x7e\x90\x88\x84\x89\x07\x40\xa3\x1d\xa2\x55\xc9\x73\xae\x0a\x21\xcc\x4c\x51\xe0\x19\x29\xeb\x62\x56\x96\x1a\x10\xd2\xdf\x6d\x12\x6d\x0a\x64\x80\x82\x57\x96\x5c\x66\x65\xde\xe9\x6e\xc0\x59\x79\x10\xed\x44\x5f\x2f\x9d\x43\xb1\xac\x6d\xd0\x7c\x02\x73\xb4\x8a\x3c\x6b\x4a\x3d\x6c\x5c\xcd\xef\xed\x68\x82\x3b\x5c\x86\x8f\xb7\xf7\x35\x77\xe4\x34\xff\xc1\xcc\xb7\x7a\xc4\x8e\xf7\xe7\x3f\x98\x4f\xba\x23\x1b\xdc\x7c\x69\xf8\x44\x7b\xe0\x13\x5f\xba\x94\x34\xb8\xb9\x87\xc8\xe3\x3e\x57\xcc\x20\x36\xce\xbd\xf1\xc9\xce\xbd\x0b\x66\xed\x9a\xab\x34\xb3\x26\x2f\x2f\x6a\x27\x50\xc0\x79\xdb\x2b\x51\xe1\x36\xc7\xee\xa4\x3e\xc8\x91\x99\x27\x8d\x04\xcb\x7d\xfd\x54\xcb\xcc\xec\xc5\x52\xd6\xbe\x52\xcd\x97\x6c\xcb\xd3\x09\x36\x0c\xe9\xd7\xfa\x05\xfb\xcd\xed\x97\x8b\xb8\xee\x5f\xc9\x7c\xa9\xae\xb5\xa5\x5c\xfd\x0a\x1c\x09\x1f\x9a\x47\x42\x42\x7b\x0e\x1d\xd4\x3e\xbb\xe1\xc8\x5d\x07\x12\xc9\xec\xae\x1d\x13\x70\xcf\x14\xe9\x78\x23\xba\x00\xc2\xca\xc8\xb7\x66\xd8\x2b\x9f\x5d\xfc\xea\x1f\x1d\xdb\xd6\x8e\x2d\x61\x52\x01\xa5\x9d\x4e\x92\x32\x87\xd0\x3f\xb9\x27\x99\xc0\x43\xd8\x8c\x22\x92\x01\xd3\xc3\x03\xb6\xd0\x4e\x6c\x33\x93\xbc\x3f\xba\xd2\xa8\x5b\x70\x43\xa2\x22\xb9\x3f\xf4\x49\x68\x2a\x37\x05\x33\x85\xd8\xb6\x6e\xbf\x15\xeb\xb2\x2a\xba\x7f\x84\x7d\x19\x24\xff\x07\x2e\x9d\x11\x87\xd1\x59\xe4\x32\xfa\xd3\xcd\xc7\x2b\xb6\xe5\x3b\xc0\x3e\x16\x9a\xe1\xa3\x40\x38\x5a\xdf\xa8\xf6\x8d\x40\xb5\xf1\xd5\x5d\x05\xfb\xd4\x81\xa8\xdb\xe3\x13\xf4\xc5\xa6\xb1\x08\x73\x86\xa6\xa4\xdd\xb3\x72\x9d\x9d\x6c\x33\xae\x22\x78\xbb\x99\xb2\xda\xe7\x63\x3c\x83\x8f\x6c\x12\x62\x0c\x2a\x00\xfe\x0a\x9a\x0b\x79\xd9\x0a\x80\x06\xde\x1d\x37\xa1\x8e\x83\x30\x74\xee\x11\xbd\xc0\xce\x0f\x28\xdf\xc1\x13\xbb\x4c\x90\x3d\xc3\xc1\x32\x3c\xb2\x87\x1b\x00\xdd\x76\x32\x80\xf3\x24\xe3\xc6\xf4\xa2\x74\x9e\x83\xc2\x3e\xce\x5a\xdc\xbf\x7d\x55\xeb\x89\x30\x42\xe0\x36\xc1\x7b\xa9\xff\x19\xd8\x12\xdc\xd6\x15\xd4\xba\x22\x7b\x3f\x52\x8d\x20\xe8\x03\xf1\x45\xc1\xfb\xc8\x04\x79\x2f\x76\xce\xc3\x45\x5b\x15\xdf\x88\x89\x77\xb6\x7a\x6f\x62\x04\xfa\x6b\x16\x3c\x53\x80\x8a\x7d\x17\x57\x8f\xbd\xd3\x7a\x82\xf8\x4c\xfa\x38\xc7\x62\x79\x8c\x70\x9a\xa9\x77\x5a\x4f\xb9\xbf\xc4\x52\xfd\x69\xbb\xa9\x7f\x90\x50\x51\x80\x39\xac\x0d\xe7\xf0\xb5\xf9\xa3\x54\xa8\x2b\x27\x37\xf6\x02\x45\xfd\x04\x33\x0a\x2a\xe4\x64\xcc\xf5\xa3\x61\x29\x52\xca\x94\xd2\xac\x21\xec\x82\x71\x4e\xf8\x3e\x1d\x29\x08\xc8\xca\xb9\x32\x76\x0d\x43\xa8\x46\x3c\x08\xf2\xd7\x56\x30\x06\x97\x6f\xdf\x7b\xd8\x12\xae\x4b\x52\x9a\xec\x58\x6d\xd1\xa5\xe3\x98\xcb\x39\xc0\xcd\x47\x10\xda\x91\x83\xf3\x03\xdf\xf6\x25\xc3\x1e\x5d\xe2\xbe\x51\xf2\x84\x5a\xf5\x1b\x15\x48\x50\x83\xf8\x5c\x25\x23\x36\xee\xbd\x3b\x75\xe4\x89\xd3\xca\x69\xbf\x5f\x2b\x65\xb0\x83\x61\xe4\x56\xb1\xff\xb8\x89\xb8\x2d\x3d\x64\xd0\xdf\x05\xed\xc6\x0e\xd2\x5e\x40\xca\x87\x4b\x7a\xca\x6e\x84\x60\x9f\xa1\xa7\xec\xc7\x3e\x93\x74\x24\xa0\xa0\x0b\x2e\x5b\x95\xbd\xe0\xe9\x4b\xb5\xd4\xc7\xed\xff\xf9\xaa\x81\xb2\x3d\xaa\x57\xda\xeb\x79\x2c\x8e\x17\x3c\xfd\xea\x79\x69\x45\x06\x1d\x0c\xb5\xb1\xfe\x14\xfc\x4d\x94\x6c\xec\x6a\x6a\x4d\x32\x18\xe2\x43\x88\xeb\x6a\x93\xc4\xb6\x72\x82\x64\xec\xf7\x4a\x3f\x2a\xdc\x8f\xe9\x4b\xec\x3b\xbb\xfe\xc0\x66\xc1\xb8\x10\x5a\x82\x25\xee\x86\x2f\x81\x1d\xfe\xcc\xff\x9b\xdd\x60\x08\x1c\xeb\x0c\x9a\x4f\x06\xec\x5d\x52\x6b\x82\x03\xfc\xbb\xb3\x09\x7b\x33\x61\xe7\x13\x36\x9d\x4e\x5f\x4e\x50\x90\x9e\x6a\x84\xaf\xe0\xd6\x5f\xf0\x95\x2d\x9b\x54\x70\x96\xd1\x07\x40\xd7\xcd\xda\x27\x8e\x04\x91\x87\xa7\x22\xaf\x9a\x6b\x02\xa6\x66\x53\x1e\x19\xc1\x85\x92\xb5\x96\xa1\x52\x80\x3c\x17\x89\xce\x1d\x76\xdd\x14\x3a\x77\x38\xdc\x07\x9e\x73\xa9\x80\xb1\x82\x37\xb3\x10\xe8\xcb\x11\x67\xbd\xf8\x85\x6f\xa0\xfd\x52\x79\xda\x5e\xdb\x4d\xb7\xbe\xfe\xc5\x6e\x4b\x71\xb6\xc7\x5c\x16\x85\x35\xc8\xcc\x4c\xdd\xb0\xd7\xff\xc2\xce\xb6\xdb\x4c\xb0\x33\xf6\x37\xf6\x86\x2b\xae\x38\x7b\xc3\xfe\xc6\xce\xb9\x2a\x78\xa6\xcb\xad\x60\xe7\xec\x6f\xb6\xdb\x6c\x79\x57\xda\x5a\x40\xbb\x09\xe3\x4c\x95\x19\x1a\x7a\xdf\x39\x8c\xeb\x4b\xdf\x2e\x1e\x46\x67\x21\x8a\x47\x21\x14\x33\x7a\x43\x47\xe1\x5f\xfd\xe9\x6f\xa4\x5a\x65\xa2\xa0\xf9\x50\x45\x23\xe3\x07\x4e\xa0\xa5\xaf\x67\xca\xfb\xa9\xff\x6a\x6b\xfc\x57\xf6\x37\x76\x55\x66\x99\xad\x92\xdd\x68\xec\x44\x7a\xcd\x5c\x76\x98\x50\xd3\x47\x79\x2f\xb7\x22\x95\x1c\xf2\xc3\xec\xbf\x4e\x6f\x61\xb4\xe7\x65\xa0\x02\x8d\xd7\xb4\xd7\xd1\x3a\x66\xeb\x79\x16\xae\x09\xaf\xf2\x16\x5b\x2b\x9d\x20\x94\xf8\xd5\xf1\x46\x70\x20\x40\xa6\xf5\x40\x77\x14\xd4\x40\x8b\x03\x94\x07\x6d\x01\xb5\xc3\xd6\x95\xd5\x72\x14\xc4\x87\xfa\xb1\x9b\x2c\x48\x23\x7e\x45\x73\xfc\xa7\x46\x17\x0d\xe6\xde\x27\xf9\xa7\x0a\x7b\x07\xd8\x92\x81\xc1\x6c\x50\x6c\xd7\x0b\x49\xfd\x54\xd5\x86\xac\x74\xb1\x96\x83\x44\x34\x6b\x95\xbd\xa3\x9b\x00\xe6\xdd\xda\x65\x2a\xb3\x53\xbb\x54\x4f\xaf\xb4\x12\x8c\x1b\x23\x57\xc8\xba\x06\x0e\x1d\x54\x9f\x74\x46\xc1\x6d\xd5\x64\x8d\x96\x00\xd8\x07\xb6\x4a\x88\xd8\x2d\xec\x2e\x60\x87\x20\xdb\xcd\x94\x7d\x83\x4e\x24\xc8\xde\x91\x9e\x9c\x1b\xbf\x46\xdc\xd7\xee\x5b\xb4\x21\x47\x85\xb7\x4c\xb0\x3e\x6a\x80\x23\x26\x1c\x65\xa2\x1e\x11\xf1\xb9\x8a\x88\x29\xa9\x34\xc7\x5a\x84\x70\x8e\x85\xc8\xb4\x5a\xd9\x59\xd1\xb5\x09\xe8\x0d\x97\xc7\xe0\xe5\xe2\x2a\x60\x61\x9d\x35\xb0\x87\x25\x3d\x42\x43\x62\xcf\x49\x99\x06\x97\x8e\x29\x17\xd6\x8e\xf0\xd1\x06\x7f\x1a\x52\xe3\xba\x78\x12\x8e\x83\xcd\xdc\x19\x91\x03\x7b\x3c\x02\xb7\x7c\x24\x0b\x0f\xce\xc0\x21\x84\x2d\x1a\xb6\xa8\x7a\xf1\xfe\xed\xde\x2f\x8a\x94\x35\x18\x23\x06\xcc\xc7\x6f\x09\xfd\x1f\x92\x10\xf0\xee\xec\xf2\x7d\xed\xb9\x66\x42\x40\x4b\xd6\xc0\xed\xe5\x87\x8b\xb7\xf3\x8f\x77\xb7\x8d\xe7\x6c\x69\xf4\xa7\x3d\x39\x01\x9d\xbd\xf7\x14\xa8\xe8\x2f\xa8\x62\x35\xd7\x4b\x97\x20\x3e\xfc\x4c\x6f\xe8\x88\x0d\x03\xdf\x15\xd1\xfd\x2a\xd6\xdb\x6a\x4e\x9c\x4e\x9a\x0b\x35\xa7\x68\xdb\xb0\xca\xd6\x3b\xec\xa3\x7a\x87\xaf\x7f\xd2\x99\x4c\xfa\xb1\xbc\xee\xb8\x5a\xeb\xc7\x16\x70\xe4\x42\x00\xb8\x9d\x5c\x7e\x54\x29\xb4\xd0\x0b\x91\x14\x21\x9a\xdc\x6c\xdc\xff\x6a\xfc\xe0\xfe\x3b\x38\x7a\xe2\x7c\xb7\x81\xae\xb0\x8f\x4f\xc3\xd9\x0a\xbc\xc1\x20\x97\x81\xee\x75\xf0\xed\x01\x6e\x23\xe1\x14\x75\xa8\xf4\x3c\x6c\xd0\x8f\x6b\x9d\x91\x47\x0e\x39\x98\x67\x6a\x2b\xf2\x44\x03\xee\x0e\xe9\x3d\x34\x4b\xd6\x32\x4b\x83\x26\xd5\x77\x90\xa8\x00\x70\xe2\x97\xa4\x36\x2a\x3c\x7e\xc2\x15\xdf\x73\xea\xba\x69\xf7\x16\x57\xf7\x51\xd8\xa3\xa7\x44\x1e\xf7\x4d\xfb\x9f\x09\x21\x8b\x5d\x41\xac\x69\xb5\x48\xb8\xed\xf4\x4a\x7d\x46\x39\xf5\xed\x71\x4b\x72\x43\x49\xb8\x38\x15\xb5\x71\xa5\x69\x56\xef\x4a\xe0\xd2\x46\x4f\x2a\xc2\xc0\x8c\x80\xea\x6c\x04\x47\x5b\x2c\x30\xdb\xd2\xa0\xce\x54\x88\xfd\xbf\x30\xb1\x5d\xd6\x3a\xce\xe8\x7f\x75\xd8\xe6\x09\x7b\x51\x69\xe8\x0b\xe0\x5a\x56\x1a\xbe\x47\xf1\xd9\x4a\xd7\xc0\x74\x9d\x30\x59\xcc\x94\x34\x38\x33\x73\x91\x89\x07\x5b\xbb\x38\x3e\x40\x88\x35\x77\x77\x76\xcd\x86\xf4\x18\xee\x58\x15\x68\xda\xd0\x22\xcc\x63\xce\x5e\x0c\x4c\xa6\xc2\x58\xbb\x11\xd4\x86\xc4\x2f\x76\x01\x48\x08\x7f\x21\xb4\x29\x15\xca\xd5\x0f\x10\x4f\x28\xd1\x3d\x53\x97\x4b\x48\x6d\x87\x84\xfa\x34\xc5\x5b\xa8\xd3\x9f\xf1\x04\x8a\x92\xe2\x01\x9a\xee\xe4\x6e\x20\x48\x2c\x17\x57\x92\x78\x10\xf9\xae\x00\xa7\x2e\xf4\xab\x12\xbc\x58\x33\x59\x4c\x80\xf9\xd2\xed\x94\x33\xc5\xd3\x94\x32\x82\xb1\x38\xdb\x35\x30\xef\x7b\xc6\x99\x7e\x5f\xe8\x87\x3e\xc3\xf6\x58\xec\x26\xae\xea\x6d\xc6\xd5\x1c\x4f\x90\x6f\x80\xde\x8c\x74\x8c\xbb\xc2\xf8\xe5\x62\xee\xd9\xba\x9e\xa4\x9e\x91\xd4\x7d\xac\x2e\x6e\xed\x58\xf7\xa1\x49\x05\x9c\xbb\x08\xc4\x0e\xde\x4f\x43\xc8\x99\x9c\x39\x74\xc1\xf0\x5d\x20\x00\x3b\x79\x0d\x65\xe3\x66\xeb\x3e\x64\xa7\x9b\x01\xbf\x56\xec\xdd\x90\x91\xaf\x9d\x21\xf5\x61\x1f\x0f\xfb\x6a\x58\x88\x07\x41\xbf\xf6\x54\xeb\x79\xe1\x5f\x9d\x7e\x94\x26\x0c\xcc\xb5\x36\x8a\xf0\x12\x78\x1c\xfd\x70\xde\xcd\xd3\xae\x53\x1d\xdf\xc3\x74\x0b\x42\xfa\x29\x7d\xd4\xb0\x4f\x0d\xf5\x94\x04\x4a\x09\xa8\xd7\x94\x5d\x2a\xe6\xcc\xbd\x09\x7b\x81\x13\xcb\xbc\x20\x17\x24\x89\x9d\x13\x5c\x22\xa5\xd5\x43\x49\xf8\x75\x98\x11\xa6\x42\x85\xe5\x86\x91\xa0\x5e\xc6\xd6\x67\xed\x97\x37\x12\x52\xb1\x0e\x61\xdb\xc0\x28\xe2\x02\x0b\x70\x99\x04\x70\xed\xde\xa1\xd1\xae\x83\x37\x3b\x34\xd8\xc5\xbb\xd8\x1b\xf7\xa2\xed\xa2\x6d\x49\xe7\xa9\xfb\x9d\xe9\x7c\xa6\x5c\x69\xe4\x92\x34\x28\x11\x57\x2f\x2a\xca\x0c\x21\x9b\x3f\x9a\xa9\x10\x0c\x76\xaa\x80\x20\x36\x19\x68\xa5\xeb\xbb\x00\xe0\x60\x16\x1e\x83\x08\x3a\x04\xe1\x6b\xd6\xf0\xb0\x13\x7c\x83\xc7\x7c\x9d\x7a\x36\xcb\x6c\xa7\xc8\xc2\x31\xdd\x46\x59\x5b\xa6\x04\xbe\xe6\x65\x69\x37\xa3\x88\xd4\x7a\xa6\x6c\xe7\xb1\xa5\x04\xf4\x3e\xf5\xcb\x4c\x7d\xd0\xc6\x91\x84\x98\xd0\x1f\x2e\xb4\x4c\xdd\xf6\xc2\x8b\x23\xd2\x1f\xde\xc2\xa1\x4d\x3e\x7f\xa4\xfb\xf2\x47\x0b\xa4\xeb\x11\xd3\xcf\x4e\x97\x79\x68\x54\xc2\xd5\x4c\xfd\x87\xed\x1e\x14\xe8\x57\x6e\x58\xf5\x12\x97\x30\x8c\x20\x04\x4b\x3e\x63\xa1\xdf\xfd\xe3\xcb\xcf\x2f\x31\xbd\xa6\x34\xa0\x47\x3b\xa9\x1e\x20\x5e\xdf\xa0\xcc\x32\x88\x44\xbb\x16\x78\x8e\x9d\xf0\x89\x5e\x24\x16\x5d\xea\xe6\xaa\x6a\x62\x0c\x59\xe8\x7d\x33\x38\x38\x9f\xcf\x58\xc2\x8b\x64\x7d\xe2\x6c\x39\xda\xc6\xdc\xe9\x47\xc3\x87\x79\x30\xd6\xd2\x6a\xa7\xf8\xb7\x17\xce\x7c\xe3\x49\x47\x2b\xf3\xc5\x36\x01\xb0\x54\xb7\x75\xbd\x2b\xcf\x89\x8c\x93\x13\x91\x20\x55\x3b\xcf\x3f\xee\xd4\x26\xc3\x8d\x93\xbc\xe4\x8a\x6f\x44\xca\x5e\x40\x22\xe8\x0b\x37\xf8\x33\xb5\x5d\x4c\xb3\xdd\xb2\x20\xe6\x3a\xdb\x29\x53\xd0\x65\xdb\x73\xca\xcd\xd3\xe6\x35\x69\x4f\x67\x77\x5e\xb4\xda\x6d\x1d\xdf\x37\xfe\x4b\xc3\x0d\x16\xf4\x71\xf9\xde\xb9\xa9\xa2\xc2\xaa\x02\x11\xdc\xdc\x4f\xd8\x22\xe7\x0a\x24\x75\xd2\xd8\xa8\x0a\xab\x13\x2e\xcf\x48\x0b\xe7\x32\xc3\x14\xcf\x76\x90\x01\x32\x99\x29\xe4\xd0\x03\xb2\xf5\x5d\x92\xc9\x84\xad\x72\xbe\x5d\xd7\xec\x20\xf1\x20\x54\x01\xca\xcc\xd7\x82\x9b\xe3\xa2\xf5\x79\xbd\x04\x36\x38\x9e\x72\xa6\xe0\xf6\xc1\x55\x8d\xf5\x18\xaa\xd7\x71\xb4\x00\x42\x4f\xa4\xf3\x71\x8c\x47\x7b\x79\x79\x2b\x6c\x8f\x44\x3d\x06\x11\x48\xdb\x38\xe6\xbe\xba\x2f\xfc\x8d\xfd\x4a\x64\x3c\x0e\xd3\x79\x6c\xc8\xde\x93\xfb\x1c\x45\xd1\x7a\x59\xb5\x22\x79\x60\x2d\x0a\x9e\x6b\xcc\x6b\x24\x4f\x85\x03\xc2\xfb\x8d\x63\x42\xca\x99\x40\xdf\xc8\xfe\x52\x2e\x74\xe6\xf8\x2f\x2f\xdf\x32\x9d\x83\xf4\x4c\xa1\xe9\x4f\x32\xed\xb2\x0e\xa4\x4a\xc5\x2f\x47\x91\xd0\xf4\x1f\xf4\xce\x6c\xb6\x9f\x89\x14\x4e\xea\x8d\x85\xdd\x29\x17\xf6\x10\x2e\xdc\xcd\xb8\xf1\x94\xa9\x83\x55\xcf\xb2\x62\x0d\x08\x52\x4c\xd2\x08\x9d\xba\xe1\x3b\x96\xac\xb9\x5a\x45\xae\x09\x00\xf4\x89\xad\xce\x51\xa2\xf5\x01\xd8\x1e\x75\xee\x92\xfc\x29\x75\x9d\x32\x45\x7c\x20\x01\x01\xda\xda\xe5\xa7\xf3\xd5\x2a\x17\x2b\x48\x64\x9c\xa9\x0a\xf9\x06\x30\x5d\x3a\x75\x18\xfc\x4e\x1f\x77\xc1\xd3\x10\x00\x75\xdd\x06\x8b\x7c\xe7\x33\xbf\x49\xdf\x38\xac\xe7\x7a\xb7\x4e\x98\x14\xd3\x09\xfb\x21\x80\xd2\x45\xa2\x95\x4f\x1d\xef\xc8\x1b\xae\xb9\xfc\xd9\x9e\xab\x43\x93\x29\xa8\xbd\xee\xf0\x5b\x43\x25\xb9\x75\xd2\xf4\xe6\xde\x17\xbc\x28\x47\x9c\x41\xa4\x84\x7f\x6e\x5f\xbe\xc1\x77\xfb\xe6\xf5\x39\x22\xc6\x1d\x4b\x9b\x7d\xde\x9e\x9c\xf6\xdb\x81\xc5\xbd\xad\xaf\xf7\x3a\x90\x33\xdd\xed\x40\x7e\x0a\x53\xdd\x51\xf1\xec\xf7\x21\x67\x1d\xf4\x32\x3d\x6d\x1a\xeb\x22\x76\xb8\x6e\x4a\x4d\x31\xf5\x6b\x6c\xcb\x0e\xb0\xcd\x75\x5a\x26\x22\xb5\x2b\x17\xee\x43\x88\x88\xf1\x2c\x37\x95\x4d\xb2\xed\xa0\xad\x50\x75\xc1\xa9\xfb\xb5\x7c\x0e\x83\xd8\xd1\x7d\xf7\xdf\x75\xf8\x1b\x9c\xc5\xd7\xd6\xe9\xf1\xfa\xc4\x7e\xca\x47\x9e\x53\xfe\xf3\x55\x4e\x73\x9d\xcb\x95\x54\xbc\xd0\x39\xfb\xce\xe7\xb2\xbf\xf4\x42\x68\xdd\x16\xc2\xc8\x6d\xa2\xd2\x45\xb8\x4d\x7c\x55\xc3\xa3\x6d\x92\xda\xa7\x4c\xc1\x37\xdb\x98\x25\xd8\xcb\xcc\x53\xcf\x64\xd8\x09\xde\x36\x01\xdf\xa9\x34\x21\x6f\x73\xa6\x28\xe2\x80\xe3\xa6\xf3\x98\xe6\xbe\xf3\x6c\xde\x96\xc5\xfc\x40\xe6\x2b\x7c\x79\x9c\xe3\x89\x60\x08\x1f\xf8\xb6\x9f\x4b\x88\x93\xcb\x01\x13\xd7\xbc\xf6\xbe\xb3\x54\xaa\xf3\xb3\x5f\x48\x66\x24\xb7\x71\x3d\x74\x7e\xfd\xde\x05\x8a\xc2\x7d\xb0\x72\xc1\x82\x81\x40\x52\x55\x4c\x04\xc2\xab\xbd\xdf\xd6\xec\x29\xee\x08\x88\xce\x33\x5d\xa6\x8c\x36\x35\x0a\xc3\xe7\x53\x3c\x1d\x81\xe5\x78\x3a\xed\x4a\x6c\x1a\x29\x70\xed\xf7\x1f\x78\xaf\x7d\x05\xc2\x6f\x1d\x3b\x70\xef\xd2\xa7\x9e\x7d\xb6\xa1\xa7\x9e\x86\xb1\xf7\xdb\xf1\xa8\xb1\xf7\x5e\x70\xa0\x5c\x1c\xe7\x20\x85\xfb\xa8\x4c\x33\x58\x6f\x71\x00\xa1\x85\x14\xba\x12\x98\x35\xf7\x47\x7f\xce\xf1\x10\xf4\x7f\x6a\xcb\x73\xa1\x8a\x39\x7c\x71\xdc\xc7\xe0\x23\x9f\xe0\xf5\x8a\xc1\x34\xc8\x11\xfc\x6f\xb7\x1a\xfd\xfb\x8e\x5f\xe9\xdf\xd9\x0d\xf9\xb4\xec\x7e\x25\x01\x44\x6a\xee\xd9\x77\x12\x30\x47\x51\x2c\xd4\x0f\x5c\xc7\x70\x51\x83\x0e\xe8\xbd\xa8\x41\x95\xad\x7d\x50\x83\x42\xed\x21\x54\x0d\xa5\x90\x7b\x8f\xb2\xc2\xed\x56\xeb\xfe\x16\x69\x2e\x5c\x55\xfe\x0d\xfc\xb8\x76\xfc\x32\xf6\x9f\x22\xd7\x21\x03\x08\x9d\x55\x71\xc1\xbd\xf6\xfa\xe1\x72\xd1\x68\x8f\xa3\x50\x71\xac\xd4\x09\x7f\x21\x0a\x2b\xf4\x28\x2c\x76\xee\x3a\xd2\x11\x42\xda\x8a\x64\xde\x21\xcb\x32\xa8\x2a\xd1\xc5\x33\x96\x59\x91\xb5\xc3\xcc\x2d\xd0\x53\xf0\x57\x50\x6a\xcd\x86\x6f\x09\xdf\x47\x50\xe2\x7a\xf0\x66\x0a\x8d\xf8\xb7\xbf\xfe\xfb\x54\x76\x24\xf9\x42\xd5\xc7\xc2\xa5\x7c\xe5\xdf\xe5\x52\xa8\x14\x82\xb1\x3c\x6d\x2a\x86\xa9\x8a\x77\xbe\xb2\x3d\xdb\x69\xf8\x24\x19\xc1\xed\x47\xad\x99\xe3\x24\xfa\x0a\x11\xfd\xb0\xc9\xfa\xe5\x5b\x89\xf7\x75\x99\x12\x66\x9e\xee\x14\xdf\xc8\xe4\xab\xd6\x71\x27\x45\x96\x42\x15\xe9\xeb\xfb\xa2\x52\xa9\x48\xee\xc7\xda\x04\x07\xeb\x1d\x88\xe4\x9e\xfd\x78\xfb\xe1\x3d\xca\xdb\x4a\x33\x53\x57\xbc\x90\x0f\xe2\x2e\xcf\x7c\x38\x80\x08\xac\xf2\xcc\xad\x91\x2a\xff\x76\xc4\xf5\xe4\xc8\xba\x9d\xe1\x10\xcb\x23\x6c\x76\x27\x8b\x32\xb9\x17\xc5\x69\xce\x55\xaa\x37\xd8\x8c\x53\x53\x2e\x97\xf2\x97\x69\xc1\xf3\x0e\xad\x04\xf4\x23\x7c\x43\x3b\x37\x28\x60\x15\xc1\xe6\x45\x53\xf7\x11\x12\x7d\x49\x57\xbd\x62\xdc\x62\x5e\x1a\xdf\x08\x20\xbb\x64\x55\x9d\x11\x28\x05\x73\x67\x41\x8e\xd3\x18\x42\xd0\x6b\x12\xfb\xfe\x1c\x19\xf7\x9f\xa3\x5a\x55\x05\xe7\x5d\xa5\x82\xc4\xe5\x86\xdf\xe3\xfd\x70\x95\x0b\x63\x26\xcc\x68\xa8\xf1\x4c\x39\x2c\xba\xcb\x97\x02\xdc\x0b\xd0\xe5\x66\x3b\x96\xe8\xad\x04\x45\x50\xdf\xae\xb5\x7e\x04\x3f\x7d\x9c\x29\x0a\x22\xce\xa5\x2a\x64\xc6\xf8\xb2\x20\x27\x3e\x68\x03\x38\x2d\x30\x33\x9d\x29\x08\xc5\x26\xd0\x7c\x80\x48\xf8\xf0\x8b\x6f\x84\x61\x4b\x9e\xc8\x4c\x16\xc4\x58\x06\x49\x46\xdc\xb6\xd7\x9e\x07\xb6\x2f\x73\xbe\xe3\x59\xb8\x58\xf1\xac\x0c\xc9\xb1\x27\x46\xf4\x30\x62\x4a\x33\x47\x07\xc1\xd7\xa0\xe0\x93\x71\xf0\x01\xd9\xc3\xcf\xec\xc7\xaf\x6a\xa7\xe8\xef\xe2\xff\xad\xdc\xc3\xfb\xac\x82\x23\x2e\xe4\xc7\x1c\x8e\xcd\x2b\xb7\x17\xd0\x0e\x76\x86\x4c\x1d\x3e\xb8\x62\x8a\x87\xf4\x53\x7f\x3c\x42\xcc\xa4\xe3\xd2\x3f\x75\xb2\x67\xcd\x2f\x8c\xe8\xbd\x76\x23\xf1\x2b\xb9\x33\xba\x28\xdd\x87\x54\xdf\x79\xe3\x3f\x69\x9d\x1d\xeb\x91\x27\x52\x06\xa9\xd5\x1c\x94\x80\x8f\xb9\x4e\xe2\x04\xf0\x8e\xad\xcb\xb7\x3e\xe6\xee\x39\xd2\xab\xfa\x61\x04\x07\xa3\x2a\xc0\x46\x06\x95\xe8\x41\x8a\x9b\x6d\x0b\xe8\x62\x24\xe2\x1d\xca\x40\xb4\x96\x33\xed\x9b\x21\x82\x88\x9f\x83\x87\x3a\x02\x8f\x6c\xad\x86\xa3\x9c\x75\xa8\xdb\x5b\xfb\x94\x77\xdc\xc5\x7c\xd3\xbe\x1f\xa3\x6f\xbb\xfe\xdc\x70\x45\x9e\x3f\xb2\xe2\x67\x2a\xb2\xd8\x91\x13\xcd\xa5\x14\xf8\x5e\x6b\xf3\xe7\x55\xa6\xe1\xd1\xfe\xbc\x63\x44\x05\x7a\x77\xce\xb7\xb1\x3c\x20\x60\x41\x12\xbd\x59\x48\xe5\x58\x09\xc8\xc9\x0d\x57\x8d\x33\xc7\xd9\xea\x03\x12\xee\xca\x80\xa2\x31\xb5\xbe\xf7\x66\x4e\x4c\x7f\x1b\x6f\x59\xfb\xae\xe3\xf1\xfd\xee\x69\xf5\x0f\x3a\x22\x8d\xf5\x16\xd8\x03\x24\x7b\xe4\x3b\x03\x12\xda\xc2\xee\x8a\x4b\x74\xec\x56\xeb\x3f\x89\xcc\x0f\xc7\x07\x3c\x53\xd0\x43\x25\x29\xeb\x53\x5b\x24\x31\x00\x64\x4e\x2c\x3c\x70\x7d\xbd\x30\xed\x9d\xf3\x6d\x62\x35\x79\x6f\xac\x06\x83\xd0\xff\x33\xc2\x33\x3d\x4e\xe0\x23\x7d\xd1\xd1\x31\x89\x16\x23\xc1\x84\x20\x71\xcb\x87\xa8\x27\x6c\xc3\xa5\xa2\x65\x80\x82\x8c\xa9\x58\x94\xab\x55\xa7\x8b\xf4\xd7\x1f\x6b\xa9\xae\x93\xbf\x7b\x5f\x78\x2f\x5b\xdd\x53\x78\x8b\x2f\xdd\x97\xd0\x7d\x6d\xef\x7d\x5f\xc7\x41\xfc\x0d\xbd\xf1\xad\x21\xb1\xc6\x24\x7a\x1a\x6f\xfc\xe5\x10\x6f\xbc\xc3\x76\x41\x8a\x1d\x5d\xa7\x1d\xfe\xe6\x37\x37\xfd\xd7\x71\xd3\x0f\x9a\x14\x48\xeb\x32\x97\x55\x03\xbd\xa7\x86\x07\x32\x1f\x7a\x32\x60\xa8\x15\xb2\x8b\xd9\xdd\x3d\x35\x6c\xc1\x93\x67\xa0\x42\x84\xd3\xf1\x78\x7f\xe0\x1e\xf0\xcb\x8d\xde\x08\x06\x9f\x32\x28\xe5\xc3\x28\x8b\x71\x02\x68\x55\xdb\xc0\x80\x18\x21\x3c\x0a\x1c\xa7\x88\x5c\x49\x83\x51\xfd\x9d\x12\x8f\xcc\x9e\x56\x93\x18\xbe\x17\x0d\x0f\x68\xbc\xbd\xb4\xd6\x61\x05\xeb\xef\x29\x1b\x72\xb1\xe2\x79\x0a\x19\x26\xb4\x24\x33\x9e\xdc\xdb\xff\x86\xfa\xd1\x17\x09\x62\xe8\xe4\x26\x10\xf6\x1a\x4a\x93\x2a\x41\x32\x3c\xc7\xea\xed\xeb\x87\xaf\x1b\xc6\x93\x5c\x1b\x74\x1a\x79\x69\x64\xc8\x70\x06\x03\xf6\x41\xa6\x25\xcf\xf0\x8b\x9d\x9e\xf6\xb1\xf0\xb5\x3a\xe0\x28\x52\x31\x6b\xa2\xd9\x68\x38\x90\xa3\x08\xba\x71\x3a\x53\x6f\x7d\xc0\xe4\x35\xbb\x33\x82\x50\x66\xc6\xf1\xc0\xf7\xd6\xf4\xd9\xcc\x87\x06\x26\xb0\xd3\x86\xe8\xe9\x00\x07\xb2\x8e\x3a\xc2\x74\xf7\xc4\x1e\x42\xcd\x63\x06\x65\x34\x31\xf0\x65\x24\xa5\x1e\xba\x05\xef\x09\xb9\xe0\xe9\x2e\x66\xe3\x93\x8a\x41\x94\x8e\xf1\x74\x23\x95\x5d\x04\x4e\xae\xd3\x9f\x34\x8e\xb9\x1f\x21\xc7\xa0\x6a\x95\x65\xb5\x4d\xd0\x30\x25\xac\x71\xc9\x73\x99\xed\xe0\x3e\xb1\xcd\xc5\x49\xf4\x9d\x68\x7c\x28\xe3\x09\x34\x08\x88\x46\xa4\x34\x62\x59\x66\x78\xeb\x80\x7b\xb9\x6f\x00\xed\x48\x77\x97\x13\x6b\x70\x14\xa4\x25\x13\x7d\x18\x15\x1a\x9f\x22\x7b\xa4\x11\xad\x1c\x17\x71\x0b\x6c\x91\x39\x80\xdc\xd7\xfa\xd1\xa5\xba\x3d\xf2\x80\x65\xee\x3a\x5d\x9f\x2c\xca\xd2\x6f\x87\xba\x1b\xa0\xdb\xa7\x22\xca\x37\x1f\x5a\xa3\xdf\x44\xea\xf7\x26\xa9\xa0\x39\x24\x72\x1c\x3c\xd7\xa5\xc1\x8c\x39\x3b\x96\x70\x7e\x39\x47\x47\xd5\x71\xcd\x7c\xeb\xa4\xd1\x8a\xcd\xca\xef\xbf\xff\xbd\x60\xdf\x43\x0a\x21\xdd\x47\x30\x3e\x06\x7c\x91\x58\x3a\x6c\xd9\xfe\x03\x02\xc9\x24\x1b\x23\xc2\xda\x20\xaa\x2e\x5f\x1f\x40\x9e\x3c\x59\x33\x53\x2e\x10\xc1\xc8\x29\xc4\xc2\x95\xe7\x9d\x7e\xaf\x01\x8c\x88\x27\xbb\xab\xfd\xff\x92\x80\x02\xca\x7e\xcc\xd4\x56\x23\x35\x3a\x40\x3f\x17\x82\x6d\x78\x7e\x0f\x2a\xae\xe8\x9e\x07\x2a\xf8\xef\xa4\x98\x56\xc3\x0b\x2f\x2b\xf5\xa1\x80\x0e\x52\x1e\xb3\xbc\x54\xca\xc9\x52\x31\x6b\x98\x06\x5f\xff\x64\xa6\x16\x65\x7c\xf7\xac\x04\x0b\xc2\xd4\x82\x80\x01\x6c\xb6\x1a\xb8\x42\xa8\x52\xdc\x84\x7a\x4d\xd9\x80\xa8\xc1\x4c\x3d\x71\xd8\x60\x9f\xc3\xef\x13\xd9\x60\xce\x99\x17\xe5\x2b\x40\x73\x63\xe5\x64\x18\x0e\x9c\xf6\x60\xe4\x7c\x02\xf9\xe4\x09\xfb\x51\x3e\x88\x09\xbb\xd9\xf2\xfc\x7e\xc2\xde\x62\xf8\xef\x4f\x7a\xd1\xe6\xc3\x6b\x10\x4a\x1c\xed\xc7\x3b\xcc\x8d\xd5\x47\xb4\xd2\x6e\xfd\xff\xdc\x20\x06\x60\x5d\xb1\xef\xff\x99\x88\xbc\x0e\xae\x8f\xbf\x77\x4f\xc4\x9e\x30\xf5\x6f\xe0\xb5\xbf\xcb\x5b\x71\x3f\xcd\xc7\xef\xe2\xff\x75\xfb\x97\xb3\xb8\xc0\xf6\xa4\x5d\xae\x15\x95\xf6\xeb\x4a\x6c\x96\x69\xfd\x50\x6e\xe6\x37\x0f\x5b\x0a\x94\x3e\x9e\xfa\xd4\xf6\x11\xa0\x7b\x7a\xd5\xf5\xd7\x79\xa6\x4d\x99\xf7\x2f\xfe\xeb\x6a\xad\xdd\xd7\x5b\xa8\x3e\x61\xb2\x6d\x16\x02\x58\x0b\x86\xc2\x4f\xf0\xb1\xf9\x7f\xe8\xc5\x1c\xb0\x56\xc7\xad\xf0\xb6\xe2\x3c\x81\xb0\x4e\x2a\x55\x0d\x27\xe4\xcd\x56\x00\xe3\x54\x30\x45\x43\x40\xa0\x36\xc3\xbc\x6b\x64\xa6\x1c\xe7\x3a\x66\xcc\xe6\xb9\x00\x72\xe8\x5c\x80\xd4\x1f\xdb\xf2\xdc\x03\x1e\x9c\x45\x14\xdd\x7c\x02\x28\x26\xce\x72\x83\x64\x55\xba\x6f\x2d\x84\x50\xbe\xb7\xc7\x98\x12\x40\x84\x5c\xeb\x7d\x42\xbb\x3d\x0a\x47\xbd\xdf\x21\x4b\xda\x78\x2f\xba\x0b\x82\xc9\xbd\x12\x45\xb4\x9b\xd7\x4c\x8b\xca\xd2\xac\x44\xa8\x7e\x55\x88\xff\xd6\x18\x74\x8d\x9c\xab\xe2\x40\x19\x14\xd3\x7b\x0a\x7f\xf9\x27\x5e\xac\xf1\x42\xbb\xd1\x85\xc0\x3d\x13\x59\x82\x70\xbe\xa0\xd7\x79\x91\xe9\x05\x68\xec\xd9\x5f\xba\xee\x86\x09\x2d\xed\x41\x5d\xd7\x1c\xb0\x21\x3b\x83\xdd\x4d\x20\xd3\x36\x17\x06\x08\x57\x9a\x51\xaa\xa1\xf8\xe4\x71\x97\xee\x66\x75\xed\xa6\xff\xb6\x71\xd9\x6e\x8a\x32\xd8\x65\x0d\x60\xd5\x8b\x03\x32\x68\x1a\x12\x17\x44\x56\x4c\x61\x60\xe4\x2b\xad\xb5\xd7\x49\xb9\xcf\xd4\x19\xfe\x12\x1d\x02\x3c\xa8\x2c\x79\x3c\x28\xa9\xf6\xfa\xf5\x87\xe9\xab\xec\x2c\x46\x20\x92\x87\x60\x12\x7c\x99\x70\x19\x98\x40\x56\xa3\x2a\x64\x2e\x98\x02\x14\xc2\x4c\x99\x72\x71\x12\x88\x49\xec\x2d\xee\x01\xc8\x74\x8c\xd8\x72\xb8\xca\x00\x5f\xd1\x49\xcb\x31\x8c\x9e\xc9\xa0\x96\xe2\x08\xfc\x78\x46\x9b\x3f\xe4\x4a\x62\x66\xbc\x6f\xbb\x2f\xc7\x5e\xd6\xe0\x16\xed\xe0\x4a\x78\xd8\xf5\xed\x17\xa0\xe7\x04\x19\x98\xd7\x88\xa2\xf8\xd6\x07\x78\x1c\x0d\x1d\x7a\x74\x43\x3c\x6d\xa6\xfe\x7f\x77\x36\x74\x83\x8a\x47\xcc\x74\xdb\x33\xf6\x88\xea\x04\x3b\x57\xea\xe6\xae\x90\x91\x11\xd8\x5d\xa9\xc6\x94\x6f\x2b\x95\x3b\x5c\x4b\x2c\xea\xa1\x29\x5d\x16\x7e\x7d\x90\x26\xa2\xfb\x86\xaf\xdd\x08\xc1\x5e\xe7\x62\xf9\xfa\x73\x2e\x96\x73\x37\xd2\x53\x68\xd0\xd4\xb6\xa8\x49\xfa\x3d\x70\x72\x98\xad\x56\xed\xe4\x87\x7b\xc8\x49\x6b\x4d\xc2\x72\xa2\x36\xc9\x25\x0b\xfa\xa6\xb6\x3d\xc0\x00\x21\xd2\x3a\x1b\x79\xa3\x66\x5f\xfd\x98\xeb\x42\x82\x0d\x80\x5a\x75\xc8\x60\xfe\xfd\x1f\x6f\x95\x3e\x1b\x72\xbc\xdd\x56\x21\x33\x6e\xb3\xe7\xca\x1f\x78\xdd\xb8\xd0\xaf\x8b\x4e\x87\x01\x34\x5b\xfe\xa8\x88\xc7\x66\x94\xeb\x69\xd8\xb1\x56\x03\x10\x45\xc7\x5a\x03\x03\x17\x56\x99\x72\x9e\x3e\xe9\x95\x14\x27\x91\xfe\x3c\xcf\xb2\x58\x53\x21\x44\xda\x66\x2a\xe4\xa5\x5a\xab\x35\xcb\x9c\x0b\xaf\x62\x6f\x78\xc9\x5b\x53\xf0\x42\x4c\x1c\xe9\x0a\xd1\x15\x52\x3c\xec\x64\xc1\x41\xdc\xd8\xab\x68\xed\x5b\xcd\x4f\x75\x89\xfc\x95\xe5\x45\xef\x89\x3c\xe3\x67\xe7\xf7\xa2\x01\x67\xde\x5b\xd7\xf6\x48\x47\x44\x29\x01\x8b\xd9\xed\xb2\x09\xcf\x73\x87\xf2\xa7\xaf\x32\x7b\x57\x5a\xf2\xa4\xe2\xe6\xec\xa8\xe7\x5a\x24\xf7\x5b\x2d\xd5\xe8\xbd\xa8\x42\x71\x01\x93\xbd\x60\xa1\x34\x7f\x3b\x1c\x74\x38\x56\xec\x49\x6c\x88\x01\x78\x85\x83\x86\x06\x32\x36\xce\xbc\x56\x72\xf7\xb4\x7b\x6a\xff\x85\x08\x67\xc3\x33\xf8\x62\x5b\xe2\x43\xb5\x53\x85\xb7\x38\x76\x2a\x4c\xa0\xbc\x91\xfd\x35\xb0\xb3\x39\xab\x50\x18\xb6\x76\x29\xb8\x20\x7f\xf3\x0c\xfd\xe6\x19\xfa\x1f\xee\x19\xfa\x9a\x6e\x21\xc0\xc6\x3c\xa7\x4f\xa8\x27\x40\x7e\xc4\x72\xf4\x5f\x1d\x9d\xe3\xd8\x6a\x1d\x4f\x22\xd9\xe7\x28\xd3\xb1\x09\xf4\x77\x44\x18\xb6\x7f\x16\x3c\xb9\x17\xaa\x33\x46\xef\xe8\x8b\x3a\x15\x38\x9f\x16\xc1\xd2\xc6\xbe\x14\xbd\xdd\x0f\x65\x09\x50\x27\x22\x0d\x6e\x23\x04\xb1\xeb\x04\x6c\x4f\xdb\xf0\x13\x00\x8d\xe9\xdc\x13\x5b\x1b\xca\xc2\xc3\x60\x24\xd2\x24\x21\x58\xaa\x46\x05\x3d\x14\x13\xe7\x3e\x3c\xdf\x6a\x9d\xb5\x42\xe3\x9e\xb4\x03\x1b\x89\x32\x43\x3b\xef\x12\x8d\x51\x13\x03\xc6\x5c\x2f\x86\xa4\x8b\x90\xa2\x81\xf9\x18\xa0\x85\x01\xb3\x29\x2d\x21\x97\x32\x74\x47\x24\xb0\xc7\xbd\xc3\x85\x30\x62\x0b\x91\x70\x90\xfe\x74\xe0\xbd\x84\xfb\xec\x93\x98\x14\xa9\x91\x0e\x62\x9a\xdf\xe9\x88\x5a\x42\xb9\x73\xd9\x26\x7c\x31\x76\x71\xd5\x2c\x04\x07\x2d\xc7\x9a\x3b\x24\x89\xa3\x5d\xdc\x27\x69\xeb\x38\xa6\xe7\xa0\xbf\x37\xec\x84\x6b\xdd\x77\x2e\xa9\xa0\x73\x28\x67\xf8\x46\xfa\x23\xa4\xe3\x6c\x06\x22\x77\x66\xea\xcc\x2b\x9d\x06\xec\x97\x47\xee\x61\xb8\x14\x31\x8b\x8d\xa1\x41\x2e\xc7\x70\x73\x99\x30\x53\x26\x6b\x60\xab\xac\xee\x53\xf1\xbe\xd5\x5c\xb1\x93\x99\xb2\x17\x22\x70\xb5\x6c\x38\xe4\xc5\x3f\x5a\x63\xd5\xc8\xff\x14\x1e\x9e\x45\xe4\x5d\x31\x22\x0b\x2f\x4e\x5a\xb5\xa2\xd7\x1c\x71\x28\x02\x2c\x02\xa6\xa4\xdc\xa6\xbc\x10\xd3\x59\x40\xdb\x48\xf4\x74\x3a\x94\x07\x99\xcc\x26\x6e\x58\x8c\x63\xac\xed\xb4\x99\x5c\x8a\x64\x97\x34\x74\x80\xfa\x69\x22\x7e\xbb\xb6\xfd\xba\xae\x6d\xc8\xb2\x8b\x39\x83\x63\xba\x96\xaa\x7a\x1d\x5e\x3f\xae\x73\x05\x8b\x6a\x62\x46\xf4\xf3\x57\xbc\x76\xb6\xd8\xc0\xe3\xec\xf9\xc1\xf7\xa0\xfe\xe3\x2c\x5c\x6c\xc3\x61\x1d\x51\x20\x34\xcc\xc2\x38\xb8\x58\xc4\x53\xc7\x1a\xb4\x83\xc3\xfa\xdd\x2c\x33\xbf\x2a\x70\xd2\x90\x8b\xab\xb5\xb8\x3d\x5c\xe9\xca\x59\xda\x4a\xe0\x79\xd7\x63\x71\x47\xac\xee\xbc\x78\x61\x7c\xaf\x57\x77\x40\x87\xfd\x7f\x2f\x4d\xf1\x53\x4d\x33\xf4\x30\xd1\xd1\x67\x33\x4d\x5d\x55\xb1\x9a\x43\x2d\xaa\xeb\xaa\xcd\xa3\x97\x6e\xce\xc1\xe5\xc9\xa9\xc4\xd9\x7a\x8f\xb9\x07\x7d\xf6\xfd\xf5\x19\x8f\xa6\xc7\x9c\x6f\xb7\x22\x77\x07\x79\xc3\xd6\x02\xc9\x35\xf8\x0a\x68\x26\xae\x05\x6a\x75\xd7\x6e\xb9\x76\x2b\xa9\x15\x0d\x8f\x41\xd7\x4d\xdb\x47\xee\xaa\xcc\xb2\xce\x91\xdb\xaf\xe4\x74\x75\xf7\xfe\xfd\xfc\xa7\xb3\xf7\x77\x17\xae\xf9\xad\xca\x48\xd1\x63\x9d\x7d\xe2\x6b\x42\x7d\x12\xb4\x17\xed\x67\x85\xd3\x0b\xd7\xa1\xd5\xe8\xe4\x2a\xb3\xac\xaa\x9a\x35\x53\x9f\xa9\x1c\x80\x69\xa3\x22\xa8\xed\x37\xd6\xdb\x71\xd5\xef\xc3\x63\x9f\x6d\xe1\x9f\xf1\xdd\x13\x16\x1a\xf1\x1a\xb4\x1d\x49\x33\xae\xbd\x5f\x29\x1b\xe6\x88\xe5\x80\x60\xe0\xae\xe5\xf0\xd4\xba\x80\x87\x2d\x8f\x3b\x05\x8c\xe4\x22\x75\x72\x7e\x4f\xb2\x3a\xb0\xef\x3e\x57\xe3\xd4\x7e\x2f\x4f\xf1\x4a\x03\xe5\x4e\x50\xcd\x0d\x34\xaa\x83\xe0\xd9\x4c\xa1\x0f\xd4\xd6\xa9\xd0\xdd\x75\x62\x97\x64\xde\x66\x5c\xad\x4a\xbe\xb2\xd6\xad\xfb\xf8\x4c\x6d\xe4\x6a\x8d\x3c\x20\xe5\x36\xe0\x93\x39\x53\x40\x17\x53\x9b\x42\x35\x7c\xb2\x54\x33\x45\x6d\x52\xab\x50\x3c\x62\x65\xff\x74\xe3\x9b\x43\xa0\x74\x2c\x88\x04\xe9\xd4\x4c\xe1\xe0\x22\x3f\x89\x8b\x84\xc0\x8d\x85\x17\xf5\xa9\xcb\x21\x76\x89\x3a\xfd\x76\x4f\x5f\x41\x4c\x66\xa6\x7c\x8a\x2e\x7a\x8e\xa8\x0d\x91\x70\x09\x56\x69\xff\x7e\xe2\x06\xc3\xad\x09\xaa\x5b\xfb\xac\x3f\xfa\x0c\xb0\x0b\x6e\x3e\x42\x7d\xba\xb9\x8d\x0d\xf4\x16\xf2\x68\xe3\xe8\xe2\x6d\x80\xbc\xec\xf6\xda\xb8\x76\xe1\x33\x9d\xd0\x56\x5d\x2e\xb2\x11\x55\xc2\xe7\x7b\x2b\x85\x5b\x72\x7f\xa5\x06\x5c\x87\xaf\x6b\x4b\xcb\x4e\xd3\xbe\xcf\x2e\xb4\xee\x18\x97\x27\x0c\x28\x56\x2a\x45\x2f\xec\xeb\x8c\x32\x29\x0e\x99\x2f\x03\x92\x15\xeb\x5d\xe4\x76\x9f\xbe\x0a\x65\xd2\x1c\x54\x9d\x60\x3f\x0d\xae\x91\xb7\x10\xe8\xb0\x1b\xb5\xc3\xd2\x39\x57\xd9\x60\x3b\xb6\x49\x8a\x27\x39\x19\x67\x89\xdb\x8b\x5d\x3c\xa8\xb1\x6c\xe7\xff\xc4\x4f\xa2\x49\x18\xb9\x09\x54\x32\x29\x73\x63\xb7\x4b\xda\xef\x68\xd7\xd6\x39\xe3\x33\xe5\x52\xd5\xdc\x76\x7c\xe6\xc0\xb9\xb9\xff\x2b\x26\x80\x6e\x91\x4f\x1f\x2c\xd6\x82\x69\x25\xdc\x6e\x38\x53\x4e\xfb\x7b\xc2\xf8\xc2\x38\x49\x6d\xae\x76\x5e\xe7\x5a\x7a\xfa\x22\xae\x18\xa0\x9e\xf7\xef\x79\x35\x33\xa0\x72\xce\xff\xce\xfe\xdf\x7f\xff\xee\xff\x05\x00\x00\xff\xff\x30\x03\x1f\xec\x8e\xb8\x04\x00") func adminSwaggerJsonBytes() ([]byte, error) { return bindataRead( @@ -93,7 +93,7 @@ func adminSwaggerJson() (*asset, error) { return nil, err } - info := bindataFileInfo{name: "admin.swagger.json", size: 309117, mode: os.FileMode(420), modTime: time.Unix(1562572800, 0)} + info := bindataFileInfo{name: "admin.swagger.json", size: 309390, 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/core/Tasks.java b/flyteidl/gen/pb-java/flyteidl/core/Tasks.java index d4416668c6..1bf0500aea 100644 --- a/flyteidl/gen/pb-java/flyteidl/core/Tasks.java +++ b/flyteidl/gen/pb-java/flyteidl/core/Tasks.java @@ -5200,6 +5200,41 @@ java.lang.String getTagsOrThrow( com.google.protobuf.ByteString getPodTemplateNameBytes(); + /** + *
+     * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+     * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + java.util.List + getCacheIgnoreInputVarsList(); + /** + *
+     * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+     * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + int getCacheIgnoreInputVarsCount(); + /** + *
+     * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+     * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + java.lang.String getCacheIgnoreInputVars(int index); + /** + *
+     * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+     * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + com.google.protobuf.ByteString + getCacheIgnoreInputVarsBytes(int index); + public flyteidl.core.Tasks.TaskMetadata.InterruptibleValueCase getInterruptibleValueCase(); } /** @@ -5222,6 +5257,7 @@ private TaskMetadata() { discoveryVersion_ = ""; deprecatedErrorMessage_ = ""; podTemplateName_ = ""; + cacheIgnoreInputVars_ = com.google.protobuf.LazyStringArrayList.EMPTY; } @java.lang.Override @@ -5338,6 +5374,15 @@ private TaskMetadata( podTemplateName_ = s; break; } + case 106: { + java.lang.String s = input.readStringRequireUtf8(); + if (!((mutable_bitField0_ & 0x00000800) != 0)) { + cacheIgnoreInputVars_ = new com.google.protobuf.LazyStringArrayList(); + mutable_bitField0_ |= 0x00000800; + } + cacheIgnoreInputVars_.add(s); + break; + } default: { if (!parseUnknownField( input, unknownFields, extensionRegistry, tag)) { @@ -5353,6 +5398,9 @@ private TaskMetadata( throw new com.google.protobuf.InvalidProtocolBufferException( e).setUnfinishedMessage(this); } finally { + if (((mutable_bitField0_ & 0x00000800) != 0)) { + cacheIgnoreInputVars_ = cacheIgnoreInputVars_.getUnmodifiableView(); + } this.unknownFields = unknownFields.build(); makeExtensionsImmutable(); } @@ -5792,6 +5840,51 @@ public java.lang.String getPodTemplateName() { } } + public static final int CACHE_IGNORE_INPUT_VARS_FIELD_NUMBER = 13; + private com.google.protobuf.LazyStringList cacheIgnoreInputVars_; + /** + *
+     * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+     * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public com.google.protobuf.ProtocolStringList + getCacheIgnoreInputVarsList() { + return cacheIgnoreInputVars_; + } + /** + *
+     * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+     * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public int getCacheIgnoreInputVarsCount() { + return cacheIgnoreInputVars_.size(); + } + /** + *
+     * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+     * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public java.lang.String getCacheIgnoreInputVars(int index) { + return cacheIgnoreInputVars_.get(index); + } + /** + *
+     * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+     * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public com.google.protobuf.ByteString + getCacheIgnoreInputVarsBytes(int index) { + return cacheIgnoreInputVars_.getByteString(index); + } + private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { @@ -5843,6 +5936,9 @@ public void writeTo(com.google.protobuf.CodedOutputStream output) if (!getPodTemplateNameBytes().isEmpty()) { com.google.protobuf.GeneratedMessageV3.writeString(output, 12, podTemplateName_); } + for (int i = 0; i < cacheIgnoreInputVars_.size(); i++) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 13, cacheIgnoreInputVars_.getRaw(i)); + } unknownFields.writeTo(output); } @@ -5900,6 +5996,14 @@ public int getSerializedSize() { if (!getPodTemplateNameBytes().isEmpty()) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(12, podTemplateName_); } + { + int dataSize = 0; + for (int i = 0; i < cacheIgnoreInputVars_.size(); i++) { + dataSize += computeStringSizeNoTag(cacheIgnoreInputVars_.getRaw(i)); + } + size += dataSize; + size += 1 * getCacheIgnoreInputVarsList().size(); + } size += unknownFields.getSerializedSize(); memoizedSize = size; return size; @@ -5944,6 +6048,8 @@ public boolean equals(final java.lang.Object obj) { other.internalGetTags())) return false; if (!getPodTemplateName() .equals(other.getPodTemplateName())) return false; + if (!getCacheIgnoreInputVarsList() + .equals(other.getCacheIgnoreInputVarsList())) return false; if (!getInterruptibleValueCase().equals(other.getInterruptibleValueCase())) return false; switch (interruptibleValueCase_) { case 8: @@ -5995,6 +6101,10 @@ public int hashCode() { } hash = (37 * hash) + POD_TEMPLATE_NAME_FIELD_NUMBER; hash = (53 * hash) + getPodTemplateName().hashCode(); + if (getCacheIgnoreInputVarsCount() > 0) { + hash = (37 * hash) + CACHE_IGNORE_INPUT_VARS_FIELD_NUMBER; + hash = (53 * hash) + getCacheIgnoreInputVarsList().hashCode(); + } switch (interruptibleValueCase_) { case 8: hash = (37 * hash) + INTERRUPTIBLE_FIELD_NUMBER; @@ -6194,6 +6304,8 @@ public Builder clear() { internalGetMutableTags().clear(); podTemplateName_ = ""; + cacheIgnoreInputVars_ = com.google.protobuf.LazyStringArrayList.EMPTY; + bitField0_ = (bitField0_ & ~0x00000800); interruptibleValueCase_ = 0; interruptibleValue_ = null; return this; @@ -6250,6 +6362,11 @@ public flyteidl.core.Tasks.TaskMetadata buildPartial() { result.tags_ = internalGetTags(); result.tags_.makeImmutable(); result.podTemplateName_ = podTemplateName_; + if (((bitField0_ & 0x00000800) != 0)) { + cacheIgnoreInputVars_ = cacheIgnoreInputVars_.getUnmodifiableView(); + bitField0_ = (bitField0_ & ~0x00000800); + } + result.cacheIgnoreInputVars_ = cacheIgnoreInputVars_; result.bitField0_ = to_bitField0_; result.interruptibleValueCase_ = interruptibleValueCase_; onBuilt(); @@ -6332,6 +6449,16 @@ public Builder mergeFrom(flyteidl.core.Tasks.TaskMetadata other) { podTemplateName_ = other.podTemplateName_; onChanged(); } + if (!other.cacheIgnoreInputVars_.isEmpty()) { + if (cacheIgnoreInputVars_.isEmpty()) { + cacheIgnoreInputVars_ = other.cacheIgnoreInputVars_; + bitField0_ = (bitField0_ & ~0x00000800); + } else { + ensureCacheIgnoreInputVarsIsMutable(); + cacheIgnoreInputVars_.addAll(other.cacheIgnoreInputVars_); + } + onChanged(); + } switch (other.getInterruptibleValueCase()) { case INTERRUPTIBLE: { setInterruptible(other.getInterruptible()); @@ -7421,6 +7548,136 @@ public Builder setPodTemplateNameBytes( onChanged(); return this; } + + private com.google.protobuf.LazyStringList cacheIgnoreInputVars_ = com.google.protobuf.LazyStringArrayList.EMPTY; + private void ensureCacheIgnoreInputVarsIsMutable() { + if (!((bitField0_ & 0x00000800) != 0)) { + cacheIgnoreInputVars_ = new com.google.protobuf.LazyStringArrayList(cacheIgnoreInputVars_); + bitField0_ |= 0x00000800; + } + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public com.google.protobuf.ProtocolStringList + getCacheIgnoreInputVarsList() { + return cacheIgnoreInputVars_.getUnmodifiableView(); + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public int getCacheIgnoreInputVarsCount() { + return cacheIgnoreInputVars_.size(); + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public java.lang.String getCacheIgnoreInputVars(int index) { + return cacheIgnoreInputVars_.get(index); + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public com.google.protobuf.ByteString + getCacheIgnoreInputVarsBytes(int index) { + return cacheIgnoreInputVars_.getByteString(index); + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public Builder setCacheIgnoreInputVars( + int index, java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + ensureCacheIgnoreInputVarsIsMutable(); + cacheIgnoreInputVars_.set(index, value); + onChanged(); + return this; + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public Builder addCacheIgnoreInputVars( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + ensureCacheIgnoreInputVarsIsMutable(); + cacheIgnoreInputVars_.add(value); + onChanged(); + return this; + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public Builder addAllCacheIgnoreInputVars( + java.lang.Iterable values) { + ensureCacheIgnoreInputVarsIsMutable(); + com.google.protobuf.AbstractMessageLite.Builder.addAll( + values, cacheIgnoreInputVars_); + onChanged(); + return this; + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public Builder clearCacheIgnoreInputVars() { + cacheIgnoreInputVars_ = com.google.protobuf.LazyStringArrayList.EMPTY; + bitField0_ = (bitField0_ & ~0x00000800); + onChanged(); + return this; + } + /** + *
+       * cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache.
+       * 
+ * + * repeated string cache_ignore_input_vars = 13; + */ + public Builder addCacheIgnoreInputVarsBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + ensureCacheIgnoreInputVarsIsMutable(); + cacheIgnoreInputVars_.add(value); + onChanged(); + return this; + } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { @@ -20639,7 +20896,7 @@ public flyteidl.core.Tasks.Sql getDefaultInstanceForType() { "r\"\225\001\n\017RuntimeMetadata\0228\n\004type\030\001 \001(\0162*.fl" + "yteidl.core.RuntimeMetadata.RuntimeType\022" + "\017\n\007version\030\002 \001(\t\022\016\n\006flavor\030\003 \001(\t\"\'\n\013Runt" + - "imeType\022\t\n\005OTHER\020\000\022\r\n\tFLYTE_SDK\020\001\"\316\003\n\014Ta" + + "imeType\022\t\n\005OTHER\020\000\022\r\n\tFLYTE_SDK\020\001\"\357\003\n\014Ta" + "skMetadata\022\024\n\014discoverable\030\001 \001(\010\022/\n\007runt" + "ime\030\002 \001(\0132\036.flyteidl.core.RuntimeMetadat" + "a\022*\n\007timeout\030\004 \001(\0132\031.google.protobuf.Dur" + @@ -20649,64 +20906,65 @@ public flyteidl.core.Tasks.Sql getDefaultInstanceForType() { "erruptible\030\010 \001(\010H\000\022\032\n\022cache_serializable" + "\030\t \001(\010\022\026\n\016generates_deck\030\n \001(\010\0223\n\004tags\030\013" + " \003(\0132%.flyteidl.core.TaskMetadata.TagsEn" + - "try\022\031\n\021pod_template_name\030\014 \001(\t\032+\n\tTagsEn" + - "try\022\013\n\003key\030\001 \001(\t\022\r\n\005value\030\002 \001(\t:\0028\001B\025\n\023i" + - "nterruptible_value\"\316\004\n\014TaskTemplate\022%\n\002i" + - "d\030\001 \001(\0132\031.flyteidl.core.Identifier\022\014\n\004ty" + - "pe\030\002 \001(\t\022-\n\010metadata\030\003 \001(\0132\033.flyteidl.co" + - "re.TaskMetadata\0220\n\tinterface\030\004 \001(\0132\035.fly" + - "teidl.core.TypedInterface\022\'\n\006custom\030\005 \001(" + - "\0132\027.google.protobuf.Struct\022-\n\tcontainer\030" + - "\006 \001(\0132\030.flyteidl.core.ContainerH\000\022(\n\007k8s" + - "_pod\030\021 \001(\0132\025.flyteidl.core.K8sPodH\000\022!\n\003s" + - "ql\030\022 \001(\0132\022.flyteidl.core.SqlH\000\022\031\n\021task_t" + - "ype_version\030\007 \001(\005\0228\n\020security_context\030\010 " + - "\001(\0132\036.flyteidl.core.SecurityContext\022<\n\022e" + - "xtended_resources\030\t \001(\0132 .flyteidl.core." + - "ExtendedResources\0227\n\006config\030\020 \003(\0132\'.flyt" + - "eidl.core.TaskTemplate.ConfigEntry\032-\n\013Co" + - "nfigEntry\022\013\n\003key\030\001 \001(\t\022\r\n\005value\030\002 \001(\t:\0028" + - "\001B\010\n\006target\"\'\n\rContainerPort\022\026\n\016containe" + - "r_port\030\001 \001(\r\"\255\003\n\tContainer\022\r\n\005image\030\001 \001(" + - "\t\022\017\n\007command\030\002 \003(\t\022\014\n\004args\030\003 \003(\t\022+\n\treso" + - "urces\030\004 \001(\0132\030.flyteidl.core.Resources\022(\n" + - "\003env\030\005 \003(\0132\033.flyteidl.core.KeyValuePair\022" + - "/\n\006config\030\006 \003(\0132\033.flyteidl.core.KeyValue" + - "PairB\002\030\001\022+\n\005ports\030\007 \003(\0132\034.flyteidl.core." + - "ContainerPort\0225\n\013data_config\030\t \001(\0132 .fly" + - "teidl.core.DataLoadingConfig\022;\n\014architec" + - "ture\030\n \001(\0162%.flyteidl.core.Container.Arc" + - "hitecture\"I\n\014Architecture\022\013\n\007UNKNOWN\020\000\022\t" + - "\n\005AMD64\020\001\022\t\n\005ARM64\020\002\022\n\n\006ARM_V6\020\003\022\n\n\006ARM_" + - "V7\020\004\"\233\002\n\nIOStrategy\022=\n\rdownload_mode\030\001 \001" + - "(\0162&.flyteidl.core.IOStrategy.DownloadMo" + - "de\0229\n\013upload_mode\030\002 \001(\0162$.flyteidl.core." + - "IOStrategy.UploadMode\"L\n\014DownloadMode\022\022\n" + - "\016DOWNLOAD_EAGER\020\000\022\023\n\017DOWNLOAD_STREAM\020\001\022\023" + - "\n\017DO_NOT_DOWNLOAD\020\002\"E\n\nUploadMode\022\022\n\016UPL" + - "OAD_ON_EXIT\020\000\022\020\n\014UPLOAD_EAGER\020\001\022\021\n\rDO_NO" + - "T_UPLOAD\020\002\"\363\001\n\021DataLoadingConfig\022\017\n\007enab" + - "led\030\001 \001(\010\022\022\n\ninput_path\030\002 \001(\t\022\023\n\013output_" + - "path\030\003 \001(\t\022A\n\006format\030\004 \001(\01621.flyteidl.co" + - "re.DataLoadingConfig.LiteralMapFormat\022.\n" + - "\013io_strategy\030\005 \001(\0132\031.flyteidl.core.IOStr" + - "ategy\"1\n\020LiteralMapFormat\022\010\n\004JSON\020\000\022\010\n\004Y" + - "AML\020\001\022\t\n\005PROTO\020\002\"\236\001\n\006K8sPod\0222\n\010metadata\030" + - "\001 \001(\0132 .flyteidl.core.K8sObjectMetadata\022" + - ")\n\010pod_spec\030\002 \001(\0132\027.google.protobuf.Stru" + - "ct\0225\n\013data_config\030\003 \001(\0132 .flyteidl.core." + - "DataLoadingConfig\"\374\001\n\021K8sObjectMetadata\022" + - "<\n\006labels\030\001 \003(\0132,.flyteidl.core.K8sObjec" + - "tMetadata.LabelsEntry\022F\n\013annotations\030\002 \003" + - "(\01321.flyteidl.core.K8sObjectMetadata.Ann" + - "otationsEntry\032-\n\013LabelsEntry\022\013\n\003key\030\001 \001(" + - "\t\022\r\n\005value\030\002 \001(\t:\0028\001\0322\n\020AnnotationsEntry" + - "\022\013\n\003key\030\001 \001(\t\022\r\n\005value\030\002 \001(\t:\0028\001\"~\n\003Sql\022" + - "\021\n\tstatement\030\001 \001(\t\022+\n\007dialect\030\002 \001(\0162\032.fl" + - "yteidl.core.Sql.Dialect\"7\n\007Dialect\022\r\n\tUN" + - "DEFINED\020\000\022\010\n\004ANSI\020\001\022\010\n\004HIVE\020\002\022\t\n\005OTHER\020\003" + - "B|null} [tags] TaskMetadata tags * @property {string|null} [podTemplateName] TaskMetadata podTemplateName + * @property {Array.|null} [cacheIgnoreInputVars] TaskMetadata cacheIgnoreInputVars */ /** @@ -12797,6 +12798,7 @@ */ function TaskMetadata(properties) { this.tags = {}; + this.cacheIgnoreInputVars = []; if (properties) for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -12891,6 +12893,14 @@ */ TaskMetadata.prototype.podTemplateName = ""; + /** + * TaskMetadata cacheIgnoreInputVars. + * @member {Array.} cacheIgnoreInputVars + * @memberof flyteidl.core.TaskMetadata + * @instance + */ + TaskMetadata.prototype.cacheIgnoreInputVars = $util.emptyArray; + // OneOf field names bound to virtual getters and setters var $oneOfFields; @@ -12952,6 +12962,9 @@ writer.uint32(/* id 11, wireType 2 =*/90).fork().uint32(/* id 1, wireType 2 =*/10).string(keys[i]).uint32(/* id 2, wireType 2 =*/18).string(message.tags[keys[i]]).ldelim(); if (message.podTemplateName != null && message.hasOwnProperty("podTemplateName")) writer.uint32(/* id 12, wireType 2 =*/98).string(message.podTemplateName); + if (message.cacheIgnoreInputVars != null && message.cacheIgnoreInputVars.length) + for (var i = 0; i < message.cacheIgnoreInputVars.length; ++i) + writer.uint32(/* id 13, wireType 2 =*/106).string(message.cacheIgnoreInputVars[i]); return writer; }; @@ -13011,6 +13024,11 @@ case 12: message.podTemplateName = reader.string(); break; + case 13: + if (!(message.cacheIgnoreInputVars && message.cacheIgnoreInputVars.length)) + message.cacheIgnoreInputVars = []; + message.cacheIgnoreInputVars.push(reader.string()); + break; default: reader.skipType(tag & 7); break; @@ -13077,6 +13095,13 @@ if (message.podTemplateName != null && message.hasOwnProperty("podTemplateName")) if (!$util.isString(message.podTemplateName)) return "podTemplateName: string expected"; + if (message.cacheIgnoreInputVars != null && message.hasOwnProperty("cacheIgnoreInputVars")) { + if (!Array.isArray(message.cacheIgnoreInputVars)) + return "cacheIgnoreInputVars: array expected"; + for (var i = 0; i < message.cacheIgnoreInputVars.length; ++i) + if (!$util.isString(message.cacheIgnoreInputVars[i])) + return "cacheIgnoreInputVars: string[] expected"; + } return null; }; diff --git a/flyteidl/gen/pb_python/flyteidl/core/tasks_pb2.py b/flyteidl/gen/pb_python/flyteidl/core/tasks_pb2.py index ba28b4716f..6add4552b9 100644 --- a/flyteidl/gen/pb_python/flyteidl/core/tasks_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/core/tasks_pb2.py @@ -19,7 +19,7 @@ from google.protobuf import struct_pb2 as google_dot_protobuf_dot_struct__pb2 -DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x19\x66lyteidl/core/tasks.proto\x12\rflyteidl.core\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x1c\x66lyteidl/core/security.proto\x1a\x1egoogle/protobuf/duration.proto\x1a\x1cgoogle/protobuf/struct.proto\"\xd0\x02\n\tResources\x12\x42\n\x08requests\x18\x01 \x03(\x0b\x32&.flyteidl.core.Resources.ResourceEntryR\x08requests\x12>\n\x06limits\x18\x02 \x03(\x0b\x32&.flyteidl.core.Resources.ResourceEntryR\x06limits\x1a`\n\rResourceEntry\x12\x39\n\x04name\x18\x01 \x01(\x0e\x32%.flyteidl.core.Resources.ResourceNameR\x04name\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value\"]\n\x0cResourceName\x12\x0b\n\x07UNKNOWN\x10\x00\x12\x07\n\x03\x43PU\x10\x01\x12\x07\n\x03GPU\x10\x02\x12\n\n\x06MEMORY\x10\x03\x12\x0b\n\x07STORAGE\x10\x04\x12\x15\n\x11\x45PHEMERAL_STORAGE\x10\x05\"\x91\x01\n\x0eGPUAccelerator\x12\x16\n\x06\x64\x65vice\x18\x01 \x01(\tR\x06\x64\x65vice\x12&\n\runpartitioned\x18\x02 \x01(\x08H\x00R\runpartitioned\x12\'\n\x0epartition_size\x18\x03 \x01(\tH\x00R\rpartitionSizeB\x16\n\x14partition_size_value\"[\n\x11\x45xtendedResources\x12\x46\n\x0fgpu_accelerator\x18\x01 \x01(\x0b\x32\x1d.flyteidl.core.GPUAcceleratorR\x0egpuAccelerator\"\xac\x01\n\x0fRuntimeMetadata\x12>\n\x04type\x18\x01 \x01(\x0e\x32*.flyteidl.core.RuntimeMetadata.RuntimeTypeR\x04type\x12\x18\n\x07version\x18\x02 \x01(\tR\x07version\x12\x16\n\x06\x66lavor\x18\x03 \x01(\tR\x06\x66lavor\"\'\n\x0bRuntimeType\x12\t\n\x05OTHER\x10\x00\x12\r\n\tFLYTE_SDK\x10\x01\"\xf5\x04\n\x0cTaskMetadata\x12\"\n\x0c\x64iscoverable\x18\x01 \x01(\x08R\x0c\x64iscoverable\x12\x38\n\x07runtime\x18\x02 \x01(\x0b\x32\x1e.flyteidl.core.RuntimeMetadataR\x07runtime\x12\x33\n\x07timeout\x18\x04 \x01(\x0b\x32\x19.google.protobuf.DurationR\x07timeout\x12\x36\n\x07retries\x18\x05 \x01(\x0b\x32\x1c.flyteidl.core.RetryStrategyR\x07retries\x12+\n\x11\x64iscovery_version\x18\x06 \x01(\tR\x10\x64iscoveryVersion\x12\x38\n\x18\x64\x65precated_error_message\x18\x07 \x01(\tR\x16\x64\x65precatedErrorMessage\x12&\n\rinterruptible\x18\x08 \x01(\x08H\x00R\rinterruptible\x12-\n\x12\x63\x61\x63he_serializable\x18\t \x01(\x08R\x11\x63\x61\x63heSerializable\x12%\n\x0egenerates_deck\x18\n \x01(\x08R\rgeneratesDeck\x12\x39\n\x04tags\x18\x0b \x03(\x0b\x32%.flyteidl.core.TaskMetadata.TagsEntryR\x04tags\x12*\n\x11pod_template_name\x18\x0c \x01(\tR\x0fpodTemplateName\x1a\x37\n\tTagsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x42\x15\n\x13interruptible_value\"\xd6\x05\n\x0cTaskTemplate\x12)\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.IdentifierR\x02id\x12\x12\n\x04type\x18\x02 \x01(\tR\x04type\x12\x37\n\x08metadata\x18\x03 \x01(\x0b\x32\x1b.flyteidl.core.TaskMetadataR\x08metadata\x12;\n\tinterface\x18\x04 \x01(\x0b\x32\x1d.flyteidl.core.TypedInterfaceR\tinterface\x12/\n\x06\x63ustom\x18\x05 \x01(\x0b\x32\x17.google.protobuf.StructR\x06\x63ustom\x12\x38\n\tcontainer\x18\x06 \x01(\x0b\x32\x18.flyteidl.core.ContainerH\x00R\tcontainer\x12\x30\n\x07k8s_pod\x18\x11 \x01(\x0b\x32\x15.flyteidl.core.K8sPodH\x00R\x06k8sPod\x12&\n\x03sql\x18\x12 \x01(\x0b\x32\x12.flyteidl.core.SqlH\x00R\x03sql\x12*\n\x11task_type_version\x18\x07 \x01(\x05R\x0ftaskTypeVersion\x12I\n\x10security_context\x18\x08 \x01(\x0b\x32\x1e.flyteidl.core.SecurityContextR\x0fsecurityContext\x12O\n\x12\x65xtended_resources\x18\t \x01(\x0b\x32 .flyteidl.core.ExtendedResourcesR\x11\x65xtendedResources\x12?\n\x06\x63onfig\x18\x10 \x03(\x0b\x32\'.flyteidl.core.TaskTemplate.ConfigEntryR\x06\x63onfig\x1a\x39\n\x0b\x43onfigEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x42\x08\n\x06target\"6\n\rContainerPort\x12%\n\x0e\x63ontainer_port\x18\x01 \x01(\rR\rcontainerPort\"\xfc\x03\n\tContainer\x12\x14\n\x05image\x18\x01 \x01(\tR\x05image\x12\x18\n\x07\x63ommand\x18\x02 \x03(\tR\x07\x63ommand\x12\x12\n\x04\x61rgs\x18\x03 \x03(\tR\x04\x61rgs\x12\x36\n\tresources\x18\x04 \x01(\x0b\x32\x18.flyteidl.core.ResourcesR\tresources\x12-\n\x03\x65nv\x18\x05 \x03(\x0b\x32\x1b.flyteidl.core.KeyValuePairR\x03\x65nv\x12\x37\n\x06\x63onfig\x18\x06 \x03(\x0b\x32\x1b.flyteidl.core.KeyValuePairB\x02\x18\x01R\x06\x63onfig\x12\x32\n\x05ports\x18\x07 \x03(\x0b\x32\x1c.flyteidl.core.ContainerPortR\x05ports\x12\x41\n\x0b\x64\x61ta_config\x18\t \x01(\x0b\x32 .flyteidl.core.DataLoadingConfigR\ndataConfig\x12I\n\x0c\x61rchitecture\x18\n \x01(\x0e\x32%.flyteidl.core.Container.ArchitectureR\x0c\x61rchitecture\"I\n\x0c\x41rchitecture\x12\x0b\n\x07UNKNOWN\x10\x00\x12\t\n\x05\x41MD64\x10\x01\x12\t\n\x05\x41RM64\x10\x02\x12\n\n\x06\x41RM_V6\x10\x03\x12\n\n\x06\x41RM_V7\x10\x04\"\xb5\x02\n\nIOStrategy\x12K\n\rdownload_mode\x18\x01 \x01(\x0e\x32&.flyteidl.core.IOStrategy.DownloadModeR\x0c\x64ownloadMode\x12\x45\n\x0bupload_mode\x18\x02 \x01(\x0e\x32$.flyteidl.core.IOStrategy.UploadModeR\nuploadMode\"L\n\x0c\x44ownloadMode\x12\x12\n\x0e\x44OWNLOAD_EAGER\x10\x00\x12\x13\n\x0f\x44OWNLOAD_STREAM\x10\x01\x12\x13\n\x0f\x44O_NOT_DOWNLOAD\x10\x02\"E\n\nUploadMode\x12\x12\n\x0eUPLOAD_ON_EXIT\x10\x00\x12\x10\n\x0cUPLOAD_EAGER\x10\x01\x12\x11\n\rDO_NOT_UPLOAD\x10\x02\"\xa7\x02\n\x11\x44\x61taLoadingConfig\x12\x18\n\x07\x65nabled\x18\x01 \x01(\x08R\x07\x65nabled\x12\x1d\n\ninput_path\x18\x02 \x01(\tR\tinputPath\x12\x1f\n\x0boutput_path\x18\x03 \x01(\tR\noutputPath\x12I\n\x06\x66ormat\x18\x04 \x01(\x0e\x32\x31.flyteidl.core.DataLoadingConfig.LiteralMapFormatR\x06\x66ormat\x12:\n\x0bio_strategy\x18\x05 \x01(\x0b\x32\x19.flyteidl.core.IOStrategyR\nioStrategy\"1\n\x10LiteralMapFormat\x12\x08\n\x04JSON\x10\x00\x12\x08\n\x04YAML\x10\x01\x12\t\n\x05PROTO\x10\x02\"\xbd\x01\n\x06K8sPod\x12<\n\x08metadata\x18\x01 \x01(\x0b\x32 .flyteidl.core.K8sObjectMetadataR\x08metadata\x12\x32\n\x08pod_spec\x18\x02 \x01(\x0b\x32\x17.google.protobuf.StructR\x07podSpec\x12\x41\n\x0b\x64\x61ta_config\x18\x03 \x01(\x0b\x32 .flyteidl.core.DataLoadingConfigR\ndataConfig\"\xa9\x02\n\x11K8sObjectMetadata\x12\x44\n\x06labels\x18\x01 \x03(\x0b\x32,.flyteidl.core.K8sObjectMetadata.LabelsEntryR\x06labels\x12S\n\x0b\x61nnotations\x18\x02 \x03(\x0b\x32\x31.flyteidl.core.K8sObjectMetadata.AnnotationsEntryR\x0b\x61nnotations\x1a\x39\n\x0bLabelsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1a>\n\x10\x41nnotationsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\"\x92\x01\n\x03Sql\x12\x1c\n\tstatement\x18\x01 \x01(\tR\tstatement\x12\x34\n\x07\x64ialect\x18\x02 \x01(\x0e\x32\x1a.flyteidl.core.Sql.DialectR\x07\x64ialect\"7\n\x07\x44ialect\x12\r\n\tUNDEFINED\x10\x00\x12\x08\n\x04\x41NSI\x10\x01\x12\x08\n\x04HIVE\x10\x02\x12\t\n\x05OTHER\x10\x03\x42\xb0\x01\n\x11\x63om.flyteidl.coreB\nTasksProtoP\x01Z:github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/core\xa2\x02\x03\x46\x43X\xaa\x02\rFlyteidl.Core\xca\x02\rFlyteidl\\Core\xe2\x02\x19\x46lyteidl\\Core\\GPBMetadata\xea\x02\x0e\x46lyteidl::Coreb\x06proto3') +DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x19\x66lyteidl/core/tasks.proto\x12\rflyteidl.core\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x1c\x66lyteidl/core/security.proto\x1a\x1egoogle/protobuf/duration.proto\x1a\x1cgoogle/protobuf/struct.proto\"\xd0\x02\n\tResources\x12\x42\n\x08requests\x18\x01 \x03(\x0b\x32&.flyteidl.core.Resources.ResourceEntryR\x08requests\x12>\n\x06limits\x18\x02 \x03(\x0b\x32&.flyteidl.core.Resources.ResourceEntryR\x06limits\x1a`\n\rResourceEntry\x12\x39\n\x04name\x18\x01 \x01(\x0e\x32%.flyteidl.core.Resources.ResourceNameR\x04name\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value\"]\n\x0cResourceName\x12\x0b\n\x07UNKNOWN\x10\x00\x12\x07\n\x03\x43PU\x10\x01\x12\x07\n\x03GPU\x10\x02\x12\n\n\x06MEMORY\x10\x03\x12\x0b\n\x07STORAGE\x10\x04\x12\x15\n\x11\x45PHEMERAL_STORAGE\x10\x05\"\x91\x01\n\x0eGPUAccelerator\x12\x16\n\x06\x64\x65vice\x18\x01 \x01(\tR\x06\x64\x65vice\x12&\n\runpartitioned\x18\x02 \x01(\x08H\x00R\runpartitioned\x12\'\n\x0epartition_size\x18\x03 \x01(\tH\x00R\rpartitionSizeB\x16\n\x14partition_size_value\"[\n\x11\x45xtendedResources\x12\x46\n\x0fgpu_accelerator\x18\x01 \x01(\x0b\x32\x1d.flyteidl.core.GPUAcceleratorR\x0egpuAccelerator\"\xac\x01\n\x0fRuntimeMetadata\x12>\n\x04type\x18\x01 \x01(\x0e\x32*.flyteidl.core.RuntimeMetadata.RuntimeTypeR\x04type\x12\x18\n\x07version\x18\x02 \x01(\tR\x07version\x12\x16\n\x06\x66lavor\x18\x03 \x01(\tR\x06\x66lavor\"\'\n\x0bRuntimeType\x12\t\n\x05OTHER\x10\x00\x12\r\n\tFLYTE_SDK\x10\x01\"\xac\x05\n\x0cTaskMetadata\x12\"\n\x0c\x64iscoverable\x18\x01 \x01(\x08R\x0c\x64iscoverable\x12\x38\n\x07runtime\x18\x02 \x01(\x0b\x32\x1e.flyteidl.core.RuntimeMetadataR\x07runtime\x12\x33\n\x07timeout\x18\x04 \x01(\x0b\x32\x19.google.protobuf.DurationR\x07timeout\x12\x36\n\x07retries\x18\x05 \x01(\x0b\x32\x1c.flyteidl.core.RetryStrategyR\x07retries\x12+\n\x11\x64iscovery_version\x18\x06 \x01(\tR\x10\x64iscoveryVersion\x12\x38\n\x18\x64\x65precated_error_message\x18\x07 \x01(\tR\x16\x64\x65precatedErrorMessage\x12&\n\rinterruptible\x18\x08 \x01(\x08H\x00R\rinterruptible\x12-\n\x12\x63\x61\x63he_serializable\x18\t \x01(\x08R\x11\x63\x61\x63heSerializable\x12%\n\x0egenerates_deck\x18\n \x01(\x08R\rgeneratesDeck\x12\x39\n\x04tags\x18\x0b \x03(\x0b\x32%.flyteidl.core.TaskMetadata.TagsEntryR\x04tags\x12*\n\x11pod_template_name\x18\x0c \x01(\tR\x0fpodTemplateName\x12\x35\n\x17\x63\x61\x63he_ignore_input_vars\x18\r \x03(\tR\x14\x63\x61\x63heIgnoreInputVars\x1a\x37\n\tTagsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x42\x15\n\x13interruptible_value\"\xd6\x05\n\x0cTaskTemplate\x12)\n\x02id\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.IdentifierR\x02id\x12\x12\n\x04type\x18\x02 \x01(\tR\x04type\x12\x37\n\x08metadata\x18\x03 \x01(\x0b\x32\x1b.flyteidl.core.TaskMetadataR\x08metadata\x12;\n\tinterface\x18\x04 \x01(\x0b\x32\x1d.flyteidl.core.TypedInterfaceR\tinterface\x12/\n\x06\x63ustom\x18\x05 \x01(\x0b\x32\x17.google.protobuf.StructR\x06\x63ustom\x12\x38\n\tcontainer\x18\x06 \x01(\x0b\x32\x18.flyteidl.core.ContainerH\x00R\tcontainer\x12\x30\n\x07k8s_pod\x18\x11 \x01(\x0b\x32\x15.flyteidl.core.K8sPodH\x00R\x06k8sPod\x12&\n\x03sql\x18\x12 \x01(\x0b\x32\x12.flyteidl.core.SqlH\x00R\x03sql\x12*\n\x11task_type_version\x18\x07 \x01(\x05R\x0ftaskTypeVersion\x12I\n\x10security_context\x18\x08 \x01(\x0b\x32\x1e.flyteidl.core.SecurityContextR\x0fsecurityContext\x12O\n\x12\x65xtended_resources\x18\t \x01(\x0b\x32 .flyteidl.core.ExtendedResourcesR\x11\x65xtendedResources\x12?\n\x06\x63onfig\x18\x10 \x03(\x0b\x32\'.flyteidl.core.TaskTemplate.ConfigEntryR\x06\x63onfig\x1a\x39\n\x0b\x43onfigEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x42\x08\n\x06target\"6\n\rContainerPort\x12%\n\x0e\x63ontainer_port\x18\x01 \x01(\rR\rcontainerPort\"\xfc\x03\n\tContainer\x12\x14\n\x05image\x18\x01 \x01(\tR\x05image\x12\x18\n\x07\x63ommand\x18\x02 \x03(\tR\x07\x63ommand\x12\x12\n\x04\x61rgs\x18\x03 \x03(\tR\x04\x61rgs\x12\x36\n\tresources\x18\x04 \x01(\x0b\x32\x18.flyteidl.core.ResourcesR\tresources\x12-\n\x03\x65nv\x18\x05 \x03(\x0b\x32\x1b.flyteidl.core.KeyValuePairR\x03\x65nv\x12\x37\n\x06\x63onfig\x18\x06 \x03(\x0b\x32\x1b.flyteidl.core.KeyValuePairB\x02\x18\x01R\x06\x63onfig\x12\x32\n\x05ports\x18\x07 \x03(\x0b\x32\x1c.flyteidl.core.ContainerPortR\x05ports\x12\x41\n\x0b\x64\x61ta_config\x18\t \x01(\x0b\x32 .flyteidl.core.DataLoadingConfigR\ndataConfig\x12I\n\x0c\x61rchitecture\x18\n \x01(\x0e\x32%.flyteidl.core.Container.ArchitectureR\x0c\x61rchitecture\"I\n\x0c\x41rchitecture\x12\x0b\n\x07UNKNOWN\x10\x00\x12\t\n\x05\x41MD64\x10\x01\x12\t\n\x05\x41RM64\x10\x02\x12\n\n\x06\x41RM_V6\x10\x03\x12\n\n\x06\x41RM_V7\x10\x04\"\xb5\x02\n\nIOStrategy\x12K\n\rdownload_mode\x18\x01 \x01(\x0e\x32&.flyteidl.core.IOStrategy.DownloadModeR\x0c\x64ownloadMode\x12\x45\n\x0bupload_mode\x18\x02 \x01(\x0e\x32$.flyteidl.core.IOStrategy.UploadModeR\nuploadMode\"L\n\x0c\x44ownloadMode\x12\x12\n\x0e\x44OWNLOAD_EAGER\x10\x00\x12\x13\n\x0f\x44OWNLOAD_STREAM\x10\x01\x12\x13\n\x0f\x44O_NOT_DOWNLOAD\x10\x02\"E\n\nUploadMode\x12\x12\n\x0eUPLOAD_ON_EXIT\x10\x00\x12\x10\n\x0cUPLOAD_EAGER\x10\x01\x12\x11\n\rDO_NOT_UPLOAD\x10\x02\"\xa7\x02\n\x11\x44\x61taLoadingConfig\x12\x18\n\x07\x65nabled\x18\x01 \x01(\x08R\x07\x65nabled\x12\x1d\n\ninput_path\x18\x02 \x01(\tR\tinputPath\x12\x1f\n\x0boutput_path\x18\x03 \x01(\tR\noutputPath\x12I\n\x06\x66ormat\x18\x04 \x01(\x0e\x32\x31.flyteidl.core.DataLoadingConfig.LiteralMapFormatR\x06\x66ormat\x12:\n\x0bio_strategy\x18\x05 \x01(\x0b\x32\x19.flyteidl.core.IOStrategyR\nioStrategy\"1\n\x10LiteralMapFormat\x12\x08\n\x04JSON\x10\x00\x12\x08\n\x04YAML\x10\x01\x12\t\n\x05PROTO\x10\x02\"\xbd\x01\n\x06K8sPod\x12<\n\x08metadata\x18\x01 \x01(\x0b\x32 .flyteidl.core.K8sObjectMetadataR\x08metadata\x12\x32\n\x08pod_spec\x18\x02 \x01(\x0b\x32\x17.google.protobuf.StructR\x07podSpec\x12\x41\n\x0b\x64\x61ta_config\x18\x03 \x01(\x0b\x32 .flyteidl.core.DataLoadingConfigR\ndataConfig\"\xa9\x02\n\x11K8sObjectMetadata\x12\x44\n\x06labels\x18\x01 \x03(\x0b\x32,.flyteidl.core.K8sObjectMetadata.LabelsEntryR\x06labels\x12S\n\x0b\x61nnotations\x18\x02 \x03(\x0b\x32\x31.flyteidl.core.K8sObjectMetadata.AnnotationsEntryR\x0b\x61nnotations\x1a\x39\n\x0bLabelsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1a>\n\x10\x41nnotationsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\"\x92\x01\n\x03Sql\x12\x1c\n\tstatement\x18\x01 \x01(\tR\tstatement\x12\x34\n\x07\x64ialect\x18\x02 \x01(\x0e\x32\x1a.flyteidl.core.Sql.DialectR\x07\x64ialect\"7\n\x07\x44ialect\x12\r\n\tUNDEFINED\x10\x00\x12\x08\n\x04\x41NSI\x10\x01\x12\x08\n\x04HIVE\x10\x02\x12\t\n\x05OTHER\x10\x03\x42\xb0\x01\n\x11\x63om.flyteidl.coreB\nTasksProtoP\x01Z:github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/core\xa2\x02\x03\x46\x43X\xaa\x02\rFlyteidl.Core\xca\x02\rFlyteidl\\Core\xe2\x02\x19\x46lyteidl\\Core\\GPBMetadata\xea\x02\x0e\x46lyteidl::Coreb\x06proto3') _globals = globals() _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals) @@ -53,39 +53,39 @@ _globals['_RUNTIMEMETADATA_RUNTIMETYPE']._serialized_start=943 _globals['_RUNTIMEMETADATA_RUNTIMETYPE']._serialized_end=982 _globals['_TASKMETADATA']._serialized_start=985 - _globals['_TASKMETADATA']._serialized_end=1614 - _globals['_TASKMETADATA_TAGSENTRY']._serialized_start=1536 - _globals['_TASKMETADATA_TAGSENTRY']._serialized_end=1591 - _globals['_TASKTEMPLATE']._serialized_start=1617 - _globals['_TASKTEMPLATE']._serialized_end=2343 - _globals['_TASKTEMPLATE_CONFIGENTRY']._serialized_start=2276 - _globals['_TASKTEMPLATE_CONFIGENTRY']._serialized_end=2333 - _globals['_CONTAINERPORT']._serialized_start=2345 - _globals['_CONTAINERPORT']._serialized_end=2399 - _globals['_CONTAINER']._serialized_start=2402 - _globals['_CONTAINER']._serialized_end=2910 - _globals['_CONTAINER_ARCHITECTURE']._serialized_start=2837 - _globals['_CONTAINER_ARCHITECTURE']._serialized_end=2910 - _globals['_IOSTRATEGY']._serialized_start=2913 - _globals['_IOSTRATEGY']._serialized_end=3222 - _globals['_IOSTRATEGY_DOWNLOADMODE']._serialized_start=3075 - _globals['_IOSTRATEGY_DOWNLOADMODE']._serialized_end=3151 - _globals['_IOSTRATEGY_UPLOADMODE']._serialized_start=3153 - _globals['_IOSTRATEGY_UPLOADMODE']._serialized_end=3222 - _globals['_DATALOADINGCONFIG']._serialized_start=3225 - _globals['_DATALOADINGCONFIG']._serialized_end=3520 - _globals['_DATALOADINGCONFIG_LITERALMAPFORMAT']._serialized_start=3471 - _globals['_DATALOADINGCONFIG_LITERALMAPFORMAT']._serialized_end=3520 - _globals['_K8SPOD']._serialized_start=3523 - _globals['_K8SPOD']._serialized_end=3712 - _globals['_K8SOBJECTMETADATA']._serialized_start=3715 - _globals['_K8SOBJECTMETADATA']._serialized_end=4012 - _globals['_K8SOBJECTMETADATA_LABELSENTRY']._serialized_start=3891 - _globals['_K8SOBJECTMETADATA_LABELSENTRY']._serialized_end=3948 - _globals['_K8SOBJECTMETADATA_ANNOTATIONSENTRY']._serialized_start=3950 - _globals['_K8SOBJECTMETADATA_ANNOTATIONSENTRY']._serialized_end=4012 - _globals['_SQL']._serialized_start=4015 - _globals['_SQL']._serialized_end=4161 - _globals['_SQL_DIALECT']._serialized_start=4106 - _globals['_SQL_DIALECT']._serialized_end=4161 + _globals['_TASKMETADATA']._serialized_end=1669 + _globals['_TASKMETADATA_TAGSENTRY']._serialized_start=1591 + _globals['_TASKMETADATA_TAGSENTRY']._serialized_end=1646 + _globals['_TASKTEMPLATE']._serialized_start=1672 + _globals['_TASKTEMPLATE']._serialized_end=2398 + _globals['_TASKTEMPLATE_CONFIGENTRY']._serialized_start=2331 + _globals['_TASKTEMPLATE_CONFIGENTRY']._serialized_end=2388 + _globals['_CONTAINERPORT']._serialized_start=2400 + _globals['_CONTAINERPORT']._serialized_end=2454 + _globals['_CONTAINER']._serialized_start=2457 + _globals['_CONTAINER']._serialized_end=2965 + _globals['_CONTAINER_ARCHITECTURE']._serialized_start=2892 + _globals['_CONTAINER_ARCHITECTURE']._serialized_end=2965 + _globals['_IOSTRATEGY']._serialized_start=2968 + _globals['_IOSTRATEGY']._serialized_end=3277 + _globals['_IOSTRATEGY_DOWNLOADMODE']._serialized_start=3130 + _globals['_IOSTRATEGY_DOWNLOADMODE']._serialized_end=3206 + _globals['_IOSTRATEGY_UPLOADMODE']._serialized_start=3208 + _globals['_IOSTRATEGY_UPLOADMODE']._serialized_end=3277 + _globals['_DATALOADINGCONFIG']._serialized_start=3280 + _globals['_DATALOADINGCONFIG']._serialized_end=3575 + _globals['_DATALOADINGCONFIG_LITERALMAPFORMAT']._serialized_start=3526 + _globals['_DATALOADINGCONFIG_LITERALMAPFORMAT']._serialized_end=3575 + _globals['_K8SPOD']._serialized_start=3578 + _globals['_K8SPOD']._serialized_end=3767 + _globals['_K8SOBJECTMETADATA']._serialized_start=3770 + _globals['_K8SOBJECTMETADATA']._serialized_end=4067 + _globals['_K8SOBJECTMETADATA_LABELSENTRY']._serialized_start=3946 + _globals['_K8SOBJECTMETADATA_LABELSENTRY']._serialized_end=4003 + _globals['_K8SOBJECTMETADATA_ANNOTATIONSENTRY']._serialized_start=4005 + _globals['_K8SOBJECTMETADATA_ANNOTATIONSENTRY']._serialized_end=4067 + _globals['_SQL']._serialized_start=4070 + _globals['_SQL']._serialized_end=4216 + _globals['_SQL_DIALECT']._serialized_start=4161 + _globals['_SQL_DIALECT']._serialized_end=4216 # @@protoc_insertion_point(module_scope) diff --git a/flyteidl/gen/pb_python/flyteidl/core/tasks_pb2.pyi b/flyteidl/gen/pb_python/flyteidl/core/tasks_pb2.pyi index 0545239443..98d1792aee 100644 --- a/flyteidl/gen/pb_python/flyteidl/core/tasks_pb2.pyi +++ b/flyteidl/gen/pb_python/flyteidl/core/tasks_pb2.pyi @@ -74,7 +74,7 @@ class RuntimeMetadata(_message.Message): def __init__(self, type: _Optional[_Union[RuntimeMetadata.RuntimeType, str]] = ..., version: _Optional[str] = ..., flavor: _Optional[str] = ...) -> None: ... class TaskMetadata(_message.Message): - __slots__ = ["discoverable", "runtime", "timeout", "retries", "discovery_version", "deprecated_error_message", "interruptible", "cache_serializable", "generates_deck", "tags", "pod_template_name"] + __slots__ = ["discoverable", "runtime", "timeout", "retries", "discovery_version", "deprecated_error_message", "interruptible", "cache_serializable", "generates_deck", "tags", "pod_template_name", "cache_ignore_input_vars"] class TagsEntry(_message.Message): __slots__ = ["key", "value"] KEY_FIELD_NUMBER: _ClassVar[int] @@ -93,6 +93,7 @@ class TaskMetadata(_message.Message): GENERATES_DECK_FIELD_NUMBER: _ClassVar[int] TAGS_FIELD_NUMBER: _ClassVar[int] POD_TEMPLATE_NAME_FIELD_NUMBER: _ClassVar[int] + CACHE_IGNORE_INPUT_VARS_FIELD_NUMBER: _ClassVar[int] discoverable: bool runtime: RuntimeMetadata timeout: _duration_pb2.Duration @@ -104,7 +105,8 @@ class TaskMetadata(_message.Message): generates_deck: bool tags: _containers.ScalarMap[str, str] pod_template_name: str - def __init__(self, discoverable: bool = ..., runtime: _Optional[_Union[RuntimeMetadata, _Mapping]] = ..., timeout: _Optional[_Union[_duration_pb2.Duration, _Mapping]] = ..., retries: _Optional[_Union[_literals_pb2.RetryStrategy, _Mapping]] = ..., discovery_version: _Optional[str] = ..., deprecated_error_message: _Optional[str] = ..., interruptible: bool = ..., cache_serializable: bool = ..., generates_deck: bool = ..., tags: _Optional[_Mapping[str, str]] = ..., pod_template_name: _Optional[str] = ...) -> None: ... + cache_ignore_input_vars: _containers.RepeatedScalarFieldContainer[str] + def __init__(self, discoverable: bool = ..., runtime: _Optional[_Union[RuntimeMetadata, _Mapping]] = ..., timeout: _Optional[_Union[_duration_pb2.Duration, _Mapping]] = ..., retries: _Optional[_Union[_literals_pb2.RetryStrategy, _Mapping]] = ..., discovery_version: _Optional[str] = ..., deprecated_error_message: _Optional[str] = ..., interruptible: bool = ..., cache_serializable: bool = ..., generates_deck: bool = ..., tags: _Optional[_Mapping[str, str]] = ..., pod_template_name: _Optional[str] = ..., cache_ignore_input_vars: _Optional[_Iterable[str]] = ...) -> None: ... class TaskTemplate(_message.Message): __slots__ = ["id", "type", "metadata", "interface", "custom", "container", "k8s_pod", "sql", "task_type_version", "security_context", "extended_resources", "config"] diff --git a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_task_metadata.py b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_task_metadata.py index fdc8331bbb..8223273a83 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_task_metadata.py +++ b/flyteidl/gen/pb_python/flyteidl/service/flyteadmin/flyteadmin/models/core_task_metadata.py @@ -44,7 +44,8 @@ class CoreTaskMetadata(object): 'cache_serializable': 'bool', 'generates_deck': 'bool', 'tags': 'dict(str, str)', - 'pod_template_name': 'str' + 'pod_template_name': 'str', + 'cache_ignore_input_vars': 'list[str]' } attribute_map = { @@ -58,10 +59,11 @@ class CoreTaskMetadata(object): 'cache_serializable': 'cache_serializable', 'generates_deck': 'generates_deck', 'tags': 'tags', - 'pod_template_name': 'pod_template_name' + 'pod_template_name': 'pod_template_name', + 'cache_ignore_input_vars': 'cache_ignore_input_vars' } - def __init__(self, discoverable=None, runtime=None, timeout=None, retries=None, discovery_version=None, deprecated_error_message=None, interruptible=None, cache_serializable=None, generates_deck=None, tags=None, pod_template_name=None): # noqa: E501 + def __init__(self, discoverable=None, runtime=None, timeout=None, retries=None, discovery_version=None, deprecated_error_message=None, interruptible=None, cache_serializable=None, generates_deck=None, tags=None, pod_template_name=None, cache_ignore_input_vars=None): # noqa: E501 """CoreTaskMetadata - a model defined in Swagger""" # noqa: E501 self._discoverable = None @@ -75,6 +77,7 @@ def __init__(self, discoverable=None, runtime=None, timeout=None, retries=None, self._generates_deck = None self._tags = None self._pod_template_name = None + self._cache_ignore_input_vars = None self.discriminator = None if discoverable is not None: @@ -99,6 +102,8 @@ def __init__(self, discoverable=None, runtime=None, timeout=None, retries=None, self.tags = tags if pod_template_name is not None: self.pod_template_name = pod_template_name + if cache_ignore_input_vars is not None: + self.cache_ignore_input_vars = cache_ignore_input_vars @property def discoverable(self): @@ -347,6 +352,29 @@ def pod_template_name(self, pod_template_name): self._pod_template_name = pod_template_name + @property + def cache_ignore_input_vars(self): + """Gets the cache_ignore_input_vars of this CoreTaskMetadata. # noqa: E501 + + cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache. # noqa: E501 + + :return: The cache_ignore_input_vars of this CoreTaskMetadata. # noqa: E501 + :rtype: list[str] + """ + return self._cache_ignore_input_vars + + @cache_ignore_input_vars.setter + def cache_ignore_input_vars(self, cache_ignore_input_vars): + """Sets the cache_ignore_input_vars of this CoreTaskMetadata. + + cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache. # noqa: E501 + + :param cache_ignore_input_vars: The cache_ignore_input_vars of this CoreTaskMetadata. # noqa: E501 + :type: list[str] + """ + + self._cache_ignore_input_vars = cache_ignore_input_vars + def to_dict(self): """Returns the model properties as a dict""" result = {} diff --git a/flyteidl/gen/pb_rust/flyteidl.core.rs b/flyteidl/gen/pb_rust/flyteidl.core.rs index bc39cf1d9c..ca946db5f8 100644 --- a/flyteidl/gen/pb_rust/flyteidl.core.rs +++ b/flyteidl/gen/pb_rust/flyteidl.core.rs @@ -1134,6 +1134,9 @@ pub struct TaskMetadata { /// identically as, the default PodTemplate configured in FlytePropeller. #[prost(string, tag="12")] pub pod_template_name: ::prost::alloc::string::String, + /// cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache. + #[prost(string, repeated, tag="13")] + pub cache_ignore_input_vars: ::prost::alloc::vec::Vec<::prost::alloc::string::String>, // For interruptible we will populate it at the node level but require it be part of TaskMetadata // for a user to set the value. // We are using oneof instead of bool because otherwise we would be unable to distinguish between value being diff --git a/flyteidl/protos/flyteidl/core/tasks.proto b/flyteidl/protos/flyteidl/core/tasks.proto index 3d3f4b6abf..ab96615be7 100644 --- a/flyteidl/protos/flyteidl/core/tasks.proto +++ b/flyteidl/protos/flyteidl/core/tasks.proto @@ -131,6 +131,9 @@ message TaskMetadata { // task creates a k8s Pod. If this value is set, the specified PodTemplate will be used instead of, but applied // identically as, the default PodTemplate configured in FlytePropeller. string pod_template_name = 12; + + // cache_ignore_input_vars is the input variables that should not be included when calculating hash for cache. + repeated string cache_ignore_input_vars = 13; } // A Task structure that uniquely identifies a task in the system diff --git a/flyteplugins/go/tasks/pluginmachinery/catalog/async_client_impl.go b/flyteplugins/go/tasks/pluginmachinery/catalog/async_client_impl.go index d9e886d0eb..c056989905 100644 --- a/flyteplugins/go/tasks/pluginmachinery/catalog/async_client_impl.go +++ b/flyteplugins/go/tasks/pluginmachinery/catalog/async_client_impl.go @@ -48,7 +48,7 @@ func hashInputs(ctx context.Context, key Key) (string, error) { } inputs = retInputs } - return HashLiteralMap(ctx, inputs) + return HashLiteralMap(ctx, inputs, key.CacheIgnoreInputVars) } func (c AsyncClientImpl) Download(ctx context.Context, requests ...DownloadRequest) (outputFuture DownloadFuture, err error) { diff --git a/flyteplugins/go/tasks/pluginmachinery/catalog/client.go b/flyteplugins/go/tasks/pluginmachinery/catalog/client.go index aedc2795dd..5d0e981e08 100644 --- a/flyteplugins/go/tasks/pluginmachinery/catalog/client.go +++ b/flyteplugins/go/tasks/pluginmachinery/catalog/client.go @@ -24,10 +24,11 @@ type Metadata struct { // An identifier for a catalog object. type Key struct { - Identifier core.Identifier - CacheVersion string - TypedInterface core.TypedInterface - InputReader io.InputReader + Identifier core.Identifier + CacheVersion string + CacheIgnoreInputVars []string + TypedInterface core.TypedInterface + InputReader io.InputReader } func (k Key) String() string { diff --git a/flyteplugins/go/tasks/pluginmachinery/catalog/hashing.go b/flyteplugins/go/tasks/pluginmachinery/catalog/hashing.go index 3c73710eac..4cc2fbd5cd 100644 --- a/flyteplugins/go/tasks/pluginmachinery/catalog/hashing.go +++ b/flyteplugins/go/tasks/pluginmachinery/catalog/hashing.go @@ -4,6 +4,8 @@ import ( "context" "encoding/base64" + "k8s.io/utils/strings/slices" + "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/core" "github.com/flyteorg/flyte/flytestdlib/pbhash" ) @@ -55,7 +57,7 @@ func hashify(literal *core.Literal) *core.Literal { return literal } -func HashLiteralMap(ctx context.Context, literalMap *core.LiteralMap) (string, error) { +func HashLiteralMap(ctx context.Context, literalMap *core.LiteralMap, cacheIgnoreInputVars []string) (string, error) { if literalMap == nil || len(literalMap.Literals) == 0 { literalMap = &emptyLiteralMap } @@ -64,7 +66,9 @@ func HashLiteralMap(ctx context.Context, literalMap *core.LiteralMap) (string, e // in case the corresponding hash is set. hashifiedLiteralMap := make(map[string]*core.Literal, len(literalMap.Literals)) for name, literal := range literalMap.Literals { - hashifiedLiteralMap[name] = hashify(literal) + if !slices.Contains(cacheIgnoreInputVars, name) { + hashifiedLiteralMap[name] = hashify(literal) + } } hashifiedInputs := &core.LiteralMap{ Literals: hashifiedLiteralMap, diff --git a/flyteplugins/go/tasks/pluginmachinery/catalog/hashing_test.go b/flyteplugins/go/tasks/pluginmachinery/catalog/hashing_test.go index 43b6754c02..51f2cdfe27 100644 --- a/flyteplugins/go/tasks/pluginmachinery/catalog/hashing_test.go +++ b/flyteplugins/go/tasks/pluginmachinery/catalog/hashing_test.go @@ -617,7 +617,7 @@ func TestHashLiteralMap_LiteralsWithHashSet(t *testing.T) { // Double-check that generating a tag is successful literalMap := &core.LiteralMap{Literals: map[string]*core.Literal{"o0": tt.literal}} - hash, err := HashLiteralMap(context.TODO(), literalMap) + hash, err := HashLiteralMap(context.TODO(), literalMap, nil) assert.NoError(t, err) assert.NotEmpty(t, hash) }) @@ -629,26 +629,43 @@ func TestInputValueSorted(t *testing.T) { literalMap, err := coreutils.MakeLiteralMap(map[string]interface{}{"1": 1, "2": 2}) assert.NoError(t, err) - hash, err := HashLiteralMap(context.TODO(), literalMap) + hash, err := HashLiteralMap(context.TODO(), literalMap, nil) assert.NoError(t, err) assert.Equal(t, "GQid5LjHbakcW68DS3P2jp80QLbiF0olFHF2hTh5bg8", hash) literalMap, err = coreutils.MakeLiteralMap(map[string]interface{}{"2": 2, "1": 1}) assert.NoError(t, err) - hashDupe, err := HashLiteralMap(context.TODO(), literalMap) + hashDupe, err := HashLiteralMap(context.TODO(), literalMap, nil) assert.NoError(t, err) assert.Equal(t, hashDupe, hash) } // Ensure that empty inputs are hashed the same way func TestNoInputValues(t *testing.T) { - hash, err := HashLiteralMap(context.TODO(), nil) + hash, err := HashLiteralMap(context.TODO(), nil, nil) assert.NoError(t, err) assert.Equal(t, "GKw-c0PwFokMUQ6T-TUmEWnZ4_VlQ2Qpgw-vCTT0-OQ", hash) - hashDupe, err := HashLiteralMap(context.TODO(), &core.LiteralMap{Literals: nil}) + hashDupe, err := HashLiteralMap(context.TODO(), &core.LiteralMap{Literals: nil}, nil) assert.NoError(t, err) assert.Equal(t, "GKw-c0PwFokMUQ6T-TUmEWnZ4_VlQ2Qpgw-vCTT0-OQ", hashDupe) assert.Equal(t, hashDupe, hash) } + +// Ensure that empty inputs are hashed the same way +func TestCacheIgnoreInputVars(t *testing.T) { + literalMap, err := coreutils.MakeLiteralMap(map[string]interface{}{"1": 1, "2": 2}) + assert.NoError(t, err) + + hash, err := HashLiteralMap(context.TODO(), literalMap, nil) + assert.NoError(t, err) + assert.Equal(t, "GQid5LjHbakcW68DS3P2jp80QLbiF0olFHF2hTh5bg8", hash) + + literalMap, err = coreutils.MakeLiteralMap(map[string]interface{}{"2": 2, "1": 1, "3": 3}) + assert.NoError(t, err) + + hashDupe, err := HashLiteralMap(context.TODO(), literalMap, []string{"3"}) + assert.NoError(t, err) + assert.Equal(t, hashDupe, hash) +} diff --git a/flyteplugins/go/tasks/plugins/array/catalog.go b/flyteplugins/go/tasks/plugins/array/catalog.go index 836ff52fda..d6bf5e8820 100644 --- a/flyteplugins/go/tasks/plugins/array/catalog.go +++ b/flyteplugins/go/tasks/plugins/array/catalog.go @@ -269,7 +269,7 @@ func WriteToDiscovery(ctx context.Context, tCtx core.TaskExecutionContext, state // Create catalog put items, but only put the ones that were not originally cached (as read from the catalog results bitset) catalogWriterItems, err := ConstructCatalogUploadRequests(*tCtx.TaskExecutionMetadata().GetTaskExecutionID().GetID().TaskId, tCtx.TaskExecutionMetadata().GetTaskExecutionID().GetID(), taskTemplate.Metadata.DiscoveryVersion, - iface, &tasksToCache, inputReaders, outputReaders) + taskTemplate.Metadata.CacheIgnoreInputVars, iface, &tasksToCache, inputReaders, outputReaders) if err != nil { return nil, externalResources, err @@ -338,7 +338,7 @@ func WriteToCatalog(ctx context.Context, ownerSignal core.SignalAsync, catalogCl } func ConstructCatalogUploadRequests(keyID idlCore.Identifier, taskExecID idlCore.TaskExecutionIdentifier, - cacheVersion string, taskInterface idlCore.TypedInterface, whichTasksToCache *bitarray.BitSet, + cacheVersion string, cacheIgnoreInputVars []string, taskInterface idlCore.TypedInterface, whichTasksToCache *bitarray.BitSet, inputReaders []io.InputReader, outputReaders []io.OutputReader) ([]catalog.UploadRequest, error) { writerWorkItems := make([]catalog.UploadRequest, 0, len(inputReaders)) @@ -355,10 +355,11 @@ func ConstructCatalogUploadRequests(keyID idlCore.Identifier, taskExecID idlCore wi := catalog.UploadRequest{ Key: catalog.Key{ - Identifier: keyID, - InputReader: input, - CacheVersion: cacheVersion, - TypedInterface: taskInterface, + Identifier: keyID, + InputReader: input, + CacheVersion: cacheVersion, + CacheIgnoreInputVars: cacheIgnoreInputVars, + TypedInterface: taskInterface, }, ArtifactData: outputReaders[idx], ArtifactMetadata: catalog.Metadata{ diff --git a/flytepropeller/pkg/controller/nodes/catalog/datacatalog/datacatalog.go b/flytepropeller/pkg/controller/nodes/catalog/datacatalog/datacatalog.go index 8296500993..3d849329be 100644 --- a/flytepropeller/pkg/controller/nodes/catalog/datacatalog/datacatalog.go +++ b/flytepropeller/pkg/controller/nodes/catalog/datacatalog/datacatalog.go @@ -111,7 +111,7 @@ func (m *CatalogClient) Get(ctx context.Context, key catalog.Key) (catalog.Entry inputs = retInputs } - tag, err := GenerateArtifactTagName(ctx, inputs) + tag, err := GenerateArtifactTagName(ctx, inputs, key.CacheIgnoreInputVars) if err != nil { logger.Errorf(ctx, "DataCatalog failed to generate tag for inputs %+v, err: %+v", inputs, err) return catalog.Entry{}, err @@ -236,7 +236,7 @@ func (m *CatalogClient) CreateArtifact(ctx context.Context, key catalog.Key, dat logger.Debugf(ctx, "Created artifact: %v, with %v outputs from execution %+v", cachedArtifact.Id, len(artifactDataList), metadata) // Tag the artifact since it is the cached artifact - tagName, err := GenerateArtifactTagName(ctx, inputs) + tagName, err := GenerateArtifactTagName(ctx, inputs, key.CacheIgnoreInputVars) if err != nil { logger.Errorf(ctx, "Failed to generate tag for artifact %+v, err: %+v", cachedArtifact.Id, err) return catalog.Status{}, err @@ -276,7 +276,7 @@ func (m *CatalogClient) UpdateArtifact(ctx context.Context, key catalog.Key, dat artifactDataList = append(artifactDataList, artifactData) } - tagName, err := GenerateArtifactTagName(ctx, inputs) + tagName, err := GenerateArtifactTagName(ctx, inputs, key.CacheIgnoreInputVars) if err != nil { logger.Errorf(ctx, "Failed to generate artifact tag name for key %+v, dataset %+v and execution %+v, err: %+v", key, datasetID, metadata, err) return catalog.Status{}, err @@ -381,7 +381,7 @@ func (m *CatalogClient) GetOrExtendReservation(ctx context.Context, key catalog. inputs = retInputs } - tag, err := GenerateArtifactTagName(ctx, inputs) + tag, err := GenerateArtifactTagName(ctx, inputs, key.CacheIgnoreInputVars) if err != nil { return nil, err } @@ -421,7 +421,7 @@ func (m *CatalogClient) ReleaseReservation(ctx context.Context, key catalog.Key, inputs = retInputs } - tag, err := GenerateArtifactTagName(ctx, inputs) + tag, err := GenerateArtifactTagName(ctx, inputs, key.CacheIgnoreInputVars) if err != nil { return err } diff --git a/flytepropeller/pkg/controller/nodes/catalog/datacatalog/transformer.go b/flytepropeller/pkg/controller/nodes/catalog/datacatalog/transformer.go index d9f48c9dce..5c0ac0c30b 100644 --- a/flytepropeller/pkg/controller/nodes/catalog/datacatalog/transformer.go +++ b/flytepropeller/pkg/controller/nodes/catalog/datacatalog/transformer.go @@ -114,9 +114,9 @@ func generateTaskSignatureHash(ctx context.Context, taskInterface core.TypedInte return fmt.Sprintf("%v-%v", inputHashString, outputHashString), nil } -// Generate a tag by hashing the input values -func GenerateArtifactTagName(ctx context.Context, inputs *core.LiteralMap) (string, error) { - hashString, err := catalog.HashLiteralMap(ctx, inputs) +// Generate a tag by hashing the input values which are not in cacheIgnoreInputVars +func GenerateArtifactTagName(ctx context.Context, inputs *core.LiteralMap, cacheIgnoreInputVars []string) (string, error) { + hashString, err := catalog.HashLiteralMap(ctx, inputs, cacheIgnoreInputVars) if err != nil { return "", err } diff --git a/flytepropeller/pkg/controller/nodes/catalog/datacatalog/transformer_test.go b/flytepropeller/pkg/controller/nodes/catalog/datacatalog/transformer_test.go index 74277dcda0..1c6b9e2e1b 100644 --- a/flytepropeller/pkg/controller/nodes/catalog/datacatalog/transformer_test.go +++ b/flytepropeller/pkg/controller/nodes/catalog/datacatalog/transformer_test.go @@ -105,7 +105,16 @@ func TestGenerateArtifactTagName(t *testing.T) { literalMap, err := coreutils.MakeLiteralMap(map[string]interface{}{"1": 1, "2": 2}) assert.NoError(t, err) - tag, err := GenerateArtifactTagName(context.TODO(), literalMap) + tag, err := GenerateArtifactTagName(context.TODO(), literalMap, nil) + assert.NoError(t, err) + assert.Equal(t, "flyte_cached-GQid5LjHbakcW68DS3P2jp80QLbiF0olFHF2hTh5bg8", tag) +} + +func TestGenerateArtifactTagNameWithIgnore(t *testing.T) { + literalMap, err := coreutils.MakeLiteralMap(map[string]interface{}{"1": 1, "2": 2, "3": 3}) + assert.NoError(t, err) + cacheIgnoreInputVars := []string{"3"} + tag, err := GenerateArtifactTagName(context.TODO(), literalMap, cacheIgnoreInputVars) assert.NoError(t, err) assert.Equal(t, "flyte_cached-GQid5LjHbakcW68DS3P2jp80QLbiF0olFHF2hTh5bg8", tag) } diff --git a/flytepropeller/pkg/controller/nodes/task/cache.go b/flytepropeller/pkg/controller/nodes/task/cache.go index 2be27dd8d3..fab3cd4d61 100644 --- a/flytepropeller/pkg/controller/nodes/task/cache.go +++ b/flytepropeller/pkg/controller/nodes/task/cache.go @@ -26,10 +26,11 @@ func (t *Handler) GetCatalogKey(ctx context.Context, nCtx interfaces.NodeExecuti } return catalog.Key{ - Identifier: *taskTemplate.Id, - CacheVersion: taskTemplate.Metadata.DiscoveryVersion, - TypedInterface: *taskTemplate.Interface, - InputReader: nCtx.InputReader(), + Identifier: *taskTemplate.Id, + CacheVersion: taskTemplate.Metadata.DiscoveryVersion, + CacheIgnoreInputVars: taskTemplate.Metadata.CacheIgnoreInputVars, + TypedInterface: *taskTemplate.Interface, + InputReader: nCtx.InputReader(), }, nil } From 6c6656cc7cfd5e869488cc05099f77e9f1f3494e Mon Sep 17 00:00:00 2001 From: Paul Dittamo <37558497+pvditt@users.noreply.github.com> Date: Tue, 19 Dec 2023 10:25:51 -0500 Subject: [PATCH 2/8] Feature/add cleanup non recoverable pod statuses (#4607) * clean up non-recoverable pods Signed-off-by: Paul Dittamo * use non-exported phaseInfoFailed function to appease linter Signed-off-by: Paul Dittamo --------- Signed-off-by: Paul Dittamo Co-authored-by: Dan Rammer --- .../go/tasks/pluginmachinery/core/phase.go | 14 +++++++++----- .../tasks/pluginmachinery/flytek8s/pod_helper.go | 8 ++++---- .../pluginmachinery/flytek8s/pod_helper_test.go | 7 +++++++ 3 files changed, 20 insertions(+), 9 deletions(-) diff --git a/flyteplugins/go/tasks/pluginmachinery/core/phase.go b/flyteplugins/go/tasks/pluginmachinery/core/phase.go index 7847b161fc..6c80cc4d24 100644 --- a/flyteplugins/go/tasks/pluginmachinery/core/phase.go +++ b/flyteplugins/go/tasks/pluginmachinery/core/phase.go @@ -261,15 +261,15 @@ func PhaseInfoSuccess(info *TaskInfo) PhaseInfo { } func PhaseInfoSystemFailure(code, reason string, info *TaskInfo) PhaseInfo { - return PhaseInfoFailed(PhasePermanentFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_SYSTEM}, info) + return phaseInfoFailed(PhasePermanentFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_SYSTEM}, info, false) } func PhaseInfoSystemFailureWithCleanup(code, reason string, info *TaskInfo) PhaseInfo { - return phaseInfoFailed(PhasePermanentFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_USER}, info, true) + return phaseInfoFailed(PhasePermanentFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_SYSTEM}, info, true) } func PhaseInfoFailure(code, reason string, info *TaskInfo) PhaseInfo { - return PhaseInfoFailed(PhasePermanentFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_USER}, info) + return phaseInfoFailed(PhasePermanentFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_USER}, info, false) } func PhaseInfoFailureWithCleanup(code, reason string, info *TaskInfo) PhaseInfo { @@ -277,7 +277,7 @@ func PhaseInfoFailureWithCleanup(code, reason string, info *TaskInfo) PhaseInfo } func PhaseInfoRetryableFailure(code, reason string, info *TaskInfo) PhaseInfo { - return PhaseInfoFailed(PhaseRetryableFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_USER}, info) + return phaseInfoFailed(PhaseRetryableFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_USER}, info, false) } func PhaseInfoRetryableFailureWithCleanup(code, reason string, info *TaskInfo) PhaseInfo { @@ -285,7 +285,11 @@ func PhaseInfoRetryableFailureWithCleanup(code, reason string, info *TaskInfo) P } func PhaseInfoSystemRetryableFailure(code, reason string, info *TaskInfo) PhaseInfo { - return PhaseInfoFailed(PhaseRetryableFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_SYSTEM}, info) + return phaseInfoFailed(PhaseRetryableFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_SYSTEM}, info, false) +} + +func PhaseInfoSystemRetryableFailureWithCleanup(code, reason string, info *TaskInfo) PhaseInfo { + return phaseInfoFailed(PhaseRetryableFailure, &core.ExecutionError{Code: code, Message: reason, Kind: core.ExecutionError_SYSTEM}, info, true) } // Creates a new PhaseInfo with phase set to PhaseWaitingForCache diff --git a/flyteplugins/go/tasks/pluginmachinery/flytek8s/pod_helper.go b/flyteplugins/go/tasks/pluginmachinery/flytek8s/pod_helper.go index 2f3447ad0e..2a17751c62 100644 --- a/flyteplugins/go/tasks/pluginmachinery/flytek8s/pod_helper.go +++ b/flyteplugins/go/tasks/pluginmachinery/flytek8s/pod_helper.go @@ -686,7 +686,7 @@ func demystifyPendingHelper(status v1.PodStatus) (pluginsCore.PhaseInfo, time.Ti gracePeriod := config.GetK8sPluginConfig().CreateContainerErrorGracePeriod.Duration if time.Since(t) >= gracePeriod { - return pluginsCore.PhaseInfoFailure(finalReason, GetMessageAfterGracePeriod(finalMessage, gracePeriod), &pluginsCore.TaskInfo{ + return pluginsCore.PhaseInfoFailureWithCleanup(finalReason, GetMessageAfterGracePeriod(finalMessage, gracePeriod), &pluginsCore.TaskInfo{ OccurredAt: &t, }), t } @@ -700,7 +700,7 @@ func demystifyPendingHelper(status v1.PodStatus) (pluginsCore.PhaseInfo, time.Ti case "CreateContainerConfigError": gracePeriod := config.GetK8sPluginConfig().CreateContainerConfigErrorGracePeriod.Duration if time.Since(t) >= gracePeriod { - return pluginsCore.PhaseInfoFailure(finalReason, GetMessageAfterGracePeriod(finalMessage, gracePeriod), &pluginsCore.TaskInfo{ + return pluginsCore.PhaseInfoFailureWithCleanup(finalReason, GetMessageAfterGracePeriod(finalMessage, gracePeriod), &pluginsCore.TaskInfo{ OccurredAt: &t, }), t } @@ -712,7 +712,7 @@ func demystifyPendingHelper(status v1.PodStatus) (pluginsCore.PhaseInfo, time.Ti ), t case "InvalidImageName": - return pluginsCore.PhaseInfoFailure(finalReason, finalMessage, &pluginsCore.TaskInfo{ + return pluginsCore.PhaseInfoFailureWithCleanup(finalReason, finalMessage, &pluginsCore.TaskInfo{ OccurredAt: &t, }), t @@ -737,7 +737,7 @@ func demystifyPendingHelper(status v1.PodStatus) (pluginsCore.PhaseInfo, time.Ti // by K8s and we get elusive 'pod not found' errors // So be default if the container is not waiting with the PodInitializing/ContainerCreating // reasons, then we will assume a failure reason, and fail instantly - return pluginsCore.PhaseInfoSystemRetryableFailure(finalReason, finalMessage, &pluginsCore.TaskInfo{ + return pluginsCore.PhaseInfoSystemRetryableFailureWithCleanup(finalReason, finalMessage, &pluginsCore.TaskInfo{ OccurredAt: &t, }), t } diff --git a/flyteplugins/go/tasks/pluginmachinery/flytek8s/pod_helper_test.go b/flyteplugins/go/tasks/pluginmachinery/flytek8s/pod_helper_test.go index 925cb00186..b5a51323d2 100644 --- a/flyteplugins/go/tasks/pluginmachinery/flytek8s/pod_helper_test.go +++ b/flyteplugins/go/tasks/pluginmachinery/flytek8s/pod_helper_test.go @@ -1351,6 +1351,7 @@ func TestDemystifyPending(t *testing.T) { taskStatus, err := DemystifyPending(s2) assert.NoError(t, err) assert.Equal(t, pluginsCore.PhaseRetryableFailure, taskStatus.Phase()) + assert.True(t, taskStatus.CleanupOnFailure()) }) t.Run("InvalidImageName", func(t *testing.T) { @@ -1368,6 +1369,7 @@ func TestDemystifyPending(t *testing.T) { taskStatus, err := DemystifyPending(s) assert.NoError(t, err) assert.Equal(t, pluginsCore.PhasePermanentFailure, taskStatus.Phase()) + assert.True(t, taskStatus.CleanupOnFailure()) }) t.Run("RegistryUnavailable", func(t *testing.T) { @@ -1385,6 +1387,7 @@ func TestDemystifyPending(t *testing.T) { taskStatus, err := DemystifyPending(s) assert.NoError(t, err) assert.Equal(t, pluginsCore.PhaseRetryableFailure, taskStatus.Phase()) + assert.True(t, taskStatus.CleanupOnFailure()) }) t.Run("RandomError", func(t *testing.T) { @@ -1402,6 +1405,7 @@ func TestDemystifyPending(t *testing.T) { taskStatus, err := DemystifyPending(s) assert.NoError(t, err) assert.Equal(t, pluginsCore.PhaseRetryableFailure, taskStatus.Phase()) + assert.True(t, taskStatus.CleanupOnFailure()) }) t.Run("CreateContainerConfigErrorWithinGracePeriod", func(t *testing.T) { @@ -1440,6 +1444,7 @@ func TestDemystifyPending(t *testing.T) { taskStatus, err := DemystifyPending(s2) assert.NoError(t, err) assert.Equal(t, pluginsCore.PhasePermanentFailure, taskStatus.Phase()) + assert.True(t, taskStatus.CleanupOnFailure()) }) t.Run("CreateContainerErrorWithinGracePeriod", func(t *testing.T) { @@ -1478,6 +1483,7 @@ func TestDemystifyPending(t *testing.T) { taskStatus, err := DemystifyPending(s2) assert.NoError(t, err) assert.Equal(t, pluginsCore.PhasePermanentFailure, taskStatus.Phase()) + assert.True(t, taskStatus.CleanupOnFailure()) }) } @@ -1510,6 +1516,7 @@ func TestDemystifyPendingTimeout(t *testing.T) { assert.NoError(t, err) assert.Equal(t, pluginsCore.PhaseRetryableFailure, taskStatus.Phase()) assert.Equal(t, "PodPendingTimeout", taskStatus.Err().Code) + assert.True(t, taskStatus.CleanupOnFailure()) }) } From 364844074c01d0d48fa3ff7788d1c2933e466c3a Mon Sep 17 00:00:00 2001 From: Future-Outlier Date: Wed, 20 Dec 2023 17:02:36 +0800 Subject: [PATCH 3/8] Agent Metadata Servicer (#4511) Signed-off-by: Future Outlier Signed-off-by: Future-Outlier Signed-off-by: Kevin Su Co-authored-by: Future Outlier Co-authored-by: Kevin Su Co-authored-by: Kevin Su Co-authored-by: Haytham Abuelfutuh --- .github/workflows/single-binary.yml | 2 +- charts/flyte-binary/templates/configmap.yaml | 9 +- charts/flyte-binary/values.yaml | 1 - .../flyte_sandbox_binary_helm_generated.yaml | 11 +- ...patch.yaml => add-agent-secret-patch.yaml} | 0 .../complete-agent/kustomization.yaml | 9 +- .../manifests/complete-agent.yaml | 16 +- .../sandbox-bundled/manifests/complete.yaml | 15 +- docker/sandbox-bundled/manifests/dev.yaml | 4 +- .../admin/mocks/AgentMetadataServiceClient.go | 114 + .../admin/mocks/AgentMetadataServiceServer.go | 98 + .../gen/pb-cpp/flyteidl/admin/agent.pb.cc | 1667 ++++++- flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h | 909 +++- .../pb-cpp/flyteidl/service/agent.grpc.pb.cc | 103 + .../pb-cpp/flyteidl/service/agent.grpc.pb.h | 379 +- .../gen/pb-cpp/flyteidl/service/agent.pb.cc | 34 +- .../gen/pb-cpp/flyteidl/service/agent.pb.h | 1 + flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go | 316 +- .../pb-go/flyteidl/admin/agent.pb.validate.go | 357 ++ .../gen/pb-go/flyteidl/service/agent.pb.go | 150 +- .../gen/pb-go/flyteidl/service/agent.pb.gw.go | 159 + .../pb-go/flyteidl/service/agent.swagger.json | 86 +- .../{Agent.java => AgentOuterClass.java} | 4153 +++++++++++++++-- .../gen/pb-java/flyteidl/service/Agent.java | 38 +- flyteidl/gen/pb-js/flyteidl.d.ts | 326 ++ flyteidl/gen/pb-js/flyteidl.js | 671 +++ .../gen/pb_python/flyteidl/admin/agent_pb2.py | 16 +- .../pb_python/flyteidl/admin/agent_pb2.pyi | 30 + .../pb_python/flyteidl/service/agent_pb2.py | 13 +- .../pb_python/flyteidl/service/agent_pb2.pyi | 1 + .../flyteidl/service/agent_pb2_grpc.py | 108 +- flyteidl/gen/pb_rust/flyteidl.admin.rs | 40 +- flyteidl/protos/flyteidl/admin/agent.proto | 32 +- flyteidl/protos/flyteidl/service/agent.proto | 22 +- .../pluginmachinery/internal/webapi/core.go | 1 + .../tasks/plugins/array/awsbatch/executor.go | 2 +- .../go/tasks/plugins/array/k8s/management.go | 8 +- .../go/tasks/plugins/webapi/agent/config.go | 4 +- .../plugins/webapi/agent/integration_test.go | 2 +- .../agent/mocks/AgentMetadataServiceClient.go | 114 + .../go/tasks/plugins/webapi/agent/plugin.go | 122 +- .../tasks/plugins/webapi/agent/plugin_test.go | 59 +- .../executors/failure_node_lookup_test.go | 3 +- 43 files changed, 9567 insertions(+), 638 deletions(-) rename docker/sandbox-bundled/kustomize/complete-agent/{patch.yaml => add-agent-secret-patch.yaml} (100%) create mode 100644 flyteidl/clients/go/admin/mocks/AgentMetadataServiceClient.go create mode 100644 flyteidl/clients/go/admin/mocks/AgentMetadataServiceServer.go create mode 100644 flyteidl/gen/pb-go/flyteidl/service/agent.pb.gw.go rename flyteidl/gen/pb-java/flyteidl/admin/{Agent.java => AgentOuterClass.java} (62%) create mode 100644 flyteplugins/go/tasks/plugins/webapi/agent/mocks/AgentMetadataServiceClient.go diff --git a/.github/workflows/single-binary.yml b/.github/workflows/single-binary.yml index e693b0d3d1..9a2c19a52c 100644 --- a/.github/workflows/single-binary.yml +++ b/.github/workflows/single-binary.yml @@ -123,7 +123,7 @@ jobs: env: FLYTESNACKS_PRIORITIES: "P0" FLYTESNACKS_VERSION: "" - timeout-minutes: 20 + timeout-minutes: 60 needs: [build-and-push-single-binary-image] steps: - name: Set latest Flytesnacks release diff --git a/charts/flyte-binary/templates/configmap.yaml b/charts/flyte-binary/templates/configmap.yaml index 4c55bf34e3..255da9fdf3 100644 --- a/charts/flyte-binary/templates/configmap.yaml +++ b/charts/flyte-binary/templates/configmap.yaml @@ -61,16 +61,9 @@ data: k8s-array: logs: config: {{- include "flyte-binary.configuration.logging.plugins" . | nindent 12 }} - {{- if .Values.configuration.agentService }} + {{- if .Values.flyteagent.enabled }} agent-service: {{- tpl ( .Values.configuration.agentService | toYaml ) . | nindent 8 }} - {{- else if .Values.flyteagent.enabled }} - agent-service: - defaultAgent: - endpoint: {{ include "flyteagent.name" . }}:{{ include "flyteagent.servicePort" . }} - insecure: true - supportedTaskTypes: - - bigquery_query_job_task {{- end }} 002-database.yaml: | {{- with .Values.configuration.database }} diff --git a/charts/flyte-binary/values.yaml b/charts/flyte-binary/values.yaml index 48ae2c47dd..b8a8b58c3c 100644 --- a/charts/flyte-binary/values.yaml +++ b/charts/flyte-binary/values.yaml @@ -168,7 +168,6 @@ configuration: timeouts: GetTask: 10s defaultTimeout: 10s - # Uncomment and modify to include configuration for Flyte Agent supportedTaskTypes: - default_task # externalConfigMap Specify an existing, external ConfigMap to use as configuration for Flyte diff --git a/deployment/sandbox-binary/flyte_sandbox_binary_helm_generated.yaml b/deployment/sandbox-binary/flyte_sandbox_binary_helm_generated.yaml index 2e667f1256..2b0d197af3 100644 --- a/deployment/sandbox-binary/flyte_sandbox_binary_helm_generated.yaml +++ b/deployment/sandbox-binary/flyte_sandbox_binary_helm_generated.yaml @@ -123,15 +123,6 @@ data: kubernetes-enabled: false cloudwatch-enabled: false stackdriver-enabled: false - agent-service: - defaultAgent: - defaultTimeout: 10s - endpoint: dns:///flyteagent.flyte.svc.cluster.local:8000 - insecure: true - timeouts: - GetTask: 10s - supportedTaskTypes: - - default_task 002-database.yaml: | database: postgres: @@ -367,7 +358,7 @@ spec: app.kubernetes.io/instance: flyte app.kubernetes.io/component: flyte-binary annotations: - checksum/configuration: 51494d8c2f3a6df2711d789217155f1e1b60e782dcbfd4564bfcccda24700576 + checksum/configuration: 94a584c983cfe1077f02569ae00f81c4fddae4505901006eda76d9338bd3dda2 checksum/configuration-secret: d5d93f4e67780b21593dc3799f0f6682aab0765e708e4020939975d14d44f929 checksum/cluster-resource-templates: 7dfa59f3d447e9c099b8f8ffad3af466fecbc9cf9f8c97295d9634254a55d4ae spec: diff --git a/docker/sandbox-bundled/kustomize/complete-agent/patch.yaml b/docker/sandbox-bundled/kustomize/complete-agent/add-agent-secret-patch.yaml similarity index 100% rename from docker/sandbox-bundled/kustomize/complete-agent/patch.yaml rename to docker/sandbox-bundled/kustomize/complete-agent/add-agent-secret-patch.yaml diff --git a/docker/sandbox-bundled/kustomize/complete-agent/kustomization.yaml b/docker/sandbox-bundled/kustomize/complete-agent/kustomization.yaml index 145388ca2f..111ae05ca8 100644 --- a/docker/sandbox-bundled/kustomize/complete-agent/kustomization.yaml +++ b/docker/sandbox-bundled/kustomize/complete-agent/kustomization.yaml @@ -4,12 +4,13 @@ helmCharts: - name: flyte-sandbox releaseName: flyte-sandbox namespace: flyte -- name: flyteagent - releaseName: flyteagent - namespace: flyte + valuesInline: + flyte-binary: + flyteagent: + enabled: True namespace: flyte resources: - ../namespace.yaml patchesStrategicMerge: - - patch.yaml + - add-agent-secret-patch.yaml diff --git a/docker/sandbox-bundled/manifests/complete-agent.yaml b/docker/sandbox-bundled/manifests/complete-agent.yaml index 4380b96277..c2843ad5d3 100644 --- a/docker/sandbox-bundled/manifests/complete-agent.yaml +++ b/docker/sandbox-bundled/manifests/complete-agent.yaml @@ -45,7 +45,7 @@ apiVersion: v1 kind: ServiceAccount metadata: labels: - app.kubernetes.io/instance: flyteagent + app.kubernetes.io/instance: flyte-sandbox app.kubernetes.io/managed-by: Helm app.kubernetes.io/name: flyteagent helm.sh/chart: flyteagent-v0.1.10 @@ -816,7 +816,7 @@ type: Opaque --- apiVersion: v1 data: - haSharedSecret: ZnNFaHlpM01FZjRaQmNJSA== + haSharedSecret: cHNOS0lPZmw0andDczdaaA== proxyPassword: "" proxyUsername: "" kind: Secret @@ -1125,7 +1125,7 @@ metadata: annotations: projectcontour.io/upstream-protocol.h2c: grpc labels: - app.kubernetes.io/instance: flyteagent + app.kubernetes.io/instance: flyte-sandbox app.kubernetes.io/managed-by: Helm app.kubernetes.io/name: flyteagent helm.sh/chart: flyteagent-v0.1.10 @@ -1138,7 +1138,7 @@ spec: protocol: TCP targetPort: agent-grpc selector: - app.kubernetes.io/instance: flyteagent + app.kubernetes.io/instance: flyte-sandbox app.kubernetes.io/name: flyteagent type: ClusterIP --- @@ -1411,7 +1411,7 @@ spec: metadata: annotations: checksum/config: 8f50e768255a87f078ba8b9879a0c174c3e045ffb46ac8723d2eedbe293c8d81 - checksum/secret: 727daf2e5024ea4e541b87b717e6f9a8706552e0ae461f82b2e5260ad564766c + checksum/secret: ce47bbc1f3ca2d8673128f8efd226bd9c7ac4f32a6ded68e54e2ebb3a843065b labels: app: docker-registry release: flyte-sandbox @@ -1722,7 +1722,7 @@ apiVersion: apps/v1 kind: Deployment metadata: labels: - app.kubernetes.io/instance: flyteagent + app.kubernetes.io/instance: flyte-sandbox app.kubernetes.io/managed-by: Helm app.kubernetes.io/name: flyteagent helm.sh/chart: flyteagent-v0.1.10 @@ -1732,12 +1732,12 @@ spec: replicas: 1 selector: matchLabels: - app.kubernetes.io/instance: flyteagent + app.kubernetes.io/instance: flyte-sandbox app.kubernetes.io/name: flyteagent template: metadata: labels: - app.kubernetes.io/instance: flyteagent + app.kubernetes.io/instance: flyte-sandbox app.kubernetes.io/managed-by: Helm app.kubernetes.io/name: flyteagent helm.sh/chart: flyteagent-v0.1.10 diff --git a/docker/sandbox-bundled/manifests/complete.yaml b/docker/sandbox-bundled/manifests/complete.yaml index 2b5b9d3168..c2d507b0f2 100644 --- a/docker/sandbox-bundled/manifests/complete.yaml +++ b/docker/sandbox-bundled/manifests/complete.yaml @@ -465,15 +465,6 @@ data: kubernetes-template-uri: http://localhost:30080/kubernetes-dashboard/#/log/{{.namespace }}/{{ .podName }}/pod?namespace={{ .namespace }} cloudwatch-enabled: false stackdriver-enabled: false - agent-service: - defaultAgent: - defaultTimeout: 10s - endpoint: dns:///flyteagent.flyte.svc.cluster.local:8000 - insecure: true - timeouts: - GetTask: 10s - supportedTaskTypes: - - default_task 002-database.yaml: | database: postgres: @@ -805,7 +796,7 @@ type: Opaque --- apiVersion: v1 data: - haSharedSecret: UlI4aW9PaVFzcFpyRzhkTA== + haSharedSecret: RjR3Qnc0dWtGbHE3S3pnbA== proxyPassword: "" proxyUsername: "" kind: Secret @@ -1203,7 +1194,7 @@ spec: metadata: annotations: checksum/cluster-resource-templates: 6fd9b172465e3089fcc59f738b92b8dc4d8939360c19de8ee65f68b0e7422035 - checksum/configuration: 6755bdc74789d7e2a80161a9f811e41ea3c0cf12bab5cb0820c7c8539b4b88fe + checksum/configuration: e2233c2adb914be363ec4fae808ed60ffb230367503f73643f011e728b853b49 checksum/configuration-secret: 09216ffaa3d29e14f88b1f30af580d02a2a5e014de4d750b7f275cc07ed4e914 labels: app.kubernetes.io/component: flyte-binary @@ -1368,7 +1359,7 @@ spec: metadata: annotations: checksum/config: 8f50e768255a87f078ba8b9879a0c174c3e045ffb46ac8723d2eedbe293c8d81 - checksum/secret: cb0b9e32c83fba67eefca5b8cd0a3375b07f5d5d29f6dab9a092f91ccf7bd200 + checksum/secret: d027248867ca693de77339af17e89c22e7ad604b7abe616e40ca947ad0626a83 labels: app: docker-registry release: flyte-sandbox diff --git a/docker/sandbox-bundled/manifests/dev.yaml b/docker/sandbox-bundled/manifests/dev.yaml index b934b7e602..5061057ee9 100644 --- a/docker/sandbox-bundled/manifests/dev.yaml +++ b/docker/sandbox-bundled/manifests/dev.yaml @@ -499,7 +499,7 @@ metadata: --- apiVersion: v1 data: - haSharedSecret: QzZJWkZlOTBQOUZxTUlvcA== + haSharedSecret: RWxBOE5BV0lIeEJ2d1c3ZA== proxyPassword: "" proxyUsername: "" kind: Secret @@ -933,7 +933,7 @@ spec: metadata: annotations: checksum/config: 8f50e768255a87f078ba8b9879a0c174c3e045ffb46ac8723d2eedbe293c8d81 - checksum/secret: dd543013ea0e17fb3c9b7be54fe7c6063e8f15ad6e0887596011ddd7f22f1540 + checksum/secret: a2181c7387731100215f7ae94400f7330557b063f01f807d5aa2f333f266126e labels: app: docker-registry release: flyte-sandbox diff --git a/flyteidl/clients/go/admin/mocks/AgentMetadataServiceClient.go b/flyteidl/clients/go/admin/mocks/AgentMetadataServiceClient.go new file mode 100644 index 0000000000..d7f40932b7 --- /dev/null +++ b/flyteidl/clients/go/admin/mocks/AgentMetadataServiceClient.go @@ -0,0 +1,114 @@ +// Code generated by mockery v1.0.1. DO NOT EDIT. + +package mocks + +import ( + context "context" + + admin "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin" + + grpc "google.golang.org/grpc" + + mock "github.com/stretchr/testify/mock" +) + +// AgentMetadataServiceClient is an autogenerated mock type for the AgentMetadataServiceClient type +type AgentMetadataServiceClient struct { + mock.Mock +} + +type AgentMetadataServiceClient_GetAgent struct { + *mock.Call +} + +func (_m AgentMetadataServiceClient_GetAgent) Return(_a0 *admin.GetAgentResponse, _a1 error) *AgentMetadataServiceClient_GetAgent { + return &AgentMetadataServiceClient_GetAgent{Call: _m.Call.Return(_a0, _a1)} +} + +func (_m *AgentMetadataServiceClient) OnGetAgent(ctx context.Context, in *admin.GetAgentRequest, opts ...grpc.CallOption) *AgentMetadataServiceClient_GetAgent { + c_call := _m.On("GetAgent", ctx, in, opts) + return &AgentMetadataServiceClient_GetAgent{Call: c_call} +} + +func (_m *AgentMetadataServiceClient) OnGetAgentMatch(matchers ...interface{}) *AgentMetadataServiceClient_GetAgent { + c_call := _m.On("GetAgent", matchers...) + return &AgentMetadataServiceClient_GetAgent{Call: c_call} +} + +// GetAgent provides a mock function with given fields: ctx, in, opts +func (_m *AgentMetadataServiceClient) GetAgent(ctx context.Context, in *admin.GetAgentRequest, opts ...grpc.CallOption) (*admin.GetAgentResponse, error) { + _va := make([]interface{}, len(opts)) + for _i := range opts { + _va[_i] = opts[_i] + } + var _ca []interface{} + _ca = append(_ca, ctx, in) + _ca = append(_ca, _va...) + ret := _m.Called(_ca...) + + var r0 *admin.GetAgentResponse + if rf, ok := ret.Get(0).(func(context.Context, *admin.GetAgentRequest, ...grpc.CallOption) *admin.GetAgentResponse); ok { + r0 = rf(ctx, in, opts...) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*admin.GetAgentResponse) + } + } + + var r1 error + if rf, ok := ret.Get(1).(func(context.Context, *admin.GetAgentRequest, ...grpc.CallOption) error); ok { + r1 = rf(ctx, in, opts...) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + +type AgentMetadataServiceClient_ListAgents struct { + *mock.Call +} + +func (_m AgentMetadataServiceClient_ListAgents) Return(_a0 *admin.ListAgentsResponse, _a1 error) *AgentMetadataServiceClient_ListAgents { + return &AgentMetadataServiceClient_ListAgents{Call: _m.Call.Return(_a0, _a1)} +} + +func (_m *AgentMetadataServiceClient) OnListAgents(ctx context.Context, in *admin.ListAgentsRequest, opts ...grpc.CallOption) *AgentMetadataServiceClient_ListAgents { + c_call := _m.On("ListAgents", ctx, in, opts) + return &AgentMetadataServiceClient_ListAgents{Call: c_call} +} + +func (_m *AgentMetadataServiceClient) OnListAgentsMatch(matchers ...interface{}) *AgentMetadataServiceClient_ListAgents { + c_call := _m.On("ListAgents", matchers...) + return &AgentMetadataServiceClient_ListAgents{Call: c_call} +} + +// ListAgents provides a mock function with given fields: ctx, in, opts +func (_m *AgentMetadataServiceClient) ListAgents(ctx context.Context, in *admin.ListAgentsRequest, opts ...grpc.CallOption) (*admin.ListAgentsResponse, error) { + _va := make([]interface{}, len(opts)) + for _i := range opts { + _va[_i] = opts[_i] + } + var _ca []interface{} + _ca = append(_ca, ctx, in) + _ca = append(_ca, _va...) + ret := _m.Called(_ca...) + + var r0 *admin.ListAgentsResponse + if rf, ok := ret.Get(0).(func(context.Context, *admin.ListAgentsRequest, ...grpc.CallOption) *admin.ListAgentsResponse); ok { + r0 = rf(ctx, in, opts...) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*admin.ListAgentsResponse) + } + } + + var r1 error + if rf, ok := ret.Get(1).(func(context.Context, *admin.ListAgentsRequest, ...grpc.CallOption) error); ok { + r1 = rf(ctx, in, opts...) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} diff --git a/flyteidl/clients/go/admin/mocks/AgentMetadataServiceServer.go b/flyteidl/clients/go/admin/mocks/AgentMetadataServiceServer.go new file mode 100644 index 0000000000..d45a5f788d --- /dev/null +++ b/flyteidl/clients/go/admin/mocks/AgentMetadataServiceServer.go @@ -0,0 +1,98 @@ +// Code generated by mockery v1.0.1. DO NOT EDIT. + +package mocks + +import ( + context "context" + + admin "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin" + + mock "github.com/stretchr/testify/mock" +) + +// AgentMetadataServiceServer is an autogenerated mock type for the AgentMetadataServiceServer type +type AgentMetadataServiceServer struct { + mock.Mock +} + +type AgentMetadataServiceServer_GetAgent struct { + *mock.Call +} + +func (_m AgentMetadataServiceServer_GetAgent) Return(_a0 *admin.GetAgentResponse, _a1 error) *AgentMetadataServiceServer_GetAgent { + return &AgentMetadataServiceServer_GetAgent{Call: _m.Call.Return(_a0, _a1)} +} + +func (_m *AgentMetadataServiceServer) OnGetAgent(_a0 context.Context, _a1 *admin.GetAgentRequest) *AgentMetadataServiceServer_GetAgent { + c_call := _m.On("GetAgent", _a0, _a1) + return &AgentMetadataServiceServer_GetAgent{Call: c_call} +} + +func (_m *AgentMetadataServiceServer) OnGetAgentMatch(matchers ...interface{}) *AgentMetadataServiceServer_GetAgent { + c_call := _m.On("GetAgent", matchers...) + return &AgentMetadataServiceServer_GetAgent{Call: c_call} +} + +// GetAgent provides a mock function with given fields: _a0, _a1 +func (_m *AgentMetadataServiceServer) GetAgent(_a0 context.Context, _a1 *admin.GetAgentRequest) (*admin.GetAgentResponse, error) { + ret := _m.Called(_a0, _a1) + + var r0 *admin.GetAgentResponse + if rf, ok := ret.Get(0).(func(context.Context, *admin.GetAgentRequest) *admin.GetAgentResponse); ok { + r0 = rf(_a0, _a1) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*admin.GetAgentResponse) + } + } + + var r1 error + if rf, ok := ret.Get(1).(func(context.Context, *admin.GetAgentRequest) error); ok { + r1 = rf(_a0, _a1) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + +type AgentMetadataServiceServer_ListAgents struct { + *mock.Call +} + +func (_m AgentMetadataServiceServer_ListAgents) Return(_a0 *admin.ListAgentsResponse, _a1 error) *AgentMetadataServiceServer_ListAgents { + return &AgentMetadataServiceServer_ListAgents{Call: _m.Call.Return(_a0, _a1)} +} + +func (_m *AgentMetadataServiceServer) OnListAgents(_a0 context.Context, _a1 *admin.ListAgentsRequest) *AgentMetadataServiceServer_ListAgents { + c_call := _m.On("ListAgents", _a0, _a1) + return &AgentMetadataServiceServer_ListAgents{Call: c_call} +} + +func (_m *AgentMetadataServiceServer) OnListAgentsMatch(matchers ...interface{}) *AgentMetadataServiceServer_ListAgents { + c_call := _m.On("ListAgents", matchers...) + return &AgentMetadataServiceServer_ListAgents{Call: c_call} +} + +// ListAgents provides a mock function with given fields: _a0, _a1 +func (_m *AgentMetadataServiceServer) ListAgents(_a0 context.Context, _a1 *admin.ListAgentsRequest) (*admin.ListAgentsResponse, error) { + ret := _m.Called(_a0, _a1) + + var r0 *admin.ListAgentsResponse + if rf, ok := ret.Get(0).(func(context.Context, *admin.ListAgentsRequest) *admin.ListAgentsResponse); ok { + r0 = rf(_a0, _a1) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*admin.ListAgentsResponse) + } + } + + var r1 error + if rf, ok := ret.Get(1).(func(context.Context, *admin.ListAgentsRequest) error); ok { + r1 = rf(_a0, _a1) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.cc index ec842a83aa..84cb28a2fc 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.cc @@ -16,6 +16,7 @@ // @@protoc_insertion_point(includes) #include +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_Agent_flyteidl_2fadmin_2fagent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_TaskExecutionMetadata_AnnotationsEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_TaskExecutionMetadata_EnvironmentVariablesEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_TaskExecutionMetadata_LabelsEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto; @@ -71,6 +72,26 @@ class DeleteTaskResponseDefaultTypeInternal { public: ::google::protobuf::internal::ExplicitlyConstructed _instance; } _DeleteTaskResponse_default_instance_; +class AgentDefaultTypeInternal { + public: + ::google::protobuf::internal::ExplicitlyConstructed _instance; +} _Agent_default_instance_; +class GetAgentRequestDefaultTypeInternal { + public: + ::google::protobuf::internal::ExplicitlyConstructed _instance; +} _GetAgentRequest_default_instance_; +class GetAgentResponseDefaultTypeInternal { + public: + ::google::protobuf::internal::ExplicitlyConstructed _instance; +} _GetAgentResponse_default_instance_; +class ListAgentsRequestDefaultTypeInternal { + public: + ::google::protobuf::internal::ExplicitlyConstructed _instance; +} _ListAgentsRequest_default_instance_; +class ListAgentsResponseDefaultTypeInternal { + public: + ::google::protobuf::internal::ExplicitlyConstructed _instance; +} _ListAgentsResponse_default_instance_; } // namespace admin } // namespace flyteidl static void InitDefaultsTaskExecutionMetadata_LabelsEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto() { @@ -234,6 +255,78 @@ static void InitDefaultsDeleteTaskResponse_flyteidl_2fadmin_2fagent_2eproto() { ::google::protobuf::internal::SCCInfo<0> scc_info_DeleteTaskResponse_flyteidl_2fadmin_2fagent_2eproto = {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 0, InitDefaultsDeleteTaskResponse_flyteidl_2fadmin_2fagent_2eproto}, {}}; +static void InitDefaultsAgent_flyteidl_2fadmin_2fagent_2eproto() { + GOOGLE_PROTOBUF_VERIFY_VERSION; + + { + void* ptr = &::flyteidl::admin::_Agent_default_instance_; + new (ptr) ::flyteidl::admin::Agent(); + ::google::protobuf::internal::OnShutdownDestroyMessage(ptr); + } + ::flyteidl::admin::Agent::InitAsDefaultInstance(); +} + +::google::protobuf::internal::SCCInfo<0> scc_info_Agent_flyteidl_2fadmin_2fagent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 0, InitDefaultsAgent_flyteidl_2fadmin_2fagent_2eproto}, {}}; + +static void InitDefaultsGetAgentRequest_flyteidl_2fadmin_2fagent_2eproto() { + GOOGLE_PROTOBUF_VERIFY_VERSION; + + { + void* ptr = &::flyteidl::admin::_GetAgentRequest_default_instance_; + new (ptr) ::flyteidl::admin::GetAgentRequest(); + ::google::protobuf::internal::OnShutdownDestroyMessage(ptr); + } + ::flyteidl::admin::GetAgentRequest::InitAsDefaultInstance(); +} + +::google::protobuf::internal::SCCInfo<0> scc_info_GetAgentRequest_flyteidl_2fadmin_2fagent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 0, InitDefaultsGetAgentRequest_flyteidl_2fadmin_2fagent_2eproto}, {}}; + +static void InitDefaultsGetAgentResponse_flyteidl_2fadmin_2fagent_2eproto() { + GOOGLE_PROTOBUF_VERIFY_VERSION; + + { + void* ptr = &::flyteidl::admin::_GetAgentResponse_default_instance_; + new (ptr) ::flyteidl::admin::GetAgentResponse(); + ::google::protobuf::internal::OnShutdownDestroyMessage(ptr); + } + ::flyteidl::admin::GetAgentResponse::InitAsDefaultInstance(); +} + +::google::protobuf::internal::SCCInfo<1> scc_info_GetAgentResponse_flyteidl_2fadmin_2fagent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsGetAgentResponse_flyteidl_2fadmin_2fagent_2eproto}, { + &scc_info_Agent_flyteidl_2fadmin_2fagent_2eproto.base,}}; + +static void InitDefaultsListAgentsRequest_flyteidl_2fadmin_2fagent_2eproto() { + GOOGLE_PROTOBUF_VERIFY_VERSION; + + { + void* ptr = &::flyteidl::admin::_ListAgentsRequest_default_instance_; + new (ptr) ::flyteidl::admin::ListAgentsRequest(); + ::google::protobuf::internal::OnShutdownDestroyMessage(ptr); + } + ::flyteidl::admin::ListAgentsRequest::InitAsDefaultInstance(); +} + +::google::protobuf::internal::SCCInfo<0> scc_info_ListAgentsRequest_flyteidl_2fadmin_2fagent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 0, InitDefaultsListAgentsRequest_flyteidl_2fadmin_2fagent_2eproto}, {}}; + +static void InitDefaultsListAgentsResponse_flyteidl_2fadmin_2fagent_2eproto() { + GOOGLE_PROTOBUF_VERIFY_VERSION; + + { + void* ptr = &::flyteidl::admin::_ListAgentsResponse_default_instance_; + new (ptr) ::flyteidl::admin::ListAgentsResponse(); + ::google::protobuf::internal::OnShutdownDestroyMessage(ptr); + } + ::flyteidl::admin::ListAgentsResponse::InitAsDefaultInstance(); +} + +::google::protobuf::internal::SCCInfo<1> scc_info_ListAgentsResponse_flyteidl_2fadmin_2fagent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsListAgentsResponse_flyteidl_2fadmin_2fagent_2eproto}, { + &scc_info_Agent_flyteidl_2fadmin_2fagent_2eproto.base,}}; + void InitDefaults_flyteidl_2fadmin_2fagent_2eproto() { ::google::protobuf::internal::InitSCC(&scc_info_TaskExecutionMetadata_LabelsEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_TaskExecutionMetadata_AnnotationsEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto.base); @@ -246,9 +339,14 @@ void InitDefaults_flyteidl_2fadmin_2fagent_2eproto() { ::google::protobuf::internal::InitSCC(&scc_info_Resource_flyteidl_2fadmin_2fagent_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_DeleteTaskRequest_flyteidl_2fadmin_2fagent_2eproto.base); ::google::protobuf::internal::InitSCC(&scc_info_DeleteTaskResponse_flyteidl_2fadmin_2fagent_2eproto.base); + ::google::protobuf::internal::InitSCC(&scc_info_Agent_flyteidl_2fadmin_2fagent_2eproto.base); + ::google::protobuf::internal::InitSCC(&scc_info_GetAgentRequest_flyteidl_2fadmin_2fagent_2eproto.base); + ::google::protobuf::internal::InitSCC(&scc_info_GetAgentResponse_flyteidl_2fadmin_2fagent_2eproto.base); + ::google::protobuf::internal::InitSCC(&scc_info_ListAgentsRequest_flyteidl_2fadmin_2fagent_2eproto.base); + ::google::protobuf::internal::InitSCC(&scc_info_ListAgentsResponse_flyteidl_2fadmin_2fagent_2eproto.base); } -::google::protobuf::Metadata file_level_metadata_flyteidl_2fadmin_2fagent_2eproto[11]; +::google::protobuf::Metadata file_level_metadata_flyteidl_2fadmin_2fagent_2eproto[16]; const ::google::protobuf::EnumDescriptor* file_level_enum_descriptors_flyteidl_2fadmin_2fagent_2eproto[1]; constexpr ::google::protobuf::ServiceDescriptor const** file_level_service_descriptors_flyteidl_2fadmin_2fagent_2eproto = nullptr; @@ -340,6 +438,36 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2fagent_2eproto::o ~0u, // no _extensions_ ~0u, // no _oneof_case_ ~0u, // no _weak_field_map_ + ~0u, // no _has_bits_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::Agent, _internal_metadata_), + ~0u, // no _extensions_ + ~0u, // no _oneof_case_ + ~0u, // no _weak_field_map_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::Agent, name_), + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::Agent, supported_task_types_), + ~0u, // no _has_bits_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::GetAgentRequest, _internal_metadata_), + ~0u, // no _extensions_ + ~0u, // no _oneof_case_ + ~0u, // no _weak_field_map_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::GetAgentRequest, name_), + ~0u, // no _has_bits_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::GetAgentResponse, _internal_metadata_), + ~0u, // no _extensions_ + ~0u, // no _oneof_case_ + ~0u, // no _weak_field_map_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::GetAgentResponse, agent_), + ~0u, // no _has_bits_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ListAgentsRequest, _internal_metadata_), + ~0u, // no _extensions_ + ~0u, // no _oneof_case_ + ~0u, // no _weak_field_map_ + ~0u, // no _has_bits_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ListAgentsResponse, _internal_metadata_), + ~0u, // no _extensions_ + ~0u, // no _oneof_case_ + ~0u, // no _weak_field_map_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::ListAgentsResponse, agents_), }; static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SECTION_VARIABLE(protodesc_cold) = { { 0, 7, sizeof(::flyteidl::admin::TaskExecutionMetadata_LabelsEntry_DoNotUse)}, @@ -353,6 +481,11 @@ static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SE { 67, -1, sizeof(::flyteidl::admin::Resource)}, { 75, -1, sizeof(::flyteidl::admin::DeleteTaskRequest)}, { 82, -1, sizeof(::flyteidl::admin::DeleteTaskResponse)}, + { 87, -1, sizeof(::flyteidl::admin::Agent)}, + { 94, -1, sizeof(::flyteidl::admin::GetAgentRequest)}, + { 100, -1, sizeof(::flyteidl::admin::GetAgentResponse)}, + { 106, -1, sizeof(::flyteidl::admin::ListAgentsRequest)}, + { 111, -1, sizeof(::flyteidl::admin::ListAgentsResponse)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -367,12 +500,17 @@ static ::google::protobuf::Message const * const file_default_instances[] = { reinterpret_cast(&::flyteidl::admin::_Resource_default_instance_), reinterpret_cast(&::flyteidl::admin::_DeleteTaskRequest_default_instance_), reinterpret_cast(&::flyteidl::admin::_DeleteTaskResponse_default_instance_), + reinterpret_cast(&::flyteidl::admin::_Agent_default_instance_), + reinterpret_cast(&::flyteidl::admin::_GetAgentRequest_default_instance_), + reinterpret_cast(&::flyteidl::admin::_GetAgentResponse_default_instance_), + reinterpret_cast(&::flyteidl::admin::_ListAgentsRequest_default_instance_), + reinterpret_cast(&::flyteidl::admin::_ListAgentsResponse_default_instance_), }; ::google::protobuf::internal::AssignDescriptorsTable assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto = { {}, AddDescriptors_flyteidl_2fadmin_2fagent_2eproto, "flyteidl/admin/agent.proto", schemas, file_default_instances, TableStruct_flyteidl_2fadmin_2fagent_2eproto::offsets, - file_level_metadata_flyteidl_2fadmin_2fagent_2eproto, 11, file_level_enum_descriptors_flyteidl_2fadmin_2fagent_2eproto, file_level_service_descriptors_flyteidl_2fadmin_2fagent_2eproto, + file_level_metadata_flyteidl_2fadmin_2fagent_2eproto, 16, file_level_enum_descriptors_flyteidl_2fadmin_2fagent_2eproto, file_level_service_descriptors_flyteidl_2fadmin_2fagent_2eproto, }; const char descriptor_table_protodef_flyteidl_2fadmin_2fagent_2eproto[] = @@ -409,16 +547,22 @@ const char descriptor_table_protodef_flyteidl_2fadmin_2fagent_2eproto[] = "tate\022*\n\007outputs\030\002 \001(\0132\031.flyteidl.core.Li" "teralMap\022\017\n\007message\030\003 \001(\t\"=\n\021DeleteTaskR" "equest\022\021\n\ttask_type\030\001 \001(\t\022\025\n\rresource_me" - "ta\030\002 \001(\014\"\024\n\022DeleteTaskResponse*^\n\005State\022" - "\025\n\021RETRYABLE_FAILURE\020\000\022\025\n\021PERMANENT_FAIL" - "URE\020\001\022\013\n\007PENDING\020\002\022\013\n\007RUNNING\020\003\022\r\n\tSUCCE" - "EDED\020\004B=Z;github.com/flyteorg/flyte/flyt" - "eidl/gen/pb-go/flyteidl/adminb\006proto3" + "ta\030\002 \001(\014\"\024\n\022DeleteTaskResponse\"3\n\005Agent\022" + "\014\n\004name\030\001 \001(\t\022\034\n\024supported_task_types\030\002 " + "\003(\t\"\037\n\017GetAgentRequest\022\014\n\004name\030\001 \001(\t\"8\n\020" + "GetAgentResponse\022$\n\005agent\030\001 \001(\0132\025.flytei" + "dl.admin.Agent\"\023\n\021ListAgentsRequest\";\n\022L" + "istAgentsResponse\022%\n\006agents\030\001 \003(\0132\025.flyt" + "eidl.admin.Agent*^\n\005State\022\025\n\021RETRYABLE_F" + "AILURE\020\000\022\025\n\021PERMANENT_FAILURE\020\001\022\013\n\007PENDI" + "NG\020\002\022\013\n\007RUNNING\020\003\022\r\n\tSUCCEEDED\020\004B=Z;gith" + "ub.com/flyteorg/flyte/flyteidl/gen/pb-go" + "/flyteidl/adminb\006proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fadmin_2fagent_2eproto = { false, InitDefaults_flyteidl_2fadmin_2fagent_2eproto, descriptor_table_protodef_flyteidl_2fadmin_2fagent_2eproto, - "flyteidl/admin/agent.proto", &assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto, 1517, + "flyteidl/admin/agent.proto", &assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto, 1743, }; void AddDescriptors_flyteidl_2fadmin_2fagent_2eproto() { @@ -3993,43 +4137,1496 @@ ::google::protobuf::Metadata DeleteTaskResponse::GetMetadata() const { } -// @@protoc_insertion_point(namespace_scope) -} // namespace admin -} // namespace flyteidl -namespace google { -namespace protobuf { -template<> PROTOBUF_NOINLINE ::flyteidl::admin::TaskExecutionMetadata_LabelsEntry_DoNotUse* Arena::CreateMaybeMessage< ::flyteidl::admin::TaskExecutionMetadata_LabelsEntry_DoNotUse >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::TaskExecutionMetadata_LabelsEntry_DoNotUse >(arena); +// =================================================================== + +void Agent::InitAsDefaultInstance() { } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::TaskExecutionMetadata_AnnotationsEntry_DoNotUse* Arena::CreateMaybeMessage< ::flyteidl::admin::TaskExecutionMetadata_AnnotationsEntry_DoNotUse >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::TaskExecutionMetadata_AnnotationsEntry_DoNotUse >(arena); +class Agent::HasBitSetters { + public: +}; + +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +const int Agent::kNameFieldNumber; +const int Agent::kSupportedTaskTypesFieldNumber; +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 + +Agent::Agent() + : ::google::protobuf::Message(), _internal_metadata_(nullptr) { + SharedCtor(); + // @@protoc_insertion_point(constructor:flyteidl.admin.Agent) } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::TaskExecutionMetadata_EnvironmentVariablesEntry_DoNotUse* Arena::CreateMaybeMessage< ::flyteidl::admin::TaskExecutionMetadata_EnvironmentVariablesEntry_DoNotUse >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::TaskExecutionMetadata_EnvironmentVariablesEntry_DoNotUse >(arena); +Agent::Agent(const Agent& from) + : ::google::protobuf::Message(), + _internal_metadata_(nullptr), + supported_task_types_(from.supported_task_types_) { + _internal_metadata_.MergeFrom(from._internal_metadata_); + name_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.name().size() > 0) { + name_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.name_); + } + // @@protoc_insertion_point(copy_constructor:flyteidl.admin.Agent) } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::TaskExecutionMetadata* Arena::CreateMaybeMessage< ::flyteidl::admin::TaskExecutionMetadata >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::TaskExecutionMetadata >(arena); + +void Agent::SharedCtor() { + ::google::protobuf::internal::InitSCC( + &scc_info_Agent_flyteidl_2fadmin_2fagent_2eproto.base); + name_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::CreateTaskRequest* Arena::CreateMaybeMessage< ::flyteidl::admin::CreateTaskRequest >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::CreateTaskRequest >(arena); + +Agent::~Agent() { + // @@protoc_insertion_point(destructor:flyteidl.admin.Agent) + SharedDtor(); } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::CreateTaskResponse* Arena::CreateMaybeMessage< ::flyteidl::admin::CreateTaskResponse >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::CreateTaskResponse >(arena); + +void Agent::SharedDtor() { + name_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::GetTaskRequest* Arena::CreateMaybeMessage< ::flyteidl::admin::GetTaskRequest >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::GetTaskRequest >(arena); + +void Agent::SetCachedSize(int size) const { + _cached_size_.Set(size); } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::GetTaskResponse* Arena::CreateMaybeMessage< ::flyteidl::admin::GetTaskResponse >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::GetTaskResponse >(arena); +const Agent& Agent::default_instance() { + ::google::protobuf::internal::InitSCC(&::scc_info_Agent_flyteidl_2fadmin_2fagent_2eproto.base); + return *internal_default_instance(); } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::Resource* Arena::CreateMaybeMessage< ::flyteidl::admin::Resource >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::Resource >(arena); + + +void Agent::Clear() { +// @@protoc_insertion_point(message_clear_start:flyteidl.admin.Agent) + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + supported_task_types_.Clear(); + name_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + _internal_metadata_.Clear(); } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::DeleteTaskRequest* Arena::CreateMaybeMessage< ::flyteidl::admin::DeleteTaskRequest >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::DeleteTaskRequest >(arena); + +#if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +const char* Agent::_InternalParse(const char* begin, const char* end, void* object, + ::google::protobuf::internal::ParseContext* ctx) { + auto msg = static_cast(object); + ::google::protobuf::int32 size; (void)size; + int depth; (void)depth; + ::google::protobuf::uint32 tag; + ::google::protobuf::internal::ParseFunc parser_till_end; (void)parser_till_end; + auto ptr = begin; + while (ptr < end) { + ptr = ::google::protobuf::io::Parse32(ptr, &tag); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + switch (tag >> 3) { + // string name = 1; + case 1: { + if (static_cast<::google::protobuf::uint8>(tag) != 10) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.admin.Agent.name"); + object = msg->mutable_name(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } + // repeated string supported_task_types = 2; + case 2: { + if (static_cast<::google::protobuf::uint8>(tag) != 18) goto handle_unusual; + do { + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.admin.Agent.supported_task_types"); + object = msg->add_supported_task_types(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + if (ptr >= end) break; + } while ((::google::protobuf::io::UnalignedLoad<::google::protobuf::uint64>(ptr) & 255) == 18 && (ptr += 1)); + break; + } + default: { + handle_unusual: + if ((tag & 7) == 4 || tag == 0) { + ctx->EndGroup(tag); + return ptr; + } + auto res = UnknownFieldParse(tag, {_InternalParse, msg}, + ptr, end, msg->_internal_metadata_.mutable_unknown_fields(), ctx); + ptr = res.first; + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr != nullptr); + if (res.second) return ptr; + } + } // switch + } // while + return ptr; +string_till_end: + static_cast<::std::string*>(object)->clear(); + static_cast<::std::string*>(object)->reserve(size); + goto len_delim_till_end; +len_delim_till_end: + return ctx->StoreAndTailCall(ptr, end, {_InternalParse, msg}, + {parser_till_end, object}, size); } -template<> PROTOBUF_NOINLINE ::flyteidl::admin::DeleteTaskResponse* Arena::CreateMaybeMessage< ::flyteidl::admin::DeleteTaskResponse >(Arena* arena) { - return Arena::CreateInternal< ::flyteidl::admin::DeleteTaskResponse >(arena); +#else // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +bool Agent::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.admin.Agent) + for (;;) { + ::std::pair<::google::protobuf::uint32, bool> p = input->ReadTagWithCutoffNoLastTag(127u); + tag = p.first; + if (!p.second) goto handle_unusual; + switch (::google::protobuf::internal::WireFormatLite::GetTagFieldNumber(tag)) { + // string name = 1; + case 1: { + if (static_cast< ::google::protobuf::uint8>(tag) == (10 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_name())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->name().data(), static_cast(this->name().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.admin.Agent.name")); + } else { + goto handle_unusual; + } + break; + } + + // repeated string supported_task_types = 2; + case 2: { + if (static_cast< ::google::protobuf::uint8>(tag) == (18 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->add_supported_task_types())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->supported_task_types(this->supported_task_types_size() - 1).data(), + static_cast(this->supported_task_types(this->supported_task_types_size() - 1).length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.admin.Agent.supported_task_types")); + } 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.admin.Agent) + return true; +failure: + // @@protoc_insertion_point(parse_failure:flyteidl.admin.Agent) + return false; +#undef DO_ +} +#endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + +void Agent::SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const { + // @@protoc_insertion_point(serialize_start:flyteidl.admin.Agent) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // string name = 1; + if (this->name().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->name().data(), static_cast(this->name().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.Agent.name"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 1, this->name(), output); + } + + // repeated string supported_task_types = 2; + for (int i = 0, n = this->supported_task_types_size(); i < n; i++) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->supported_task_types(i).data(), static_cast(this->supported_task_types(i).length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.Agent.supported_task_types"); + ::google::protobuf::internal::WireFormatLite::WriteString( + 2, this->supported_task_types(i), output); + } + + if (_internal_metadata_.have_unknown_fields()) { + ::google::protobuf::internal::WireFormat::SerializeUnknownFields( + _internal_metadata_.unknown_fields(), output); + } + // @@protoc_insertion_point(serialize_end:flyteidl.admin.Agent) +} + +::google::protobuf::uint8* Agent::InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const { + // @@protoc_insertion_point(serialize_to_array_start:flyteidl.admin.Agent) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // string name = 1; + if (this->name().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->name().data(), static_cast(this->name().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.Agent.name"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 1, this->name(), target); + } + + // repeated string supported_task_types = 2; + for (int i = 0, n = this->supported_task_types_size(); i < n; i++) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->supported_task_types(i).data(), static_cast(this->supported_task_types(i).length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.Agent.supported_task_types"); + target = ::google::protobuf::internal::WireFormatLite:: + WriteStringToArray(2, this->supported_task_types(i), 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.admin.Agent) + return target; +} + +size_t Agent::ByteSizeLong() const { +// @@protoc_insertion_point(message_byte_size_start:flyteidl.admin.Agent) + 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; + + // repeated string supported_task_types = 2; + total_size += 1 * + ::google::protobuf::internal::FromIntSize(this->supported_task_types_size()); + for (int i = 0, n = this->supported_task_types_size(); i < n; i++) { + total_size += ::google::protobuf::internal::WireFormatLite::StringSize( + this->supported_task_types(i)); + } + + // string name = 1; + if (this->name().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->name()); + } + + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); + SetCachedSize(cached_size); + return total_size; +} + +void Agent::MergeFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_merge_from_start:flyteidl.admin.Agent) + GOOGLE_DCHECK_NE(&from, this); + const Agent* source = + ::google::protobuf::DynamicCastToGenerated( + &from); + if (source == nullptr) { + // @@protoc_insertion_point(generalized_merge_from_cast_fail:flyteidl.admin.Agent) + ::google::protobuf::internal::ReflectionOps::Merge(from, this); + } else { + // @@protoc_insertion_point(generalized_merge_from_cast_success:flyteidl.admin.Agent) + MergeFrom(*source); + } +} + +void Agent::MergeFrom(const Agent& from) { +// @@protoc_insertion_point(class_specific_merge_from_start:flyteidl.admin.Agent) + GOOGLE_DCHECK_NE(&from, this); + _internal_metadata_.MergeFrom(from._internal_metadata_); + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + supported_task_types_.MergeFrom(from.supported_task_types_); + if (from.name().size() > 0) { + + name_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.name_); + } +} + +void Agent::CopyFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_copy_from_start:flyteidl.admin.Agent) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +void Agent::CopyFrom(const Agent& from) { +// @@protoc_insertion_point(class_specific_copy_from_start:flyteidl.admin.Agent) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +bool Agent::IsInitialized() const { + return true; +} + +void Agent::Swap(Agent* other) { + if (other == this) return; + InternalSwap(other); +} +void Agent::InternalSwap(Agent* other) { + using std::swap; + _internal_metadata_.Swap(&other->_internal_metadata_); + supported_task_types_.InternalSwap(CastToBase(&other->supported_task_types_)); + name_.Swap(&other->name_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); +} + +::google::protobuf::Metadata Agent::GetMetadata() const { + ::google::protobuf::internal::AssignDescriptors(&::assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto); + return ::file_level_metadata_flyteidl_2fadmin_2fagent_2eproto[kIndexInFileMessages]; +} + + +// =================================================================== + +void GetAgentRequest::InitAsDefaultInstance() { +} +class GetAgentRequest::HasBitSetters { + public: +}; + +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +const int GetAgentRequest::kNameFieldNumber; +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 + +GetAgentRequest::GetAgentRequest() + : ::google::protobuf::Message(), _internal_metadata_(nullptr) { + SharedCtor(); + // @@protoc_insertion_point(constructor:flyteidl.admin.GetAgentRequest) +} +GetAgentRequest::GetAgentRequest(const GetAgentRequest& from) + : ::google::protobuf::Message(), + _internal_metadata_(nullptr) { + _internal_metadata_.MergeFrom(from._internal_metadata_); + name_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (from.name().size() > 0) { + name_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.name_); + } + // @@protoc_insertion_point(copy_constructor:flyteidl.admin.GetAgentRequest) +} + +void GetAgentRequest::SharedCtor() { + ::google::protobuf::internal::InitSCC( + &scc_info_GetAgentRequest_flyteidl_2fadmin_2fagent_2eproto.base); + name_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} + +GetAgentRequest::~GetAgentRequest() { + // @@protoc_insertion_point(destructor:flyteidl.admin.GetAgentRequest) + SharedDtor(); +} + +void GetAgentRequest::SharedDtor() { + name_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} + +void GetAgentRequest::SetCachedSize(int size) const { + _cached_size_.Set(size); +} +const GetAgentRequest& GetAgentRequest::default_instance() { + ::google::protobuf::internal::InitSCC(&::scc_info_GetAgentRequest_flyteidl_2fadmin_2fagent_2eproto.base); + return *internal_default_instance(); +} + + +void GetAgentRequest::Clear() { +// @@protoc_insertion_point(message_clear_start:flyteidl.admin.GetAgentRequest) + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + name_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + _internal_metadata_.Clear(); +} + +#if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +const char* GetAgentRequest::_InternalParse(const char* begin, const char* end, void* object, + ::google::protobuf::internal::ParseContext* ctx) { + auto msg = static_cast(object); + ::google::protobuf::int32 size; (void)size; + int depth; (void)depth; + ::google::protobuf::uint32 tag; + ::google::protobuf::internal::ParseFunc parser_till_end; (void)parser_till_end; + auto ptr = begin; + while (ptr < end) { + ptr = ::google::protobuf::io::Parse32(ptr, &tag); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + switch (tag >> 3) { + // string name = 1; + case 1: { + if (static_cast<::google::protobuf::uint8>(tag) != 10) goto handle_unusual; + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + ctx->extra_parse_data().SetFieldName("flyteidl.admin.GetAgentRequest.name"); + object = msg->mutable_name(); + if (size > end - ptr + ::google::protobuf::internal::ParseContext::kSlopBytes) { + parser_till_end = ::google::protobuf::internal::GreedyStringParserUTF8; + goto string_till_end; + } + GOOGLE_PROTOBUF_PARSER_ASSERT(::google::protobuf::internal::StringCheckUTF8(ptr, size, ctx)); + ::google::protobuf::internal::InlineGreedyStringParser(object, ptr, size, ctx); + ptr += size; + break; + } + default: { + handle_unusual: + if ((tag & 7) == 4 || tag == 0) { + ctx->EndGroup(tag); + return ptr; + } + auto res = UnknownFieldParse(tag, {_InternalParse, msg}, + ptr, end, msg->_internal_metadata_.mutable_unknown_fields(), ctx); + ptr = res.first; + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr != nullptr); + if (res.second) return ptr; + } + } // switch + } // while + return ptr; +string_till_end: + static_cast<::std::string*>(object)->clear(); + static_cast<::std::string*>(object)->reserve(size); + goto len_delim_till_end; +len_delim_till_end: + return ctx->StoreAndTailCall(ptr, end, {_InternalParse, msg}, + {parser_till_end, object}, size); +} +#else // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +bool GetAgentRequest::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.admin.GetAgentRequest) + for (;;) { + ::std::pair<::google::protobuf::uint32, bool> p = input->ReadTagWithCutoffNoLastTag(127u); + tag = p.first; + if (!p.second) goto handle_unusual; + switch (::google::protobuf::internal::WireFormatLite::GetTagFieldNumber(tag)) { + // string name = 1; + case 1: { + if (static_cast< ::google::protobuf::uint8>(tag) == (10 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadString( + input, this->mutable_name())); + DO_(::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->name().data(), static_cast(this->name().length()), + ::google::protobuf::internal::WireFormatLite::PARSE, + "flyteidl.admin.GetAgentRequest.name")); + } 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.admin.GetAgentRequest) + return true; +failure: + // @@protoc_insertion_point(parse_failure:flyteidl.admin.GetAgentRequest) + return false; +#undef DO_ +} +#endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + +void GetAgentRequest::SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const { + // @@protoc_insertion_point(serialize_start:flyteidl.admin.GetAgentRequest) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // string name = 1; + if (this->name().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->name().data(), static_cast(this->name().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.GetAgentRequest.name"); + ::google::protobuf::internal::WireFormatLite::WriteStringMaybeAliased( + 1, this->name(), output); + } + + if (_internal_metadata_.have_unknown_fields()) { + ::google::protobuf::internal::WireFormat::SerializeUnknownFields( + _internal_metadata_.unknown_fields(), output); + } + // @@protoc_insertion_point(serialize_end:flyteidl.admin.GetAgentRequest) +} + +::google::protobuf::uint8* GetAgentRequest::InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const { + // @@protoc_insertion_point(serialize_to_array_start:flyteidl.admin.GetAgentRequest) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // string name = 1; + if (this->name().size() > 0) { + ::google::protobuf::internal::WireFormatLite::VerifyUtf8String( + this->name().data(), static_cast(this->name().length()), + ::google::protobuf::internal::WireFormatLite::SERIALIZE, + "flyteidl.admin.GetAgentRequest.name"); + target = + ::google::protobuf::internal::WireFormatLite::WriteStringToArray( + 1, this->name(), 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.admin.GetAgentRequest) + return target; +} + +size_t GetAgentRequest::ByteSizeLong() const { +// @@protoc_insertion_point(message_byte_size_start:flyteidl.admin.GetAgentRequest) + size_t total_size = 0; + + if (_internal_metadata_.have_unknown_fields()) { + total_size += + ::google::protobuf::internal::WireFormat::ComputeUnknownFieldsSize( + _internal_metadata_.unknown_fields()); + } + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + // string name = 1; + if (this->name().size() > 0) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::StringSize( + this->name()); + } + + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); + SetCachedSize(cached_size); + return total_size; +} + +void GetAgentRequest::MergeFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_merge_from_start:flyteidl.admin.GetAgentRequest) + GOOGLE_DCHECK_NE(&from, this); + const GetAgentRequest* source = + ::google::protobuf::DynamicCastToGenerated( + &from); + if (source == nullptr) { + // @@protoc_insertion_point(generalized_merge_from_cast_fail:flyteidl.admin.GetAgentRequest) + ::google::protobuf::internal::ReflectionOps::Merge(from, this); + } else { + // @@protoc_insertion_point(generalized_merge_from_cast_success:flyteidl.admin.GetAgentRequest) + MergeFrom(*source); + } +} + +void GetAgentRequest::MergeFrom(const GetAgentRequest& from) { +// @@protoc_insertion_point(class_specific_merge_from_start:flyteidl.admin.GetAgentRequest) + GOOGLE_DCHECK_NE(&from, this); + _internal_metadata_.MergeFrom(from._internal_metadata_); + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + if (from.name().size() > 0) { + + name_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.name_); + } +} + +void GetAgentRequest::CopyFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_copy_from_start:flyteidl.admin.GetAgentRequest) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +void GetAgentRequest::CopyFrom(const GetAgentRequest& from) { +// @@protoc_insertion_point(class_specific_copy_from_start:flyteidl.admin.GetAgentRequest) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +bool GetAgentRequest::IsInitialized() const { + return true; +} + +void GetAgentRequest::Swap(GetAgentRequest* other) { + if (other == this) return; + InternalSwap(other); +} +void GetAgentRequest::InternalSwap(GetAgentRequest* other) { + using std::swap; + _internal_metadata_.Swap(&other->_internal_metadata_); + name_.Swap(&other->name_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), + GetArenaNoVirtual()); +} + +::google::protobuf::Metadata GetAgentRequest::GetMetadata() const { + ::google::protobuf::internal::AssignDescriptors(&::assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto); + return ::file_level_metadata_flyteidl_2fadmin_2fagent_2eproto[kIndexInFileMessages]; +} + + +// =================================================================== + +void GetAgentResponse::InitAsDefaultInstance() { + ::flyteidl::admin::_GetAgentResponse_default_instance_._instance.get_mutable()->agent_ = const_cast< ::flyteidl::admin::Agent*>( + ::flyteidl::admin::Agent::internal_default_instance()); +} +class GetAgentResponse::HasBitSetters { + public: + static const ::flyteidl::admin::Agent& agent(const GetAgentResponse* msg); +}; + +const ::flyteidl::admin::Agent& +GetAgentResponse::HasBitSetters::agent(const GetAgentResponse* msg) { + return *msg->agent_; +} +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +const int GetAgentResponse::kAgentFieldNumber; +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 + +GetAgentResponse::GetAgentResponse() + : ::google::protobuf::Message(), _internal_metadata_(nullptr) { + SharedCtor(); + // @@protoc_insertion_point(constructor:flyteidl.admin.GetAgentResponse) +} +GetAgentResponse::GetAgentResponse(const GetAgentResponse& from) + : ::google::protobuf::Message(), + _internal_metadata_(nullptr) { + _internal_metadata_.MergeFrom(from._internal_metadata_); + if (from.has_agent()) { + agent_ = new ::flyteidl::admin::Agent(*from.agent_); + } else { + agent_ = nullptr; + } + // @@protoc_insertion_point(copy_constructor:flyteidl.admin.GetAgentResponse) +} + +void GetAgentResponse::SharedCtor() { + ::google::protobuf::internal::InitSCC( + &scc_info_GetAgentResponse_flyteidl_2fadmin_2fagent_2eproto.base); + agent_ = nullptr; +} + +GetAgentResponse::~GetAgentResponse() { + // @@protoc_insertion_point(destructor:flyteidl.admin.GetAgentResponse) + SharedDtor(); +} + +void GetAgentResponse::SharedDtor() { + if (this != internal_default_instance()) delete agent_; +} + +void GetAgentResponse::SetCachedSize(int size) const { + _cached_size_.Set(size); +} +const GetAgentResponse& GetAgentResponse::default_instance() { + ::google::protobuf::internal::InitSCC(&::scc_info_GetAgentResponse_flyteidl_2fadmin_2fagent_2eproto.base); + return *internal_default_instance(); +} + + +void GetAgentResponse::Clear() { +// @@protoc_insertion_point(message_clear_start:flyteidl.admin.GetAgentResponse) + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + if (GetArenaNoVirtual() == nullptr && agent_ != nullptr) { + delete agent_; + } + agent_ = nullptr; + _internal_metadata_.Clear(); +} + +#if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +const char* GetAgentResponse::_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.admin.Agent agent = 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 = ::flyteidl::admin::Agent::_InternalParse; + object = msg->mutable_agent(); + 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 GetAgentResponse::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.admin.GetAgentResponse) + 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.admin.Agent agent = 1; + case 1: { + if (static_cast< ::google::protobuf::uint8>(tag) == (10 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_agent())); + } 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.admin.GetAgentResponse) + return true; +failure: + // @@protoc_insertion_point(parse_failure:flyteidl.admin.GetAgentResponse) + return false; +#undef DO_ +} +#endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + +void GetAgentResponse::SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const { + // @@protoc_insertion_point(serialize_start:flyteidl.admin.GetAgentResponse) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // .flyteidl.admin.Agent agent = 1; + if (this->has_agent()) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 1, HasBitSetters::agent(this), output); + } + + if (_internal_metadata_.have_unknown_fields()) { + ::google::protobuf::internal::WireFormat::SerializeUnknownFields( + _internal_metadata_.unknown_fields(), output); + } + // @@protoc_insertion_point(serialize_end:flyteidl.admin.GetAgentResponse) +} + +::google::protobuf::uint8* GetAgentResponse::InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const { + // @@protoc_insertion_point(serialize_to_array_start:flyteidl.admin.GetAgentResponse) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // .flyteidl.admin.Agent agent = 1; + if (this->has_agent()) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 1, HasBitSetters::agent(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.admin.GetAgentResponse) + return target; +} + +size_t GetAgentResponse::ByteSizeLong() const { +// @@protoc_insertion_point(message_byte_size_start:flyteidl.admin.GetAgentResponse) + 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; + + // .flyteidl.admin.Agent agent = 1; + if (this->has_agent()) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *agent_); + } + + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); + SetCachedSize(cached_size); + return total_size; +} + +void GetAgentResponse::MergeFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_merge_from_start:flyteidl.admin.GetAgentResponse) + GOOGLE_DCHECK_NE(&from, this); + const GetAgentResponse* source = + ::google::protobuf::DynamicCastToGenerated( + &from); + if (source == nullptr) { + // @@protoc_insertion_point(generalized_merge_from_cast_fail:flyteidl.admin.GetAgentResponse) + ::google::protobuf::internal::ReflectionOps::Merge(from, this); + } else { + // @@protoc_insertion_point(generalized_merge_from_cast_success:flyteidl.admin.GetAgentResponse) + MergeFrom(*source); + } +} + +void GetAgentResponse::MergeFrom(const GetAgentResponse& from) { +// @@protoc_insertion_point(class_specific_merge_from_start:flyteidl.admin.GetAgentResponse) + 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_agent()) { + mutable_agent()->::flyteidl::admin::Agent::MergeFrom(from.agent()); + } +} + +void GetAgentResponse::CopyFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_copy_from_start:flyteidl.admin.GetAgentResponse) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +void GetAgentResponse::CopyFrom(const GetAgentResponse& from) { +// @@protoc_insertion_point(class_specific_copy_from_start:flyteidl.admin.GetAgentResponse) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +bool GetAgentResponse::IsInitialized() const { + return true; +} + +void GetAgentResponse::Swap(GetAgentResponse* other) { + if (other == this) return; + InternalSwap(other); +} +void GetAgentResponse::InternalSwap(GetAgentResponse* other) { + using std::swap; + _internal_metadata_.Swap(&other->_internal_metadata_); + swap(agent_, other->agent_); +} + +::google::protobuf::Metadata GetAgentResponse::GetMetadata() const { + ::google::protobuf::internal::AssignDescriptors(&::assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto); + return ::file_level_metadata_flyteidl_2fadmin_2fagent_2eproto[kIndexInFileMessages]; +} + + +// =================================================================== + +void ListAgentsRequest::InitAsDefaultInstance() { +} +class ListAgentsRequest::HasBitSetters { + public: +}; + +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 + +ListAgentsRequest::ListAgentsRequest() + : ::google::protobuf::Message(), _internal_metadata_(nullptr) { + SharedCtor(); + // @@protoc_insertion_point(constructor:flyteidl.admin.ListAgentsRequest) +} +ListAgentsRequest::ListAgentsRequest(const ListAgentsRequest& from) + : ::google::protobuf::Message(), + _internal_metadata_(nullptr) { + _internal_metadata_.MergeFrom(from._internal_metadata_); + // @@protoc_insertion_point(copy_constructor:flyteidl.admin.ListAgentsRequest) +} + +void ListAgentsRequest::SharedCtor() { +} + +ListAgentsRequest::~ListAgentsRequest() { + // @@protoc_insertion_point(destructor:flyteidl.admin.ListAgentsRequest) + SharedDtor(); +} + +void ListAgentsRequest::SharedDtor() { +} + +void ListAgentsRequest::SetCachedSize(int size) const { + _cached_size_.Set(size); +} +const ListAgentsRequest& ListAgentsRequest::default_instance() { + ::google::protobuf::internal::InitSCC(&::scc_info_ListAgentsRequest_flyteidl_2fadmin_2fagent_2eproto.base); + return *internal_default_instance(); +} + + +void ListAgentsRequest::Clear() { +// @@protoc_insertion_point(message_clear_start:flyteidl.admin.ListAgentsRequest) + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + _internal_metadata_.Clear(); +} + +#if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +const char* ListAgentsRequest::_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) { + default: { + 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; +} +#else // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +bool ListAgentsRequest::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.admin.ListAgentsRequest) + for (;;) { + ::std::pair<::google::protobuf::uint32, bool> p = input->ReadTagWithCutoffNoLastTag(127u); + tag = p.first; + if (!p.second) goto handle_unusual; + handle_unusual: + if (tag == 0) { + goto success; + } + DO_(::google::protobuf::internal::WireFormat::SkipField( + input, tag, _internal_metadata_.mutable_unknown_fields())); + } +success: + // @@protoc_insertion_point(parse_success:flyteidl.admin.ListAgentsRequest) + return true; +failure: + // @@protoc_insertion_point(parse_failure:flyteidl.admin.ListAgentsRequest) + return false; +#undef DO_ +} +#endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + +void ListAgentsRequest::SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const { + // @@protoc_insertion_point(serialize_start:flyteidl.admin.ListAgentsRequest) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + if (_internal_metadata_.have_unknown_fields()) { + ::google::protobuf::internal::WireFormat::SerializeUnknownFields( + _internal_metadata_.unknown_fields(), output); + } + // @@protoc_insertion_point(serialize_end:flyteidl.admin.ListAgentsRequest) +} + +::google::protobuf::uint8* ListAgentsRequest::InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const { + // @@protoc_insertion_point(serialize_to_array_start:flyteidl.admin.ListAgentsRequest) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + 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.admin.ListAgentsRequest) + return target; +} + +size_t ListAgentsRequest::ByteSizeLong() const { +// @@protoc_insertion_point(message_byte_size_start:flyteidl.admin.ListAgentsRequest) + 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; + + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); + SetCachedSize(cached_size); + return total_size; +} + +void ListAgentsRequest::MergeFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_merge_from_start:flyteidl.admin.ListAgentsRequest) + GOOGLE_DCHECK_NE(&from, this); + const ListAgentsRequest* source = + ::google::protobuf::DynamicCastToGenerated( + &from); + if (source == nullptr) { + // @@protoc_insertion_point(generalized_merge_from_cast_fail:flyteidl.admin.ListAgentsRequest) + ::google::protobuf::internal::ReflectionOps::Merge(from, this); + } else { + // @@protoc_insertion_point(generalized_merge_from_cast_success:flyteidl.admin.ListAgentsRequest) + MergeFrom(*source); + } +} + +void ListAgentsRequest::MergeFrom(const ListAgentsRequest& from) { +// @@protoc_insertion_point(class_specific_merge_from_start:flyteidl.admin.ListAgentsRequest) + GOOGLE_DCHECK_NE(&from, this); + _internal_metadata_.MergeFrom(from._internal_metadata_); + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + +} + +void ListAgentsRequest::CopyFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_copy_from_start:flyteidl.admin.ListAgentsRequest) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +void ListAgentsRequest::CopyFrom(const ListAgentsRequest& from) { +// @@protoc_insertion_point(class_specific_copy_from_start:flyteidl.admin.ListAgentsRequest) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +bool ListAgentsRequest::IsInitialized() const { + return true; +} + +void ListAgentsRequest::Swap(ListAgentsRequest* other) { + if (other == this) return; + InternalSwap(other); +} +void ListAgentsRequest::InternalSwap(ListAgentsRequest* other) { + using std::swap; + _internal_metadata_.Swap(&other->_internal_metadata_); +} + +::google::protobuf::Metadata ListAgentsRequest::GetMetadata() const { + ::google::protobuf::internal::AssignDescriptors(&::assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto); + return ::file_level_metadata_flyteidl_2fadmin_2fagent_2eproto[kIndexInFileMessages]; +} + + +// =================================================================== + +void ListAgentsResponse::InitAsDefaultInstance() { +} +class ListAgentsResponse::HasBitSetters { + public: +}; + +#if !defined(_MSC_VER) || _MSC_VER >= 1900 +const int ListAgentsResponse::kAgentsFieldNumber; +#endif // !defined(_MSC_VER) || _MSC_VER >= 1900 + +ListAgentsResponse::ListAgentsResponse() + : ::google::protobuf::Message(), _internal_metadata_(nullptr) { + SharedCtor(); + // @@protoc_insertion_point(constructor:flyteidl.admin.ListAgentsResponse) +} +ListAgentsResponse::ListAgentsResponse(const ListAgentsResponse& from) + : ::google::protobuf::Message(), + _internal_metadata_(nullptr), + agents_(from.agents_) { + _internal_metadata_.MergeFrom(from._internal_metadata_); + // @@protoc_insertion_point(copy_constructor:flyteidl.admin.ListAgentsResponse) +} + +void ListAgentsResponse::SharedCtor() { + ::google::protobuf::internal::InitSCC( + &scc_info_ListAgentsResponse_flyteidl_2fadmin_2fagent_2eproto.base); +} + +ListAgentsResponse::~ListAgentsResponse() { + // @@protoc_insertion_point(destructor:flyteidl.admin.ListAgentsResponse) + SharedDtor(); +} + +void ListAgentsResponse::SharedDtor() { +} + +void ListAgentsResponse::SetCachedSize(int size) const { + _cached_size_.Set(size); +} +const ListAgentsResponse& ListAgentsResponse::default_instance() { + ::google::protobuf::internal::InitSCC(&::scc_info_ListAgentsResponse_flyteidl_2fadmin_2fagent_2eproto.base); + return *internal_default_instance(); +} + + +void ListAgentsResponse::Clear() { +// @@protoc_insertion_point(message_clear_start:flyteidl.admin.ListAgentsResponse) + ::google::protobuf::uint32 cached_has_bits = 0; + // Prevent compiler warnings about cached_has_bits being unused + (void) cached_has_bits; + + agents_.Clear(); + _internal_metadata_.Clear(); +} + +#if GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER +const char* ListAgentsResponse::_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) { + // repeated .flyteidl.admin.Agent agents = 1; + case 1: { + if (static_cast<::google::protobuf::uint8>(tag) != 10) goto handle_unusual; + do { + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + parser_till_end = ::flyteidl::admin::Agent::_InternalParse; + object = msg->add_agents(); + if (size > end - ptr) goto len_delim_till_end; + ptr += size; + GOOGLE_PROTOBUF_PARSER_ASSERT(ctx->ParseExactRange( + {parser_till_end, object}, ptr - size, ptr)); + if (ptr >= end) break; + } while ((::google::protobuf::io::UnalignedLoad<::google::protobuf::uint64>(ptr) & 255) == 10 && (ptr += 1)); + 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 ListAgentsResponse::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.admin.ListAgentsResponse) + 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)) { + // repeated .flyteidl.admin.Agent agents = 1; + case 1: { + if (static_cast< ::google::protobuf::uint8>(tag) == (10 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, add_agents())); + } 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.admin.ListAgentsResponse) + return true; +failure: + // @@protoc_insertion_point(parse_failure:flyteidl.admin.ListAgentsResponse) + return false; +#undef DO_ +} +#endif // GOOGLE_PROTOBUF_ENABLE_EXPERIMENTAL_PARSER + +void ListAgentsResponse::SerializeWithCachedSizes( + ::google::protobuf::io::CodedOutputStream* output) const { + // @@protoc_insertion_point(serialize_start:flyteidl.admin.ListAgentsResponse) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // repeated .flyteidl.admin.Agent agents = 1; + for (unsigned int i = 0, + n = static_cast(this->agents_size()); i < n; i++) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 1, + this->agents(static_cast(i)), + output); + } + + if (_internal_metadata_.have_unknown_fields()) { + ::google::protobuf::internal::WireFormat::SerializeUnknownFields( + _internal_metadata_.unknown_fields(), output); + } + // @@protoc_insertion_point(serialize_end:flyteidl.admin.ListAgentsResponse) +} + +::google::protobuf::uint8* ListAgentsResponse::InternalSerializeWithCachedSizesToArray( + ::google::protobuf::uint8* target) const { + // @@protoc_insertion_point(serialize_to_array_start:flyteidl.admin.ListAgentsResponse) + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + // repeated .flyteidl.admin.Agent agents = 1; + for (unsigned int i = 0, + n = static_cast(this->agents_size()); i < n; i++) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 1, this->agents(static_cast(i)), 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.admin.ListAgentsResponse) + return target; +} + +size_t ListAgentsResponse::ByteSizeLong() const { +// @@protoc_insertion_point(message_byte_size_start:flyteidl.admin.ListAgentsResponse) + 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; + + // repeated .flyteidl.admin.Agent agents = 1; + { + unsigned int count = static_cast(this->agents_size()); + total_size += 1UL * count; + for (unsigned int i = 0; i < count; i++) { + total_size += + ::google::protobuf::internal::WireFormatLite::MessageSize( + this->agents(static_cast(i))); + } + } + + int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); + SetCachedSize(cached_size); + return total_size; +} + +void ListAgentsResponse::MergeFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_merge_from_start:flyteidl.admin.ListAgentsResponse) + GOOGLE_DCHECK_NE(&from, this); + const ListAgentsResponse* source = + ::google::protobuf::DynamicCastToGenerated( + &from); + if (source == nullptr) { + // @@protoc_insertion_point(generalized_merge_from_cast_fail:flyteidl.admin.ListAgentsResponse) + ::google::protobuf::internal::ReflectionOps::Merge(from, this); + } else { + // @@protoc_insertion_point(generalized_merge_from_cast_success:flyteidl.admin.ListAgentsResponse) + MergeFrom(*source); + } +} + +void ListAgentsResponse::MergeFrom(const ListAgentsResponse& from) { +// @@protoc_insertion_point(class_specific_merge_from_start:flyteidl.admin.ListAgentsResponse) + GOOGLE_DCHECK_NE(&from, this); + _internal_metadata_.MergeFrom(from._internal_metadata_); + ::google::protobuf::uint32 cached_has_bits = 0; + (void) cached_has_bits; + + agents_.MergeFrom(from.agents_); +} + +void ListAgentsResponse::CopyFrom(const ::google::protobuf::Message& from) { +// @@protoc_insertion_point(generalized_copy_from_start:flyteidl.admin.ListAgentsResponse) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +void ListAgentsResponse::CopyFrom(const ListAgentsResponse& from) { +// @@protoc_insertion_point(class_specific_copy_from_start:flyteidl.admin.ListAgentsResponse) + if (&from == this) return; + Clear(); + MergeFrom(from); +} + +bool ListAgentsResponse::IsInitialized() const { + return true; +} + +void ListAgentsResponse::Swap(ListAgentsResponse* other) { + if (other == this) return; + InternalSwap(other); +} +void ListAgentsResponse::InternalSwap(ListAgentsResponse* other) { + using std::swap; + _internal_metadata_.Swap(&other->_internal_metadata_); + CastToBase(&agents_)->InternalSwap(CastToBase(&other->agents_)); +} + +::google::protobuf::Metadata ListAgentsResponse::GetMetadata() const { + ::google::protobuf::internal::AssignDescriptors(&::assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto); + return ::file_level_metadata_flyteidl_2fadmin_2fagent_2eproto[kIndexInFileMessages]; +} + + +// @@protoc_insertion_point(namespace_scope) +} // namespace admin +} // namespace flyteidl +namespace google { +namespace protobuf { +template<> PROTOBUF_NOINLINE ::flyteidl::admin::TaskExecutionMetadata_LabelsEntry_DoNotUse* Arena::CreateMaybeMessage< ::flyteidl::admin::TaskExecutionMetadata_LabelsEntry_DoNotUse >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::TaskExecutionMetadata_LabelsEntry_DoNotUse >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::TaskExecutionMetadata_AnnotationsEntry_DoNotUse* Arena::CreateMaybeMessage< ::flyteidl::admin::TaskExecutionMetadata_AnnotationsEntry_DoNotUse >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::TaskExecutionMetadata_AnnotationsEntry_DoNotUse >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::TaskExecutionMetadata_EnvironmentVariablesEntry_DoNotUse* Arena::CreateMaybeMessage< ::flyteidl::admin::TaskExecutionMetadata_EnvironmentVariablesEntry_DoNotUse >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::TaskExecutionMetadata_EnvironmentVariablesEntry_DoNotUse >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::TaskExecutionMetadata* Arena::CreateMaybeMessage< ::flyteidl::admin::TaskExecutionMetadata >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::TaskExecutionMetadata >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::CreateTaskRequest* Arena::CreateMaybeMessage< ::flyteidl::admin::CreateTaskRequest >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::CreateTaskRequest >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::CreateTaskResponse* Arena::CreateMaybeMessage< ::flyteidl::admin::CreateTaskResponse >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::CreateTaskResponse >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::GetTaskRequest* Arena::CreateMaybeMessage< ::flyteidl::admin::GetTaskRequest >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::GetTaskRequest >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::GetTaskResponse* Arena::CreateMaybeMessage< ::flyteidl::admin::GetTaskResponse >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::GetTaskResponse >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::Resource* Arena::CreateMaybeMessage< ::flyteidl::admin::Resource >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::Resource >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::DeleteTaskRequest* Arena::CreateMaybeMessage< ::flyteidl::admin::DeleteTaskRequest >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::DeleteTaskRequest >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::DeleteTaskResponse* Arena::CreateMaybeMessage< ::flyteidl::admin::DeleteTaskResponse >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::DeleteTaskResponse >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::Agent* Arena::CreateMaybeMessage< ::flyteidl::admin::Agent >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::Agent >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::GetAgentRequest* Arena::CreateMaybeMessage< ::flyteidl::admin::GetAgentRequest >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::GetAgentRequest >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::GetAgentResponse* Arena::CreateMaybeMessage< ::flyteidl::admin::GetAgentResponse >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::GetAgentResponse >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::ListAgentsRequest* Arena::CreateMaybeMessage< ::flyteidl::admin::ListAgentsRequest >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::ListAgentsRequest >(arena); +} +template<> PROTOBUF_NOINLINE ::flyteidl::admin::ListAgentsResponse* Arena::CreateMaybeMessage< ::flyteidl::admin::ListAgentsResponse >(Arena* arena) { + return Arena::CreateInternal< ::flyteidl::admin::ListAgentsResponse >(arena); } } // namespace protobuf } // namespace google diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h b/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h index 6c44bf09f8..7360e91d06 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h @@ -50,7 +50,7 @@ struct TableStruct_flyteidl_2fadmin_2fagent_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[11] + static const ::google::protobuf::internal::ParseTable schema[16] PROTOBUF_SECTION_VARIABLE(protodesc_cold); static const ::google::protobuf::internal::FieldMetadata field_metadata[]; static const ::google::protobuf::internal::SerializationTable serialization_table[]; @@ -59,6 +59,9 @@ struct TableStruct_flyteidl_2fadmin_2fagent_2eproto { void AddDescriptors_flyteidl_2fadmin_2fagent_2eproto(); namespace flyteidl { namespace admin { +class Agent; +class AgentDefaultTypeInternal; +extern AgentDefaultTypeInternal _Agent_default_instance_; class CreateTaskRequest; class CreateTaskRequestDefaultTypeInternal; extern CreateTaskRequestDefaultTypeInternal _CreateTaskRequest_default_instance_; @@ -71,12 +74,24 @@ extern DeleteTaskRequestDefaultTypeInternal _DeleteTaskRequest_default_instance_ class DeleteTaskResponse; class DeleteTaskResponseDefaultTypeInternal; extern DeleteTaskResponseDefaultTypeInternal _DeleteTaskResponse_default_instance_; +class GetAgentRequest; +class GetAgentRequestDefaultTypeInternal; +extern GetAgentRequestDefaultTypeInternal _GetAgentRequest_default_instance_; +class GetAgentResponse; +class GetAgentResponseDefaultTypeInternal; +extern GetAgentResponseDefaultTypeInternal _GetAgentResponse_default_instance_; class GetTaskRequest; class GetTaskRequestDefaultTypeInternal; extern GetTaskRequestDefaultTypeInternal _GetTaskRequest_default_instance_; class GetTaskResponse; class GetTaskResponseDefaultTypeInternal; extern GetTaskResponseDefaultTypeInternal _GetTaskResponse_default_instance_; +class ListAgentsRequest; +class ListAgentsRequestDefaultTypeInternal; +extern ListAgentsRequestDefaultTypeInternal _ListAgentsRequest_default_instance_; +class ListAgentsResponse; +class ListAgentsResponseDefaultTypeInternal; +extern ListAgentsResponseDefaultTypeInternal _ListAgentsResponse_default_instance_; class Resource; class ResourceDefaultTypeInternal; extern ResourceDefaultTypeInternal _Resource_default_instance_; @@ -96,12 +111,17 @@ extern TaskExecutionMetadata_LabelsEntry_DoNotUseDefaultTypeInternal _TaskExecut } // namespace flyteidl namespace google { namespace protobuf { +template<> ::flyteidl::admin::Agent* Arena::CreateMaybeMessage<::flyteidl::admin::Agent>(Arena*); template<> ::flyteidl::admin::CreateTaskRequest* Arena::CreateMaybeMessage<::flyteidl::admin::CreateTaskRequest>(Arena*); template<> ::flyteidl::admin::CreateTaskResponse* Arena::CreateMaybeMessage<::flyteidl::admin::CreateTaskResponse>(Arena*); template<> ::flyteidl::admin::DeleteTaskRequest* Arena::CreateMaybeMessage<::flyteidl::admin::DeleteTaskRequest>(Arena*); template<> ::flyteidl::admin::DeleteTaskResponse* Arena::CreateMaybeMessage<::flyteidl::admin::DeleteTaskResponse>(Arena*); +template<> ::flyteidl::admin::GetAgentRequest* Arena::CreateMaybeMessage<::flyteidl::admin::GetAgentRequest>(Arena*); +template<> ::flyteidl::admin::GetAgentResponse* Arena::CreateMaybeMessage<::flyteidl::admin::GetAgentResponse>(Arena*); template<> ::flyteidl::admin::GetTaskRequest* Arena::CreateMaybeMessage<::flyteidl::admin::GetTaskRequest>(Arena*); template<> ::flyteidl::admin::GetTaskResponse* Arena::CreateMaybeMessage<::flyteidl::admin::GetTaskResponse>(Arena*); +template<> ::flyteidl::admin::ListAgentsRequest* Arena::CreateMaybeMessage<::flyteidl::admin::ListAgentsRequest>(Arena*); +template<> ::flyteidl::admin::ListAgentsResponse* Arena::CreateMaybeMessage<::flyteidl::admin::ListAgentsResponse>(Arena*); template<> ::flyteidl::admin::Resource* Arena::CreateMaybeMessage<::flyteidl::admin::Resource>(Arena*); template<> ::flyteidl::admin::TaskExecutionMetadata* Arena::CreateMaybeMessage<::flyteidl::admin::TaskExecutionMetadata>(Arena*); template<> ::flyteidl::admin::TaskExecutionMetadata_AnnotationsEntry_DoNotUse* Arena::CreateMaybeMessage<::flyteidl::admin::TaskExecutionMetadata_AnnotationsEntry_DoNotUse>(Arena*); @@ -1309,6 +1329,607 @@ class DeleteTaskResponse final : mutable ::google::protobuf::internal::CachedSize _cached_size_; friend struct ::TableStruct_flyteidl_2fadmin_2fagent_2eproto; }; +// ------------------------------------------------------------------- + +class Agent final : + public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.admin.Agent) */ { + public: + Agent(); + virtual ~Agent(); + + Agent(const Agent& from); + + inline Agent& operator=(const Agent& from) { + CopyFrom(from); + return *this; + } + #if LANG_CXX11 + Agent(Agent&& from) noexcept + : Agent() { + *this = ::std::move(from); + } + + inline Agent& operator=(Agent&& 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 Agent& default_instance(); + + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY + static inline const Agent* internal_default_instance() { + return reinterpret_cast( + &_Agent_default_instance_); + } + static constexpr int kIndexInFileMessages = + 11; + + void Swap(Agent* other); + friend void swap(Agent& a, Agent& b) { + a.Swap(&b); + } + + // implements Message ---------------------------------------------- + + inline Agent* New() const final { + return CreateMaybeMessage(nullptr); + } + + Agent* 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 Agent& from); + void MergeFrom(const Agent& 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(Agent* 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 ------------------------------------------------------- + + // repeated string supported_task_types = 2; + int supported_task_types_size() const; + void clear_supported_task_types(); + static const int kSupportedTaskTypesFieldNumber = 2; + const ::std::string& supported_task_types(int index) const; + ::std::string* mutable_supported_task_types(int index); + void set_supported_task_types(int index, const ::std::string& value); + #if LANG_CXX11 + void set_supported_task_types(int index, ::std::string&& value); + #endif + void set_supported_task_types(int index, const char* value); + void set_supported_task_types(int index, const char* value, size_t size); + ::std::string* add_supported_task_types(); + void add_supported_task_types(const ::std::string& value); + #if LANG_CXX11 + void add_supported_task_types(::std::string&& value); + #endif + void add_supported_task_types(const char* value); + void add_supported_task_types(const char* value, size_t size); + const ::google::protobuf::RepeatedPtrField<::std::string>& supported_task_types() const; + ::google::protobuf::RepeatedPtrField<::std::string>* mutable_supported_task_types(); + + // string name = 1; + void clear_name(); + static const int kNameFieldNumber = 1; + const ::std::string& name() const; + void set_name(const ::std::string& value); + #if LANG_CXX11 + void set_name(::std::string&& value); + #endif + void set_name(const char* value); + void set_name(const char* value, size_t size); + ::std::string* mutable_name(); + ::std::string* release_name(); + void set_allocated_name(::std::string* name); + + // @@protoc_insertion_point(class_scope:flyteidl.admin.Agent) + private: + class HasBitSetters; + + ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + ::google::protobuf::RepeatedPtrField<::std::string> supported_task_types_; + ::google::protobuf::internal::ArenaStringPtr name_; + mutable ::google::protobuf::internal::CachedSize _cached_size_; + friend struct ::TableStruct_flyteidl_2fadmin_2fagent_2eproto; +}; +// ------------------------------------------------------------------- + +class GetAgentRequest final : + public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.admin.GetAgentRequest) */ { + public: + GetAgentRequest(); + virtual ~GetAgentRequest(); + + GetAgentRequest(const GetAgentRequest& from); + + inline GetAgentRequest& operator=(const GetAgentRequest& from) { + CopyFrom(from); + return *this; + } + #if LANG_CXX11 + GetAgentRequest(GetAgentRequest&& from) noexcept + : GetAgentRequest() { + *this = ::std::move(from); + } + + inline GetAgentRequest& operator=(GetAgentRequest&& 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 GetAgentRequest& default_instance(); + + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY + static inline const GetAgentRequest* internal_default_instance() { + return reinterpret_cast( + &_GetAgentRequest_default_instance_); + } + static constexpr int kIndexInFileMessages = + 12; + + void Swap(GetAgentRequest* other); + friend void swap(GetAgentRequest& a, GetAgentRequest& b) { + a.Swap(&b); + } + + // implements Message ---------------------------------------------- + + inline GetAgentRequest* New() const final { + return CreateMaybeMessage(nullptr); + } + + GetAgentRequest* 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 GetAgentRequest& from); + void MergeFrom(const GetAgentRequest& 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(GetAgentRequest* other); + private: + inline ::google::protobuf::Arena* GetArenaNoVirtual() const { + return nullptr; + } + inline void* MaybeArenaPtr() const { + return nullptr; + } + public: + + ::google::protobuf::Metadata GetMetadata() const final; + + // nested types ---------------------------------------------------- + + // accessors ------------------------------------------------------- + + // string name = 1; + void clear_name(); + static const int kNameFieldNumber = 1; + const ::std::string& name() const; + void set_name(const ::std::string& value); + #if LANG_CXX11 + void set_name(::std::string&& value); + #endif + void set_name(const char* value); + void set_name(const char* value, size_t size); + ::std::string* mutable_name(); + ::std::string* release_name(); + void set_allocated_name(::std::string* name); + + // @@protoc_insertion_point(class_scope:flyteidl.admin.GetAgentRequest) + private: + class HasBitSetters; + + ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + ::google::protobuf::internal::ArenaStringPtr name_; + mutable ::google::protobuf::internal::CachedSize _cached_size_; + friend struct ::TableStruct_flyteidl_2fadmin_2fagent_2eproto; +}; +// ------------------------------------------------------------------- + +class GetAgentResponse final : + public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.admin.GetAgentResponse) */ { + public: + GetAgentResponse(); + virtual ~GetAgentResponse(); + + GetAgentResponse(const GetAgentResponse& from); + + inline GetAgentResponse& operator=(const GetAgentResponse& from) { + CopyFrom(from); + return *this; + } + #if LANG_CXX11 + GetAgentResponse(GetAgentResponse&& from) noexcept + : GetAgentResponse() { + *this = ::std::move(from); + } + + inline GetAgentResponse& operator=(GetAgentResponse&& 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 GetAgentResponse& default_instance(); + + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY + static inline const GetAgentResponse* internal_default_instance() { + return reinterpret_cast( + &_GetAgentResponse_default_instance_); + } + static constexpr int kIndexInFileMessages = + 13; + + void Swap(GetAgentResponse* other); + friend void swap(GetAgentResponse& a, GetAgentResponse& b) { + a.Swap(&b); + } + + // implements Message ---------------------------------------------- + + inline GetAgentResponse* New() const final { + return CreateMaybeMessage(nullptr); + } + + GetAgentResponse* 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 GetAgentResponse& from); + void MergeFrom(const GetAgentResponse& 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(GetAgentResponse* 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 ------------------------------------------------------- + + // .flyteidl.admin.Agent agent = 1; + bool has_agent() const; + void clear_agent(); + static const int kAgentFieldNumber = 1; + const ::flyteidl::admin::Agent& agent() const; + ::flyteidl::admin::Agent* release_agent(); + ::flyteidl::admin::Agent* mutable_agent(); + void set_allocated_agent(::flyteidl::admin::Agent* agent); + + // @@protoc_insertion_point(class_scope:flyteidl.admin.GetAgentResponse) + private: + class HasBitSetters; + + ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + ::flyteidl::admin::Agent* agent_; + mutable ::google::protobuf::internal::CachedSize _cached_size_; + friend struct ::TableStruct_flyteidl_2fadmin_2fagent_2eproto; +}; +// ------------------------------------------------------------------- + +class ListAgentsRequest final : + public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.admin.ListAgentsRequest) */ { + public: + ListAgentsRequest(); + virtual ~ListAgentsRequest(); + + ListAgentsRequest(const ListAgentsRequest& from); + + inline ListAgentsRequest& operator=(const ListAgentsRequest& from) { + CopyFrom(from); + return *this; + } + #if LANG_CXX11 + ListAgentsRequest(ListAgentsRequest&& from) noexcept + : ListAgentsRequest() { + *this = ::std::move(from); + } + + inline ListAgentsRequest& operator=(ListAgentsRequest&& 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 ListAgentsRequest& default_instance(); + + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY + static inline const ListAgentsRequest* internal_default_instance() { + return reinterpret_cast( + &_ListAgentsRequest_default_instance_); + } + static constexpr int kIndexInFileMessages = + 14; + + void Swap(ListAgentsRequest* other); + friend void swap(ListAgentsRequest& a, ListAgentsRequest& b) { + a.Swap(&b); + } + + // implements Message ---------------------------------------------- + + inline ListAgentsRequest* New() const final { + return CreateMaybeMessage(nullptr); + } + + ListAgentsRequest* 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 ListAgentsRequest& from); + void MergeFrom(const ListAgentsRequest& 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(ListAgentsRequest* 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 ------------------------------------------------------- + + // @@protoc_insertion_point(class_scope:flyteidl.admin.ListAgentsRequest) + private: + class HasBitSetters; + + ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + mutable ::google::protobuf::internal::CachedSize _cached_size_; + friend struct ::TableStruct_flyteidl_2fadmin_2fagent_2eproto; +}; +// ------------------------------------------------------------------- + +class ListAgentsResponse final : + public ::google::protobuf::Message /* @@protoc_insertion_point(class_definition:flyteidl.admin.ListAgentsResponse) */ { + public: + ListAgentsResponse(); + virtual ~ListAgentsResponse(); + + ListAgentsResponse(const ListAgentsResponse& from); + + inline ListAgentsResponse& operator=(const ListAgentsResponse& from) { + CopyFrom(from); + return *this; + } + #if LANG_CXX11 + ListAgentsResponse(ListAgentsResponse&& from) noexcept + : ListAgentsResponse() { + *this = ::std::move(from); + } + + inline ListAgentsResponse& operator=(ListAgentsResponse&& 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 ListAgentsResponse& default_instance(); + + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY + static inline const ListAgentsResponse* internal_default_instance() { + return reinterpret_cast( + &_ListAgentsResponse_default_instance_); + } + static constexpr int kIndexInFileMessages = + 15; + + void Swap(ListAgentsResponse* other); + friend void swap(ListAgentsResponse& a, ListAgentsResponse& b) { + a.Swap(&b); + } + + // implements Message ---------------------------------------------- + + inline ListAgentsResponse* New() const final { + return CreateMaybeMessage(nullptr); + } + + ListAgentsResponse* 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 ListAgentsResponse& from); + void MergeFrom(const ListAgentsResponse& 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(ListAgentsResponse* 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 ------------------------------------------------------- + + // repeated .flyteidl.admin.Agent agents = 1; + int agents_size() const; + void clear_agents(); + static const int kAgentsFieldNumber = 1; + ::flyteidl::admin::Agent* mutable_agents(int index); + ::google::protobuf::RepeatedPtrField< ::flyteidl::admin::Agent >* + mutable_agents(); + const ::flyteidl::admin::Agent& agents(int index) const; + ::flyteidl::admin::Agent* add_agents(); + const ::google::protobuf::RepeatedPtrField< ::flyteidl::admin::Agent >& + agents() const; + + // @@protoc_insertion_point(class_scope:flyteidl.admin.ListAgentsResponse) + private: + class HasBitSetters; + + ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + ::google::protobuf::RepeatedPtrField< ::flyteidl::admin::Agent > agents_; + mutable ::google::protobuf::internal::CachedSize _cached_size_; + friend struct ::TableStruct_flyteidl_2fadmin_2fagent_2eproto; +}; // =================================================================== @@ -2208,6 +2829,282 @@ inline void DeleteTaskRequest::set_allocated_resource_meta(::std::string* resour // DeleteTaskResponse +// ------------------------------------------------------------------- + +// Agent + +// string name = 1; +inline void Agent::clear_name() { + name_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& Agent::name() const { + // @@protoc_insertion_point(field_get:flyteidl.admin.Agent.name) + return name_.GetNoArena(); +} +inline void Agent::set_name(const ::std::string& value) { + + name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.admin.Agent.name) +} +#if LANG_CXX11 +inline void Agent::set_name(::std::string&& value) { + + name_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.admin.Agent.name) +} +#endif +inline void Agent::set_name(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.admin.Agent.name) +} +inline void Agent::set_name(const char* value, size_t size) { + + name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.admin.Agent.name) +} +inline ::std::string* Agent::mutable_name() { + + // @@protoc_insertion_point(field_mutable:flyteidl.admin.Agent.name) + return name_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* Agent::release_name() { + // @@protoc_insertion_point(field_release:flyteidl.admin.Agent.name) + + return name_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void Agent::set_allocated_name(::std::string* name) { + if (name != nullptr) { + + } else { + + } + name_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), name); + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.Agent.name) +} + +// repeated string supported_task_types = 2; +inline int Agent::supported_task_types_size() const { + return supported_task_types_.size(); +} +inline void Agent::clear_supported_task_types() { + supported_task_types_.Clear(); +} +inline const ::std::string& Agent::supported_task_types(int index) const { + // @@protoc_insertion_point(field_get:flyteidl.admin.Agent.supported_task_types) + return supported_task_types_.Get(index); +} +inline ::std::string* Agent::mutable_supported_task_types(int index) { + // @@protoc_insertion_point(field_mutable:flyteidl.admin.Agent.supported_task_types) + return supported_task_types_.Mutable(index); +} +inline void Agent::set_supported_task_types(int index, const ::std::string& value) { + // @@protoc_insertion_point(field_set:flyteidl.admin.Agent.supported_task_types) + supported_task_types_.Mutable(index)->assign(value); +} +#if LANG_CXX11 +inline void Agent::set_supported_task_types(int index, ::std::string&& value) { + // @@protoc_insertion_point(field_set:flyteidl.admin.Agent.supported_task_types) + supported_task_types_.Mutable(index)->assign(std::move(value)); +} +#endif +inline void Agent::set_supported_task_types(int index, const char* value) { + GOOGLE_DCHECK(value != nullptr); + supported_task_types_.Mutable(index)->assign(value); + // @@protoc_insertion_point(field_set_char:flyteidl.admin.Agent.supported_task_types) +} +inline void Agent::set_supported_task_types(int index, const char* value, size_t size) { + supported_task_types_.Mutable(index)->assign( + reinterpret_cast(value), size); + // @@protoc_insertion_point(field_set_pointer:flyteidl.admin.Agent.supported_task_types) +} +inline ::std::string* Agent::add_supported_task_types() { + // @@protoc_insertion_point(field_add_mutable:flyteidl.admin.Agent.supported_task_types) + return supported_task_types_.Add(); +} +inline void Agent::add_supported_task_types(const ::std::string& value) { + supported_task_types_.Add()->assign(value); + // @@protoc_insertion_point(field_add:flyteidl.admin.Agent.supported_task_types) +} +#if LANG_CXX11 +inline void Agent::add_supported_task_types(::std::string&& value) { + supported_task_types_.Add(std::move(value)); + // @@protoc_insertion_point(field_add:flyteidl.admin.Agent.supported_task_types) +} +#endif +inline void Agent::add_supported_task_types(const char* value) { + GOOGLE_DCHECK(value != nullptr); + supported_task_types_.Add()->assign(value); + // @@protoc_insertion_point(field_add_char:flyteidl.admin.Agent.supported_task_types) +} +inline void Agent::add_supported_task_types(const char* value, size_t size) { + supported_task_types_.Add()->assign(reinterpret_cast(value), size); + // @@protoc_insertion_point(field_add_pointer:flyteidl.admin.Agent.supported_task_types) +} +inline const ::google::protobuf::RepeatedPtrField<::std::string>& +Agent::supported_task_types() const { + // @@protoc_insertion_point(field_list:flyteidl.admin.Agent.supported_task_types) + return supported_task_types_; +} +inline ::google::protobuf::RepeatedPtrField<::std::string>* +Agent::mutable_supported_task_types() { + // @@protoc_insertion_point(field_mutable_list:flyteidl.admin.Agent.supported_task_types) + return &supported_task_types_; +} + +// ------------------------------------------------------------------- + +// GetAgentRequest + +// string name = 1; +inline void GetAgentRequest::clear_name() { + name_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline const ::std::string& GetAgentRequest::name() const { + // @@protoc_insertion_point(field_get:flyteidl.admin.GetAgentRequest.name) + return name_.GetNoArena(); +} +inline void GetAgentRequest::set_name(const ::std::string& value) { + + name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.admin.GetAgentRequest.name) +} +#if LANG_CXX11 +inline void GetAgentRequest::set_name(::std::string&& value) { + + name_.SetNoArena( + &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set_rvalue:flyteidl.admin.GetAgentRequest.name) +} +#endif +inline void GetAgentRequest::set_name(const char* value) { + GOOGLE_DCHECK(value != nullptr); + + name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + // @@protoc_insertion_point(field_set_char:flyteidl.admin.GetAgentRequest.name) +} +inline void GetAgentRequest::set_name(const char* value, size_t size) { + + name_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(reinterpret_cast(value), size)); + // @@protoc_insertion_point(field_set_pointer:flyteidl.admin.GetAgentRequest.name) +} +inline ::std::string* GetAgentRequest::mutable_name() { + + // @@protoc_insertion_point(field_mutable:flyteidl.admin.GetAgentRequest.name) + return name_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline ::std::string* GetAgentRequest::release_name() { + // @@protoc_insertion_point(field_release:flyteidl.admin.GetAgentRequest.name) + + return name_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); +} +inline void GetAgentRequest::set_allocated_name(::std::string* name) { + if (name != nullptr) { + + } else { + + } + name_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), name); + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.GetAgentRequest.name) +} + +// ------------------------------------------------------------------- + +// GetAgentResponse + +// .flyteidl.admin.Agent agent = 1; +inline bool GetAgentResponse::has_agent() const { + return this != internal_default_instance() && agent_ != nullptr; +} +inline void GetAgentResponse::clear_agent() { + if (GetArenaNoVirtual() == nullptr && agent_ != nullptr) { + delete agent_; + } + agent_ = nullptr; +} +inline const ::flyteidl::admin::Agent& GetAgentResponse::agent() const { + const ::flyteidl::admin::Agent* p = agent_; + // @@protoc_insertion_point(field_get:flyteidl.admin.GetAgentResponse.agent) + return p != nullptr ? *p : *reinterpret_cast( + &::flyteidl::admin::_Agent_default_instance_); +} +inline ::flyteidl::admin::Agent* GetAgentResponse::release_agent() { + // @@protoc_insertion_point(field_release:flyteidl.admin.GetAgentResponse.agent) + + ::flyteidl::admin::Agent* temp = agent_; + agent_ = nullptr; + return temp; +} +inline ::flyteidl::admin::Agent* GetAgentResponse::mutable_agent() { + + if (agent_ == nullptr) { + auto* p = CreateMaybeMessage<::flyteidl::admin::Agent>(GetArenaNoVirtual()); + agent_ = p; + } + // @@protoc_insertion_point(field_mutable:flyteidl.admin.GetAgentResponse.agent) + return agent_; +} +inline void GetAgentResponse::set_allocated_agent(::flyteidl::admin::Agent* agent) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + if (message_arena == nullptr) { + delete agent_; + } + if (agent) { + ::google::protobuf::Arena* submessage_arena = nullptr; + if (message_arena != submessage_arena) { + agent = ::google::protobuf::internal::GetOwnedMessage( + message_arena, agent, submessage_arena); + } + + } else { + + } + agent_ = agent; + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.GetAgentResponse.agent) +} + +// ------------------------------------------------------------------- + +// ListAgentsRequest + +// ------------------------------------------------------------------- + +// ListAgentsResponse + +// repeated .flyteidl.admin.Agent agents = 1; +inline int ListAgentsResponse::agents_size() const { + return agents_.size(); +} +inline void ListAgentsResponse::clear_agents() { + agents_.Clear(); +} +inline ::flyteidl::admin::Agent* ListAgentsResponse::mutable_agents(int index) { + // @@protoc_insertion_point(field_mutable:flyteidl.admin.ListAgentsResponse.agents) + return agents_.Mutable(index); +} +inline ::google::protobuf::RepeatedPtrField< ::flyteidl::admin::Agent >* +ListAgentsResponse::mutable_agents() { + // @@protoc_insertion_point(field_mutable_list:flyteidl.admin.ListAgentsResponse.agents) + return &agents_; +} +inline const ::flyteidl::admin::Agent& ListAgentsResponse::agents(int index) const { + // @@protoc_insertion_point(field_get:flyteidl.admin.ListAgentsResponse.agents) + return agents_.Get(index); +} +inline ::flyteidl::admin::Agent* ListAgentsResponse::add_agents() { + // @@protoc_insertion_point(field_add:flyteidl.admin.ListAgentsResponse.agents) + return agents_.Add(); +} +inline const ::google::protobuf::RepeatedPtrField< ::flyteidl::admin::Agent >& +ListAgentsResponse::agents() const { + // @@protoc_insertion_point(field_list:flyteidl.admin.ListAgentsResponse.agents) + return agents_; +} + #ifdef __GNUC__ #pragma GCC diagnostic pop #endif // __GNUC__ @@ -2231,6 +3128,16 @@ inline void DeleteTaskRequest::set_allocated_resource_meta(::std::string* resour // ------------------------------------------------------------------- +// ------------------------------------------------------------------- + +// ------------------------------------------------------------------- + +// ------------------------------------------------------------------- + +// ------------------------------------------------------------------- + +// ------------------------------------------------------------------- + // @@protoc_insertion_point(namespace_scope) diff --git a/flyteidl/gen/pb-cpp/flyteidl/service/agent.grpc.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/service/agent.grpc.pb.cc index d3505f4ce8..0dd9e3d2d1 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/service/agent.grpc.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/service/agent.grpc.pb.cc @@ -164,6 +164,109 @@ ::grpc::Status AsyncAgentService::Service::DeleteTask(::grpc::ServerContext* con } +static const char* AgentMetadataService_method_names[] = { + "/flyteidl.service.AgentMetadataService/GetAgent", + "/flyteidl.service.AgentMetadataService/ListAgents", +}; + +std::unique_ptr< AgentMetadataService::Stub> AgentMetadataService::NewStub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options) { + (void)options; + std::unique_ptr< AgentMetadataService::Stub> stub(new AgentMetadataService::Stub(channel)); + return stub; +} + +AgentMetadataService::Stub::Stub(const std::shared_ptr< ::grpc::ChannelInterface>& channel) + : channel_(channel), rpcmethod_GetAgent_(AgentMetadataService_method_names[0], ::grpc::internal::RpcMethod::NORMAL_RPC, channel) + , rpcmethod_ListAgents_(AgentMetadataService_method_names[1], ::grpc::internal::RpcMethod::NORMAL_RPC, channel) + {} + +::grpc::Status AgentMetadataService::Stub::GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::flyteidl::admin::GetAgentResponse* response) { + return ::grpc::internal::BlockingUnaryCall(channel_.get(), rpcmethod_GetAgent_, context, request, response); +} + +void AgentMetadataService::Stub::experimental_async::GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response, std::function f) { + ::grpc::internal::CallbackUnaryCall(stub_->channel_.get(), stub_->rpcmethod_GetAgent_, context, request, response, std::move(f)); +} + +void AgentMetadataService::Stub::experimental_async::GetAgent(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::GetAgentResponse* response, std::function f) { + ::grpc::internal::CallbackUnaryCall(stub_->channel_.get(), stub_->rpcmethod_GetAgent_, context, request, response, std::move(f)); +} + +void AgentMetadataService::Stub::experimental_async::GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) { + ::grpc::internal::ClientCallbackUnaryFactory::Create(stub_->channel_.get(), stub_->rpcmethod_GetAgent_, context, request, response, reactor); +} + +void AgentMetadataService::Stub::experimental_async::GetAgent(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::GetAgentResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) { + ::grpc::internal::ClientCallbackUnaryFactory::Create(stub_->channel_.get(), stub_->rpcmethod_GetAgent_, context, request, response, reactor); +} + +::grpc::ClientAsyncResponseReader< ::flyteidl::admin::GetAgentResponse>* AgentMetadataService::Stub::AsyncGetAgentRaw(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) { + return ::grpc::internal::ClientAsyncResponseReaderFactory< ::flyteidl::admin::GetAgentResponse>::Create(channel_.get(), cq, rpcmethod_GetAgent_, context, request, true); +} + +::grpc::ClientAsyncResponseReader< ::flyteidl::admin::GetAgentResponse>* AgentMetadataService::Stub::PrepareAsyncGetAgentRaw(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) { + return ::grpc::internal::ClientAsyncResponseReaderFactory< ::flyteidl::admin::GetAgentResponse>::Create(channel_.get(), cq, rpcmethod_GetAgent_, context, request, false); +} + +::grpc::Status AgentMetadataService::Stub::ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::flyteidl::admin::ListAgentsResponse* response) { + return ::grpc::internal::BlockingUnaryCall(channel_.get(), rpcmethod_ListAgents_, context, request, response); +} + +void AgentMetadataService::Stub::experimental_async::ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response, std::function f) { + ::grpc::internal::CallbackUnaryCall(stub_->channel_.get(), stub_->rpcmethod_ListAgents_, context, request, response, std::move(f)); +} + +void AgentMetadataService::Stub::experimental_async::ListAgents(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::ListAgentsResponse* response, std::function f) { + ::grpc::internal::CallbackUnaryCall(stub_->channel_.get(), stub_->rpcmethod_ListAgents_, context, request, response, std::move(f)); +} + +void AgentMetadataService::Stub::experimental_async::ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) { + ::grpc::internal::ClientCallbackUnaryFactory::Create(stub_->channel_.get(), stub_->rpcmethod_ListAgents_, context, request, response, reactor); +} + +void AgentMetadataService::Stub::experimental_async::ListAgents(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::ListAgentsResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) { + ::grpc::internal::ClientCallbackUnaryFactory::Create(stub_->channel_.get(), stub_->rpcmethod_ListAgents_, context, request, response, reactor); +} + +::grpc::ClientAsyncResponseReader< ::flyteidl::admin::ListAgentsResponse>* AgentMetadataService::Stub::AsyncListAgentsRaw(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) { + return ::grpc::internal::ClientAsyncResponseReaderFactory< ::flyteidl::admin::ListAgentsResponse>::Create(channel_.get(), cq, rpcmethod_ListAgents_, context, request, true); +} + +::grpc::ClientAsyncResponseReader< ::flyteidl::admin::ListAgentsResponse>* AgentMetadataService::Stub::PrepareAsyncListAgentsRaw(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) { + return ::grpc::internal::ClientAsyncResponseReaderFactory< ::flyteidl::admin::ListAgentsResponse>::Create(channel_.get(), cq, rpcmethod_ListAgents_, context, request, false); +} + +AgentMetadataService::Service::Service() { + AddMethod(new ::grpc::internal::RpcServiceMethod( + AgentMetadataService_method_names[0], + ::grpc::internal::RpcMethod::NORMAL_RPC, + new ::grpc::internal::RpcMethodHandler< AgentMetadataService::Service, ::flyteidl::admin::GetAgentRequest, ::flyteidl::admin::GetAgentResponse>( + std::mem_fn(&AgentMetadataService::Service::GetAgent), this))); + AddMethod(new ::grpc::internal::RpcServiceMethod( + AgentMetadataService_method_names[1], + ::grpc::internal::RpcMethod::NORMAL_RPC, + new ::grpc::internal::RpcMethodHandler< AgentMetadataService::Service, ::flyteidl::admin::ListAgentsRequest, ::flyteidl::admin::ListAgentsResponse>( + std::mem_fn(&AgentMetadataService::Service::ListAgents), this))); +} + +AgentMetadataService::Service::~Service() { +} + +::grpc::Status AgentMetadataService::Service::GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response) { + (void) context; + (void) request; + (void) response; + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); +} + +::grpc::Status AgentMetadataService::Service::ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response) { + (void) context; + (void) request; + (void) response; + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); +} + + } // namespace flyteidl } // namespace service diff --git a/flyteidl/gen/pb-cpp/flyteidl/service/agent.grpc.pb.h b/flyteidl/gen/pb-cpp/flyteidl/service/agent.grpc.pb.h index 16b36b249a..e1cb5da223 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/service/agent.grpc.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/service/agent.grpc.pb.h @@ -40,7 +40,7 @@ class ServerContext; namespace flyteidl { namespace service { -// AgentService defines an RPC Service that allows propeller to send the request to the agent server. +// AsyncAgentService defines an RPC Service that allows propeller to send the request to the agent server. class AsyncAgentService final { public: static constexpr char const* service_full_name() { @@ -580,6 +580,383 @@ class AsyncAgentService final { typedef WithStreamedUnaryMethod_CreateTask > > StreamedService; }; +// AgentMetadataService defines an RPC service that is also served over HTTP via grpc-gateway. +// This service allows propeller or users to get the metadata of agents. +class AgentMetadataService final { + public: + static constexpr char const* service_full_name() { + return "flyteidl.service.AgentMetadataService"; + } + class StubInterface { + public: + virtual ~StubInterface() {} + // Fetch a :ref:`ref_flyteidl.admin.Agent` definition. + virtual ::grpc::Status GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::flyteidl::admin::GetAgentResponse* response) = 0; + std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::GetAgentResponse>> AsyncGetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) { + return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::GetAgentResponse>>(AsyncGetAgentRaw(context, request, cq)); + } + std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::GetAgentResponse>> PrepareAsyncGetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) { + return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::GetAgentResponse>>(PrepareAsyncGetAgentRaw(context, request, cq)); + } + // Fetch a list of :ref:`ref_flyteidl.admin.Agent` definitions. + virtual ::grpc::Status ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::flyteidl::admin::ListAgentsResponse* response) = 0; + std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::ListAgentsResponse>> AsyncListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) { + return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::ListAgentsResponse>>(AsyncListAgentsRaw(context, request, cq)); + } + std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::ListAgentsResponse>> PrepareAsyncListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) { + return std::unique_ptr< ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::ListAgentsResponse>>(PrepareAsyncListAgentsRaw(context, request, cq)); + } + class experimental_async_interface { + public: + virtual ~experimental_async_interface() {} + // Fetch a :ref:`ref_flyteidl.admin.Agent` definition. + virtual void GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response, std::function) = 0; + virtual void GetAgent(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::GetAgentResponse* response, std::function) = 0; + virtual void GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) = 0; + virtual void GetAgent(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::GetAgentResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) = 0; + // Fetch a list of :ref:`ref_flyteidl.admin.Agent` definitions. + virtual void ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response, std::function) = 0; + virtual void ListAgents(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::ListAgentsResponse* response, std::function) = 0; + virtual void ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) = 0; + virtual void ListAgents(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::ListAgentsResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) = 0; + }; + virtual class experimental_async_interface* experimental_async() { return nullptr; } + private: + virtual ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::GetAgentResponse>* AsyncGetAgentRaw(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) = 0; + virtual ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::GetAgentResponse>* PrepareAsyncGetAgentRaw(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) = 0; + virtual ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::ListAgentsResponse>* AsyncListAgentsRaw(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) = 0; + virtual ::grpc::ClientAsyncResponseReaderInterface< ::flyteidl::admin::ListAgentsResponse>* PrepareAsyncListAgentsRaw(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) = 0; + }; + class Stub final : public StubInterface { + public: + Stub(const std::shared_ptr< ::grpc::ChannelInterface>& channel); + ::grpc::Status GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::flyteidl::admin::GetAgentResponse* response) override; + std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::GetAgentResponse>> AsyncGetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) { + return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::GetAgentResponse>>(AsyncGetAgentRaw(context, request, cq)); + } + std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::GetAgentResponse>> PrepareAsyncGetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) { + return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::GetAgentResponse>>(PrepareAsyncGetAgentRaw(context, request, cq)); + } + ::grpc::Status ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::flyteidl::admin::ListAgentsResponse* response) override; + std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::ListAgentsResponse>> AsyncListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) { + return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::ListAgentsResponse>>(AsyncListAgentsRaw(context, request, cq)); + } + std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::ListAgentsResponse>> PrepareAsyncListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) { + return std::unique_ptr< ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::ListAgentsResponse>>(PrepareAsyncListAgentsRaw(context, request, cq)); + } + class experimental_async final : + public StubInterface::experimental_async_interface { + public: + void GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response, std::function) override; + void GetAgent(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::GetAgentResponse* response, std::function) override; + void GetAgent(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) override; + void GetAgent(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::GetAgentResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) override; + void ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response, std::function) override; + void ListAgents(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::ListAgentsResponse* response, std::function) override; + void ListAgents(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) override; + void ListAgents(::grpc::ClientContext* context, const ::grpc::ByteBuffer* request, ::flyteidl::admin::ListAgentsResponse* response, ::grpc::experimental::ClientUnaryReactor* reactor) override; + private: + friend class Stub; + explicit experimental_async(Stub* stub): stub_(stub) { } + Stub* stub() { return stub_; } + Stub* stub_; + }; + class experimental_async_interface* experimental_async() override { return &async_stub_; } + + private: + std::shared_ptr< ::grpc::ChannelInterface> channel_; + class experimental_async async_stub_{this}; + ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::GetAgentResponse>* AsyncGetAgentRaw(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) override; + ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::GetAgentResponse>* PrepareAsyncGetAgentRaw(::grpc::ClientContext* context, const ::flyteidl::admin::GetAgentRequest& request, ::grpc::CompletionQueue* cq) override; + ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::ListAgentsResponse>* AsyncListAgentsRaw(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) override; + ::grpc::ClientAsyncResponseReader< ::flyteidl::admin::ListAgentsResponse>* PrepareAsyncListAgentsRaw(::grpc::ClientContext* context, const ::flyteidl::admin::ListAgentsRequest& request, ::grpc::CompletionQueue* cq) override; + const ::grpc::internal::RpcMethod rpcmethod_GetAgent_; + const ::grpc::internal::RpcMethod rpcmethod_ListAgents_; + }; + static std::unique_ptr NewStub(const std::shared_ptr< ::grpc::ChannelInterface>& channel, const ::grpc::StubOptions& options = ::grpc::StubOptions()); + + class Service : public ::grpc::Service { + public: + Service(); + virtual ~Service(); + // Fetch a :ref:`ref_flyteidl.admin.Agent` definition. + virtual ::grpc::Status GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response); + // Fetch a list of :ref:`ref_flyteidl.admin.Agent` definitions. + virtual ::grpc::Status ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response); + }; + template + class WithAsyncMethod_GetAgent : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + WithAsyncMethod_GetAgent() { + ::grpc::Service::MarkMethodAsync(0); + } + ~WithAsyncMethod_GetAgent() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + void RequestGetAgent(::grpc::ServerContext* context, ::flyteidl::admin::GetAgentRequest* request, ::grpc::ServerAsyncResponseWriter< ::flyteidl::admin::GetAgentResponse>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) { + ::grpc::Service::RequestAsyncUnary(0, context, request, response, new_call_cq, notification_cq, tag); + } + }; + template + class WithAsyncMethod_ListAgents : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + WithAsyncMethod_ListAgents() { + ::grpc::Service::MarkMethodAsync(1); + } + ~WithAsyncMethod_ListAgents() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + void RequestListAgents(::grpc::ServerContext* context, ::flyteidl::admin::ListAgentsRequest* request, ::grpc::ServerAsyncResponseWriter< ::flyteidl::admin::ListAgentsResponse>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) { + ::grpc::Service::RequestAsyncUnary(1, context, request, response, new_call_cq, notification_cq, tag); + } + }; + typedef WithAsyncMethod_GetAgent > AsyncService; + template + class ExperimentalWithCallbackMethod_GetAgent : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + ExperimentalWithCallbackMethod_GetAgent() { + ::grpc::Service::experimental().MarkMethodCallback(0, + new ::grpc::internal::CallbackUnaryHandler< ::flyteidl::admin::GetAgentRequest, ::flyteidl::admin::GetAgentResponse>( + [this](::grpc::ServerContext* context, + const ::flyteidl::admin::GetAgentRequest* request, + ::flyteidl::admin::GetAgentResponse* response, + ::grpc::experimental::ServerCallbackRpcController* controller) { + return this->GetAgent(context, request, response, controller); + })); + } + void SetMessageAllocatorFor_GetAgent( + ::grpc::experimental::MessageAllocator< ::flyteidl::admin::GetAgentRequest, ::flyteidl::admin::GetAgentResponse>* allocator) { + static_cast<::grpc::internal::CallbackUnaryHandler< ::flyteidl::admin::GetAgentRequest, ::flyteidl::admin::GetAgentResponse>*>( + ::grpc::Service::experimental().GetHandler(0)) + ->SetMessageAllocator(allocator); + } + ~ExperimentalWithCallbackMethod_GetAgent() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + virtual void GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response, ::grpc::experimental::ServerCallbackRpcController* controller) { controller->Finish(::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "")); } + }; + template + class ExperimentalWithCallbackMethod_ListAgents : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + ExperimentalWithCallbackMethod_ListAgents() { + ::grpc::Service::experimental().MarkMethodCallback(1, + new ::grpc::internal::CallbackUnaryHandler< ::flyteidl::admin::ListAgentsRequest, ::flyteidl::admin::ListAgentsResponse>( + [this](::grpc::ServerContext* context, + const ::flyteidl::admin::ListAgentsRequest* request, + ::flyteidl::admin::ListAgentsResponse* response, + ::grpc::experimental::ServerCallbackRpcController* controller) { + return this->ListAgents(context, request, response, controller); + })); + } + void SetMessageAllocatorFor_ListAgents( + ::grpc::experimental::MessageAllocator< ::flyteidl::admin::ListAgentsRequest, ::flyteidl::admin::ListAgentsResponse>* allocator) { + static_cast<::grpc::internal::CallbackUnaryHandler< ::flyteidl::admin::ListAgentsRequest, ::flyteidl::admin::ListAgentsResponse>*>( + ::grpc::Service::experimental().GetHandler(1)) + ->SetMessageAllocator(allocator); + } + ~ExperimentalWithCallbackMethod_ListAgents() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + virtual void ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response, ::grpc::experimental::ServerCallbackRpcController* controller) { controller->Finish(::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "")); } + }; + typedef ExperimentalWithCallbackMethod_GetAgent > ExperimentalCallbackService; + template + class WithGenericMethod_GetAgent : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + WithGenericMethod_GetAgent() { + ::grpc::Service::MarkMethodGeneric(0); + } + ~WithGenericMethod_GetAgent() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + }; + template + class WithGenericMethod_ListAgents : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + WithGenericMethod_ListAgents() { + ::grpc::Service::MarkMethodGeneric(1); + } + ~WithGenericMethod_ListAgents() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + }; + template + class WithRawMethod_GetAgent : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + WithRawMethod_GetAgent() { + ::grpc::Service::MarkMethodRaw(0); + } + ~WithRawMethod_GetAgent() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + void RequestGetAgent(::grpc::ServerContext* context, ::grpc::ByteBuffer* request, ::grpc::ServerAsyncResponseWriter< ::grpc::ByteBuffer>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) { + ::grpc::Service::RequestAsyncUnary(0, context, request, response, new_call_cq, notification_cq, tag); + } + }; + template + class WithRawMethod_ListAgents : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + WithRawMethod_ListAgents() { + ::grpc::Service::MarkMethodRaw(1); + } + ~WithRawMethod_ListAgents() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + void RequestListAgents(::grpc::ServerContext* context, ::grpc::ByteBuffer* request, ::grpc::ServerAsyncResponseWriter< ::grpc::ByteBuffer>* response, ::grpc::CompletionQueue* new_call_cq, ::grpc::ServerCompletionQueue* notification_cq, void *tag) { + ::grpc::Service::RequestAsyncUnary(1, context, request, response, new_call_cq, notification_cq, tag); + } + }; + template + class ExperimentalWithRawCallbackMethod_GetAgent : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + ExperimentalWithRawCallbackMethod_GetAgent() { + ::grpc::Service::experimental().MarkMethodRawCallback(0, + new ::grpc::internal::CallbackUnaryHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>( + [this](::grpc::ServerContext* context, + const ::grpc::ByteBuffer* request, + ::grpc::ByteBuffer* response, + ::grpc::experimental::ServerCallbackRpcController* controller) { + this->GetAgent(context, request, response, controller); + })); + } + ~ExperimentalWithRawCallbackMethod_GetAgent() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + virtual void GetAgent(::grpc::ServerContext* context, const ::grpc::ByteBuffer* request, ::grpc::ByteBuffer* response, ::grpc::experimental::ServerCallbackRpcController* controller) { controller->Finish(::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "")); } + }; + template + class ExperimentalWithRawCallbackMethod_ListAgents : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + ExperimentalWithRawCallbackMethod_ListAgents() { + ::grpc::Service::experimental().MarkMethodRawCallback(1, + new ::grpc::internal::CallbackUnaryHandler< ::grpc::ByteBuffer, ::grpc::ByteBuffer>( + [this](::grpc::ServerContext* context, + const ::grpc::ByteBuffer* request, + ::grpc::ByteBuffer* response, + ::grpc::experimental::ServerCallbackRpcController* controller) { + this->ListAgents(context, request, response, controller); + })); + } + ~ExperimentalWithRawCallbackMethod_ListAgents() override { + BaseClassMustBeDerivedFromService(this); + } + // disable synchronous version of this method + ::grpc::Status ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + virtual void ListAgents(::grpc::ServerContext* context, const ::grpc::ByteBuffer* request, ::grpc::ByteBuffer* response, ::grpc::experimental::ServerCallbackRpcController* controller) { controller->Finish(::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, "")); } + }; + template + class WithStreamedUnaryMethod_GetAgent : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + WithStreamedUnaryMethod_GetAgent() { + ::grpc::Service::MarkMethodStreamed(0, + new ::grpc::internal::StreamedUnaryHandler< ::flyteidl::admin::GetAgentRequest, ::flyteidl::admin::GetAgentResponse>(std::bind(&WithStreamedUnaryMethod_GetAgent::StreamedGetAgent, this, std::placeholders::_1, std::placeholders::_2))); + } + ~WithStreamedUnaryMethod_GetAgent() override { + BaseClassMustBeDerivedFromService(this); + } + // disable regular version of this method + ::grpc::Status GetAgent(::grpc::ServerContext* context, const ::flyteidl::admin::GetAgentRequest* request, ::flyteidl::admin::GetAgentResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + // replace default version of method with streamed unary + virtual ::grpc::Status StreamedGetAgent(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::flyteidl::admin::GetAgentRequest,::flyteidl::admin::GetAgentResponse>* server_unary_streamer) = 0; + }; + template + class WithStreamedUnaryMethod_ListAgents : public BaseClass { + private: + void BaseClassMustBeDerivedFromService(const Service *service) {} + public: + WithStreamedUnaryMethod_ListAgents() { + ::grpc::Service::MarkMethodStreamed(1, + new ::grpc::internal::StreamedUnaryHandler< ::flyteidl::admin::ListAgentsRequest, ::flyteidl::admin::ListAgentsResponse>(std::bind(&WithStreamedUnaryMethod_ListAgents::StreamedListAgents, this, std::placeholders::_1, std::placeholders::_2))); + } + ~WithStreamedUnaryMethod_ListAgents() override { + BaseClassMustBeDerivedFromService(this); + } + // disable regular version of this method + ::grpc::Status ListAgents(::grpc::ServerContext* context, const ::flyteidl::admin::ListAgentsRequest* request, ::flyteidl::admin::ListAgentsResponse* response) override { + abort(); + return ::grpc::Status(::grpc::StatusCode::UNIMPLEMENTED, ""); + } + // replace default version of method with streamed unary + virtual ::grpc::Status StreamedListAgents(::grpc::ServerContext* context, ::grpc::ServerUnaryStreamer< ::flyteidl::admin::ListAgentsRequest,::flyteidl::admin::ListAgentsResponse>* server_unary_streamer) = 0; + }; + typedef WithStreamedUnaryMethod_GetAgent > StreamedUnaryService; + typedef Service SplitStreamedService; + typedef WithStreamedUnaryMethod_GetAgent > StreamedService; +}; + } // namespace service } // namespace flyteidl diff --git a/flyteidl/gen/pb-cpp/flyteidl/service/agent.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/service/agent.pb.cc index 4963d13cc8..4b7c5d0557 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/service/agent.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/service/agent.pb.cc @@ -38,29 +38,37 @@ ::google::protobuf::internal::AssignDescriptorsTable assign_descriptors_table_fl const char descriptor_table_protodef_flyteidl_2fservice_2fagent_2eproto[] = "\n\034flyteidl/service/agent.proto\022\020flyteidl" - ".service\032\032flyteidl/admin/agent.proto2\217\002\n" - "\021AsyncAgentService\022U\n\nCreateTask\022!.flyte" - "idl.admin.CreateTaskRequest\032\".flyteidl.a" - "dmin.CreateTaskResponse\"\000\022L\n\007GetTask\022\036.f" - "lyteidl.admin.GetTaskRequest\032\037.flyteidl." - "admin.GetTaskResponse\"\000\022U\n\nDeleteTask\022!." - "flyteidl.admin.DeleteTaskRequest\032\".flyte" - "idl.admin.DeleteTaskResponse\"\000B\?Z=github" - ".com/flyteorg/flyte/flyteidl/gen/pb-go/f" - "lyteidl/serviceb\006proto3" + ".service\032\034google/api/annotations.proto\032\032" + "flyteidl/admin/agent.proto2\217\002\n\021AsyncAgen" + "tService\022U\n\nCreateTask\022!.flyteidl.admin." + "CreateTaskRequest\032\".flyteidl.admin.Creat" + "eTaskResponse\"\000\022L\n\007GetTask\022\036.flyteidl.ad" + "min.GetTaskRequest\032\037.flyteidl.admin.GetT" + "askResponse\"\000\022U\n\nDeleteTask\022!.flyteidl.a" + "dmin.DeleteTaskRequest\032\".flyteidl.admin." + "DeleteTaskResponse\"\0002\360\001\n\024AgentMetadataSe" + "rvice\022k\n\010GetAgent\022\037.flyteidl.admin.GetAg" + "entRequest\032 .flyteidl.admin.GetAgentResp" + "onse\"\034\202\323\344\223\002\026\022\024/api/v1/agent/{name}\022k\n\nLi" + "stAgents\022!.flyteidl.admin.ListAgentsRequ" + "est\032\".flyteidl.admin.ListAgentsResponse\"" + "\026\202\323\344\223\002\020\022\016/api/v1/agentsB\?Z=github.com/fl" + "yteorg/flyte/flyteidl/gen/pb-go/flyteidl" + "/serviceb\006proto3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fservice_2fagent_2eproto = { false, InitDefaults_flyteidl_2fservice_2fagent_2eproto, descriptor_table_protodef_flyteidl_2fservice_2fagent_2eproto, - "flyteidl/service/agent.proto", &assign_descriptors_table_flyteidl_2fservice_2fagent_2eproto, 423, + "flyteidl/service/agent.proto", &assign_descriptors_table_flyteidl_2fservice_2fagent_2eproto, 696, }; void AddDescriptors_flyteidl_2fservice_2fagent_2eproto() { - static constexpr ::google::protobuf::internal::InitFunc deps[1] = + static constexpr ::google::protobuf::internal::InitFunc deps[2] = { + ::AddDescriptors_google_2fapi_2fannotations_2eproto, ::AddDescriptors_flyteidl_2fadmin_2fagent_2eproto, }; - ::google::protobuf::internal::AddDescriptors(&descriptor_table_flyteidl_2fservice_2fagent_2eproto, deps, 1); + ::google::protobuf::internal::AddDescriptors(&descriptor_table_flyteidl_2fservice_2fagent_2eproto, deps, 2); } // Force running AddDescriptors() at dynamic initialization time. diff --git a/flyteidl/gen/pb-cpp/flyteidl/service/agent.pb.h b/flyteidl/gen/pb-cpp/flyteidl/service/agent.pb.h index 367d5b767e..2b91672863 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/service/agent.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/service/agent.pb.h @@ -29,6 +29,7 @@ #include #include // IWYU pragma: export #include // IWYU pragma: export +#include "google/api/annotations.pb.h" #include "flyteidl/admin/agent.pb.h" // @@protoc_insertion_point(includes) #include diff --git a/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go b/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go index e070c2e85e..aeb5a70ed1 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go @@ -306,7 +306,7 @@ func (m *GetTaskRequest) GetResourceMeta() []byte { // Response to get an individual task resource. type GetTaskResponse struct { Resource *Resource `protobuf:"bytes,1,opt,name=resource,proto3" json:"resource,omitempty"` - // log information for the task execution. + // log information for the task execution LogLinks []*core.TaskLog `protobuf:"bytes,2,rep,name=log_links,json=logLinks,proto3" json:"log_links,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` @@ -494,6 +494,209 @@ func (m *DeleteTaskResponse) XXX_DiscardUnknown() { var xxx_messageInfo_DeleteTaskResponse proto.InternalMessageInfo +// A message containing the agent metadata. +type Agent struct { + // Name is the developer-assigned name of the agent. + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + // SupportedTaskTypes are the types of the tasks that the agent can handle. + SupportedTaskTypes []string `protobuf:"bytes,2,rep,name=supported_task_types,json=supportedTaskTypes,proto3" json:"supported_task_types,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *Agent) Reset() { *m = Agent{} } +func (m *Agent) String() string { return proto.CompactTextString(m) } +func (*Agent) ProtoMessage() {} +func (*Agent) Descriptor() ([]byte, []int) { + return fileDescriptor_c434e52bb0028071, []int{8} +} + +func (m *Agent) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_Agent.Unmarshal(m, b) +} +func (m *Agent) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_Agent.Marshal(b, m, deterministic) +} +func (m *Agent) XXX_Merge(src proto.Message) { + xxx_messageInfo_Agent.Merge(m, src) +} +func (m *Agent) XXX_Size() int { + return xxx_messageInfo_Agent.Size(m) +} +func (m *Agent) XXX_DiscardUnknown() { + xxx_messageInfo_Agent.DiscardUnknown(m) +} + +var xxx_messageInfo_Agent proto.InternalMessageInfo + +func (m *Agent) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +func (m *Agent) GetSupportedTaskTypes() []string { + if m != nil { + return m.SupportedTaskTypes + } + return nil +} + +// A request to get an agent. +type GetAgentRequest struct { + // The name of the agent. + Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *GetAgentRequest) Reset() { *m = GetAgentRequest{} } +func (m *GetAgentRequest) String() string { return proto.CompactTextString(m) } +func (*GetAgentRequest) ProtoMessage() {} +func (*GetAgentRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_c434e52bb0028071, []int{9} +} + +func (m *GetAgentRequest) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_GetAgentRequest.Unmarshal(m, b) +} +func (m *GetAgentRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_GetAgentRequest.Marshal(b, m, deterministic) +} +func (m *GetAgentRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_GetAgentRequest.Merge(m, src) +} +func (m *GetAgentRequest) XXX_Size() int { + return xxx_messageInfo_GetAgentRequest.Size(m) +} +func (m *GetAgentRequest) XXX_DiscardUnknown() { + xxx_messageInfo_GetAgentRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_GetAgentRequest proto.InternalMessageInfo + +func (m *GetAgentRequest) GetName() string { + if m != nil { + return m.Name + } + return "" +} + +// A response containing an agent. +type GetAgentResponse struct { + Agent *Agent `protobuf:"bytes,1,opt,name=agent,proto3" json:"agent,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *GetAgentResponse) Reset() { *m = GetAgentResponse{} } +func (m *GetAgentResponse) String() string { return proto.CompactTextString(m) } +func (*GetAgentResponse) ProtoMessage() {} +func (*GetAgentResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_c434e52bb0028071, []int{10} +} + +func (m *GetAgentResponse) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_GetAgentResponse.Unmarshal(m, b) +} +func (m *GetAgentResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_GetAgentResponse.Marshal(b, m, deterministic) +} +func (m *GetAgentResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_GetAgentResponse.Merge(m, src) +} +func (m *GetAgentResponse) XXX_Size() int { + return xxx_messageInfo_GetAgentResponse.Size(m) +} +func (m *GetAgentResponse) XXX_DiscardUnknown() { + xxx_messageInfo_GetAgentResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_GetAgentResponse proto.InternalMessageInfo + +func (m *GetAgentResponse) GetAgent() *Agent { + if m != nil { + return m.Agent + } + return nil +} + +// A request to list all agents. +type ListAgentsRequest struct { + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ListAgentsRequest) Reset() { *m = ListAgentsRequest{} } +func (m *ListAgentsRequest) String() string { return proto.CompactTextString(m) } +func (*ListAgentsRequest) ProtoMessage() {} +func (*ListAgentsRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_c434e52bb0028071, []int{11} +} + +func (m *ListAgentsRequest) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_ListAgentsRequest.Unmarshal(m, b) +} +func (m *ListAgentsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_ListAgentsRequest.Marshal(b, m, deterministic) +} +func (m *ListAgentsRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_ListAgentsRequest.Merge(m, src) +} +func (m *ListAgentsRequest) XXX_Size() int { + return xxx_messageInfo_ListAgentsRequest.Size(m) +} +func (m *ListAgentsRequest) XXX_DiscardUnknown() { + xxx_messageInfo_ListAgentsRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_ListAgentsRequest proto.InternalMessageInfo + +// A response containing a list of agents. +type ListAgentsResponse struct { + Agents []*Agent `protobuf:"bytes,1,rep,name=agents,proto3" json:"agents,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` +} + +func (m *ListAgentsResponse) Reset() { *m = ListAgentsResponse{} } +func (m *ListAgentsResponse) String() string { return proto.CompactTextString(m) } +func (*ListAgentsResponse) ProtoMessage() {} +func (*ListAgentsResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_c434e52bb0028071, []int{12} +} + +func (m *ListAgentsResponse) XXX_Unmarshal(b []byte) error { + return xxx_messageInfo_ListAgentsResponse.Unmarshal(m, b) +} +func (m *ListAgentsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + return xxx_messageInfo_ListAgentsResponse.Marshal(b, m, deterministic) +} +func (m *ListAgentsResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_ListAgentsResponse.Merge(m, src) +} +func (m *ListAgentsResponse) XXX_Size() int { + return xxx_messageInfo_ListAgentsResponse.Size(m) +} +func (m *ListAgentsResponse) XXX_DiscardUnknown() { + xxx_messageInfo_ListAgentsResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_ListAgentsResponse proto.InternalMessageInfo + +func (m *ListAgentsResponse) GetAgents() []*Agent { + if m != nil { + return m.Agents + } + return nil +} + func init() { proto.RegisterEnum("flyteidl.admin.State", State_name, State_value) proto.RegisterType((*TaskExecutionMetadata)(nil), "flyteidl.admin.TaskExecutionMetadata") @@ -507,59 +710,70 @@ func init() { proto.RegisterType((*Resource)(nil), "flyteidl.admin.Resource") proto.RegisterType((*DeleteTaskRequest)(nil), "flyteidl.admin.DeleteTaskRequest") proto.RegisterType((*DeleteTaskResponse)(nil), "flyteidl.admin.DeleteTaskResponse") + proto.RegisterType((*Agent)(nil), "flyteidl.admin.Agent") + proto.RegisterType((*GetAgentRequest)(nil), "flyteidl.admin.GetAgentRequest") + proto.RegisterType((*GetAgentResponse)(nil), "flyteidl.admin.GetAgentResponse") + proto.RegisterType((*ListAgentsRequest)(nil), "flyteidl.admin.ListAgentsRequest") + proto.RegisterType((*ListAgentsResponse)(nil), "flyteidl.admin.ListAgentsResponse") } func init() { proto.RegisterFile("flyteidl/admin/agent.proto", fileDescriptor_c434e52bb0028071) } var fileDescriptor_c434e52bb0028071 = []byte{ - // 773 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x55, 0x7f, 0x6f, 0xe3, 0x44, - 0x10, 0x25, 0x49, 0xd3, 0x26, 0x93, 0x5e, 0x2f, 0x59, 0x1a, 0x70, 0x73, 0x07, 0xaa, 0x82, 0x40, - 0x15, 0x08, 0x47, 0xd7, 0x22, 0xe8, 0x81, 0x00, 0xe5, 0x5a, 0x53, 0x45, 0x4a, 0xa3, 0x6a, 0x9b, - 0x20, 0x40, 0x02, 0x6b, 0xe3, 0x4c, 0x8c, 0x15, 0x67, 0xd7, 0x78, 0xd7, 0xd1, 0x45, 0xe2, 0x3f, - 0x24, 0x3e, 0x03, 0x1f, 0x17, 0x79, 0xfd, 0xa3, 0x49, 0x64, 0x50, 0x4f, 0xf7, 0x9f, 0x77, 0xde, - 0x9b, 0x37, 0x6f, 0x67, 0xc6, 0x5a, 0xe8, 0xcc, 0xfd, 0xb5, 0x42, 0x6f, 0xe6, 0xf7, 0xd8, 0x6c, - 0xe9, 0xf1, 0x1e, 0x73, 0x91, 0x2b, 0x33, 0x08, 0x85, 0x12, 0xe4, 0x28, 0xc3, 0x4c, 0x8d, 0x75, - 0x9e, 0xe7, 0x5c, 0x47, 0x84, 0xd8, 0xf3, 0x3d, 0x85, 0x21, 0xf3, 0x65, 0xc2, 0xee, 0x9c, 0x6c, - 0xa3, 0x8a, 0xc9, 0x45, 0x06, 0x7d, 0xb0, 0x0d, 0x79, 0x5c, 0x61, 0x38, 0x67, 0x0e, 0xa6, 0xf0, - 0x87, 0x3b, 0xf0, 0x0c, 0xb9, 0xf2, 0xe6, 0x1e, 0x86, 0xc5, 0xe9, 0xf8, 0x1a, 0x9d, 0x48, 0x79, - 0x82, 0x27, 0x70, 0xf7, 0x9f, 0x2a, 0xb4, 0xc7, 0x4c, 0x2e, 0xac, 0x2c, 0x7e, 0x8b, 0x8a, 0xcd, - 0x98, 0x62, 0x84, 0x42, 0x2b, 0xb6, 0x61, 0xe7, 0x19, 0xb6, 0x37, 0x33, 0x4a, 0xa7, 0xa5, 0xb3, - 0xc6, 0xf9, 0x27, 0x66, 0x7e, 0xb9, 0x58, 0xd4, 0xdc, 0x12, 0x18, 0xe4, 0x0e, 0xe8, 0x53, 0xb5, - 0x0d, 0x90, 0xe7, 0x50, 0xe7, 0x6c, 0x89, 0x32, 0x60, 0x0e, 0x1a, 0xe5, 0xd3, 0xd2, 0x59, 0x9d, - 0x3e, 0x04, 0xc8, 0x00, 0xf6, 0x7d, 0x36, 0x45, 0x5f, 0x1a, 0x95, 0xd3, 0xca, 0x59, 0xe3, 0xfc, - 0x85, 0xb9, 0xdd, 0x43, 0xb3, 0xd0, 0xa8, 0x39, 0xd4, 0x39, 0x16, 0x57, 0xe1, 0x9a, 0xa6, 0x02, - 0xe4, 0x27, 0x68, 0x30, 0xce, 0x85, 0x62, 0x31, 0x53, 0x1a, 0x7b, 0x5a, 0xef, 0xcb, 0xc7, 0xe9, - 0xf5, 0x1f, 0x12, 0x13, 0xd1, 0x4d, 0x29, 0x62, 0xc2, 0xbb, 0x8b, 0x4b, 0x69, 0x4b, 0x0c, 0x57, - 0x9e, 0x83, 0x36, 0x73, 0x1c, 0x11, 0x71, 0x65, 0x54, 0xf5, 0x65, 0x5a, 0x8b, 0x4b, 0x79, 0x9f, - 0x20, 0xfd, 0x04, 0x20, 0x0a, 0xda, 0xc8, 0x57, 0x5e, 0x28, 0xf8, 0x12, 0xb9, 0xb2, 0x57, 0x2c, - 0xf4, 0xd8, 0xd4, 0x47, 0x69, 0xec, 0x6b, 0x4f, 0xdf, 0x3f, 0xce, 0x93, 0xf5, 0x20, 0xf1, 0x63, - 0xa6, 0x90, 0x98, 0x3b, 0xc6, 0x02, 0xa8, 0xf3, 0x12, 0x1a, 0x1b, 0x6d, 0x21, 0x4d, 0xa8, 0x2c, - 0x70, 0xad, 0xa7, 0x57, 0xa7, 0xf1, 0x27, 0x39, 0x86, 0xea, 0x8a, 0xf9, 0x51, 0x36, 0x85, 0xe4, - 0xf0, 0x75, 0xf9, 0xb2, 0xd4, 0xf9, 0x0e, 0x9a, 0xbb, 0x1d, 0x78, 0xa3, 0xfc, 0x1b, 0x38, 0xf9, - 0x4f, 0xb7, 0x6f, 0x22, 0xd4, 0xfd, 0xab, 0x0c, 0xad, 0xab, 0x10, 0x99, 0xc2, 0xb8, 0x27, 0x14, - 0xff, 0x88, 0x50, 0x2a, 0xf2, 0x02, 0xf6, 0x3d, 0x1e, 0x44, 0x4a, 0xa6, 0xbb, 0x78, 0xb2, 0xb3, - 0x8b, 0xc3, 0xe4, 0xc7, 0xba, 0x65, 0x01, 0x4d, 0x89, 0xe4, 0x2b, 0xa8, 0x29, 0x5c, 0x06, 0x3e, - 0x53, 0x49, 0x95, 0xc6, 0xf9, 0xb3, 0x82, 0x05, 0x1e, 0xa7, 0x14, 0x9a, 0x93, 0xc9, 0x47, 0xf0, - 0x44, 0x44, 0x2a, 0x88, 0x94, 0x1d, 0x84, 0x38, 0xf7, 0x5e, 0x1b, 0x15, 0xed, 0xf1, 0x30, 0x09, - 0xde, 0xe9, 0x18, 0xf9, 0x15, 0xde, 0xdf, 0xf9, 0x4f, 0x96, 0xe9, 0xd4, 0x8c, 0x3d, 0x5d, 0xec, - 0xe3, 0x47, 0x8d, 0x98, 0xb6, 0x55, 0x51, 0xb8, 0xfb, 0x12, 0xc8, 0x66, 0x13, 0x64, 0x20, 0xb8, - 0xd4, 0xce, 0x42, 0x94, 0x22, 0x0a, 0x1d, 0xd4, 0xe5, 0x74, 0x33, 0x0e, 0xe9, 0x61, 0x16, 0x8c, - 0xd3, 0xbb, 0x14, 0x8e, 0x6e, 0x50, 0x6d, 0x36, 0xef, 0x19, 0xd4, 0xb5, 0x57, 0xb5, 0x0e, 0x30, - 0x1d, 0x42, 0x2d, 0x0e, 0x8c, 0xd7, 0x41, 0x81, 0x66, 0xb9, 0x40, 0xf3, 0x4f, 0x78, 0x9a, 0x6b, - 0xa6, 0x5e, 0xbe, 0x80, 0x5a, 0x46, 0x49, 0x67, 0x62, 0xec, 0xde, 0x98, 0xa6, 0x38, 0xcd, 0x99, - 0xe4, 0x02, 0xea, 0xbe, 0x70, 0x6d, 0xdf, 0xe3, 0x0b, 0x69, 0x94, 0xf5, 0xbf, 0xf0, 0x5e, 0xc1, - 0x54, 0x86, 0xc2, 0xa5, 0x35, 0x5f, 0xb8, 0xc3, 0x98, 0xd7, 0xfd, 0xbb, 0x04, 0xb5, 0x4c, 0x8b, - 0x7c, 0x06, 0x55, 0xa9, 0xe2, 0x99, 0xc6, 0x45, 0x8f, 0xce, 0xdb, 0xbb, 0x45, 0xef, 0x63, 0x90, - 0x26, 0x1c, 0x72, 0x01, 0x07, 0xc9, 0xd4, 0x64, 0xba, 0x02, 0xff, 0xb3, 0x37, 0x19, 0x93, 0x18, - 0x70, 0xb0, 0x44, 0x29, 0x99, 0x8b, 0xe9, 0xe4, 0xb3, 0x63, 0x77, 0x02, 0xad, 0x6b, 0xf4, 0x71, - 0x7b, 0x35, 0xdf, 0xbe, 0xbb, 0xc7, 0x40, 0x36, 0x65, 0x93, 0x06, 0x7f, 0xfa, 0x1b, 0x54, 0xf5, - 0x5d, 0x48, 0x1b, 0x5a, 0xd4, 0x1a, 0xd3, 0x9f, 0xfb, 0xaf, 0x86, 0x96, 0xfd, 0x43, 0x7f, 0x30, - 0x9c, 0x50, 0xab, 0xf9, 0x4e, 0x1c, 0xbe, 0xb3, 0xe8, 0x6d, 0x7f, 0x64, 0x8d, 0xc6, 0x79, 0xb8, - 0x44, 0x1a, 0x70, 0x70, 0x67, 0x8d, 0xae, 0x07, 0xa3, 0x9b, 0x66, 0x39, 0x3e, 0xd0, 0xc9, 0x68, - 0x14, 0x1f, 0x2a, 0xe4, 0x09, 0xd4, 0xef, 0x27, 0x57, 0x57, 0x96, 0x75, 0x6d, 0x5d, 0x37, 0xf7, - 0x5e, 0x7d, 0xfb, 0xcb, 0x37, 0xae, 0xa7, 0x7e, 0x8f, 0xa6, 0xa6, 0x23, 0x96, 0x3d, 0xdd, 0x16, - 0x11, 0xba, 0xc9, 0x47, 0x2f, 0x7f, 0x3e, 0x5c, 0xe4, 0xbd, 0x60, 0xfa, 0xb9, 0x2b, 0x7a, 0xdb, - 0xaf, 0xde, 0x74, 0x5f, 0xbf, 0x24, 0x17, 0xff, 0x06, 0x00, 0x00, 0xff, 0xff, 0xdc, 0x8d, 0xa5, - 0xb7, 0x0e, 0x07, 0x00, 0x00, + // 869 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x56, 0xf1, 0x6f, 0xdb, 0x44, + 0x14, 0x26, 0x49, 0xd3, 0x26, 0x2f, 0x5d, 0x97, 0xdc, 0x1a, 0x70, 0xb3, 0x81, 0x2a, 0xa3, 0xa1, + 0x8a, 0x69, 0x0e, 0x6b, 0x11, 0x74, 0x20, 0x98, 0xb2, 0xd6, 0x54, 0x95, 0xd2, 0xa8, 0xba, 0xa6, + 0x08, 0x90, 0xc0, 0xba, 0x38, 0xaf, 0xc6, 0x8a, 0x63, 0x1b, 0xdf, 0xb9, 0x5a, 0x24, 0x7e, 0x43, + 0xe2, 0x6f, 0xe0, 0xcf, 0x45, 0xbe, 0x3b, 0xbb, 0x49, 0xf0, 0x50, 0xa7, 0xfd, 0x66, 0xbf, 0xef, + 0xbb, 0xef, 0x7d, 0x7e, 0xdf, 0x5d, 0x2e, 0xd0, 0xbb, 0x09, 0x16, 0x02, 0xfd, 0x69, 0xd0, 0x67, + 0xd3, 0xb9, 0x1f, 0xf6, 0x99, 0x87, 0xa1, 0xb0, 0xe2, 0x24, 0x12, 0x11, 0xd9, 0xc9, 0x31, 0x4b, + 0x62, 0xbd, 0x27, 0x05, 0xd7, 0x8d, 0x12, 0xec, 0x07, 0xbe, 0xc0, 0x84, 0x05, 0x5c, 0xb1, 0x7b, + 0x7b, 0xab, 0xa8, 0x60, 0x7c, 0x96, 0x43, 0x1f, 0xaf, 0x42, 0x7e, 0x28, 0x30, 0xb9, 0x61, 0x2e, + 0x6a, 0xf8, 0x93, 0x35, 0x78, 0x8a, 0xa1, 0xf0, 0x6f, 0x7c, 0x4c, 0xca, 0x97, 0xe3, 0x1b, 0x74, + 0x53, 0xe1, 0x47, 0xa1, 0x82, 0xcd, 0x7f, 0xea, 0xd0, 0x1d, 0x33, 0x3e, 0xb3, 0xf3, 0xfa, 0x05, + 0x0a, 0x36, 0x65, 0x82, 0x11, 0x0a, 0x9d, 0xcc, 0x86, 0x53, 0xac, 0x70, 0xfc, 0xa9, 0x51, 0xd9, + 0xaf, 0x1c, 0xb4, 0x0e, 0x3f, 0xb3, 0x8a, 0x8f, 0xcb, 0x44, 0xad, 0x15, 0x81, 0xf3, 0xc2, 0x01, + 0x7d, 0x28, 0x56, 0x01, 0xf2, 0x04, 0x9a, 0x21, 0x9b, 0x23, 0x8f, 0x99, 0x8b, 0x46, 0x75, 0xbf, + 0x72, 0xd0, 0xa4, 0x77, 0x05, 0x72, 0x0e, 0x9b, 0x01, 0x9b, 0x60, 0xc0, 0x8d, 0xda, 0x7e, 0xed, + 0xa0, 0x75, 0xf8, 0xc2, 0x5a, 0x9d, 0xa1, 0x55, 0x6a, 0xd4, 0x1a, 0xca, 0x35, 0x76, 0x28, 0x92, + 0x05, 0xd5, 0x02, 0xe4, 0x27, 0x68, 0xb1, 0x30, 0x8c, 0x04, 0xcb, 0x98, 0xdc, 0xd8, 0x90, 0x7a, + 0x5f, 0xdd, 0x4f, 0x6f, 0x70, 0xb7, 0x50, 0x89, 0x2e, 0x4b, 0x11, 0x0b, 0x1e, 0xcd, 0x8e, 0xb9, + 0xc3, 0x31, 0xb9, 0xf5, 0x5d, 0x74, 0x98, 0xeb, 0x46, 0x69, 0x28, 0x8c, 0xba, 0xfc, 0x98, 0xce, + 0xec, 0x98, 0x5f, 0x29, 0x64, 0xa0, 0x00, 0x22, 0xa0, 0x8b, 0xe1, 0xad, 0x9f, 0x44, 0xe1, 0x1c, + 0x43, 0xe1, 0xdc, 0xb2, 0xc4, 0x67, 0x93, 0x00, 0xb9, 0xb1, 0x29, 0x3d, 0xbd, 0xba, 0x9f, 0x27, + 0xfb, 0x4e, 0xe2, 0xc7, 0x5c, 0x41, 0x99, 0xdb, 0xc5, 0x12, 0xa8, 0xf7, 0x12, 0x5a, 0x4b, 0x63, + 0x21, 0x6d, 0xa8, 0xcd, 0x70, 0x21, 0xd3, 0x6b, 0xd2, 0xec, 0x91, 0xec, 0x42, 0xfd, 0x96, 0x05, + 0x69, 0x9e, 0x82, 0x7a, 0xf9, 0xa6, 0x7a, 0x5c, 0xe9, 0x7d, 0x0f, 0xed, 0xf5, 0x09, 0xbc, 0xd3, + 0xfa, 0x33, 0xd8, 0x7b, 0xab, 0xdb, 0x77, 0x11, 0x32, 0xff, 0xaa, 0x42, 0xe7, 0x24, 0x41, 0x26, + 0x30, 0x9b, 0x09, 0xc5, 0x3f, 0x52, 0xe4, 0x82, 0xbc, 0x80, 0x4d, 0x3f, 0x8c, 0x53, 0xc1, 0xf5, + 0x5e, 0xdc, 0x5b, 0xdb, 0x8b, 0x43, 0x75, 0xb0, 0x2e, 0x58, 0x4c, 0x35, 0x91, 0x7c, 0x0d, 0x0d, + 0x81, 0xf3, 0x38, 0x60, 0x42, 0x75, 0x69, 0x1d, 0x3e, 0x2e, 0xd9, 0xc0, 0x63, 0x4d, 0xa1, 0x05, + 0x99, 0x7c, 0x0a, 0x0f, 0xa2, 0x54, 0xc4, 0xa9, 0x70, 0xe2, 0x04, 0x6f, 0xfc, 0x37, 0x46, 0x4d, + 0x7a, 0xdc, 0x56, 0xc5, 0x4b, 0x59, 0x23, 0xbf, 0xc2, 0x47, 0x6b, 0xe7, 0x64, 0xae, 0x53, 0x33, + 0x36, 0x64, 0xb3, 0xa7, 0xf7, 0x8a, 0x98, 0x76, 0x45, 0x59, 0xd9, 0x7c, 0x09, 0x64, 0x79, 0x08, + 0x3c, 0x8e, 0x42, 0x2e, 0x9d, 0x25, 0xc8, 0xa3, 0x34, 0x71, 0x51, 0xb6, 0x93, 0xc3, 0xd8, 0xa6, + 0xdb, 0x79, 0x31, 0x5b, 0x6e, 0x52, 0xd8, 0x39, 0x43, 0xb1, 0x3c, 0xbc, 0xc7, 0xd0, 0x94, 0x5e, + 0xc5, 0x22, 0x46, 0x1d, 0x42, 0x23, 0x2b, 0x8c, 0x17, 0x71, 0x89, 0x66, 0xb5, 0x44, 0xf3, 0x4f, + 0x78, 0x58, 0x68, 0x6a, 0x2f, 0x5f, 0x42, 0x23, 0xa7, 0xe8, 0x4c, 0x8c, 0xf5, 0x2f, 0xa6, 0x1a, + 0xa7, 0x05, 0x93, 0x1c, 0x41, 0x33, 0x88, 0x3c, 0x27, 0xf0, 0xc3, 0x19, 0x37, 0xaa, 0xf2, 0x2c, + 0x7c, 0x58, 0x92, 0xca, 0x30, 0xf2, 0x68, 0x23, 0x88, 0xbc, 0x61, 0xc6, 0x33, 0xff, 0xae, 0x40, + 0x23, 0xd7, 0x22, 0xcf, 0xa0, 0xce, 0x45, 0x96, 0x69, 0xd6, 0x74, 0xe7, 0xb0, 0xbb, 0xde, 0xf4, + 0x2a, 0x03, 0xa9, 0xe2, 0x90, 0x23, 0xd8, 0x52, 0xa9, 0x71, 0xbd, 0x05, 0xfe, 0x67, 0xdf, 0xe4, + 0x4c, 0x62, 0xc0, 0xd6, 0x1c, 0x39, 0x67, 0x1e, 0xea, 0xe4, 0xf3, 0x57, 0xf3, 0x1a, 0x3a, 0xa7, + 0x18, 0xe0, 0xea, 0xd6, 0x7c, 0xff, 0xe9, 0xee, 0x02, 0x59, 0x96, 0x55, 0x03, 0x36, 0x2f, 0xa0, + 0x3e, 0xc8, 0x6e, 0x16, 0x42, 0x60, 0x23, 0xfb, 0xb5, 0xd4, 0xda, 0xf2, 0x99, 0x7c, 0x01, 0xbb, + 0x3c, 0x8d, 0xe3, 0x28, 0x11, 0x38, 0x75, 0x8a, 0xf6, 0x6a, 0xa4, 0x4d, 0x4a, 0x0a, 0x6c, 0xac, + 0x8d, 0x70, 0xf3, 0xa9, 0x8c, 0x50, 0x2a, 0xe6, 0xce, 0x4b, 0x84, 0xcd, 0x57, 0xd0, 0xbe, 0xa3, + 0xe9, 0xa8, 0x9f, 0x41, 0x5d, 0xde, 0x71, 0x3a, 0xe7, 0xff, 0x8c, 0x5c, 0xb1, 0x15, 0xc7, 0x7c, + 0x04, 0x9d, 0xa1, 0xcf, 0x95, 0x02, 0xd7, 0x9d, 0xcc, 0x13, 0x20, 0xcb, 0x45, 0xad, 0xfb, 0x1c, + 0x36, 0xe5, 0x9a, 0xec, 0x50, 0xd7, 0xde, 0x2e, 0xac, 0x49, 0x9f, 0xff, 0x06, 0x75, 0x19, 0x2e, + 0xe9, 0x42, 0x87, 0xda, 0x63, 0xfa, 0xf3, 0xe0, 0xf5, 0xd0, 0x76, 0x7e, 0x18, 0x9c, 0x0f, 0xaf, + 0xa9, 0xdd, 0xfe, 0x20, 0x2b, 0x5f, 0xda, 0xf4, 0x62, 0x30, 0xb2, 0x47, 0xe3, 0xa2, 0x5c, 0x21, + 0x2d, 0xd8, 0xba, 0xb4, 0x47, 0xa7, 0xe7, 0xa3, 0xb3, 0x76, 0x35, 0x7b, 0xa1, 0xd7, 0xa3, 0x51, + 0xf6, 0x52, 0x23, 0x0f, 0xa0, 0x79, 0x75, 0x7d, 0x72, 0x62, 0xdb, 0xa7, 0xf6, 0x69, 0x7b, 0xe3, + 0xf5, 0x77, 0xbf, 0x7c, 0xeb, 0xf9, 0xe2, 0xf7, 0x74, 0x62, 0xb9, 0xd1, 0xbc, 0x2f, 0xad, 0x44, + 0x89, 0xa7, 0x1e, 0xfa, 0xc5, 0x7d, 0xea, 0x61, 0xd8, 0x8f, 0x27, 0xcf, 0xbd, 0xa8, 0xbf, 0xfa, + 0x37, 0x60, 0xb2, 0x29, 0xaf, 0xd6, 0xa3, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0x81, 0xa7, 0x12, + 0x0e, 0x1f, 0x08, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.validate.go index 221003b999..c4767d006c 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.validate.go @@ -665,3 +665,360 @@ var _ interface { Cause() error ErrorName() string } = DeleteTaskResponseValidationError{} + +// Validate checks the field values on Agent with the rules defined in the +// proto definition for this message. If any rules are violated, an error is returned. +func (m *Agent) Validate() error { + if m == nil { + return nil + } + + // no validation rules for Name + + return nil +} + +// AgentValidationError is the validation error returned by Agent.Validate if +// the designated constraints aren't met. +type AgentValidationError struct { + field string + reason string + cause error + key bool +} + +// Field function returns field value. +func (e AgentValidationError) Field() string { return e.field } + +// Reason function returns reason value. +func (e AgentValidationError) Reason() string { return e.reason } + +// Cause function returns cause value. +func (e AgentValidationError) Cause() error { return e.cause } + +// Key function returns key value. +func (e AgentValidationError) Key() bool { return e.key } + +// ErrorName returns error name. +func (e AgentValidationError) ErrorName() string { return "AgentValidationError" } + +// Error satisfies the builtin error interface +func (e AgentValidationError) 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 %sAgent.%s: %s%s", + key, + e.field, + e.reason, + cause) +} + +var _ error = AgentValidationError{} + +var _ interface { + Field() string + Reason() string + Key() bool + Cause() error + ErrorName() string +} = AgentValidationError{} + +// Validate checks the field values on GetAgentRequest with the rules defined +// in the proto definition for this message. If any rules are violated, an +// error is returned. +func (m *GetAgentRequest) Validate() error { + if m == nil { + return nil + } + + // no validation rules for Name + + return nil +} + +// GetAgentRequestValidationError is the validation error returned by +// GetAgentRequest.Validate if the designated constraints aren't met. +type GetAgentRequestValidationError struct { + field string + reason string + cause error + key bool +} + +// Field function returns field value. +func (e GetAgentRequestValidationError) Field() string { return e.field } + +// Reason function returns reason value. +func (e GetAgentRequestValidationError) Reason() string { return e.reason } + +// Cause function returns cause value. +func (e GetAgentRequestValidationError) Cause() error { return e.cause } + +// Key function returns key value. +func (e GetAgentRequestValidationError) Key() bool { return e.key } + +// ErrorName returns error name. +func (e GetAgentRequestValidationError) ErrorName() string { return "GetAgentRequestValidationError" } + +// Error satisfies the builtin error interface +func (e GetAgentRequestValidationError) 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 %sGetAgentRequest.%s: %s%s", + key, + e.field, + e.reason, + cause) +} + +var _ error = GetAgentRequestValidationError{} + +var _ interface { + Field() string + Reason() string + Key() bool + Cause() error + ErrorName() string +} = GetAgentRequestValidationError{} + +// Validate checks the field values on GetAgentResponse with the rules defined +// in the proto definition for this message. If any rules are violated, an +// error is returned. +func (m *GetAgentResponse) Validate() error { + if m == nil { + return nil + } + + if v, ok := interface{}(m.GetAgent()).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return GetAgentResponseValidationError{ + field: "Agent", + reason: "embedded message failed validation", + cause: err, + } + } + } + + return nil +} + +// GetAgentResponseValidationError is the validation error returned by +// GetAgentResponse.Validate if the designated constraints aren't met. +type GetAgentResponseValidationError struct { + field string + reason string + cause error + key bool +} + +// Field function returns field value. +func (e GetAgentResponseValidationError) Field() string { return e.field } + +// Reason function returns reason value. +func (e GetAgentResponseValidationError) Reason() string { return e.reason } + +// Cause function returns cause value. +func (e GetAgentResponseValidationError) Cause() error { return e.cause } + +// Key function returns key value. +func (e GetAgentResponseValidationError) Key() bool { return e.key } + +// ErrorName returns error name. +func (e GetAgentResponseValidationError) ErrorName() string { return "GetAgentResponseValidationError" } + +// Error satisfies the builtin error interface +func (e GetAgentResponseValidationError) 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 %sGetAgentResponse.%s: %s%s", + key, + e.field, + e.reason, + cause) +} + +var _ error = GetAgentResponseValidationError{} + +var _ interface { + Field() string + Reason() string + Key() bool + Cause() error + ErrorName() string +} = GetAgentResponseValidationError{} + +// Validate checks the field values on ListAgentsRequest with the rules defined +// in the proto definition for this message. If any rules are violated, an +// error is returned. +func (m *ListAgentsRequest) Validate() error { + if m == nil { + return nil + } + + return nil +} + +// ListAgentsRequestValidationError is the validation error returned by +// ListAgentsRequest.Validate if the designated constraints aren't met. +type ListAgentsRequestValidationError struct { + field string + reason string + cause error + key bool +} + +// Field function returns field value. +func (e ListAgentsRequestValidationError) Field() string { return e.field } + +// Reason function returns reason value. +func (e ListAgentsRequestValidationError) Reason() string { return e.reason } + +// Cause function returns cause value. +func (e ListAgentsRequestValidationError) Cause() error { return e.cause } + +// Key function returns key value. +func (e ListAgentsRequestValidationError) Key() bool { return e.key } + +// ErrorName returns error name. +func (e ListAgentsRequestValidationError) ErrorName() string { + return "ListAgentsRequestValidationError" +} + +// Error satisfies the builtin error interface +func (e ListAgentsRequestValidationError) 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 %sListAgentsRequest.%s: %s%s", + key, + e.field, + e.reason, + cause) +} + +var _ error = ListAgentsRequestValidationError{} + +var _ interface { + Field() string + Reason() string + Key() bool + Cause() error + ErrorName() string +} = ListAgentsRequestValidationError{} + +// Validate checks the field values on ListAgentsResponse with the rules +// defined in the proto definition for this message. If any rules are +// violated, an error is returned. +func (m *ListAgentsResponse) Validate() error { + if m == nil { + return nil + } + + for idx, item := range m.GetAgents() { + _, _ = idx, item + + if v, ok := interface{}(item).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return ListAgentsResponseValidationError{ + field: fmt.Sprintf("Agents[%v]", idx), + reason: "embedded message failed validation", + cause: err, + } + } + } + + } + + return nil +} + +// ListAgentsResponseValidationError is the validation error returned by +// ListAgentsResponse.Validate if the designated constraints aren't met. +type ListAgentsResponseValidationError struct { + field string + reason string + cause error + key bool +} + +// Field function returns field value. +func (e ListAgentsResponseValidationError) Field() string { return e.field } + +// Reason function returns reason value. +func (e ListAgentsResponseValidationError) Reason() string { return e.reason } + +// Cause function returns cause value. +func (e ListAgentsResponseValidationError) Cause() error { return e.cause } + +// Key function returns key value. +func (e ListAgentsResponseValidationError) Key() bool { return e.key } + +// ErrorName returns error name. +func (e ListAgentsResponseValidationError) ErrorName() string { + return "ListAgentsResponseValidationError" +} + +// Error satisfies the builtin error interface +func (e ListAgentsResponseValidationError) 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 %sListAgentsResponse.%s: %s%s", + key, + e.field, + e.reason, + cause) +} + +var _ error = ListAgentsResponseValidationError{} + +var _ interface { + Field() string + Reason() string + Key() bool + Cause() error + ErrorName() string +} = ListAgentsResponseValidationError{} diff --git a/flyteidl/gen/pb-go/flyteidl/service/agent.pb.go b/flyteidl/gen/pb-go/flyteidl/service/agent.pb.go index 274daaf196..c816a1f3ac 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/agent.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/service/agent.pb.go @@ -8,6 +8,7 @@ import ( fmt "fmt" admin "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin" proto "github.com/golang/protobuf/proto" + _ "google.golang.org/genproto/googleapis/api/annotations" grpc "google.golang.org/grpc" codes "google.golang.org/grpc/codes" status "google.golang.org/grpc/status" @@ -28,21 +29,28 @@ const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package func init() { proto.RegisterFile("flyteidl/service/agent.proto", fileDescriptor_f7d1dfd1fb77d2ef) } var fileDescriptor_f7d1dfd1fb77d2ef = []byte{ - // 214 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x92, 0x49, 0xcb, 0xa9, 0x2c, - 0x49, 0xcd, 0x4c, 0xc9, 0xd1, 0x2f, 0x4e, 0x2d, 0x2a, 0xcb, 0x4c, 0x4e, 0xd5, 0x4f, 0x4c, 0x4f, - 0xcd, 0x2b, 0xd1, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x12, 0x80, 0xc9, 0xea, 0x41, 0x65, 0xa5, - 0xa4, 0xe0, 0xea, 0x13, 0x53, 0x72, 0x33, 0xf3, 0x90, 0x55, 0x1b, 0xf5, 0x33, 0x71, 0x09, 0x3a, - 0x16, 0x57, 0xe6, 0x25, 0x3b, 0x82, 0x04, 0x83, 0x21, 0x3a, 0x84, 0x42, 0xb9, 0xb8, 0x9c, 0x8b, - 0x52, 0x13, 0x4b, 0x52, 0x43, 0x12, 0x8b, 0xb3, 0x85, 0x14, 0xf5, 0xe0, 0x46, 0x82, 0x0d, 0xd0, - 0x43, 0xc8, 0x05, 0xa5, 0x16, 0x96, 0xa6, 0x16, 0x97, 0x48, 0x29, 0xe1, 0x53, 0x52, 0x5c, 0x90, - 0x9f, 0x57, 0x9c, 0xaa, 0xc4, 0x20, 0xe4, 0xc3, 0xc5, 0xee, 0x9e, 0x5a, 0x02, 0x36, 0x53, 0x0e, - 0x5d, 0x03, 0x54, 0x02, 0x66, 0xa0, 0x3c, 0x4e, 0x79, 0xb8, 0x69, 0xa1, 0x5c, 0x5c, 0x2e, 0xa9, - 0x39, 0xa9, 0xb8, 0x1c, 0x89, 0x90, 0xc3, 0xe9, 0x48, 0x64, 0x25, 0x30, 0x63, 0x9d, 0xec, 0xa3, - 0x6c, 0xd3, 0x33, 0x4b, 0x32, 0x4a, 0x93, 0xf4, 0x92, 0xf3, 0x73, 0xf5, 0xc1, 0x3a, 0xf2, 0x8b, - 0xd2, 0x21, 0x0c, 0x7d, 0x78, 0x48, 0xa6, 0xa7, 0xe6, 0xe9, 0x17, 0x24, 0xe9, 0xa6, 0xe7, 0xeb, - 0xa3, 0x47, 0x46, 0x12, 0x1b, 0x38, 0x64, 0x8d, 0x01, 0x01, 0x00, 0x00, 0xff, 0xff, 0x92, 0xbb, - 0xf6, 0x3c, 0xa7, 0x01, 0x00, 0x00, + // 324 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x7c, 0x92, 0xbd, 0x4e, 0xf3, 0x30, + 0x14, 0x86, 0xbf, 0xaf, 0x03, 0x20, 0x0f, 0xa8, 0x58, 0x55, 0x87, 0xa8, 0xe2, 0xa7, 0x3b, 0xb1, + 0x28, 0x33, 0x42, 0x05, 0xa4, 0x2e, 0x65, 0x01, 0xba, 0xb0, 0x9d, 0x26, 0x07, 0x63, 0x25, 0xb1, + 0x43, 0x7c, 0x5a, 0xa9, 0x42, 0x2c, 0xdc, 0x00, 0x03, 0x97, 0xc6, 0x2d, 0x70, 0x01, 0x5c, 0x02, + 0xc2, 0xf9, 0xa5, 0x10, 0xb6, 0x28, 0xcf, 0xeb, 0xe7, 0xf5, 0xcf, 0x61, 0x83, 0xbb, 0x78, 0x45, + 0xa8, 0xc2, 0x58, 0x58, 0xcc, 0x96, 0x2a, 0x40, 0x01, 0x12, 0x35, 0xf9, 0x69, 0x66, 0xc8, 0xf0, + 0x6e, 0x49, 0xfd, 0x82, 0x7a, 0x03, 0x69, 0x8c, 0x8c, 0x51, 0x40, 0xaa, 0x04, 0x68, 0x6d, 0x08, + 0x48, 0x19, 0x6d, 0xf3, 0xbc, 0xe7, 0x55, 0x36, 0x08, 0x13, 0xa5, 0x9b, 0xae, 0xd1, 0x4b, 0x87, + 0xed, 0x8c, 0xed, 0x4a, 0x07, 0xe3, 0xaf, 0x9f, 0xd7, 0xb9, 0x8f, 0xcf, 0x18, 0x3b, 0xcf, 0x10, + 0x08, 0x6f, 0xc0, 0x46, 0xfc, 0xc0, 0xaf, 0x0a, 0x9d, 0xc0, 0xaf, 0xd9, 0x15, 0x3e, 0x2c, 0xd0, + 0x92, 0x37, 0xfc, 0x2b, 0x62, 0x53, 0xa3, 0x2d, 0x0e, 0xff, 0xf1, 0x29, 0xdb, 0x9c, 0x20, 0x39, + 0xe7, 0xee, 0xfa, 0x82, 0x02, 0x94, 0xc2, 0xbd, 0x56, 0x5e, 0xd9, 0x66, 0x8c, 0x5d, 0x60, 0x8c, + 0x6d, 0x9b, 0xac, 0x59, 0xeb, 0x26, 0x9b, 0x91, 0x52, 0x3b, 0xfa, 0xf8, 0xcf, 0x7a, 0xee, 0x32, + 0x2e, 0x91, 0x20, 0x04, 0x82, 0xf2, 0x52, 0x22, 0xb6, 0x35, 0x41, 0x72, 0x88, 0xff, 0xb6, 0x3d, + 0x47, 0xca, 0xae, 0xfd, 0xf6, 0x40, 0xd1, 0x34, 0x78, 0x7e, 0x7b, 0x7f, 0xed, 0xf4, 0x79, 0xcf, + 0xbd, 0xda, 0xf2, 0x28, 0x7f, 0x16, 0xf1, 0xa8, 0x21, 0xc1, 0x27, 0x1e, 0x31, 0x36, 0x55, 0x36, + 0x5f, 0x62, 0x7f, 0x1e, 0xae, 0x66, 0xad, 0x87, 0x6b, 0x46, 0x8a, 0xca, 0xbe, 0xab, 0xec, 0xf2, + 0xed, 0x6f, 0x95, 0xf6, 0xec, 0xf4, 0xf6, 0x44, 0x2a, 0xba, 0x5f, 0xcc, 0xfd, 0xc0, 0x24, 0xc2, + 0x79, 0x4c, 0x26, 0xf3, 0x0f, 0x51, 0x0d, 0x8f, 0x44, 0x2d, 0xd2, 0xf9, 0xa1, 0x34, 0x62, 0x7d, + 0x3a, 0xe7, 0x1b, 0x6e, 0x98, 0x8e, 0x3f, 0x03, 0x00, 0x00, 0xff, 0xff, 0xf5, 0x2d, 0xd1, 0xd9, + 0xb8, 0x02, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -202,3 +210,115 @@ var _AsyncAgentService_serviceDesc = grpc.ServiceDesc{ Streams: []grpc.StreamDesc{}, Metadata: "flyteidl/service/agent.proto", } + +// AgentMetadataServiceClient is the client API for AgentMetadataService service. +// +// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. +type AgentMetadataServiceClient interface { + // Fetch a :ref:`ref_flyteidl.admin.Agent` definition. + GetAgent(ctx context.Context, in *admin.GetAgentRequest, opts ...grpc.CallOption) (*admin.GetAgentResponse, error) + // Fetch a list of :ref:`ref_flyteidl.admin.Agent` definitions. + ListAgents(ctx context.Context, in *admin.ListAgentsRequest, opts ...grpc.CallOption) (*admin.ListAgentsResponse, error) +} + +type agentMetadataServiceClient struct { + cc *grpc.ClientConn +} + +func NewAgentMetadataServiceClient(cc *grpc.ClientConn) AgentMetadataServiceClient { + return &agentMetadataServiceClient{cc} +} + +func (c *agentMetadataServiceClient) GetAgent(ctx context.Context, in *admin.GetAgentRequest, opts ...grpc.CallOption) (*admin.GetAgentResponse, error) { + out := new(admin.GetAgentResponse) + err := c.cc.Invoke(ctx, "/flyteidl.service.AgentMetadataService/GetAgent", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *agentMetadataServiceClient) ListAgents(ctx context.Context, in *admin.ListAgentsRequest, opts ...grpc.CallOption) (*admin.ListAgentsResponse, error) { + out := new(admin.ListAgentsResponse) + err := c.cc.Invoke(ctx, "/flyteidl.service.AgentMetadataService/ListAgents", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +// AgentMetadataServiceServer is the server API for AgentMetadataService service. +type AgentMetadataServiceServer interface { + // Fetch a :ref:`ref_flyteidl.admin.Agent` definition. + GetAgent(context.Context, *admin.GetAgentRequest) (*admin.GetAgentResponse, error) + // Fetch a list of :ref:`ref_flyteidl.admin.Agent` definitions. + ListAgents(context.Context, *admin.ListAgentsRequest) (*admin.ListAgentsResponse, error) +} + +// UnimplementedAgentMetadataServiceServer can be embedded to have forward compatible implementations. +type UnimplementedAgentMetadataServiceServer struct { +} + +func (*UnimplementedAgentMetadataServiceServer) GetAgent(ctx context.Context, req *admin.GetAgentRequest) (*admin.GetAgentResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method GetAgent not implemented") +} +func (*UnimplementedAgentMetadataServiceServer) ListAgents(ctx context.Context, req *admin.ListAgentsRequest) (*admin.ListAgentsResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method ListAgents not implemented") +} + +func RegisterAgentMetadataServiceServer(s *grpc.Server, srv AgentMetadataServiceServer) { + s.RegisterService(&_AgentMetadataService_serviceDesc, srv) +} + +func _AgentMetadataService_GetAgent_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(admin.GetAgentRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(AgentMetadataServiceServer).GetAgent(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/flyteidl.service.AgentMetadataService/GetAgent", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(AgentMetadataServiceServer).GetAgent(ctx, req.(*admin.GetAgentRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _AgentMetadataService_ListAgents_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(admin.ListAgentsRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(AgentMetadataServiceServer).ListAgents(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/flyteidl.service.AgentMetadataService/ListAgents", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(AgentMetadataServiceServer).ListAgents(ctx, req.(*admin.ListAgentsRequest)) + } + return interceptor(ctx, in, info, handler) +} + +var _AgentMetadataService_serviceDesc = grpc.ServiceDesc{ + ServiceName: "flyteidl.service.AgentMetadataService", + HandlerType: (*AgentMetadataServiceServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "GetAgent", + Handler: _AgentMetadataService_GetAgent_Handler, + }, + { + MethodName: "ListAgents", + Handler: _AgentMetadataService_ListAgents_Handler, + }, + }, + Streams: []grpc.StreamDesc{}, + Metadata: "flyteidl/service/agent.proto", +} diff --git a/flyteidl/gen/pb-go/flyteidl/service/agent.pb.gw.go b/flyteidl/gen/pb-go/flyteidl/service/agent.pb.gw.go new file mode 100644 index 0000000000..33e7c2fb7f --- /dev/null +++ b/flyteidl/gen/pb-go/flyteidl/service/agent.pb.gw.go @@ -0,0 +1,159 @@ +// Code generated by protoc-gen-grpc-gateway. DO NOT EDIT. +// source: flyteidl/service/agent.proto + +/* +Package service is a reverse proxy. + +It translates gRPC into RESTful JSON APIs. +*/ +package service + +import ( + "context" + "io" + "net/http" + + "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin" + "github.com/golang/protobuf/proto" + "github.com/grpc-ecosystem/grpc-gateway/runtime" + "github.com/grpc-ecosystem/grpc-gateway/utilities" + "google.golang.org/grpc" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/status" +) + +var _ codes.Code +var _ io.Reader +var _ status.Status +var _ = runtime.String +var _ = utilities.NewDoubleArray + +func request_AgentMetadataService_GetAgent_0(ctx context.Context, marshaler runtime.Marshaler, client AgentMetadataServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq admin.GetAgentRequest + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["name"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "name") + } + + protoReq.Name, err = runtime.String(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "name", err) + } + + msg, err := client.GetAgent(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func request_AgentMetadataService_ListAgents_0(ctx context.Context, marshaler runtime.Marshaler, client AgentMetadataServiceClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq admin.ListAgentsRequest + var metadata runtime.ServerMetadata + + msg, err := client.ListAgents(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +// RegisterAgentMetadataServiceHandlerFromEndpoint is same as RegisterAgentMetadataServiceHandler but +// automatically dials to "endpoint" and closes the connection when "ctx" gets done. +func RegisterAgentMetadataServiceHandlerFromEndpoint(ctx context.Context, mux *runtime.ServeMux, endpoint string, opts []grpc.DialOption) (err error) { + conn, err := grpc.Dial(endpoint, opts...) + if err != nil { + return err + } + defer func() { + if err != nil { + if cerr := conn.Close(); cerr != nil { + grpclog.Infof("Failed to close conn to %s: %v", endpoint, cerr) + } + return + } + go func() { + <-ctx.Done() + if cerr := conn.Close(); cerr != nil { + grpclog.Infof("Failed to close conn to %s: %v", endpoint, cerr) + } + }() + }() + + return RegisterAgentMetadataServiceHandler(ctx, mux, conn) +} + +// RegisterAgentMetadataServiceHandler registers the http handlers for service AgentMetadataService to "mux". +// The handlers forward requests to the grpc endpoint over "conn". +func RegisterAgentMetadataServiceHandler(ctx context.Context, mux *runtime.ServeMux, conn *grpc.ClientConn) error { + return RegisterAgentMetadataServiceHandlerClient(ctx, mux, NewAgentMetadataServiceClient(conn)) +} + +// RegisterAgentMetadataServiceHandlerClient registers the http handlers for service AgentMetadataService +// to "mux". The handlers forward requests to the grpc endpoint over the given implementation of "AgentMetadataServiceClient". +// Note: the gRPC framework executes interceptors within the gRPC handler. If the passed in "AgentMetadataServiceClient" +// doesn't go through the normal gRPC flow (creating a gRPC client etc.) then it will be up to the passed in +// "AgentMetadataServiceClient" to call the correct interceptors. +func RegisterAgentMetadataServiceHandlerClient(ctx context.Context, mux *runtime.ServeMux, client AgentMetadataServiceClient) error { + + mux.Handle("GET", pattern_AgentMetadataService_GetAgent_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_AgentMetadataService_GetAgent_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_AgentMetadataService_GetAgent_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + mux.Handle("GET", pattern_AgentMetadataService_ListAgents_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_AgentMetadataService_ListAgents_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_AgentMetadataService_ListAgents_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + + return nil +} + +var ( + pattern_AgentMetadataService_GetAgent_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3}, []string{"api", "v1", "agent", "name"}, "")) + + pattern_AgentMetadataService_ListAgents_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"api", "v1", "agents"}, "")) +) + +var ( + forward_AgentMetadataService_GetAgent_0 = runtime.ForwardResponseMessage + + forward_AgentMetadataService_ListAgents_0 = runtime.ForwardResponseMessage +) diff --git a/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json b/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json index e623c1b872..b9cb5d6b5b 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json +++ b/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json @@ -14,7 +14,51 @@ "produces": [ "application/json" ], - "paths": {}, + "paths": { + "/api/v1/agent/{name}": { + "get": { + "summary": "Send a task create request to the agent server.", + "operationId": "GetAgent", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/adminGetAgentResponse" + } + } + }, + "parameters": [ + { + "name": "name", + "description": "The name of the agent.", + "in": "path", + "required": true, + "type": "string" + } + ], + "tags": [ + "AgentMetadataService" + ] + } + }, + "/api/v1/agents": { + "get": { + "summary": "Get job status.", + "operationId": "ListAgents", + "responses": { + "200": { + "description": "A successful response.", + "schema": { + "$ref": "#/definitions/adminListAgentsResponse" + } + } + }, + "tags": [ + "AgentMetadataService" + ] + } + } + }, "definitions": { "BlobTypeBlobDimensionality": { "type": "string", @@ -172,6 +216,23 @@ ], "default": "UNKNOWN" }, + "adminAgent": { + "type": "object", + "properties": { + "name": { + "type": "string", + "description": "Name is the developer-assigned name of the agent." + }, + "supported_task_types": { + "type": "array", + "items": { + "type": "string" + }, + "description": "SupportedTaskTypes are the types of the tasks that the agent can handle." + } + }, + "description": "A message containing the agent metadata." + }, "adminCreateTaskResponse": { "type": "object", "properties": { @@ -187,6 +248,15 @@ "type": "object", "description": "Response to delete a task." }, + "adminGetAgentResponse": { + "type": "object", + "properties": { + "agent": { + "$ref": "#/definitions/adminAgent" + } + }, + "description": "A response containing an agent." + }, "adminGetTaskResponse": { "type": "object", "properties": { @@ -198,11 +268,23 @@ "items": { "$ref": "#/definitions/coreTaskLog" }, - "description": "log information for the task execution." + "title": "log information for the task execution" } }, "description": "Response to get an individual task resource." }, + "adminListAgentsResponse": { + "type": "object", + "properties": { + "agents": { + "type": "array", + "items": { + "$ref": "#/definitions/adminAgent" + } + } + }, + "description": "A response containing a list of agents." + }, "adminResource": { "type": "object", "properties": { diff --git a/flyteidl/gen/pb-java/flyteidl/admin/Agent.java b/flyteidl/gen/pb-java/flyteidl/admin/AgentOuterClass.java similarity index 62% rename from flyteidl/gen/pb-java/flyteidl/admin/Agent.java rename to flyteidl/gen/pb-java/flyteidl/admin/AgentOuterClass.java index b18c298749..a6fa424d2a 100644 --- a/flyteidl/gen/pb-java/flyteidl/admin/Agent.java +++ b/flyteidl/gen/pb-java/flyteidl/admin/AgentOuterClass.java @@ -3,8 +3,8 @@ package flyteidl.admin; -public final class Agent { - private Agent() {} +public final class AgentOuterClass { + private AgentOuterClass() {} public static void registerAllExtensions( com.google.protobuf.ExtensionRegistryLite registry) { } @@ -117,7 +117,7 @@ public State findValueByNumber(int number) { } public static final com.google.protobuf.Descriptors.EnumDescriptor getDescriptor() { - return flyteidl.admin.Agent.getDescriptor().getEnumTypes().get(0); + return flyteidl.admin.AgentOuterClass.getDescriptor().getEnumTypes().get(0); } private static final State[] VALUES = values(); @@ -500,7 +500,7 @@ private TaskExecutionMetadata( } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_TaskExecutionMetadata_descriptor; + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_TaskExecutionMetadata_descriptor; } @SuppressWarnings({"rawtypes"}) @@ -522,9 +522,9 @@ protected com.google.protobuf.MapField internalGetMapField( @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_TaskExecutionMetadata_fieldAccessorTable + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_TaskExecutionMetadata_fieldAccessorTable .ensureFieldAccessorsInitialized( - flyteidl.admin.Agent.TaskExecutionMetadata.class, flyteidl.admin.Agent.TaskExecutionMetadata.Builder.class); + flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.class, flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.Builder.class); } private int bitField0_; @@ -609,7 +609,7 @@ private static final class LabelsDefaultEntryHolder { java.lang.String, java.lang.String> defaultEntry = com.google.protobuf.MapEntry .newDefaultInstance( - flyteidl.admin.Agent.internal_static_flyteidl_admin_TaskExecutionMetadata_LabelsEntry_descriptor, + flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_TaskExecutionMetadata_LabelsEntry_descriptor, com.google.protobuf.WireFormat.FieldType.STRING, "", com.google.protobuf.WireFormat.FieldType.STRING, @@ -701,7 +701,7 @@ private static final class AnnotationsDefaultEntryHolder { java.lang.String, java.lang.String> defaultEntry = com.google.protobuf.MapEntry .newDefaultInstance( - flyteidl.admin.Agent.internal_static_flyteidl_admin_TaskExecutionMetadata_AnnotationsEntry_descriptor, + flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_TaskExecutionMetadata_AnnotationsEntry_descriptor, com.google.protobuf.WireFormat.FieldType.STRING, "", com.google.protobuf.WireFormat.FieldType.STRING, @@ -835,7 +835,7 @@ private static final class EnvironmentVariablesDefaultEntryHolder { java.lang.String, java.lang.String> defaultEntry = com.google.protobuf.MapEntry .newDefaultInstance( - flyteidl.admin.Agent.internal_static_flyteidl_admin_TaskExecutionMetadata_EnvironmentVariablesEntry_descriptor, + flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_TaskExecutionMetadata_EnvironmentVariablesEntry_descriptor, com.google.protobuf.WireFormat.FieldType.STRING, "", com.google.protobuf.WireFormat.FieldType.STRING, @@ -1021,10 +1021,10 @@ public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } - if (!(obj instanceof flyteidl.admin.Agent.TaskExecutionMetadata)) { + if (!(obj instanceof flyteidl.admin.AgentOuterClass.TaskExecutionMetadata)) { return super.equals(obj); } - flyteidl.admin.Agent.TaskExecutionMetadata other = (flyteidl.admin.Agent.TaskExecutionMetadata) obj; + flyteidl.admin.AgentOuterClass.TaskExecutionMetadata other = (flyteidl.admin.AgentOuterClass.TaskExecutionMetadata) obj; if (hasTaskExecutionId() != other.hasTaskExecutionId()) return false; if (hasTaskExecutionId()) { @@ -1077,69 +1077,69 @@ public int hashCode() { return hash; } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom( java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom(byte[] data) + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom(java.io.InputStream input) + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata 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.admin.Agent.TaskExecutionMetadata parseDelimitedFrom(java.io.InputStream input) + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseDelimitedFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata 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.admin.Agent.TaskExecutionMetadata parseFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } - public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom( + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { @@ -1152,7 +1152,7 @@ public static flyteidl.admin.Agent.TaskExecutionMetadata parseFrom( public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } - public static Builder newBuilder(flyteidl.admin.Agent.TaskExecutionMetadata prototype) { + public static Builder newBuilder(flyteidl.admin.AgentOuterClass.TaskExecutionMetadata prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override @@ -1177,10 +1177,10 @@ protected Builder newBuilderForType( public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements // @@protoc_insertion_point(builder_implements:flyteidl.admin.TaskExecutionMetadata) - flyteidl.admin.Agent.TaskExecutionMetadataOrBuilder { + flyteidl.admin.AgentOuterClass.TaskExecutionMetadataOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_TaskExecutionMetadata_descriptor; + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_TaskExecutionMetadata_descriptor; } @SuppressWarnings({"rawtypes"}) @@ -1216,12 +1216,12 @@ protected com.google.protobuf.MapField internalGetMutableMapField( @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_TaskExecutionMetadata_fieldAccessorTable + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_TaskExecutionMetadata_fieldAccessorTable .ensureFieldAccessorsInitialized( - flyteidl.admin.Agent.TaskExecutionMetadata.class, flyteidl.admin.Agent.TaskExecutionMetadata.Builder.class); + flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.class, flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.Builder.class); } - // Construct using flyteidl.admin.Agent.TaskExecutionMetadata.newBuilder() + // Construct using flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.newBuilder() private Builder() { maybeForceBuilderInitialization(); } @@ -1258,17 +1258,17 @@ public Builder clear() { @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_TaskExecutionMetadata_descriptor; + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_TaskExecutionMetadata_descriptor; } @java.lang.Override - public flyteidl.admin.Agent.TaskExecutionMetadata getDefaultInstanceForType() { - return flyteidl.admin.Agent.TaskExecutionMetadata.getDefaultInstance(); + public flyteidl.admin.AgentOuterClass.TaskExecutionMetadata getDefaultInstanceForType() { + return flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.getDefaultInstance(); } @java.lang.Override - public flyteidl.admin.Agent.TaskExecutionMetadata build() { - flyteidl.admin.Agent.TaskExecutionMetadata result = buildPartial(); + public flyteidl.admin.AgentOuterClass.TaskExecutionMetadata build() { + flyteidl.admin.AgentOuterClass.TaskExecutionMetadata result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } @@ -1276,8 +1276,8 @@ public flyteidl.admin.Agent.TaskExecutionMetadata build() { } @java.lang.Override - public flyteidl.admin.Agent.TaskExecutionMetadata buildPartial() { - flyteidl.admin.Agent.TaskExecutionMetadata result = new flyteidl.admin.Agent.TaskExecutionMetadata(this); + public flyteidl.admin.AgentOuterClass.TaskExecutionMetadata buildPartial() { + flyteidl.admin.AgentOuterClass.TaskExecutionMetadata result = new flyteidl.admin.AgentOuterClass.TaskExecutionMetadata(this); int from_bitField0_ = bitField0_; int to_bitField0_ = 0; if (taskExecutionIdBuilder_ == null) { @@ -1332,16 +1332,16 @@ public Builder addRepeatedField( } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { - if (other instanceof flyteidl.admin.Agent.TaskExecutionMetadata) { - return mergeFrom((flyteidl.admin.Agent.TaskExecutionMetadata)other); + if (other instanceof flyteidl.admin.AgentOuterClass.TaskExecutionMetadata) { + return mergeFrom((flyteidl.admin.AgentOuterClass.TaskExecutionMetadata)other); } else { super.mergeFrom(other); return this; } } - public Builder mergeFrom(flyteidl.admin.Agent.TaskExecutionMetadata other) { - if (other == flyteidl.admin.Agent.TaskExecutionMetadata.getDefaultInstance()) return this; + public Builder mergeFrom(flyteidl.admin.AgentOuterClass.TaskExecutionMetadata other) { + if (other == flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.getDefaultInstance()) return this; if (other.hasTaskExecutionId()) { mergeTaskExecutionId(other.getTaskExecutionId()); } @@ -1374,11 +1374,11 @@ public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { - flyteidl.admin.Agent.TaskExecutionMetadata parsedMessage = null; + flyteidl.admin.AgentOuterClass.TaskExecutionMetadata parsedMessage = null; try { parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { - parsedMessage = (flyteidl.admin.Agent.TaskExecutionMetadata) e.getUnfinishedMessage(); + parsedMessage = (flyteidl.admin.AgentOuterClass.TaskExecutionMetadata) e.getUnfinishedMessage(); throw e.unwrapIOException(); } finally { if (parsedMessage != null) { @@ -2189,12 +2189,12 @@ public final Builder mergeUnknownFields( } // @@protoc_insertion_point(class_scope:flyteidl.admin.TaskExecutionMetadata) - private static final flyteidl.admin.Agent.TaskExecutionMetadata DEFAULT_INSTANCE; + private static final flyteidl.admin.AgentOuterClass.TaskExecutionMetadata DEFAULT_INSTANCE; static { - DEFAULT_INSTANCE = new flyteidl.admin.Agent.TaskExecutionMetadata(); + DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.TaskExecutionMetadata(); } - public static flyteidl.admin.Agent.TaskExecutionMetadata getDefaultInstance() { + public static flyteidl.admin.AgentOuterClass.TaskExecutionMetadata getDefaultInstance() { return DEFAULT_INSTANCE; } @@ -2219,7 +2219,7 @@ public com.google.protobuf.Parser getParserForType() { } @java.lang.Override - public flyteidl.admin.Agent.TaskExecutionMetadata getDefaultInstanceForType() { + public flyteidl.admin.AgentOuterClass.TaskExecutionMetadata getDefaultInstanceForType() { return DEFAULT_INSTANCE; } @@ -2318,7 +2318,7 @@ public interface CreateTaskRequestOrBuilder extends * * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4; */ - flyteidl.admin.Agent.TaskExecutionMetadata getTaskExecutionMetadata(); + flyteidl.admin.AgentOuterClass.TaskExecutionMetadata getTaskExecutionMetadata(); /** *
      * subset of runtime task execution metadata.
@@ -2326,7 +2326,7 @@ public interface CreateTaskRequestOrBuilder extends
      *
      * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
      */
-    flyteidl.admin.Agent.TaskExecutionMetadataOrBuilder getTaskExecutionMetadataOrBuilder();
+    flyteidl.admin.AgentOuterClass.TaskExecutionMetadataOrBuilder getTaskExecutionMetadataOrBuilder();
   }
   /**
    * 
@@ -2405,11 +2405,11 @@ private CreateTaskRequest(
               break;
             }
             case 34: {
-              flyteidl.admin.Agent.TaskExecutionMetadata.Builder subBuilder = null;
+              flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.Builder subBuilder = null;
               if (taskExecutionMetadata_ != null) {
                 subBuilder = taskExecutionMetadata_.toBuilder();
               }
-              taskExecutionMetadata_ = input.readMessage(flyteidl.admin.Agent.TaskExecutionMetadata.parser(), extensionRegistry);
+              taskExecutionMetadata_ = input.readMessage(flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.parser(), extensionRegistry);
               if (subBuilder != null) {
                 subBuilder.mergeFrom(taskExecutionMetadata_);
                 taskExecutionMetadata_ = subBuilder.buildPartial();
@@ -2438,15 +2438,15 @@ private CreateTaskRequest(
     }
     public static final com.google.protobuf.Descriptors.Descriptor
         getDescriptor() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskRequest_descriptor;
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskRequest_descriptor;
     }
 
     @java.lang.Override
     protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
         internalGetFieldAccessorTable() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskRequest_fieldAccessorTable
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskRequest_fieldAccessorTable
           .ensureFieldAccessorsInitialized(
-              flyteidl.admin.Agent.CreateTaskRequest.class, flyteidl.admin.Agent.CreateTaskRequest.Builder.class);
+              flyteidl.admin.AgentOuterClass.CreateTaskRequest.class, flyteidl.admin.AgentOuterClass.CreateTaskRequest.Builder.class);
     }
 
     public static final int INPUTS_FIELD_NUMBER = 1;
@@ -2564,7 +2564,7 @@ public java.lang.String getOutputPrefix() {
     }
 
     public static final int TASK_EXECUTION_METADATA_FIELD_NUMBER = 4;
-    private flyteidl.admin.Agent.TaskExecutionMetadata taskExecutionMetadata_;
+    private flyteidl.admin.AgentOuterClass.TaskExecutionMetadata taskExecutionMetadata_;
     /**
      * 
      * subset of runtime task execution metadata.
@@ -2582,8 +2582,8 @@ public boolean hasTaskExecutionMetadata() {
      *
      * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
      */
-    public flyteidl.admin.Agent.TaskExecutionMetadata getTaskExecutionMetadata() {
-      return taskExecutionMetadata_ == null ? flyteidl.admin.Agent.TaskExecutionMetadata.getDefaultInstance() : taskExecutionMetadata_;
+    public flyteidl.admin.AgentOuterClass.TaskExecutionMetadata getTaskExecutionMetadata() {
+      return taskExecutionMetadata_ == null ? flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.getDefaultInstance() : taskExecutionMetadata_;
     }
     /**
      * 
@@ -2592,7 +2592,7 @@ public flyteidl.admin.Agent.TaskExecutionMetadata getTaskExecutionMetadata() {
      *
      * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
      */
-    public flyteidl.admin.Agent.TaskExecutionMetadataOrBuilder getTaskExecutionMetadataOrBuilder() {
+    public flyteidl.admin.AgentOuterClass.TaskExecutionMetadataOrBuilder getTaskExecutionMetadataOrBuilder() {
       return getTaskExecutionMetadata();
     }
 
@@ -2656,10 +2656,10 @@ public boolean equals(final java.lang.Object obj) {
       if (obj == this) {
        return true;
       }
-      if (!(obj instanceof flyteidl.admin.Agent.CreateTaskRequest)) {
+      if (!(obj instanceof flyteidl.admin.AgentOuterClass.CreateTaskRequest)) {
         return super.equals(obj);
       }
-      flyteidl.admin.Agent.CreateTaskRequest other = (flyteidl.admin.Agent.CreateTaskRequest) obj;
+      flyteidl.admin.AgentOuterClass.CreateTaskRequest other = (flyteidl.admin.AgentOuterClass.CreateTaskRequest) obj;
 
       if (hasInputs() != other.hasInputs()) return false;
       if (hasInputs()) {
@@ -2708,69 +2708,69 @@ public int hashCode() {
       return hash;
     }
 
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(
         java.nio.ByteBuffer data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(
         java.nio.ByteBuffer data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(
         com.google.protobuf.ByteString data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(
         com.google.protobuf.ByteString data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(byte[] data)
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(byte[] data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(
         byte[] data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest 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.admin.Agent.CreateTaskRequest parseDelimitedFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseDelimitedFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseDelimitedWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseDelimitedFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest 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.admin.Agent.CreateTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(
         com.google.protobuf.CodedInputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest parseFrom(
         com.google.protobuf.CodedInputStream input,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws java.io.IOException {
@@ -2783,7 +2783,7 @@ public static flyteidl.admin.Agent.CreateTaskRequest parseFrom(
     public static Builder newBuilder() {
       return DEFAULT_INSTANCE.toBuilder();
     }
-    public static Builder newBuilder(flyteidl.admin.Agent.CreateTaskRequest prototype) {
+    public static Builder newBuilder(flyteidl.admin.AgentOuterClass.CreateTaskRequest prototype) {
       return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
     }
     @java.lang.Override
@@ -2808,21 +2808,21 @@ protected Builder newBuilderForType(
     public static final class Builder extends
         com.google.protobuf.GeneratedMessageV3.Builder implements
         // @@protoc_insertion_point(builder_implements:flyteidl.admin.CreateTaskRequest)
-        flyteidl.admin.Agent.CreateTaskRequestOrBuilder {
+        flyteidl.admin.AgentOuterClass.CreateTaskRequestOrBuilder {
       public static final com.google.protobuf.Descriptors.Descriptor
           getDescriptor() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskRequest_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskRequest_descriptor;
       }
 
       @java.lang.Override
       protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
           internalGetFieldAccessorTable() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskRequest_fieldAccessorTable
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskRequest_fieldAccessorTable
             .ensureFieldAccessorsInitialized(
-                flyteidl.admin.Agent.CreateTaskRequest.class, flyteidl.admin.Agent.CreateTaskRequest.Builder.class);
+                flyteidl.admin.AgentOuterClass.CreateTaskRequest.class, flyteidl.admin.AgentOuterClass.CreateTaskRequest.Builder.class);
       }
 
-      // Construct using flyteidl.admin.Agent.CreateTaskRequest.newBuilder()
+      // Construct using flyteidl.admin.AgentOuterClass.CreateTaskRequest.newBuilder()
       private Builder() {
         maybeForceBuilderInitialization();
       }
@@ -2866,17 +2866,17 @@ public Builder clear() {
       @java.lang.Override
       public com.google.protobuf.Descriptors.Descriptor
           getDescriptorForType() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskRequest_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskRequest_descriptor;
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.CreateTaskRequest getDefaultInstanceForType() {
-        return flyteidl.admin.Agent.CreateTaskRequest.getDefaultInstance();
+      public flyteidl.admin.AgentOuterClass.CreateTaskRequest getDefaultInstanceForType() {
+        return flyteidl.admin.AgentOuterClass.CreateTaskRequest.getDefaultInstance();
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.CreateTaskRequest build() {
-        flyteidl.admin.Agent.CreateTaskRequest result = buildPartial();
+      public flyteidl.admin.AgentOuterClass.CreateTaskRequest build() {
+        flyteidl.admin.AgentOuterClass.CreateTaskRequest result = buildPartial();
         if (!result.isInitialized()) {
           throw newUninitializedMessageException(result);
         }
@@ -2884,8 +2884,8 @@ public flyteidl.admin.Agent.CreateTaskRequest build() {
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.CreateTaskRequest buildPartial() {
-        flyteidl.admin.Agent.CreateTaskRequest result = new flyteidl.admin.Agent.CreateTaskRequest(this);
+      public flyteidl.admin.AgentOuterClass.CreateTaskRequest buildPartial() {
+        flyteidl.admin.AgentOuterClass.CreateTaskRequest result = new flyteidl.admin.AgentOuterClass.CreateTaskRequest(this);
         if (inputsBuilder_ == null) {
           result.inputs_ = inputs_;
         } else {
@@ -2940,16 +2940,16 @@ public Builder addRepeatedField(
       }
       @java.lang.Override
       public Builder mergeFrom(com.google.protobuf.Message other) {
-        if (other instanceof flyteidl.admin.Agent.CreateTaskRequest) {
-          return mergeFrom((flyteidl.admin.Agent.CreateTaskRequest)other);
+        if (other instanceof flyteidl.admin.AgentOuterClass.CreateTaskRequest) {
+          return mergeFrom((flyteidl.admin.AgentOuterClass.CreateTaskRequest)other);
         } else {
           super.mergeFrom(other);
           return this;
         }
       }
 
-      public Builder mergeFrom(flyteidl.admin.Agent.CreateTaskRequest other) {
-        if (other == flyteidl.admin.Agent.CreateTaskRequest.getDefaultInstance()) return this;
+      public Builder mergeFrom(flyteidl.admin.AgentOuterClass.CreateTaskRequest other) {
+        if (other == flyteidl.admin.AgentOuterClass.CreateTaskRequest.getDefaultInstance()) return this;
         if (other.hasInputs()) {
           mergeInputs(other.getInputs());
         }
@@ -2978,11 +2978,11 @@ public Builder mergeFrom(
           com.google.protobuf.CodedInputStream input,
           com.google.protobuf.ExtensionRegistryLite extensionRegistry)
           throws java.io.IOException {
-        flyteidl.admin.Agent.CreateTaskRequest parsedMessage = null;
+        flyteidl.admin.AgentOuterClass.CreateTaskRequest parsedMessage = null;
         try {
           parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
         } catch (com.google.protobuf.InvalidProtocolBufferException e) {
-          parsedMessage = (flyteidl.admin.Agent.CreateTaskRequest) e.getUnfinishedMessage();
+          parsedMessage = (flyteidl.admin.AgentOuterClass.CreateTaskRequest) e.getUnfinishedMessage();
           throw e.unwrapIOException();
         } finally {
           if (parsedMessage != null) {
@@ -3405,9 +3405,9 @@ public Builder setOutputPrefixBytes(
         return this;
       }
 
-      private flyteidl.admin.Agent.TaskExecutionMetadata taskExecutionMetadata_;
+      private flyteidl.admin.AgentOuterClass.TaskExecutionMetadata taskExecutionMetadata_;
       private com.google.protobuf.SingleFieldBuilderV3<
-          flyteidl.admin.Agent.TaskExecutionMetadata, flyteidl.admin.Agent.TaskExecutionMetadata.Builder, flyteidl.admin.Agent.TaskExecutionMetadataOrBuilder> taskExecutionMetadataBuilder_;
+          flyteidl.admin.AgentOuterClass.TaskExecutionMetadata, flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.Builder, flyteidl.admin.AgentOuterClass.TaskExecutionMetadataOrBuilder> taskExecutionMetadataBuilder_;
       /**
        * 
        * subset of runtime task execution metadata.
@@ -3425,9 +3425,9 @@ public boolean hasTaskExecutionMetadata() {
        *
        * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
        */
-      public flyteidl.admin.Agent.TaskExecutionMetadata getTaskExecutionMetadata() {
+      public flyteidl.admin.AgentOuterClass.TaskExecutionMetadata getTaskExecutionMetadata() {
         if (taskExecutionMetadataBuilder_ == null) {
-          return taskExecutionMetadata_ == null ? flyteidl.admin.Agent.TaskExecutionMetadata.getDefaultInstance() : taskExecutionMetadata_;
+          return taskExecutionMetadata_ == null ? flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.getDefaultInstance() : taskExecutionMetadata_;
         } else {
           return taskExecutionMetadataBuilder_.getMessage();
         }
@@ -3439,7 +3439,7 @@ public flyteidl.admin.Agent.TaskExecutionMetadata getTaskExecutionMetadata() {
        *
        * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
        */
-      public Builder setTaskExecutionMetadata(flyteidl.admin.Agent.TaskExecutionMetadata value) {
+      public Builder setTaskExecutionMetadata(flyteidl.admin.AgentOuterClass.TaskExecutionMetadata value) {
         if (taskExecutionMetadataBuilder_ == null) {
           if (value == null) {
             throw new NullPointerException();
@@ -3460,7 +3460,7 @@ public Builder setTaskExecutionMetadata(flyteidl.admin.Agent.TaskExecutionMetada
        * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
        */
       public Builder setTaskExecutionMetadata(
-          flyteidl.admin.Agent.TaskExecutionMetadata.Builder builderForValue) {
+          flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.Builder builderForValue) {
         if (taskExecutionMetadataBuilder_ == null) {
           taskExecutionMetadata_ = builderForValue.build();
           onChanged();
@@ -3477,11 +3477,11 @@ public Builder setTaskExecutionMetadata(
        *
        * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
        */
-      public Builder mergeTaskExecutionMetadata(flyteidl.admin.Agent.TaskExecutionMetadata value) {
+      public Builder mergeTaskExecutionMetadata(flyteidl.admin.AgentOuterClass.TaskExecutionMetadata value) {
         if (taskExecutionMetadataBuilder_ == null) {
           if (taskExecutionMetadata_ != null) {
             taskExecutionMetadata_ =
-              flyteidl.admin.Agent.TaskExecutionMetadata.newBuilder(taskExecutionMetadata_).mergeFrom(value).buildPartial();
+              flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.newBuilder(taskExecutionMetadata_).mergeFrom(value).buildPartial();
           } else {
             taskExecutionMetadata_ = value;
           }
@@ -3517,7 +3517,7 @@ public Builder clearTaskExecutionMetadata() {
        *
        * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
        */
-      public flyteidl.admin.Agent.TaskExecutionMetadata.Builder getTaskExecutionMetadataBuilder() {
+      public flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.Builder getTaskExecutionMetadataBuilder() {
         
         onChanged();
         return getTaskExecutionMetadataFieldBuilder().getBuilder();
@@ -3529,12 +3529,12 @@ public flyteidl.admin.Agent.TaskExecutionMetadata.Builder getTaskExecutionMetada
        *
        * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
        */
-      public flyteidl.admin.Agent.TaskExecutionMetadataOrBuilder getTaskExecutionMetadataOrBuilder() {
+      public flyteidl.admin.AgentOuterClass.TaskExecutionMetadataOrBuilder getTaskExecutionMetadataOrBuilder() {
         if (taskExecutionMetadataBuilder_ != null) {
           return taskExecutionMetadataBuilder_.getMessageOrBuilder();
         } else {
           return taskExecutionMetadata_ == null ?
-              flyteidl.admin.Agent.TaskExecutionMetadata.getDefaultInstance() : taskExecutionMetadata_;
+              flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.getDefaultInstance() : taskExecutionMetadata_;
         }
       }
       /**
@@ -3545,11 +3545,11 @@ public flyteidl.admin.Agent.TaskExecutionMetadataOrBuilder getTaskExecutionMetad
        * .flyteidl.admin.TaskExecutionMetadata task_execution_metadata = 4;
        */
       private com.google.protobuf.SingleFieldBuilderV3<
-          flyteidl.admin.Agent.TaskExecutionMetadata, flyteidl.admin.Agent.TaskExecutionMetadata.Builder, flyteidl.admin.Agent.TaskExecutionMetadataOrBuilder> 
+          flyteidl.admin.AgentOuterClass.TaskExecutionMetadata, flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.Builder, flyteidl.admin.AgentOuterClass.TaskExecutionMetadataOrBuilder> 
           getTaskExecutionMetadataFieldBuilder() {
         if (taskExecutionMetadataBuilder_ == null) {
           taskExecutionMetadataBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
-              flyteidl.admin.Agent.TaskExecutionMetadata, flyteidl.admin.Agent.TaskExecutionMetadata.Builder, flyteidl.admin.Agent.TaskExecutionMetadataOrBuilder>(
+              flyteidl.admin.AgentOuterClass.TaskExecutionMetadata, flyteidl.admin.AgentOuterClass.TaskExecutionMetadata.Builder, flyteidl.admin.AgentOuterClass.TaskExecutionMetadataOrBuilder>(
                   getTaskExecutionMetadata(),
                   getParentForChildren(),
                   isClean());
@@ -3574,12 +3574,12 @@ public final Builder mergeUnknownFields(
     }
 
     // @@protoc_insertion_point(class_scope:flyteidl.admin.CreateTaskRequest)
-    private static final flyteidl.admin.Agent.CreateTaskRequest DEFAULT_INSTANCE;
+    private static final flyteidl.admin.AgentOuterClass.CreateTaskRequest DEFAULT_INSTANCE;
     static {
-      DEFAULT_INSTANCE = new flyteidl.admin.Agent.CreateTaskRequest();
+      DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.CreateTaskRequest();
     }
 
-    public static flyteidl.admin.Agent.CreateTaskRequest getDefaultInstance() {
+    public static flyteidl.admin.AgentOuterClass.CreateTaskRequest getDefaultInstance() {
       return DEFAULT_INSTANCE;
     }
 
@@ -3604,7 +3604,7 @@ public com.google.protobuf.Parser getParserForType() {
     }
 
     @java.lang.Override
-    public flyteidl.admin.Agent.CreateTaskRequest getDefaultInstanceForType() {
+    public flyteidl.admin.AgentOuterClass.CreateTaskRequest getDefaultInstanceForType() {
       return DEFAULT_INSTANCE;
     }
 
@@ -3693,15 +3693,15 @@ private CreateTaskResponse(
     }
     public static final com.google.protobuf.Descriptors.Descriptor
         getDescriptor() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskResponse_descriptor;
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskResponse_descriptor;
     }
 
     @java.lang.Override
     protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
         internalGetFieldAccessorTable() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskResponse_fieldAccessorTable
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskResponse_fieldAccessorTable
           .ensureFieldAccessorsInitialized(
-              flyteidl.admin.Agent.CreateTaskResponse.class, flyteidl.admin.Agent.CreateTaskResponse.Builder.class);
+              flyteidl.admin.AgentOuterClass.CreateTaskResponse.class, flyteidl.admin.AgentOuterClass.CreateTaskResponse.Builder.class);
     }
 
     public static final int RESOURCE_META_FIELD_NUMBER = 1;
@@ -3757,10 +3757,10 @@ public boolean equals(final java.lang.Object obj) {
       if (obj == this) {
        return true;
       }
-      if (!(obj instanceof flyteidl.admin.Agent.CreateTaskResponse)) {
+      if (!(obj instanceof flyteidl.admin.AgentOuterClass.CreateTaskResponse)) {
         return super.equals(obj);
       }
-      flyteidl.admin.Agent.CreateTaskResponse other = (flyteidl.admin.Agent.CreateTaskResponse) obj;
+      flyteidl.admin.AgentOuterClass.CreateTaskResponse other = (flyteidl.admin.AgentOuterClass.CreateTaskResponse) obj;
 
       if (!getResourceMeta()
           .equals(other.getResourceMeta())) return false;
@@ -3782,69 +3782,69 @@ public int hashCode() {
       return hash;
     }
 
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(
         java.nio.ByteBuffer data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(
         java.nio.ByteBuffer data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(
         com.google.protobuf.ByteString data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(
         com.google.protobuf.ByteString data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(byte[] data)
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(byte[] data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(
         byte[] data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse 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.admin.Agent.CreateTaskResponse parseDelimitedFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseDelimitedFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseDelimitedWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseDelimitedFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse 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.admin.Agent.CreateTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(
         com.google.protobuf.CodedInputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse parseFrom(
         com.google.protobuf.CodedInputStream input,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws java.io.IOException {
@@ -3857,7 +3857,7 @@ public static flyteidl.admin.Agent.CreateTaskResponse parseFrom(
     public static Builder newBuilder() {
       return DEFAULT_INSTANCE.toBuilder();
     }
-    public static Builder newBuilder(flyteidl.admin.Agent.CreateTaskResponse prototype) {
+    public static Builder newBuilder(flyteidl.admin.AgentOuterClass.CreateTaskResponse prototype) {
       return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
     }
     @java.lang.Override
@@ -3882,21 +3882,21 @@ protected Builder newBuilderForType(
     public static final class Builder extends
         com.google.protobuf.GeneratedMessageV3.Builder implements
         // @@protoc_insertion_point(builder_implements:flyteidl.admin.CreateTaskResponse)
-        flyteidl.admin.Agent.CreateTaskResponseOrBuilder {
+        flyteidl.admin.AgentOuterClass.CreateTaskResponseOrBuilder {
       public static final com.google.protobuf.Descriptors.Descriptor
           getDescriptor() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskResponse_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskResponse_descriptor;
       }
 
       @java.lang.Override
       protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
           internalGetFieldAccessorTable() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskResponse_fieldAccessorTable
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskResponse_fieldAccessorTable
             .ensureFieldAccessorsInitialized(
-                flyteidl.admin.Agent.CreateTaskResponse.class, flyteidl.admin.Agent.CreateTaskResponse.Builder.class);
+                flyteidl.admin.AgentOuterClass.CreateTaskResponse.class, flyteidl.admin.AgentOuterClass.CreateTaskResponse.Builder.class);
       }
 
-      // Construct using flyteidl.admin.Agent.CreateTaskResponse.newBuilder()
+      // Construct using flyteidl.admin.AgentOuterClass.CreateTaskResponse.newBuilder()
       private Builder() {
         maybeForceBuilderInitialization();
       }
@@ -3922,17 +3922,17 @@ public Builder clear() {
       @java.lang.Override
       public com.google.protobuf.Descriptors.Descriptor
           getDescriptorForType() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_CreateTaskResponse_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_CreateTaskResponse_descriptor;
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.CreateTaskResponse getDefaultInstanceForType() {
-        return flyteidl.admin.Agent.CreateTaskResponse.getDefaultInstance();
+      public flyteidl.admin.AgentOuterClass.CreateTaskResponse getDefaultInstanceForType() {
+        return flyteidl.admin.AgentOuterClass.CreateTaskResponse.getDefaultInstance();
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.CreateTaskResponse build() {
-        flyteidl.admin.Agent.CreateTaskResponse result = buildPartial();
+      public flyteidl.admin.AgentOuterClass.CreateTaskResponse build() {
+        flyteidl.admin.AgentOuterClass.CreateTaskResponse result = buildPartial();
         if (!result.isInitialized()) {
           throw newUninitializedMessageException(result);
         }
@@ -3940,8 +3940,8 @@ public flyteidl.admin.Agent.CreateTaskResponse build() {
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.CreateTaskResponse buildPartial() {
-        flyteidl.admin.Agent.CreateTaskResponse result = new flyteidl.admin.Agent.CreateTaskResponse(this);
+      public flyteidl.admin.AgentOuterClass.CreateTaskResponse buildPartial() {
+        flyteidl.admin.AgentOuterClass.CreateTaskResponse result = new flyteidl.admin.AgentOuterClass.CreateTaskResponse(this);
         result.resourceMeta_ = resourceMeta_;
         onBuilt();
         return result;
@@ -3981,16 +3981,16 @@ public Builder addRepeatedField(
       }
       @java.lang.Override
       public Builder mergeFrom(com.google.protobuf.Message other) {
-        if (other instanceof flyteidl.admin.Agent.CreateTaskResponse) {
-          return mergeFrom((flyteidl.admin.Agent.CreateTaskResponse)other);
+        if (other instanceof flyteidl.admin.AgentOuterClass.CreateTaskResponse) {
+          return mergeFrom((flyteidl.admin.AgentOuterClass.CreateTaskResponse)other);
         } else {
           super.mergeFrom(other);
           return this;
         }
       }
 
-      public Builder mergeFrom(flyteidl.admin.Agent.CreateTaskResponse other) {
-        if (other == flyteidl.admin.Agent.CreateTaskResponse.getDefaultInstance()) return this;
+      public Builder mergeFrom(flyteidl.admin.AgentOuterClass.CreateTaskResponse other) {
+        if (other == flyteidl.admin.AgentOuterClass.CreateTaskResponse.getDefaultInstance()) return this;
         if (other.getResourceMeta() != com.google.protobuf.ByteString.EMPTY) {
           setResourceMeta(other.getResourceMeta());
         }
@@ -4009,11 +4009,11 @@ public Builder mergeFrom(
           com.google.protobuf.CodedInputStream input,
           com.google.protobuf.ExtensionRegistryLite extensionRegistry)
           throws java.io.IOException {
-        flyteidl.admin.Agent.CreateTaskResponse parsedMessage = null;
+        flyteidl.admin.AgentOuterClass.CreateTaskResponse parsedMessage = null;
         try {
           parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
         } catch (com.google.protobuf.InvalidProtocolBufferException e) {
-          parsedMessage = (flyteidl.admin.Agent.CreateTaskResponse) e.getUnfinishedMessage();
+          parsedMessage = (flyteidl.admin.AgentOuterClass.CreateTaskResponse) e.getUnfinishedMessage();
           throw e.unwrapIOException();
         } finally {
           if (parsedMessage != null) {
@@ -4080,12 +4080,12 @@ public final Builder mergeUnknownFields(
     }
 
     // @@protoc_insertion_point(class_scope:flyteidl.admin.CreateTaskResponse)
-    private static final flyteidl.admin.Agent.CreateTaskResponse DEFAULT_INSTANCE;
+    private static final flyteidl.admin.AgentOuterClass.CreateTaskResponse DEFAULT_INSTANCE;
     static {
-      DEFAULT_INSTANCE = new flyteidl.admin.Agent.CreateTaskResponse();
+      DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.CreateTaskResponse();
     }
 
-    public static flyteidl.admin.Agent.CreateTaskResponse getDefaultInstance() {
+    public static flyteidl.admin.AgentOuterClass.CreateTaskResponse getDefaultInstance() {
       return DEFAULT_INSTANCE;
     }
 
@@ -4110,7 +4110,7 @@ public com.google.protobuf.Parser getParserForType() {
     }
 
     @java.lang.Override
-    public flyteidl.admin.Agent.CreateTaskResponse getDefaultInstanceForType() {
+    public flyteidl.admin.AgentOuterClass.CreateTaskResponse getDefaultInstanceForType() {
       return DEFAULT_INSTANCE;
     }
 
@@ -4224,15 +4224,15 @@ private GetTaskRequest(
     }
     public static final com.google.protobuf.Descriptors.Descriptor
         getDescriptor() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskRequest_descriptor;
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskRequest_descriptor;
     }
 
     @java.lang.Override
     protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
         internalGetFieldAccessorTable() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskRequest_fieldAccessorTable
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskRequest_fieldAccessorTable
           .ensureFieldAccessorsInitialized(
-              flyteidl.admin.Agent.GetTaskRequest.class, flyteidl.admin.Agent.GetTaskRequest.Builder.class);
+              flyteidl.admin.AgentOuterClass.GetTaskRequest.class, flyteidl.admin.AgentOuterClass.GetTaskRequest.Builder.class);
     }
 
     public static final int TASK_TYPE_FIELD_NUMBER = 1;
@@ -4336,10 +4336,10 @@ public boolean equals(final java.lang.Object obj) {
       if (obj == this) {
        return true;
       }
-      if (!(obj instanceof flyteidl.admin.Agent.GetTaskRequest)) {
+      if (!(obj instanceof flyteidl.admin.AgentOuterClass.GetTaskRequest)) {
         return super.equals(obj);
       }
-      flyteidl.admin.Agent.GetTaskRequest other = (flyteidl.admin.Agent.GetTaskRequest) obj;
+      flyteidl.admin.AgentOuterClass.GetTaskRequest other = (flyteidl.admin.AgentOuterClass.GetTaskRequest) obj;
 
       if (!getTaskType()
           .equals(other.getTaskType())) return false;
@@ -4365,69 +4365,69 @@ public int hashCode() {
       return hash;
     }
 
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(
         java.nio.ByteBuffer data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(
         java.nio.ByteBuffer data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(
         com.google.protobuf.ByteString data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(
         com.google.protobuf.ByteString data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(byte[] data)
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(byte[] data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(
         byte[] data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest 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.admin.Agent.GetTaskRequest parseDelimitedFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseDelimitedFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseDelimitedWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseDelimitedFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest 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.admin.Agent.GetTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(
         com.google.protobuf.CodedInputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.GetTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest parseFrom(
         com.google.protobuf.CodedInputStream input,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws java.io.IOException {
@@ -4440,7 +4440,7 @@ public static flyteidl.admin.Agent.GetTaskRequest parseFrom(
     public static Builder newBuilder() {
       return DEFAULT_INSTANCE.toBuilder();
     }
-    public static Builder newBuilder(flyteidl.admin.Agent.GetTaskRequest prototype) {
+    public static Builder newBuilder(flyteidl.admin.AgentOuterClass.GetTaskRequest prototype) {
       return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
     }
     @java.lang.Override
@@ -4465,21 +4465,21 @@ protected Builder newBuilderForType(
     public static final class Builder extends
         com.google.protobuf.GeneratedMessageV3.Builder implements
         // @@protoc_insertion_point(builder_implements:flyteidl.admin.GetTaskRequest)
-        flyteidl.admin.Agent.GetTaskRequestOrBuilder {
+        flyteidl.admin.AgentOuterClass.GetTaskRequestOrBuilder {
       public static final com.google.protobuf.Descriptors.Descriptor
           getDescriptor() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskRequest_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskRequest_descriptor;
       }
 
       @java.lang.Override
       protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
           internalGetFieldAccessorTable() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskRequest_fieldAccessorTable
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskRequest_fieldAccessorTable
             .ensureFieldAccessorsInitialized(
-                flyteidl.admin.Agent.GetTaskRequest.class, flyteidl.admin.Agent.GetTaskRequest.Builder.class);
+                flyteidl.admin.AgentOuterClass.GetTaskRequest.class, flyteidl.admin.AgentOuterClass.GetTaskRequest.Builder.class);
       }
 
-      // Construct using flyteidl.admin.Agent.GetTaskRequest.newBuilder()
+      // Construct using flyteidl.admin.AgentOuterClass.GetTaskRequest.newBuilder()
       private Builder() {
         maybeForceBuilderInitialization();
       }
@@ -4507,17 +4507,17 @@ public Builder clear() {
       @java.lang.Override
       public com.google.protobuf.Descriptors.Descriptor
           getDescriptorForType() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskRequest_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskRequest_descriptor;
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.GetTaskRequest getDefaultInstanceForType() {
-        return flyteidl.admin.Agent.GetTaskRequest.getDefaultInstance();
+      public flyteidl.admin.AgentOuterClass.GetTaskRequest getDefaultInstanceForType() {
+        return flyteidl.admin.AgentOuterClass.GetTaskRequest.getDefaultInstance();
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.GetTaskRequest build() {
-        flyteidl.admin.Agent.GetTaskRequest result = buildPartial();
+      public flyteidl.admin.AgentOuterClass.GetTaskRequest build() {
+        flyteidl.admin.AgentOuterClass.GetTaskRequest result = buildPartial();
         if (!result.isInitialized()) {
           throw newUninitializedMessageException(result);
         }
@@ -4525,8 +4525,8 @@ public flyteidl.admin.Agent.GetTaskRequest build() {
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.GetTaskRequest buildPartial() {
-        flyteidl.admin.Agent.GetTaskRequest result = new flyteidl.admin.Agent.GetTaskRequest(this);
+      public flyteidl.admin.AgentOuterClass.GetTaskRequest buildPartial() {
+        flyteidl.admin.AgentOuterClass.GetTaskRequest result = new flyteidl.admin.AgentOuterClass.GetTaskRequest(this);
         result.taskType_ = taskType_;
         result.resourceMeta_ = resourceMeta_;
         onBuilt();
@@ -4567,16 +4567,16 @@ public Builder addRepeatedField(
       }
       @java.lang.Override
       public Builder mergeFrom(com.google.protobuf.Message other) {
-        if (other instanceof flyteidl.admin.Agent.GetTaskRequest) {
-          return mergeFrom((flyteidl.admin.Agent.GetTaskRequest)other);
+        if (other instanceof flyteidl.admin.AgentOuterClass.GetTaskRequest) {
+          return mergeFrom((flyteidl.admin.AgentOuterClass.GetTaskRequest)other);
         } else {
           super.mergeFrom(other);
           return this;
         }
       }
 
-      public Builder mergeFrom(flyteidl.admin.Agent.GetTaskRequest other) {
-        if (other == flyteidl.admin.Agent.GetTaskRequest.getDefaultInstance()) return this;
+      public Builder mergeFrom(flyteidl.admin.AgentOuterClass.GetTaskRequest other) {
+        if (other == flyteidl.admin.AgentOuterClass.GetTaskRequest.getDefaultInstance()) return this;
         if (!other.getTaskType().isEmpty()) {
           taskType_ = other.taskType_;
           onChanged();
@@ -4599,11 +4599,11 @@ public Builder mergeFrom(
           com.google.protobuf.CodedInputStream input,
           com.google.protobuf.ExtensionRegistryLite extensionRegistry)
           throws java.io.IOException {
-        flyteidl.admin.Agent.GetTaskRequest parsedMessage = null;
+        flyteidl.admin.AgentOuterClass.GetTaskRequest parsedMessage = null;
         try {
           parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
         } catch (com.google.protobuf.InvalidProtocolBufferException e) {
-          parsedMessage = (flyteidl.admin.Agent.GetTaskRequest) e.getUnfinishedMessage();
+          parsedMessage = (flyteidl.admin.AgentOuterClass.GetTaskRequest) e.getUnfinishedMessage();
           throw e.unwrapIOException();
         } finally {
           if (parsedMessage != null) {
@@ -4759,12 +4759,12 @@ public final Builder mergeUnknownFields(
     }
 
     // @@protoc_insertion_point(class_scope:flyteidl.admin.GetTaskRequest)
-    private static final flyteidl.admin.Agent.GetTaskRequest DEFAULT_INSTANCE;
+    private static final flyteidl.admin.AgentOuterClass.GetTaskRequest DEFAULT_INSTANCE;
     static {
-      DEFAULT_INSTANCE = new flyteidl.admin.Agent.GetTaskRequest();
+      DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.GetTaskRequest();
     }
 
-    public static flyteidl.admin.Agent.GetTaskRequest getDefaultInstance() {
+    public static flyteidl.admin.AgentOuterClass.GetTaskRequest getDefaultInstance() {
       return DEFAULT_INSTANCE;
     }
 
@@ -4789,7 +4789,7 @@ public com.google.protobuf.Parser getParserForType() {
     }
 
     @java.lang.Override
-    public flyteidl.admin.Agent.GetTaskRequest getDefaultInstanceForType() {
+    public flyteidl.admin.AgentOuterClass.GetTaskRequest getDefaultInstanceForType() {
       return DEFAULT_INSTANCE;
     }
 
@@ -4806,15 +4806,15 @@ public interface GetTaskResponseOrBuilder extends
     /**
      * .flyteidl.admin.Resource resource = 1;
      */
-    flyteidl.admin.Agent.Resource getResource();
+    flyteidl.admin.AgentOuterClass.Resource getResource();
     /**
      * .flyteidl.admin.Resource resource = 1;
      */
-    flyteidl.admin.Agent.ResourceOrBuilder getResourceOrBuilder();
+    flyteidl.admin.AgentOuterClass.ResourceOrBuilder getResourceOrBuilder();
 
     /**
      * 
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -4823,7 +4823,7 @@ public interface GetTaskResponseOrBuilder extends getLogLinksList(); /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -4831,7 +4831,7 @@ public interface GetTaskResponseOrBuilder extends flyteidl.core.Execution.TaskLog getLogLinks(int index); /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -4839,7 +4839,7 @@ public interface GetTaskResponseOrBuilder extends int getLogLinksCount(); /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -4848,7 +4848,7 @@ public interface GetTaskResponseOrBuilder extends getLogLinksOrBuilderList(); /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -4901,11 +4901,11 @@ private GetTaskResponse( done = true; break; case 10: { - flyteidl.admin.Agent.Resource.Builder subBuilder = null; + flyteidl.admin.AgentOuterClass.Resource.Builder subBuilder = null; if (resource_ != null) { subBuilder = resource_.toBuilder(); } - resource_ = input.readMessage(flyteidl.admin.Agent.Resource.parser(), extensionRegistry); + resource_ = input.readMessage(flyteidl.admin.AgentOuterClass.Resource.parser(), extensionRegistry); if (subBuilder != null) { subBuilder.mergeFrom(resource_); resource_ = subBuilder.buildPartial(); @@ -4946,20 +4946,20 @@ private GetTaskResponse( } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskResponse_descriptor; + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskResponse_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskResponse_fieldAccessorTable + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskResponse_fieldAccessorTable .ensureFieldAccessorsInitialized( - flyteidl.admin.Agent.GetTaskResponse.class, flyteidl.admin.Agent.GetTaskResponse.Builder.class); + flyteidl.admin.AgentOuterClass.GetTaskResponse.class, flyteidl.admin.AgentOuterClass.GetTaskResponse.Builder.class); } private int bitField0_; public static final int RESOURCE_FIELD_NUMBER = 1; - private flyteidl.admin.Agent.Resource resource_; + private flyteidl.admin.AgentOuterClass.Resource resource_; /** * .flyteidl.admin.Resource resource = 1; */ @@ -4969,13 +4969,13 @@ public boolean hasResource() { /** * .flyteidl.admin.Resource resource = 1; */ - public flyteidl.admin.Agent.Resource getResource() { - return resource_ == null ? flyteidl.admin.Agent.Resource.getDefaultInstance() : resource_; + public flyteidl.admin.AgentOuterClass.Resource getResource() { + return resource_ == null ? flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance() : resource_; } /** * .flyteidl.admin.Resource resource = 1; */ - public flyteidl.admin.Agent.ResourceOrBuilder getResourceOrBuilder() { + public flyteidl.admin.AgentOuterClass.ResourceOrBuilder getResourceOrBuilder() { return getResource(); } @@ -4983,7 +4983,7 @@ public flyteidl.admin.Agent.ResourceOrBuilder getResourceOrBuilder() { private java.util.List logLinks_; /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -4993,7 +4993,7 @@ public java.util.List getLogLinksList() { } /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5004,7 +5004,7 @@ public java.util.List getLogLinksList() { } /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5014,7 +5014,7 @@ public int getLogLinksCount() { } /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5024,7 +5024,7 @@ public flyteidl.core.Execution.TaskLog getLogLinks(int index) { } /** *
-     * log information for the task execution.
+     * log information for the task execution
      * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5081,10 +5081,10 @@ public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } - if (!(obj instanceof flyteidl.admin.Agent.GetTaskResponse)) { + if (!(obj instanceof flyteidl.admin.AgentOuterClass.GetTaskResponse)) { return super.equals(obj); } - flyteidl.admin.Agent.GetTaskResponse other = (flyteidl.admin.Agent.GetTaskResponse) obj; + flyteidl.admin.AgentOuterClass.GetTaskResponse other = (flyteidl.admin.AgentOuterClass.GetTaskResponse) obj; if (hasResource() != other.hasResource()) return false; if (hasResource()) { @@ -5117,69 +5117,69 @@ public int hashCode() { return hash; } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom( java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom(byte[] data) + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom(java.io.InputStream input) + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse 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.admin.Agent.GetTaskResponse parseDelimitedFrom(java.io.InputStream input) + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input); } - public static flyteidl.admin.Agent.GetTaskResponse parseDelimitedFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse 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.admin.Agent.GetTaskResponse parseFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } - public static flyteidl.admin.Agent.GetTaskResponse parseFrom( + public static flyteidl.admin.AgentOuterClass.GetTaskResponse parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { @@ -5192,7 +5192,7 @@ public static flyteidl.admin.Agent.GetTaskResponse parseFrom( public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } - public static Builder newBuilder(flyteidl.admin.Agent.GetTaskResponse prototype) { + public static Builder newBuilder(flyteidl.admin.AgentOuterClass.GetTaskResponse prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override @@ -5217,21 +5217,21 @@ protected Builder newBuilderForType( public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements // @@protoc_insertion_point(builder_implements:flyteidl.admin.GetTaskResponse) - flyteidl.admin.Agent.GetTaskResponseOrBuilder { + flyteidl.admin.AgentOuterClass.GetTaskResponseOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskResponse_descriptor; + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskResponse_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskResponse_fieldAccessorTable + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskResponse_fieldAccessorTable .ensureFieldAccessorsInitialized( - flyteidl.admin.Agent.GetTaskResponse.class, flyteidl.admin.Agent.GetTaskResponse.Builder.class); + flyteidl.admin.AgentOuterClass.GetTaskResponse.class, flyteidl.admin.AgentOuterClass.GetTaskResponse.Builder.class); } - // Construct using flyteidl.admin.Agent.GetTaskResponse.newBuilder() + // Construct using flyteidl.admin.AgentOuterClass.GetTaskResponse.newBuilder() private Builder() { maybeForceBuilderInitialization(); } @@ -5268,17 +5268,17 @@ public Builder clear() { @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { - return flyteidl.admin.Agent.internal_static_flyteidl_admin_GetTaskResponse_descriptor; + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetTaskResponse_descriptor; } @java.lang.Override - public flyteidl.admin.Agent.GetTaskResponse getDefaultInstanceForType() { - return flyteidl.admin.Agent.GetTaskResponse.getDefaultInstance(); + public flyteidl.admin.AgentOuterClass.GetTaskResponse getDefaultInstanceForType() { + return flyteidl.admin.AgentOuterClass.GetTaskResponse.getDefaultInstance(); } @java.lang.Override - public flyteidl.admin.Agent.GetTaskResponse build() { - flyteidl.admin.Agent.GetTaskResponse result = buildPartial(); + public flyteidl.admin.AgentOuterClass.GetTaskResponse build() { + flyteidl.admin.AgentOuterClass.GetTaskResponse result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } @@ -5286,8 +5286,8 @@ public flyteidl.admin.Agent.GetTaskResponse build() { } @java.lang.Override - public flyteidl.admin.Agent.GetTaskResponse buildPartial() { - flyteidl.admin.Agent.GetTaskResponse result = new flyteidl.admin.Agent.GetTaskResponse(this); + public flyteidl.admin.AgentOuterClass.GetTaskResponse buildPartial() { + flyteidl.admin.AgentOuterClass.GetTaskResponse result = new flyteidl.admin.AgentOuterClass.GetTaskResponse(this); int from_bitField0_ = bitField0_; int to_bitField0_ = 0; if (resourceBuilder_ == null) { @@ -5343,16 +5343,16 @@ public Builder addRepeatedField( } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { - if (other instanceof flyteidl.admin.Agent.GetTaskResponse) { - return mergeFrom((flyteidl.admin.Agent.GetTaskResponse)other); + if (other instanceof flyteidl.admin.AgentOuterClass.GetTaskResponse) { + return mergeFrom((flyteidl.admin.AgentOuterClass.GetTaskResponse)other); } else { super.mergeFrom(other); return this; } } - public Builder mergeFrom(flyteidl.admin.Agent.GetTaskResponse other) { - if (other == flyteidl.admin.Agent.GetTaskResponse.getDefaultInstance()) return this; + public Builder mergeFrom(flyteidl.admin.AgentOuterClass.GetTaskResponse other) { + if (other == flyteidl.admin.AgentOuterClass.GetTaskResponse.getDefaultInstance()) return this; if (other.hasResource()) { mergeResource(other.getResource()); } @@ -5397,11 +5397,11 @@ public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { - flyteidl.admin.Agent.GetTaskResponse parsedMessage = null; + flyteidl.admin.AgentOuterClass.GetTaskResponse parsedMessage = null; try { parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { - parsedMessage = (flyteidl.admin.Agent.GetTaskResponse) e.getUnfinishedMessage(); + parsedMessage = (flyteidl.admin.AgentOuterClass.GetTaskResponse) e.getUnfinishedMessage(); throw e.unwrapIOException(); } finally { if (parsedMessage != null) { @@ -5412,9 +5412,9 @@ public Builder mergeFrom( } private int bitField0_; - private flyteidl.admin.Agent.Resource resource_; + private flyteidl.admin.AgentOuterClass.Resource resource_; private com.google.protobuf.SingleFieldBuilderV3< - flyteidl.admin.Agent.Resource, flyteidl.admin.Agent.Resource.Builder, flyteidl.admin.Agent.ResourceOrBuilder> resourceBuilder_; + flyteidl.admin.AgentOuterClass.Resource, flyteidl.admin.AgentOuterClass.Resource.Builder, flyteidl.admin.AgentOuterClass.ResourceOrBuilder> resourceBuilder_; /** * .flyteidl.admin.Resource resource = 1; */ @@ -5424,9 +5424,9 @@ public boolean hasResource() { /** * .flyteidl.admin.Resource resource = 1; */ - public flyteidl.admin.Agent.Resource getResource() { + public flyteidl.admin.AgentOuterClass.Resource getResource() { if (resourceBuilder_ == null) { - return resource_ == null ? flyteidl.admin.Agent.Resource.getDefaultInstance() : resource_; + return resource_ == null ? flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance() : resource_; } else { return resourceBuilder_.getMessage(); } @@ -5434,7 +5434,7 @@ public flyteidl.admin.Agent.Resource getResource() { /** * .flyteidl.admin.Resource resource = 1; */ - public Builder setResource(flyteidl.admin.Agent.Resource value) { + public Builder setResource(flyteidl.admin.AgentOuterClass.Resource value) { if (resourceBuilder_ == null) { if (value == null) { throw new NullPointerException(); @@ -5451,7 +5451,7 @@ public Builder setResource(flyteidl.admin.Agent.Resource value) { * .flyteidl.admin.Resource resource = 1; */ public Builder setResource( - flyteidl.admin.Agent.Resource.Builder builderForValue) { + flyteidl.admin.AgentOuterClass.Resource.Builder builderForValue) { if (resourceBuilder_ == null) { resource_ = builderForValue.build(); onChanged(); @@ -5464,11 +5464,11 @@ public Builder setResource( /** * .flyteidl.admin.Resource resource = 1; */ - public Builder mergeResource(flyteidl.admin.Agent.Resource value) { + public Builder mergeResource(flyteidl.admin.AgentOuterClass.Resource value) { if (resourceBuilder_ == null) { if (resource_ != null) { resource_ = - flyteidl.admin.Agent.Resource.newBuilder(resource_).mergeFrom(value).buildPartial(); + flyteidl.admin.AgentOuterClass.Resource.newBuilder(resource_).mergeFrom(value).buildPartial(); } else { resource_ = value; } @@ -5496,7 +5496,7 @@ public Builder clearResource() { /** * .flyteidl.admin.Resource resource = 1; */ - public flyteidl.admin.Agent.Resource.Builder getResourceBuilder() { + public flyteidl.admin.AgentOuterClass.Resource.Builder getResourceBuilder() { onChanged(); return getResourceFieldBuilder().getBuilder(); @@ -5504,23 +5504,23 @@ public flyteidl.admin.Agent.Resource.Builder getResourceBuilder() { /** * .flyteidl.admin.Resource resource = 1; */ - public flyteidl.admin.Agent.ResourceOrBuilder getResourceOrBuilder() { + public flyteidl.admin.AgentOuterClass.ResourceOrBuilder getResourceOrBuilder() { if (resourceBuilder_ != null) { return resourceBuilder_.getMessageOrBuilder(); } else { return resource_ == null ? - flyteidl.admin.Agent.Resource.getDefaultInstance() : resource_; + flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance() : resource_; } } /** * .flyteidl.admin.Resource resource = 1; */ private com.google.protobuf.SingleFieldBuilderV3< - flyteidl.admin.Agent.Resource, flyteidl.admin.Agent.Resource.Builder, flyteidl.admin.Agent.ResourceOrBuilder> + flyteidl.admin.AgentOuterClass.Resource, flyteidl.admin.AgentOuterClass.Resource.Builder, flyteidl.admin.AgentOuterClass.ResourceOrBuilder> getResourceFieldBuilder() { if (resourceBuilder_ == null) { resourceBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< - flyteidl.admin.Agent.Resource, flyteidl.admin.Agent.Resource.Builder, flyteidl.admin.Agent.ResourceOrBuilder>( + flyteidl.admin.AgentOuterClass.Resource, flyteidl.admin.AgentOuterClass.Resource.Builder, flyteidl.admin.AgentOuterClass.ResourceOrBuilder>( getResource(), getParentForChildren(), isClean()); @@ -5543,7 +5543,7 @@ private void ensureLogLinksIsMutable() { /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5557,7 +5557,7 @@ public java.util.List getLogLinksList() { } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5571,7 +5571,7 @@ public int getLogLinksCount() { } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5585,7 +5585,7 @@ public flyteidl.core.Execution.TaskLog getLogLinks(int index) { } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5606,7 +5606,7 @@ public Builder setLogLinks( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5624,7 +5624,7 @@ public Builder setLogLinks( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5644,7 +5644,7 @@ public Builder addLogLinks(flyteidl.core.Execution.TaskLog value) { } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5665,7 +5665,7 @@ public Builder addLogLinks( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5683,7 +5683,7 @@ public Builder addLogLinks( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5701,7 +5701,7 @@ public Builder addLogLinks( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5720,7 +5720,7 @@ public Builder addAllLogLinks( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5737,7 +5737,7 @@ public Builder clearLogLinks() { } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5754,7 +5754,7 @@ public Builder removeLogLinks(int index) { } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5765,7 +5765,7 @@ public flyteidl.core.Execution.TaskLog.Builder getLogLinksBuilder( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5779,7 +5779,7 @@ public flyteidl.core.Execution.TaskLogOrBuilder getLogLinksOrBuilder( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5794,7 +5794,7 @@ public flyteidl.core.Execution.TaskLogOrBuilder getLogLinksOrBuilder( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5805,7 +5805,7 @@ public flyteidl.core.Execution.TaskLog.Builder addLogLinksBuilder() { } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5817,7 +5817,7 @@ public flyteidl.core.Execution.TaskLog.Builder addLogLinksBuilder( } /** *
-       * log information for the task execution.
+       * log information for the task execution
        * 
* * repeated .flyteidl.core.TaskLog log_links = 2; @@ -5857,12 +5857,12 @@ public final Builder mergeUnknownFields( } // @@protoc_insertion_point(class_scope:flyteidl.admin.GetTaskResponse) - private static final flyteidl.admin.Agent.GetTaskResponse DEFAULT_INSTANCE; + private static final flyteidl.admin.AgentOuterClass.GetTaskResponse DEFAULT_INSTANCE; static { - DEFAULT_INSTANCE = new flyteidl.admin.Agent.GetTaskResponse(); + DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.GetTaskResponse(); } - public static flyteidl.admin.Agent.GetTaskResponse getDefaultInstance() { + public static flyteidl.admin.AgentOuterClass.GetTaskResponse getDefaultInstance() { return DEFAULT_INSTANCE; } @@ -5887,7 +5887,7 @@ public com.google.protobuf.Parser getParserForType() { } @java.lang.Override - public flyteidl.admin.Agent.GetTaskResponse getDefaultInstanceForType() { + public flyteidl.admin.AgentOuterClass.GetTaskResponse getDefaultInstanceForType() { return DEFAULT_INSTANCE; } @@ -5912,7 +5912,7 @@ public interface ResourceOrBuilder extends * * .flyteidl.admin.State state = 1; */ - flyteidl.admin.Agent.State getState(); + flyteidl.admin.AgentOuterClass.State getState(); /** *
@@ -6050,15 +6050,15 @@ private Resource(
     }
     public static final com.google.protobuf.Descriptors.Descriptor
         getDescriptor() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_Resource_descriptor;
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Resource_descriptor;
     }
 
     @java.lang.Override
     protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
         internalGetFieldAccessorTable() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_Resource_fieldAccessorTable
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Resource_fieldAccessorTable
           .ensureFieldAccessorsInitialized(
-              flyteidl.admin.Agent.Resource.class, flyteidl.admin.Agent.Resource.Builder.class);
+              flyteidl.admin.AgentOuterClass.Resource.class, flyteidl.admin.AgentOuterClass.Resource.Builder.class);
     }
 
     public static final int STATE_FIELD_NUMBER = 1;
@@ -6080,10 +6080,10 @@ public int getStateValue() {
      *
      * .flyteidl.admin.State state = 1;
      */
-    public flyteidl.admin.Agent.State getState() {
+    public flyteidl.admin.AgentOuterClass.State getState() {
       @SuppressWarnings("deprecation")
-      flyteidl.admin.Agent.State result = flyteidl.admin.Agent.State.valueOf(state_);
-      return result == null ? flyteidl.admin.Agent.State.UNRECOGNIZED : result;
+      flyteidl.admin.AgentOuterClass.State result = flyteidl.admin.AgentOuterClass.State.valueOf(state_);
+      return result == null ? flyteidl.admin.AgentOuterClass.State.UNRECOGNIZED : result;
     }
 
     public static final int OUTPUTS_FIELD_NUMBER = 2;
@@ -6181,7 +6181,7 @@ public final boolean isInitialized() {
     @java.lang.Override
     public void writeTo(com.google.protobuf.CodedOutputStream output)
                         throws java.io.IOException {
-      if (state_ != flyteidl.admin.Agent.State.RETRYABLE_FAILURE.getNumber()) {
+      if (state_ != flyteidl.admin.AgentOuterClass.State.RETRYABLE_FAILURE.getNumber()) {
         output.writeEnum(1, state_);
       }
       if (outputs_ != null) {
@@ -6199,7 +6199,7 @@ public int getSerializedSize() {
       if (size != -1) return size;
 
       size = 0;
-      if (state_ != flyteidl.admin.Agent.State.RETRYABLE_FAILURE.getNumber()) {
+      if (state_ != flyteidl.admin.AgentOuterClass.State.RETRYABLE_FAILURE.getNumber()) {
         size += com.google.protobuf.CodedOutputStream
           .computeEnumSize(1, state_);
       }
@@ -6220,10 +6220,10 @@ public boolean equals(final java.lang.Object obj) {
       if (obj == this) {
        return true;
       }
-      if (!(obj instanceof flyteidl.admin.Agent.Resource)) {
+      if (!(obj instanceof flyteidl.admin.AgentOuterClass.Resource)) {
         return super.equals(obj);
       }
-      flyteidl.admin.Agent.Resource other = (flyteidl.admin.Agent.Resource) obj;
+      flyteidl.admin.AgentOuterClass.Resource other = (flyteidl.admin.AgentOuterClass.Resource) obj;
 
       if (state_ != other.state_) return false;
       if (hasOutputs() != other.hasOutputs()) return false;
@@ -6257,69 +6257,69 @@ public int hashCode() {
       return hash;
     }
 
-    public static flyteidl.admin.Agent.Resource parseFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(
         java.nio.ByteBuffer data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.Resource parseFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(
         java.nio.ByteBuffer data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.Resource parseFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(
         com.google.protobuf.ByteString data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.Resource parseFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(
         com.google.protobuf.ByteString data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.Resource parseFrom(byte[] data)
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(byte[] data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.Resource parseFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(
         byte[] data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.Resource parseFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.Resource parseFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource 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.admin.Agent.Resource parseDelimitedFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.Resource parseDelimitedFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseDelimitedWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.Resource parseDelimitedFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource 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.admin.Agent.Resource parseFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(
         com.google.protobuf.CodedInputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.Resource parseFrom(
+    public static flyteidl.admin.AgentOuterClass.Resource parseFrom(
         com.google.protobuf.CodedInputStream input,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws java.io.IOException {
@@ -6332,7 +6332,7 @@ public static flyteidl.admin.Agent.Resource parseFrom(
     public static Builder newBuilder() {
       return DEFAULT_INSTANCE.toBuilder();
     }
-    public static Builder newBuilder(flyteidl.admin.Agent.Resource prototype) {
+    public static Builder newBuilder(flyteidl.admin.AgentOuterClass.Resource prototype) {
       return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
     }
     @java.lang.Override
@@ -6353,21 +6353,21 @@ protected Builder newBuilderForType(
     public static final class Builder extends
         com.google.protobuf.GeneratedMessageV3.Builder implements
         // @@protoc_insertion_point(builder_implements:flyteidl.admin.Resource)
-        flyteidl.admin.Agent.ResourceOrBuilder {
+        flyteidl.admin.AgentOuterClass.ResourceOrBuilder {
       public static final com.google.protobuf.Descriptors.Descriptor
           getDescriptor() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_Resource_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Resource_descriptor;
       }
 
       @java.lang.Override
       protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
           internalGetFieldAccessorTable() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_Resource_fieldAccessorTable
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Resource_fieldAccessorTable
             .ensureFieldAccessorsInitialized(
-                flyteidl.admin.Agent.Resource.class, flyteidl.admin.Agent.Resource.Builder.class);
+                flyteidl.admin.AgentOuterClass.Resource.class, flyteidl.admin.AgentOuterClass.Resource.Builder.class);
       }
 
-      // Construct using flyteidl.admin.Agent.Resource.newBuilder()
+      // Construct using flyteidl.admin.AgentOuterClass.Resource.newBuilder()
       private Builder() {
         maybeForceBuilderInitialization();
       }
@@ -6401,17 +6401,17 @@ public Builder clear() {
       @java.lang.Override
       public com.google.protobuf.Descriptors.Descriptor
           getDescriptorForType() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_Resource_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Resource_descriptor;
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.Resource getDefaultInstanceForType() {
-        return flyteidl.admin.Agent.Resource.getDefaultInstance();
+      public flyteidl.admin.AgentOuterClass.Resource getDefaultInstanceForType() {
+        return flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance();
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.Resource build() {
-        flyteidl.admin.Agent.Resource result = buildPartial();
+      public flyteidl.admin.AgentOuterClass.Resource build() {
+        flyteidl.admin.AgentOuterClass.Resource result = buildPartial();
         if (!result.isInitialized()) {
           throw newUninitializedMessageException(result);
         }
@@ -6419,8 +6419,8 @@ public flyteidl.admin.Agent.Resource build() {
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.Resource buildPartial() {
-        flyteidl.admin.Agent.Resource result = new flyteidl.admin.Agent.Resource(this);
+      public flyteidl.admin.AgentOuterClass.Resource buildPartial() {
+        flyteidl.admin.AgentOuterClass.Resource result = new flyteidl.admin.AgentOuterClass.Resource(this);
         result.state_ = state_;
         if (outputsBuilder_ == null) {
           result.outputs_ = outputs_;
@@ -6466,16 +6466,16 @@ public Builder addRepeatedField(
       }
       @java.lang.Override
       public Builder mergeFrom(com.google.protobuf.Message other) {
-        if (other instanceof flyteidl.admin.Agent.Resource) {
-          return mergeFrom((flyteidl.admin.Agent.Resource)other);
+        if (other instanceof flyteidl.admin.AgentOuterClass.Resource) {
+          return mergeFrom((flyteidl.admin.AgentOuterClass.Resource)other);
         } else {
           super.mergeFrom(other);
           return this;
         }
       }
 
-      public Builder mergeFrom(flyteidl.admin.Agent.Resource other) {
-        if (other == flyteidl.admin.Agent.Resource.getDefaultInstance()) return this;
+      public Builder mergeFrom(flyteidl.admin.AgentOuterClass.Resource other) {
+        if (other == flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance()) return this;
         if (other.state_ != 0) {
           setStateValue(other.getStateValue());
         }
@@ -6501,11 +6501,11 @@ public Builder mergeFrom(
           com.google.protobuf.CodedInputStream input,
           com.google.protobuf.ExtensionRegistryLite extensionRegistry)
           throws java.io.IOException {
-        flyteidl.admin.Agent.Resource parsedMessage = null;
+        flyteidl.admin.AgentOuterClass.Resource parsedMessage = null;
         try {
           parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
         } catch (com.google.protobuf.InvalidProtocolBufferException e) {
-          parsedMessage = (flyteidl.admin.Agent.Resource) e.getUnfinishedMessage();
+          parsedMessage = (flyteidl.admin.AgentOuterClass.Resource) e.getUnfinishedMessage();
           throw e.unwrapIOException();
         } finally {
           if (parsedMessage != null) {
@@ -6545,10 +6545,10 @@ public Builder setStateValue(int value) {
        *
        * .flyteidl.admin.State state = 1;
        */
-      public flyteidl.admin.Agent.State getState() {
+      public flyteidl.admin.AgentOuterClass.State getState() {
         @SuppressWarnings("deprecation")
-        flyteidl.admin.Agent.State result = flyteidl.admin.Agent.State.valueOf(state_);
-        return result == null ? flyteidl.admin.Agent.State.UNRECOGNIZED : result;
+        flyteidl.admin.AgentOuterClass.State result = flyteidl.admin.AgentOuterClass.State.valueOf(state_);
+        return result == null ? flyteidl.admin.AgentOuterClass.State.UNRECOGNIZED : result;
       }
       /**
        * 
@@ -6557,7 +6557,7 @@ public flyteidl.admin.Agent.State getState() {
        *
        * .flyteidl.admin.State state = 1;
        */
-      public Builder setState(flyteidl.admin.Agent.State value) {
+      public Builder setState(flyteidl.admin.AgentOuterClass.State value) {
         if (value == null) {
           throw new NullPointerException();
         }
@@ -6856,12 +6856,12 @@ public final Builder mergeUnknownFields(
     }
 
     // @@protoc_insertion_point(class_scope:flyteidl.admin.Resource)
-    private static final flyteidl.admin.Agent.Resource DEFAULT_INSTANCE;
+    private static final flyteidl.admin.AgentOuterClass.Resource DEFAULT_INSTANCE;
     static {
-      DEFAULT_INSTANCE = new flyteidl.admin.Agent.Resource();
+      DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.Resource();
     }
 
-    public static flyteidl.admin.Agent.Resource getDefaultInstance() {
+    public static flyteidl.admin.AgentOuterClass.Resource getDefaultInstance() {
       return DEFAULT_INSTANCE;
     }
 
@@ -6886,7 +6886,7 @@ public com.google.protobuf.Parser getParserForType() {
     }
 
     @java.lang.Override
-    public flyteidl.admin.Agent.Resource getDefaultInstanceForType() {
+    public flyteidl.admin.AgentOuterClass.Resource getDefaultInstanceForType() {
       return DEFAULT_INSTANCE;
     }
 
@@ -7000,15 +7000,15 @@ private DeleteTaskRequest(
     }
     public static final com.google.protobuf.Descriptors.Descriptor
         getDescriptor() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskRequest_descriptor;
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskRequest_descriptor;
     }
 
     @java.lang.Override
     protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
         internalGetFieldAccessorTable() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskRequest_fieldAccessorTable
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskRequest_fieldAccessorTable
           .ensureFieldAccessorsInitialized(
-              flyteidl.admin.Agent.DeleteTaskRequest.class, flyteidl.admin.Agent.DeleteTaskRequest.Builder.class);
+              flyteidl.admin.AgentOuterClass.DeleteTaskRequest.class, flyteidl.admin.AgentOuterClass.DeleteTaskRequest.Builder.class);
     }
 
     public static final int TASK_TYPE_FIELD_NUMBER = 1;
@@ -7112,10 +7112,10 @@ public boolean equals(final java.lang.Object obj) {
       if (obj == this) {
        return true;
       }
-      if (!(obj instanceof flyteidl.admin.Agent.DeleteTaskRequest)) {
+      if (!(obj instanceof flyteidl.admin.AgentOuterClass.DeleteTaskRequest)) {
         return super.equals(obj);
       }
-      flyteidl.admin.Agent.DeleteTaskRequest other = (flyteidl.admin.Agent.DeleteTaskRequest) obj;
+      flyteidl.admin.AgentOuterClass.DeleteTaskRequest other = (flyteidl.admin.AgentOuterClass.DeleteTaskRequest) obj;
 
       if (!getTaskType()
           .equals(other.getTaskType())) return false;
@@ -7141,69 +7141,69 @@ public int hashCode() {
       return hash;
     }
 
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(
         java.nio.ByteBuffer data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(
         java.nio.ByteBuffer data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(
         com.google.protobuf.ByteString data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(
         com.google.protobuf.ByteString data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(byte[] data)
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(byte[] data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(
         byte[] data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest 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.admin.Agent.DeleteTaskRequest parseDelimitedFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseDelimitedFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseDelimitedWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseDelimitedFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest 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.admin.Agent.DeleteTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(
         com.google.protobuf.CodedInputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest parseFrom(
         com.google.protobuf.CodedInputStream input,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws java.io.IOException {
@@ -7216,7 +7216,7 @@ public static flyteidl.admin.Agent.DeleteTaskRequest parseFrom(
     public static Builder newBuilder() {
       return DEFAULT_INSTANCE.toBuilder();
     }
-    public static Builder newBuilder(flyteidl.admin.Agent.DeleteTaskRequest prototype) {
+    public static Builder newBuilder(flyteidl.admin.AgentOuterClass.DeleteTaskRequest prototype) {
       return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
     }
     @java.lang.Override
@@ -7241,21 +7241,21 @@ protected Builder newBuilderForType(
     public static final class Builder extends
         com.google.protobuf.GeneratedMessageV3.Builder implements
         // @@protoc_insertion_point(builder_implements:flyteidl.admin.DeleteTaskRequest)
-        flyteidl.admin.Agent.DeleteTaskRequestOrBuilder {
+        flyteidl.admin.AgentOuterClass.DeleteTaskRequestOrBuilder {
       public static final com.google.protobuf.Descriptors.Descriptor
           getDescriptor() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskRequest_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskRequest_descriptor;
       }
 
       @java.lang.Override
       protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
           internalGetFieldAccessorTable() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskRequest_fieldAccessorTable
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskRequest_fieldAccessorTable
             .ensureFieldAccessorsInitialized(
-                flyteidl.admin.Agent.DeleteTaskRequest.class, flyteidl.admin.Agent.DeleteTaskRequest.Builder.class);
+                flyteidl.admin.AgentOuterClass.DeleteTaskRequest.class, flyteidl.admin.AgentOuterClass.DeleteTaskRequest.Builder.class);
       }
 
-      // Construct using flyteidl.admin.Agent.DeleteTaskRequest.newBuilder()
+      // Construct using flyteidl.admin.AgentOuterClass.DeleteTaskRequest.newBuilder()
       private Builder() {
         maybeForceBuilderInitialization();
       }
@@ -7283,17 +7283,17 @@ public Builder clear() {
       @java.lang.Override
       public com.google.protobuf.Descriptors.Descriptor
           getDescriptorForType() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskRequest_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskRequest_descriptor;
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.DeleteTaskRequest getDefaultInstanceForType() {
-        return flyteidl.admin.Agent.DeleteTaskRequest.getDefaultInstance();
+      public flyteidl.admin.AgentOuterClass.DeleteTaskRequest getDefaultInstanceForType() {
+        return flyteidl.admin.AgentOuterClass.DeleteTaskRequest.getDefaultInstance();
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.DeleteTaskRequest build() {
-        flyteidl.admin.Agent.DeleteTaskRequest result = buildPartial();
+      public flyteidl.admin.AgentOuterClass.DeleteTaskRequest build() {
+        flyteidl.admin.AgentOuterClass.DeleteTaskRequest result = buildPartial();
         if (!result.isInitialized()) {
           throw newUninitializedMessageException(result);
         }
@@ -7301,8 +7301,8 @@ public flyteidl.admin.Agent.DeleteTaskRequest build() {
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.DeleteTaskRequest buildPartial() {
-        flyteidl.admin.Agent.DeleteTaskRequest result = new flyteidl.admin.Agent.DeleteTaskRequest(this);
+      public flyteidl.admin.AgentOuterClass.DeleteTaskRequest buildPartial() {
+        flyteidl.admin.AgentOuterClass.DeleteTaskRequest result = new flyteidl.admin.AgentOuterClass.DeleteTaskRequest(this);
         result.taskType_ = taskType_;
         result.resourceMeta_ = resourceMeta_;
         onBuilt();
@@ -7343,16 +7343,16 @@ public Builder addRepeatedField(
       }
       @java.lang.Override
       public Builder mergeFrom(com.google.protobuf.Message other) {
-        if (other instanceof flyteidl.admin.Agent.DeleteTaskRequest) {
-          return mergeFrom((flyteidl.admin.Agent.DeleteTaskRequest)other);
+        if (other instanceof flyteidl.admin.AgentOuterClass.DeleteTaskRequest) {
+          return mergeFrom((flyteidl.admin.AgentOuterClass.DeleteTaskRequest)other);
         } else {
           super.mergeFrom(other);
           return this;
         }
       }
 
-      public Builder mergeFrom(flyteidl.admin.Agent.DeleteTaskRequest other) {
-        if (other == flyteidl.admin.Agent.DeleteTaskRequest.getDefaultInstance()) return this;
+      public Builder mergeFrom(flyteidl.admin.AgentOuterClass.DeleteTaskRequest other) {
+        if (other == flyteidl.admin.AgentOuterClass.DeleteTaskRequest.getDefaultInstance()) return this;
         if (!other.getTaskType().isEmpty()) {
           taskType_ = other.taskType_;
           onChanged();
@@ -7375,11 +7375,11 @@ public Builder mergeFrom(
           com.google.protobuf.CodedInputStream input,
           com.google.protobuf.ExtensionRegistryLite extensionRegistry)
           throws java.io.IOException {
-        flyteidl.admin.Agent.DeleteTaskRequest parsedMessage = null;
+        flyteidl.admin.AgentOuterClass.DeleteTaskRequest parsedMessage = null;
         try {
           parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
         } catch (com.google.protobuf.InvalidProtocolBufferException e) {
-          parsedMessage = (flyteidl.admin.Agent.DeleteTaskRequest) e.getUnfinishedMessage();
+          parsedMessage = (flyteidl.admin.AgentOuterClass.DeleteTaskRequest) e.getUnfinishedMessage();
           throw e.unwrapIOException();
         } finally {
           if (parsedMessage != null) {
@@ -7535,12 +7535,12 @@ public final Builder mergeUnknownFields(
     }
 
     // @@protoc_insertion_point(class_scope:flyteidl.admin.DeleteTaskRequest)
-    private static final flyteidl.admin.Agent.DeleteTaskRequest DEFAULT_INSTANCE;
+    private static final flyteidl.admin.AgentOuterClass.DeleteTaskRequest DEFAULT_INSTANCE;
     static {
-      DEFAULT_INSTANCE = new flyteidl.admin.Agent.DeleteTaskRequest();
+      DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.DeleteTaskRequest();
     }
 
-    public static flyteidl.admin.Agent.DeleteTaskRequest getDefaultInstance() {
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskRequest getDefaultInstance() {
       return DEFAULT_INSTANCE;
     }
 
@@ -7565,7 +7565,7 @@ public com.google.protobuf.Parser getParserForType() {
     }
 
     @java.lang.Override
-    public flyteidl.admin.Agent.DeleteTaskRequest getDefaultInstanceForType() {
+    public flyteidl.admin.AgentOuterClass.DeleteTaskRequest getDefaultInstanceForType() {
       return DEFAULT_INSTANCE;
     }
 
@@ -7638,15 +7638,15 @@ private DeleteTaskResponse(
     }
     public static final com.google.protobuf.Descriptors.Descriptor
         getDescriptor() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskResponse_descriptor;
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskResponse_descriptor;
     }
 
     @java.lang.Override
     protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
         internalGetFieldAccessorTable() {
-      return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskResponse_fieldAccessorTable
+      return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskResponse_fieldAccessorTable
           .ensureFieldAccessorsInitialized(
-              flyteidl.admin.Agent.DeleteTaskResponse.class, flyteidl.admin.Agent.DeleteTaskResponse.Builder.class);
+              flyteidl.admin.AgentOuterClass.DeleteTaskResponse.class, flyteidl.admin.AgentOuterClass.DeleteTaskResponse.Builder.class);
     }
 
     private byte memoizedIsInitialized = -1;
@@ -7682,10 +7682,10 @@ public boolean equals(final java.lang.Object obj) {
       if (obj == this) {
        return true;
       }
-      if (!(obj instanceof flyteidl.admin.Agent.DeleteTaskResponse)) {
+      if (!(obj instanceof flyteidl.admin.AgentOuterClass.DeleteTaskResponse)) {
         return super.equals(obj);
       }
-      flyteidl.admin.Agent.DeleteTaskResponse other = (flyteidl.admin.Agent.DeleteTaskResponse) obj;
+      flyteidl.admin.AgentOuterClass.DeleteTaskResponse other = (flyteidl.admin.AgentOuterClass.DeleteTaskResponse) obj;
 
       if (!unknownFields.equals(other.unknownFields)) return false;
       return true;
@@ -7703,69 +7703,69 @@ public int hashCode() {
       return hash;
     }
 
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(
         java.nio.ByteBuffer data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(
         java.nio.ByteBuffer data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(
         com.google.protobuf.ByteString data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(
         com.google.protobuf.ByteString data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(byte[] data)
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(byte[] data)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(
         byte[] data,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws com.google.protobuf.InvalidProtocolBufferException {
       return PARSER.parseFrom(data, extensionRegistry);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse 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.admin.Agent.DeleteTaskResponse parseDelimitedFrom(java.io.InputStream input)
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseDelimitedFrom(java.io.InputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseDelimitedWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseDelimitedFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse 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.admin.Agent.DeleteTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(
         com.google.protobuf.CodedInputStream input)
         throws java.io.IOException {
       return com.google.protobuf.GeneratedMessageV3
           .parseWithIOException(PARSER, input);
     }
-    public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse parseFrom(
         com.google.protobuf.CodedInputStream input,
         com.google.protobuf.ExtensionRegistryLite extensionRegistry)
         throws java.io.IOException {
@@ -7778,7 +7778,7 @@ public static flyteidl.admin.Agent.DeleteTaskResponse parseFrom(
     public static Builder newBuilder() {
       return DEFAULT_INSTANCE.toBuilder();
     }
-    public static Builder newBuilder(flyteidl.admin.Agent.DeleteTaskResponse prototype) {
+    public static Builder newBuilder(flyteidl.admin.AgentOuterClass.DeleteTaskResponse prototype) {
       return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
     }
     @java.lang.Override
@@ -7803,21 +7803,21 @@ protected Builder newBuilderForType(
     public static final class Builder extends
         com.google.protobuf.GeneratedMessageV3.Builder implements
         // @@protoc_insertion_point(builder_implements:flyteidl.admin.DeleteTaskResponse)
-        flyteidl.admin.Agent.DeleteTaskResponseOrBuilder {
+        flyteidl.admin.AgentOuterClass.DeleteTaskResponseOrBuilder {
       public static final com.google.protobuf.Descriptors.Descriptor
           getDescriptor() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskResponse_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskResponse_descriptor;
       }
 
       @java.lang.Override
       protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
           internalGetFieldAccessorTable() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskResponse_fieldAccessorTable
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskResponse_fieldAccessorTable
             .ensureFieldAccessorsInitialized(
-                flyteidl.admin.Agent.DeleteTaskResponse.class, flyteidl.admin.Agent.DeleteTaskResponse.Builder.class);
+                flyteidl.admin.AgentOuterClass.DeleteTaskResponse.class, flyteidl.admin.AgentOuterClass.DeleteTaskResponse.Builder.class);
       }
 
-      // Construct using flyteidl.admin.Agent.DeleteTaskResponse.newBuilder()
+      // Construct using flyteidl.admin.AgentOuterClass.DeleteTaskResponse.newBuilder()
       private Builder() {
         maybeForceBuilderInitialization();
       }
@@ -7841,17 +7841,17 @@ public Builder clear() {
       @java.lang.Override
       public com.google.protobuf.Descriptors.Descriptor
           getDescriptorForType() {
-        return flyteidl.admin.Agent.internal_static_flyteidl_admin_DeleteTaskResponse_descriptor;
+        return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_DeleteTaskResponse_descriptor;
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.DeleteTaskResponse getDefaultInstanceForType() {
-        return flyteidl.admin.Agent.DeleteTaskResponse.getDefaultInstance();
+      public flyteidl.admin.AgentOuterClass.DeleteTaskResponse getDefaultInstanceForType() {
+        return flyteidl.admin.AgentOuterClass.DeleteTaskResponse.getDefaultInstance();
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.DeleteTaskResponse build() {
-        flyteidl.admin.Agent.DeleteTaskResponse result = buildPartial();
+      public flyteidl.admin.AgentOuterClass.DeleteTaskResponse build() {
+        flyteidl.admin.AgentOuterClass.DeleteTaskResponse result = buildPartial();
         if (!result.isInitialized()) {
           throw newUninitializedMessageException(result);
         }
@@ -7859,8 +7859,8 @@ public flyteidl.admin.Agent.DeleteTaskResponse build() {
       }
 
       @java.lang.Override
-      public flyteidl.admin.Agent.DeleteTaskResponse buildPartial() {
-        flyteidl.admin.Agent.DeleteTaskResponse result = new flyteidl.admin.Agent.DeleteTaskResponse(this);
+      public flyteidl.admin.AgentOuterClass.DeleteTaskResponse buildPartial() {
+        flyteidl.admin.AgentOuterClass.DeleteTaskResponse result = new flyteidl.admin.AgentOuterClass.DeleteTaskResponse(this);
         onBuilt();
         return result;
       }
@@ -7899,16 +7899,16 @@ public Builder addRepeatedField(
       }
       @java.lang.Override
       public Builder mergeFrom(com.google.protobuf.Message other) {
-        if (other instanceof flyteidl.admin.Agent.DeleteTaskResponse) {
-          return mergeFrom((flyteidl.admin.Agent.DeleteTaskResponse)other);
+        if (other instanceof flyteidl.admin.AgentOuterClass.DeleteTaskResponse) {
+          return mergeFrom((flyteidl.admin.AgentOuterClass.DeleteTaskResponse)other);
         } else {
           super.mergeFrom(other);
           return this;
         }
       }
 
-      public Builder mergeFrom(flyteidl.admin.Agent.DeleteTaskResponse other) {
-        if (other == flyteidl.admin.Agent.DeleteTaskResponse.getDefaultInstance()) return this;
+      public Builder mergeFrom(flyteidl.admin.AgentOuterClass.DeleteTaskResponse other) {
+        if (other == flyteidl.admin.AgentOuterClass.DeleteTaskResponse.getDefaultInstance()) return this;
         this.mergeUnknownFields(other.unknownFields);
         onChanged();
         return this;
@@ -7924,11 +7924,11 @@ public Builder mergeFrom(
           com.google.protobuf.CodedInputStream input,
           com.google.protobuf.ExtensionRegistryLite extensionRegistry)
           throws java.io.IOException {
-        flyteidl.admin.Agent.DeleteTaskResponse parsedMessage = null;
+        flyteidl.admin.AgentOuterClass.DeleteTaskResponse parsedMessage = null;
         try {
           parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
         } catch (com.google.protobuf.InvalidProtocolBufferException e) {
-          parsedMessage = (flyteidl.admin.Agent.DeleteTaskResponse) e.getUnfinishedMessage();
+          parsedMessage = (flyteidl.admin.AgentOuterClass.DeleteTaskResponse) e.getUnfinishedMessage();
           throw e.unwrapIOException();
         } finally {
           if (parsedMessage != null) {
@@ -7954,12 +7954,12 @@ public final Builder mergeUnknownFields(
     }
 
     // @@protoc_insertion_point(class_scope:flyteidl.admin.DeleteTaskResponse)
-    private static final flyteidl.admin.Agent.DeleteTaskResponse DEFAULT_INSTANCE;
+    private static final flyteidl.admin.AgentOuterClass.DeleteTaskResponse DEFAULT_INSTANCE;
     static {
-      DEFAULT_INSTANCE = new flyteidl.admin.Agent.DeleteTaskResponse();
+      DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.DeleteTaskResponse();
     }
 
-    public static flyteidl.admin.Agent.DeleteTaskResponse getDefaultInstance() {
+    public static flyteidl.admin.AgentOuterClass.DeleteTaskResponse getDefaultInstance() {
       return DEFAULT_INSTANCE;
     }
 
@@ -7984,7 +7984,3277 @@ public com.google.protobuf.Parser getParserForType() {
     }
 
     @java.lang.Override
-    public flyteidl.admin.Agent.DeleteTaskResponse getDefaultInstanceForType() {
+    public flyteidl.admin.AgentOuterClass.DeleteTaskResponse getDefaultInstanceForType() {
+      return DEFAULT_INSTANCE;
+    }
+
+  }
+
+  public interface AgentOrBuilder extends
+      // @@protoc_insertion_point(interface_extends:flyteidl.admin.Agent)
+      com.google.protobuf.MessageOrBuilder {
+
+    /**
+     * 
+     * Name is the developer-assigned name of the agent.
+     * 
+ * + * string name = 1; + */ + java.lang.String getName(); + /** + *
+     * Name is the developer-assigned name of the agent.
+     * 
+ * + * string name = 1; + */ + com.google.protobuf.ByteString + getNameBytes(); + + /** + *
+     * SupportedTaskTypes are the types of the tasks that the agent can handle.
+     * 
+ * + * repeated string supported_task_types = 2; + */ + java.util.List + getSupportedTaskTypesList(); + /** + *
+     * SupportedTaskTypes are the types of the tasks that the agent can handle.
+     * 
+ * + * repeated string supported_task_types = 2; + */ + int getSupportedTaskTypesCount(); + /** + *
+     * SupportedTaskTypes are the types of the tasks that the agent can handle.
+     * 
+ * + * repeated string supported_task_types = 2; + */ + java.lang.String getSupportedTaskTypes(int index); + /** + *
+     * SupportedTaskTypes are the types of the tasks that the agent can handle.
+     * 
+ * + * repeated string supported_task_types = 2; + */ + com.google.protobuf.ByteString + getSupportedTaskTypesBytes(int index); + } + /** + *
+   * A message containing the agent metadata.
+   * 
+ * + * Protobuf type {@code flyteidl.admin.Agent} + */ + public static final class Agent extends + com.google.protobuf.GeneratedMessageV3 implements + // @@protoc_insertion_point(message_implements:flyteidl.admin.Agent) + AgentOrBuilder { + private static final long serialVersionUID = 0L; + // Use Agent.newBuilder() to construct. + private Agent(com.google.protobuf.GeneratedMessageV3.Builder builder) { + super(builder); + } + private Agent() { + name_ = ""; + supportedTaskTypes_ = com.google.protobuf.LazyStringArrayList.EMPTY; + } + + @java.lang.Override + public final com.google.protobuf.UnknownFieldSet + getUnknownFields() { + return this.unknownFields; + } + private Agent( + 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: { + java.lang.String s = input.readStringRequireUtf8(); + + name_ = s; + break; + } + case 18: { + java.lang.String s = input.readStringRequireUtf8(); + if (!((mutable_bitField0_ & 0x00000002) != 0)) { + supportedTaskTypes_ = new com.google.protobuf.LazyStringArrayList(); + mutable_bitField0_ |= 0x00000002; + } + supportedTaskTypes_.add(s); + 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 { + if (((mutable_bitField0_ & 0x00000002) != 0)) { + supportedTaskTypes_ = supportedTaskTypes_.getUnmodifiableView(); + } + this.unknownFields = unknownFields.build(); + makeExtensionsImmutable(); + } + } + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Agent_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Agent_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.Agent.class, flyteidl.admin.AgentOuterClass.Agent.Builder.class); + } + + private int bitField0_; + public static final int NAME_FIELD_NUMBER = 1; + private volatile java.lang.Object name_; + /** + *
+     * Name is the developer-assigned name of the agent.
+     * 
+ * + * string name = 1; + */ + public java.lang.String getName() { + java.lang.Object ref = name_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + name_ = s; + return s; + } + } + /** + *
+     * Name is the developer-assigned name of the agent.
+     * 
+ * + * string name = 1; + */ + public com.google.protobuf.ByteString + getNameBytes() { + java.lang.Object ref = name_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + name_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + + public static final int SUPPORTED_TASK_TYPES_FIELD_NUMBER = 2; + private com.google.protobuf.LazyStringList supportedTaskTypes_; + /** + *
+     * SupportedTaskTypes are the types of the tasks that the agent can handle.
+     * 
+ * + * repeated string supported_task_types = 2; + */ + public com.google.protobuf.ProtocolStringList + getSupportedTaskTypesList() { + return supportedTaskTypes_; + } + /** + *
+     * SupportedTaskTypes are the types of the tasks that the agent can handle.
+     * 
+ * + * repeated string supported_task_types = 2; + */ + public int getSupportedTaskTypesCount() { + return supportedTaskTypes_.size(); + } + /** + *
+     * SupportedTaskTypes are the types of the tasks that the agent can handle.
+     * 
+ * + * repeated string supported_task_types = 2; + */ + public java.lang.String getSupportedTaskTypes(int index) { + return supportedTaskTypes_.get(index); + } + /** + *
+     * SupportedTaskTypes are the types of the tasks that the agent can handle.
+     * 
+ * + * repeated string supported_task_types = 2; + */ + public com.google.protobuf.ByteString + getSupportedTaskTypesBytes(int index) { + return supportedTaskTypes_.getByteString(index); + } + + 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 (!getNameBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 1, name_); + } + for (int i = 0; i < supportedTaskTypes_.size(); i++) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 2, supportedTaskTypes_.getRaw(i)); + } + unknownFields.writeTo(output); + } + + @java.lang.Override + public int getSerializedSize() { + int size = memoizedSize; + if (size != -1) return size; + + size = 0; + if (!getNameBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, name_); + } + { + int dataSize = 0; + for (int i = 0; i < supportedTaskTypes_.size(); i++) { + dataSize += computeStringSizeNoTag(supportedTaskTypes_.getRaw(i)); + } + size += dataSize; + size += 1 * getSupportedTaskTypesList().size(); + } + 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.admin.AgentOuterClass.Agent)) { + return super.equals(obj); + } + flyteidl.admin.AgentOuterClass.Agent other = (flyteidl.admin.AgentOuterClass.Agent) obj; + + if (!getName() + .equals(other.getName())) return false; + if (!getSupportedTaskTypesList() + .equals(other.getSupportedTaskTypesList())) 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(); + hash = (37 * hash) + NAME_FIELD_NUMBER; + hash = (53 * hash) + getName().hashCode(); + if (getSupportedTaskTypesCount() > 0) { + hash = (37 * hash) + SUPPORTED_TASK_TYPES_FIELD_NUMBER; + hash = (53 * hash) + getSupportedTaskTypesList().hashCode(); + } + hash = (29 * hash) + unknownFields.hashCode(); + memoizedHashCode = hash; + return hash; + } + + public static flyteidl.admin.AgentOuterClass.Agent parseFrom( + java.nio.ByteBuffer data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.Agent parseFrom( + java.nio.ByteBuffer data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.Agent parseFrom( + com.google.protobuf.ByteString data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.Agent parseFrom( + com.google.protobuf.ByteString data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.Agent parseFrom(byte[] data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.Agent parseFrom( + byte[] data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.Agent parseFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.Agent 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.admin.AgentOuterClass.Agent parseDelimitedFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.Agent 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.admin.AgentOuterClass.Agent parseFrom( + com.google.protobuf.CodedInputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.Agent 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.admin.AgentOuterClass.Agent 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; + } + /** + *
+     * A message containing the agent metadata.
+     * 
+ * + * Protobuf type {@code flyteidl.admin.Agent} + */ + public static final class Builder extends + com.google.protobuf.GeneratedMessageV3.Builder implements + // @@protoc_insertion_point(builder_implements:flyteidl.admin.Agent) + flyteidl.admin.AgentOuterClass.AgentOrBuilder { + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Agent_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Agent_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.Agent.class, flyteidl.admin.AgentOuterClass.Agent.Builder.class); + } + + // Construct using flyteidl.admin.AgentOuterClass.Agent.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(); + name_ = ""; + + supportedTaskTypes_ = com.google.protobuf.LazyStringArrayList.EMPTY; + bitField0_ = (bitField0_ & ~0x00000002); + return this; + } + + @java.lang.Override + public com.google.protobuf.Descriptors.Descriptor + getDescriptorForType() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_Agent_descriptor; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.Agent getDefaultInstanceForType() { + return flyteidl.admin.AgentOuterClass.Agent.getDefaultInstance(); + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.Agent build() { + flyteidl.admin.AgentOuterClass.Agent result = buildPartial(); + if (!result.isInitialized()) { + throw newUninitializedMessageException(result); + } + return result; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.Agent buildPartial() { + flyteidl.admin.AgentOuterClass.Agent result = new flyteidl.admin.AgentOuterClass.Agent(this); + int from_bitField0_ = bitField0_; + int to_bitField0_ = 0; + result.name_ = name_; + if (((bitField0_ & 0x00000002) != 0)) { + supportedTaskTypes_ = supportedTaskTypes_.getUnmodifiableView(); + bitField0_ = (bitField0_ & ~0x00000002); + } + result.supportedTaskTypes_ = supportedTaskTypes_; + result.bitField0_ = to_bitField0_; + 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.admin.AgentOuterClass.Agent) { + return mergeFrom((flyteidl.admin.AgentOuterClass.Agent)other); + } else { + super.mergeFrom(other); + return this; + } + } + + public Builder mergeFrom(flyteidl.admin.AgentOuterClass.Agent other) { + if (other == flyteidl.admin.AgentOuterClass.Agent.getDefaultInstance()) return this; + if (!other.getName().isEmpty()) { + name_ = other.name_; + onChanged(); + } + if (!other.supportedTaskTypes_.isEmpty()) { + if (supportedTaskTypes_.isEmpty()) { + supportedTaskTypes_ = other.supportedTaskTypes_; + bitField0_ = (bitField0_ & ~0x00000002); + } else { + ensureSupportedTaskTypesIsMutable(); + supportedTaskTypes_.addAll(other.supportedTaskTypes_); + } + onChanged(); + } + 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.admin.AgentOuterClass.Agent parsedMessage = null; + try { + parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + parsedMessage = (flyteidl.admin.AgentOuterClass.Agent) e.getUnfinishedMessage(); + throw e.unwrapIOException(); + } finally { + if (parsedMessage != null) { + mergeFrom(parsedMessage); + } + } + return this; + } + private int bitField0_; + + private java.lang.Object name_ = ""; + /** + *
+       * Name is the developer-assigned name of the agent.
+       * 
+ * + * string name = 1; + */ + public java.lang.String getName() { + java.lang.Object ref = name_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + name_ = s; + return s; + } else { + return (java.lang.String) ref; + } + } + /** + *
+       * Name is the developer-assigned name of the agent.
+       * 
+ * + * string name = 1; + */ + public com.google.protobuf.ByteString + getNameBytes() { + java.lang.Object ref = name_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + name_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + /** + *
+       * Name is the developer-assigned name of the agent.
+       * 
+ * + * string name = 1; + */ + public Builder setName( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + name_ = value; + onChanged(); + return this; + } + /** + *
+       * Name is the developer-assigned name of the agent.
+       * 
+ * + * string name = 1; + */ + public Builder clearName() { + + name_ = getDefaultInstance().getName(); + onChanged(); + return this; + } + /** + *
+       * Name is the developer-assigned name of the agent.
+       * 
+ * + * string name = 1; + */ + public Builder setNameBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + + name_ = value; + onChanged(); + return this; + } + + private com.google.protobuf.LazyStringList supportedTaskTypes_ = com.google.protobuf.LazyStringArrayList.EMPTY; + private void ensureSupportedTaskTypesIsMutable() { + if (!((bitField0_ & 0x00000002) != 0)) { + supportedTaskTypes_ = new com.google.protobuf.LazyStringArrayList(supportedTaskTypes_); + bitField0_ |= 0x00000002; + } + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public com.google.protobuf.ProtocolStringList + getSupportedTaskTypesList() { + return supportedTaskTypes_.getUnmodifiableView(); + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public int getSupportedTaskTypesCount() { + return supportedTaskTypes_.size(); + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public java.lang.String getSupportedTaskTypes(int index) { + return supportedTaskTypes_.get(index); + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public com.google.protobuf.ByteString + getSupportedTaskTypesBytes(int index) { + return supportedTaskTypes_.getByteString(index); + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public Builder setSupportedTaskTypes( + int index, java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + ensureSupportedTaskTypesIsMutable(); + supportedTaskTypes_.set(index, value); + onChanged(); + return this; + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public Builder addSupportedTaskTypes( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + ensureSupportedTaskTypesIsMutable(); + supportedTaskTypes_.add(value); + onChanged(); + return this; + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public Builder addAllSupportedTaskTypes( + java.lang.Iterable values) { + ensureSupportedTaskTypesIsMutable(); + com.google.protobuf.AbstractMessageLite.Builder.addAll( + values, supportedTaskTypes_); + onChanged(); + return this; + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public Builder clearSupportedTaskTypes() { + supportedTaskTypes_ = com.google.protobuf.LazyStringArrayList.EMPTY; + bitField0_ = (bitField0_ & ~0x00000002); + onChanged(); + return this; + } + /** + *
+       * SupportedTaskTypes are the types of the tasks that the agent can handle.
+       * 
+ * + * repeated string supported_task_types = 2; + */ + public Builder addSupportedTaskTypesBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + ensureSupportedTaskTypesIsMutable(); + supportedTaskTypes_.add(value); + onChanged(); + return this; + } + @java.lang.Override + public final Builder setUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.setUnknownFields(unknownFields); + } + + @java.lang.Override + public final Builder mergeUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.mergeUnknownFields(unknownFields); + } + + + // @@protoc_insertion_point(builder_scope:flyteidl.admin.Agent) + } + + // @@protoc_insertion_point(class_scope:flyteidl.admin.Agent) + private static final flyteidl.admin.AgentOuterClass.Agent DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.Agent(); + } + + public static flyteidl.admin.AgentOuterClass.Agent getDefaultInstance() { + return DEFAULT_INSTANCE; + } + + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { + @java.lang.Override + public Agent parsePartialFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return new Agent(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.admin.AgentOuterClass.Agent getDefaultInstanceForType() { + return DEFAULT_INSTANCE; + } + + } + + public interface GetAgentRequestOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.admin.GetAgentRequest) + com.google.protobuf.MessageOrBuilder { + + /** + *
+     * The name of the agent.
+     * 
+ * + * string name = 1; + */ + java.lang.String getName(); + /** + *
+     * The name of the agent.
+     * 
+ * + * string name = 1; + */ + com.google.protobuf.ByteString + getNameBytes(); + } + /** + *
+   * A request to get an agent.
+   * 
+ * + * Protobuf type {@code flyteidl.admin.GetAgentRequest} + */ + public static final class GetAgentRequest extends + com.google.protobuf.GeneratedMessageV3 implements + // @@protoc_insertion_point(message_implements:flyteidl.admin.GetAgentRequest) + GetAgentRequestOrBuilder { + private static final long serialVersionUID = 0L; + // Use GetAgentRequest.newBuilder() to construct. + private GetAgentRequest(com.google.protobuf.GeneratedMessageV3.Builder builder) { + super(builder); + } + private GetAgentRequest() { + name_ = ""; + } + + @java.lang.Override + public final com.google.protobuf.UnknownFieldSet + getUnknownFields() { + return this.unknownFields; + } + private GetAgentRequest( + 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: { + java.lang.String s = input.readStringRequireUtf8(); + + name_ = s; + 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.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentRequest_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentRequest_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.GetAgentRequest.class, flyteidl.admin.AgentOuterClass.GetAgentRequest.Builder.class); + } + + public static final int NAME_FIELD_NUMBER = 1; + private volatile java.lang.Object name_; + /** + *
+     * The name of the agent.
+     * 
+ * + * string name = 1; + */ + public java.lang.String getName() { + java.lang.Object ref = name_; + if (ref instanceof java.lang.String) { + return (java.lang.String) ref; + } else { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + name_ = s; + return s; + } + } + /** + *
+     * The name of the agent.
+     * 
+ * + * string name = 1; + */ + public com.google.protobuf.ByteString + getNameBytes() { + java.lang.Object ref = name_; + if (ref instanceof java.lang.String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + name_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + + 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 (!getNameBytes().isEmpty()) { + com.google.protobuf.GeneratedMessageV3.writeString(output, 1, name_); + } + unknownFields.writeTo(output); + } + + @java.lang.Override + public int getSerializedSize() { + int size = memoizedSize; + if (size != -1) return size; + + size = 0; + if (!getNameBytes().isEmpty()) { + size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, name_); + } + 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.admin.AgentOuterClass.GetAgentRequest)) { + return super.equals(obj); + } + flyteidl.admin.AgentOuterClass.GetAgentRequest other = (flyteidl.admin.AgentOuterClass.GetAgentRequest) obj; + + if (!getName() + .equals(other.getName())) 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(); + hash = (37 * hash) + NAME_FIELD_NUMBER; + hash = (53 * hash) + getName().hashCode(); + hash = (29 * hash) + unknownFields.hashCode(); + memoizedHashCode = hash; + return hash; + } + + public static flyteidl.admin.AgentOuterClass.GetAgentRequest parseFrom( + java.nio.ByteBuffer data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest parseFrom( + java.nio.ByteBuffer data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest parseFrom( + com.google.protobuf.ByteString data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest parseFrom( + com.google.protobuf.ByteString data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest parseFrom(byte[] data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest parseFrom( + byte[] data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest parseFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest 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.admin.AgentOuterClass.GetAgentRequest parseDelimitedFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest 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.admin.AgentOuterClass.GetAgentRequest parseFrom( + com.google.protobuf.CodedInputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.GetAgentRequest 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.admin.AgentOuterClass.GetAgentRequest 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; + } + /** + *
+     * A request to get an agent.
+     * 
+ * + * Protobuf type {@code flyteidl.admin.GetAgentRequest} + */ + public static final class Builder extends + com.google.protobuf.GeneratedMessageV3.Builder implements + // @@protoc_insertion_point(builder_implements:flyteidl.admin.GetAgentRequest) + flyteidl.admin.AgentOuterClass.GetAgentRequestOrBuilder { + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentRequest_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentRequest_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.GetAgentRequest.class, flyteidl.admin.AgentOuterClass.GetAgentRequest.Builder.class); + } + + // Construct using flyteidl.admin.AgentOuterClass.GetAgentRequest.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(); + name_ = ""; + + return this; + } + + @java.lang.Override + public com.google.protobuf.Descriptors.Descriptor + getDescriptorForType() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentRequest_descriptor; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.GetAgentRequest getDefaultInstanceForType() { + return flyteidl.admin.AgentOuterClass.GetAgentRequest.getDefaultInstance(); + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.GetAgentRequest build() { + flyteidl.admin.AgentOuterClass.GetAgentRequest result = buildPartial(); + if (!result.isInitialized()) { + throw newUninitializedMessageException(result); + } + return result; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.GetAgentRequest buildPartial() { + flyteidl.admin.AgentOuterClass.GetAgentRequest result = new flyteidl.admin.AgentOuterClass.GetAgentRequest(this); + result.name_ = name_; + 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.admin.AgentOuterClass.GetAgentRequest) { + return mergeFrom((flyteidl.admin.AgentOuterClass.GetAgentRequest)other); + } else { + super.mergeFrom(other); + return this; + } + } + + public Builder mergeFrom(flyteidl.admin.AgentOuterClass.GetAgentRequest other) { + if (other == flyteidl.admin.AgentOuterClass.GetAgentRequest.getDefaultInstance()) return this; + if (!other.getName().isEmpty()) { + name_ = other.name_; + onChanged(); + } + 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.admin.AgentOuterClass.GetAgentRequest parsedMessage = null; + try { + parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + parsedMessage = (flyteidl.admin.AgentOuterClass.GetAgentRequest) e.getUnfinishedMessage(); + throw e.unwrapIOException(); + } finally { + if (parsedMessage != null) { + mergeFrom(parsedMessage); + } + } + return this; + } + + private java.lang.Object name_ = ""; + /** + *
+       * The name of the agent.
+       * 
+ * + * string name = 1; + */ + public java.lang.String getName() { + java.lang.Object ref = name_; + if (!(ref instanceof java.lang.String)) { + com.google.protobuf.ByteString bs = + (com.google.protobuf.ByteString) ref; + java.lang.String s = bs.toStringUtf8(); + name_ = s; + return s; + } else { + return (java.lang.String) ref; + } + } + /** + *
+       * The name of the agent.
+       * 
+ * + * string name = 1; + */ + public com.google.protobuf.ByteString + getNameBytes() { + java.lang.Object ref = name_; + if (ref instanceof String) { + com.google.protobuf.ByteString b = + com.google.protobuf.ByteString.copyFromUtf8( + (java.lang.String) ref); + name_ = b; + return b; + } else { + return (com.google.protobuf.ByteString) ref; + } + } + /** + *
+       * The name of the agent.
+       * 
+ * + * string name = 1; + */ + public Builder setName( + java.lang.String value) { + if (value == null) { + throw new NullPointerException(); + } + + name_ = value; + onChanged(); + return this; + } + /** + *
+       * The name of the agent.
+       * 
+ * + * string name = 1; + */ + public Builder clearName() { + + name_ = getDefaultInstance().getName(); + onChanged(); + return this; + } + /** + *
+       * The name of the agent.
+       * 
+ * + * string name = 1; + */ + public Builder setNameBytes( + com.google.protobuf.ByteString value) { + if (value == null) { + throw new NullPointerException(); + } + checkByteStringIsUtf8(value); + + name_ = value; + onChanged(); + return this; + } + @java.lang.Override + public final Builder setUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.setUnknownFields(unknownFields); + } + + @java.lang.Override + public final Builder mergeUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.mergeUnknownFields(unknownFields); + } + + + // @@protoc_insertion_point(builder_scope:flyteidl.admin.GetAgentRequest) + } + + // @@protoc_insertion_point(class_scope:flyteidl.admin.GetAgentRequest) + private static final flyteidl.admin.AgentOuterClass.GetAgentRequest DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.GetAgentRequest(); + } + + public static flyteidl.admin.AgentOuterClass.GetAgentRequest getDefaultInstance() { + return DEFAULT_INSTANCE; + } + + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { + @java.lang.Override + public GetAgentRequest parsePartialFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return new GetAgentRequest(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.admin.AgentOuterClass.GetAgentRequest getDefaultInstanceForType() { + return DEFAULT_INSTANCE; + } + + } + + public interface GetAgentResponseOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.admin.GetAgentResponse) + com.google.protobuf.MessageOrBuilder { + + /** + * .flyteidl.admin.Agent agent = 1; + */ + boolean hasAgent(); + /** + * .flyteidl.admin.Agent agent = 1; + */ + flyteidl.admin.AgentOuterClass.Agent getAgent(); + /** + * .flyteidl.admin.Agent agent = 1; + */ + flyteidl.admin.AgentOuterClass.AgentOrBuilder getAgentOrBuilder(); + } + /** + *
+   * A response containing an agent.
+   * 
+ * + * Protobuf type {@code flyteidl.admin.GetAgentResponse} + */ + public static final class GetAgentResponse extends + com.google.protobuf.GeneratedMessageV3 implements + // @@protoc_insertion_point(message_implements:flyteidl.admin.GetAgentResponse) + GetAgentResponseOrBuilder { + private static final long serialVersionUID = 0L; + // Use GetAgentResponse.newBuilder() to construct. + private GetAgentResponse(com.google.protobuf.GeneratedMessageV3.Builder builder) { + super(builder); + } + private GetAgentResponse() { + } + + @java.lang.Override + public final com.google.protobuf.UnknownFieldSet + getUnknownFields() { + return this.unknownFields; + } + private GetAgentResponse( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + this(); + if (extensionRegistry == null) { + throw new java.lang.NullPointerException(); + } + int mutable_bitField0_ = 0; + com.google.protobuf.UnknownFieldSet.Builder unknownFields = + com.google.protobuf.UnknownFieldSet.newBuilder(); + try { + boolean done = false; + while (!done) { + int tag = input.readTag(); + switch (tag) { + case 0: + done = true; + break; + case 10: { + flyteidl.admin.AgentOuterClass.Agent.Builder subBuilder = null; + if (agent_ != null) { + subBuilder = agent_.toBuilder(); + } + agent_ = input.readMessage(flyteidl.admin.AgentOuterClass.Agent.parser(), extensionRegistry); + if (subBuilder != null) { + subBuilder.mergeFrom(agent_); + agent_ = 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.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentResponse_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentResponse_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.GetAgentResponse.class, flyteidl.admin.AgentOuterClass.GetAgentResponse.Builder.class); + } + + public static final int AGENT_FIELD_NUMBER = 1; + private flyteidl.admin.AgentOuterClass.Agent agent_; + /** + * .flyteidl.admin.Agent agent = 1; + */ + public boolean hasAgent() { + return agent_ != null; + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public flyteidl.admin.AgentOuterClass.Agent getAgent() { + return agent_ == null ? flyteidl.admin.AgentOuterClass.Agent.getDefaultInstance() : agent_; + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public flyteidl.admin.AgentOuterClass.AgentOrBuilder getAgentOrBuilder() { + return getAgent(); + } + + 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 (agent_ != null) { + output.writeMessage(1, getAgent()); + } + unknownFields.writeTo(output); + } + + @java.lang.Override + public int getSerializedSize() { + int size = memoizedSize; + if (size != -1) return size; + + size = 0; + if (agent_ != null) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(1, getAgent()); + } + 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.admin.AgentOuterClass.GetAgentResponse)) { + return super.equals(obj); + } + flyteidl.admin.AgentOuterClass.GetAgentResponse other = (flyteidl.admin.AgentOuterClass.GetAgentResponse) obj; + + if (hasAgent() != other.hasAgent()) return false; + if (hasAgent()) { + if (!getAgent() + .equals(other.getAgent())) 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 (hasAgent()) { + hash = (37 * hash) + AGENT_FIELD_NUMBER; + hash = (53 * hash) + getAgent().hashCode(); + } + hash = (29 * hash) + unknownFields.hashCode(); + memoizedHashCode = hash; + return hash; + } + + public static flyteidl.admin.AgentOuterClass.GetAgentResponse parseFrom( + java.nio.ByteBuffer data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse parseFrom( + java.nio.ByteBuffer data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse parseFrom( + com.google.protobuf.ByteString data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse parseFrom( + com.google.protobuf.ByteString data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse parseFrom(byte[] data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse parseFrom( + byte[] data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse parseFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse 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.admin.AgentOuterClass.GetAgentResponse parseDelimitedFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse 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.admin.AgentOuterClass.GetAgentResponse parseFrom( + com.google.protobuf.CodedInputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.GetAgentResponse 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.admin.AgentOuterClass.GetAgentResponse 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; + } + /** + *
+     * A response containing an agent.
+     * 
+ * + * Protobuf type {@code flyteidl.admin.GetAgentResponse} + */ + public static final class Builder extends + com.google.protobuf.GeneratedMessageV3.Builder implements + // @@protoc_insertion_point(builder_implements:flyteidl.admin.GetAgentResponse) + flyteidl.admin.AgentOuterClass.GetAgentResponseOrBuilder { + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentResponse_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentResponse_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.GetAgentResponse.class, flyteidl.admin.AgentOuterClass.GetAgentResponse.Builder.class); + } + + // Construct using flyteidl.admin.AgentOuterClass.GetAgentResponse.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 (agentBuilder_ == null) { + agent_ = null; + } else { + agent_ = null; + agentBuilder_ = null; + } + return this; + } + + @java.lang.Override + public com.google.protobuf.Descriptors.Descriptor + getDescriptorForType() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_GetAgentResponse_descriptor; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.GetAgentResponse getDefaultInstanceForType() { + return flyteidl.admin.AgentOuterClass.GetAgentResponse.getDefaultInstance(); + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.GetAgentResponse build() { + flyteidl.admin.AgentOuterClass.GetAgentResponse result = buildPartial(); + if (!result.isInitialized()) { + throw newUninitializedMessageException(result); + } + return result; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.GetAgentResponse buildPartial() { + flyteidl.admin.AgentOuterClass.GetAgentResponse result = new flyteidl.admin.AgentOuterClass.GetAgentResponse(this); + if (agentBuilder_ == null) { + result.agent_ = agent_; + } else { + result.agent_ = agentBuilder_.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.admin.AgentOuterClass.GetAgentResponse) { + return mergeFrom((flyteidl.admin.AgentOuterClass.GetAgentResponse)other); + } else { + super.mergeFrom(other); + return this; + } + } + + public Builder mergeFrom(flyteidl.admin.AgentOuterClass.GetAgentResponse other) { + if (other == flyteidl.admin.AgentOuterClass.GetAgentResponse.getDefaultInstance()) return this; + if (other.hasAgent()) { + mergeAgent(other.getAgent()); + } + 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.admin.AgentOuterClass.GetAgentResponse parsedMessage = null; + try { + parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + parsedMessage = (flyteidl.admin.AgentOuterClass.GetAgentResponse) e.getUnfinishedMessage(); + throw e.unwrapIOException(); + } finally { + if (parsedMessage != null) { + mergeFrom(parsedMessage); + } + } + return this; + } + + private flyteidl.admin.AgentOuterClass.Agent agent_; + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Agent, flyteidl.admin.AgentOuterClass.Agent.Builder, flyteidl.admin.AgentOuterClass.AgentOrBuilder> agentBuilder_; + /** + * .flyteidl.admin.Agent agent = 1; + */ + public boolean hasAgent() { + return agentBuilder_ != null || agent_ != null; + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public flyteidl.admin.AgentOuterClass.Agent getAgent() { + if (agentBuilder_ == null) { + return agent_ == null ? flyteidl.admin.AgentOuterClass.Agent.getDefaultInstance() : agent_; + } else { + return agentBuilder_.getMessage(); + } + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public Builder setAgent(flyteidl.admin.AgentOuterClass.Agent value) { + if (agentBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + agent_ = value; + onChanged(); + } else { + agentBuilder_.setMessage(value); + } + + return this; + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public Builder setAgent( + flyteidl.admin.AgentOuterClass.Agent.Builder builderForValue) { + if (agentBuilder_ == null) { + agent_ = builderForValue.build(); + onChanged(); + } else { + agentBuilder_.setMessage(builderForValue.build()); + } + + return this; + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public Builder mergeAgent(flyteidl.admin.AgentOuterClass.Agent value) { + if (agentBuilder_ == null) { + if (agent_ != null) { + agent_ = + flyteidl.admin.AgentOuterClass.Agent.newBuilder(agent_).mergeFrom(value).buildPartial(); + } else { + agent_ = value; + } + onChanged(); + } else { + agentBuilder_.mergeFrom(value); + } + + return this; + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public Builder clearAgent() { + if (agentBuilder_ == null) { + agent_ = null; + onChanged(); + } else { + agent_ = null; + agentBuilder_ = null; + } + + return this; + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public flyteidl.admin.AgentOuterClass.Agent.Builder getAgentBuilder() { + + onChanged(); + return getAgentFieldBuilder().getBuilder(); + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + public flyteidl.admin.AgentOuterClass.AgentOrBuilder getAgentOrBuilder() { + if (agentBuilder_ != null) { + return agentBuilder_.getMessageOrBuilder(); + } else { + return agent_ == null ? + flyteidl.admin.AgentOuterClass.Agent.getDefaultInstance() : agent_; + } + } + /** + * .flyteidl.admin.Agent agent = 1; + */ + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Agent, flyteidl.admin.AgentOuterClass.Agent.Builder, flyteidl.admin.AgentOuterClass.AgentOrBuilder> + getAgentFieldBuilder() { + if (agentBuilder_ == null) { + agentBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Agent, flyteidl.admin.AgentOuterClass.Agent.Builder, flyteidl.admin.AgentOuterClass.AgentOrBuilder>( + getAgent(), + getParentForChildren(), + isClean()); + agent_ = null; + } + return agentBuilder_; + } + @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.admin.GetAgentResponse) + } + + // @@protoc_insertion_point(class_scope:flyteidl.admin.GetAgentResponse) + private static final flyteidl.admin.AgentOuterClass.GetAgentResponse DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.GetAgentResponse(); + } + + public static flyteidl.admin.AgentOuterClass.GetAgentResponse getDefaultInstance() { + return DEFAULT_INSTANCE; + } + + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { + @java.lang.Override + public GetAgentResponse parsePartialFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return new GetAgentResponse(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.admin.AgentOuterClass.GetAgentResponse getDefaultInstanceForType() { + return DEFAULT_INSTANCE; + } + + } + + public interface ListAgentsRequestOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.admin.ListAgentsRequest) + com.google.protobuf.MessageOrBuilder { + } + /** + *
+   * A request to list all agents.
+   * 
+ * + * Protobuf type {@code flyteidl.admin.ListAgentsRequest} + */ + public static final class ListAgentsRequest extends + com.google.protobuf.GeneratedMessageV3 implements + // @@protoc_insertion_point(message_implements:flyteidl.admin.ListAgentsRequest) + ListAgentsRequestOrBuilder { + private static final long serialVersionUID = 0L; + // Use ListAgentsRequest.newBuilder() to construct. + private ListAgentsRequest(com.google.protobuf.GeneratedMessageV3.Builder builder) { + super(builder); + } + private ListAgentsRequest() { + } + + @java.lang.Override + public final com.google.protobuf.UnknownFieldSet + getUnknownFields() { + return this.unknownFields; + } + private ListAgentsRequest( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + this(); + if (extensionRegistry == null) { + throw new java.lang.NullPointerException(); + } + 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; + 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.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsRequest_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsRequest_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.ListAgentsRequest.class, flyteidl.admin.AgentOuterClass.ListAgentsRequest.Builder.class); + } + + 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 { + unknownFields.writeTo(output); + } + + @java.lang.Override + public int getSerializedSize() { + int size = memoizedSize; + if (size != -1) return size; + + size = 0; + 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.admin.AgentOuterClass.ListAgentsRequest)) { + return super.equals(obj); + } + flyteidl.admin.AgentOuterClass.ListAgentsRequest other = (flyteidl.admin.AgentOuterClass.ListAgentsRequest) obj; + + 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(); + hash = (29 * hash) + unknownFields.hashCode(); + memoizedHashCode = hash; + return hash; + } + + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest parseFrom( + java.nio.ByteBuffer data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest parseFrom( + java.nio.ByteBuffer data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest parseFrom( + com.google.protobuf.ByteString data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest parseFrom( + com.google.protobuf.ByteString data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest parseFrom(byte[] data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest parseFrom( + byte[] data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest parseFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest 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.admin.AgentOuterClass.ListAgentsRequest parseDelimitedFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest 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.admin.AgentOuterClass.ListAgentsRequest parseFrom( + com.google.protobuf.CodedInputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest 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.admin.AgentOuterClass.ListAgentsRequest 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; + } + /** + *
+     * A request to list all agents.
+     * 
+ * + * Protobuf type {@code flyteidl.admin.ListAgentsRequest} + */ + public static final class Builder extends + com.google.protobuf.GeneratedMessageV3.Builder implements + // @@protoc_insertion_point(builder_implements:flyteidl.admin.ListAgentsRequest) + flyteidl.admin.AgentOuterClass.ListAgentsRequestOrBuilder { + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsRequest_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsRequest_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.ListAgentsRequest.class, flyteidl.admin.AgentOuterClass.ListAgentsRequest.Builder.class); + } + + // Construct using flyteidl.admin.AgentOuterClass.ListAgentsRequest.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(); + return this; + } + + @java.lang.Override + public com.google.protobuf.Descriptors.Descriptor + getDescriptorForType() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsRequest_descriptor; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.ListAgentsRequest getDefaultInstanceForType() { + return flyteidl.admin.AgentOuterClass.ListAgentsRequest.getDefaultInstance(); + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.ListAgentsRequest build() { + flyteidl.admin.AgentOuterClass.ListAgentsRequest result = buildPartial(); + if (!result.isInitialized()) { + throw newUninitializedMessageException(result); + } + return result; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.ListAgentsRequest buildPartial() { + flyteidl.admin.AgentOuterClass.ListAgentsRequest result = new flyteidl.admin.AgentOuterClass.ListAgentsRequest(this); + 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.admin.AgentOuterClass.ListAgentsRequest) { + return mergeFrom((flyteidl.admin.AgentOuterClass.ListAgentsRequest)other); + } else { + super.mergeFrom(other); + return this; + } + } + + public Builder mergeFrom(flyteidl.admin.AgentOuterClass.ListAgentsRequest other) { + if (other == flyteidl.admin.AgentOuterClass.ListAgentsRequest.getDefaultInstance()) return this; + 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.admin.AgentOuterClass.ListAgentsRequest parsedMessage = null; + try { + parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + parsedMessage = (flyteidl.admin.AgentOuterClass.ListAgentsRequest) e.getUnfinishedMessage(); + throw e.unwrapIOException(); + } finally { + if (parsedMessage != null) { + mergeFrom(parsedMessage); + } + } + return this; + } + @java.lang.Override + public final Builder setUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.setUnknownFields(unknownFields); + } + + @java.lang.Override + public final Builder mergeUnknownFields( + final com.google.protobuf.UnknownFieldSet unknownFields) { + return super.mergeUnknownFields(unknownFields); + } + + + // @@protoc_insertion_point(builder_scope:flyteidl.admin.ListAgentsRequest) + } + + // @@protoc_insertion_point(class_scope:flyteidl.admin.ListAgentsRequest) + private static final flyteidl.admin.AgentOuterClass.ListAgentsRequest DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.ListAgentsRequest(); + } + + public static flyteidl.admin.AgentOuterClass.ListAgentsRequest getDefaultInstance() { + return DEFAULT_INSTANCE; + } + + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { + @java.lang.Override + public ListAgentsRequest parsePartialFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return new ListAgentsRequest(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.admin.AgentOuterClass.ListAgentsRequest getDefaultInstanceForType() { + return DEFAULT_INSTANCE; + } + + } + + public interface ListAgentsResponseOrBuilder extends + // @@protoc_insertion_point(interface_extends:flyteidl.admin.ListAgentsResponse) + com.google.protobuf.MessageOrBuilder { + + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + java.util.List + getAgentsList(); + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + flyteidl.admin.AgentOuterClass.Agent getAgents(int index); + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + int getAgentsCount(); + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + java.util.List + getAgentsOrBuilderList(); + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + flyteidl.admin.AgentOuterClass.AgentOrBuilder getAgentsOrBuilder( + int index); + } + /** + *
+   * A response containing a list of agents.
+   * 
+ * + * Protobuf type {@code flyteidl.admin.ListAgentsResponse} + */ + public static final class ListAgentsResponse extends + com.google.protobuf.GeneratedMessageV3 implements + // @@protoc_insertion_point(message_implements:flyteidl.admin.ListAgentsResponse) + ListAgentsResponseOrBuilder { + private static final long serialVersionUID = 0L; + // Use ListAgentsResponse.newBuilder() to construct. + private ListAgentsResponse(com.google.protobuf.GeneratedMessageV3.Builder builder) { + super(builder); + } + private ListAgentsResponse() { + agents_ = java.util.Collections.emptyList(); + } + + @java.lang.Override + public final com.google.protobuf.UnknownFieldSet + getUnknownFields() { + return this.unknownFields; + } + private ListAgentsResponse( + 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: { + if (!((mutable_bitField0_ & 0x00000001) != 0)) { + agents_ = new java.util.ArrayList(); + mutable_bitField0_ |= 0x00000001; + } + agents_.add( + input.readMessage(flyteidl.admin.AgentOuterClass.Agent.parser(), extensionRegistry)); + 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 { + if (((mutable_bitField0_ & 0x00000001) != 0)) { + agents_ = java.util.Collections.unmodifiableList(agents_); + } + this.unknownFields = unknownFields.build(); + makeExtensionsImmutable(); + } + } + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsResponse_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsResponse_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.ListAgentsResponse.class, flyteidl.admin.AgentOuterClass.ListAgentsResponse.Builder.class); + } + + public static final int AGENTS_FIELD_NUMBER = 1; + private java.util.List agents_; + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public java.util.List getAgentsList() { + return agents_; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public java.util.List + getAgentsOrBuilderList() { + return agents_; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public int getAgentsCount() { + return agents_.size(); + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public flyteidl.admin.AgentOuterClass.Agent getAgents(int index) { + return agents_.get(index); + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public flyteidl.admin.AgentOuterClass.AgentOrBuilder getAgentsOrBuilder( + int index) { + return agents_.get(index); + } + + 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 { + for (int i = 0; i < agents_.size(); i++) { + output.writeMessage(1, agents_.get(i)); + } + unknownFields.writeTo(output); + } + + @java.lang.Override + public int getSerializedSize() { + int size = memoizedSize; + if (size != -1) return size; + + size = 0; + for (int i = 0; i < agents_.size(); i++) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(1, agents_.get(i)); + } + 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.admin.AgentOuterClass.ListAgentsResponse)) { + return super.equals(obj); + } + flyteidl.admin.AgentOuterClass.ListAgentsResponse other = (flyteidl.admin.AgentOuterClass.ListAgentsResponse) obj; + + if (!getAgentsList() + .equals(other.getAgentsList())) 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 (getAgentsCount() > 0) { + hash = (37 * hash) + AGENTS_FIELD_NUMBER; + hash = (53 * hash) + getAgentsList().hashCode(); + } + hash = (29 * hash) + unknownFields.hashCode(); + memoizedHashCode = hash; + return hash; + } + + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse parseFrom( + java.nio.ByteBuffer data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse parseFrom( + java.nio.ByteBuffer data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse parseFrom( + com.google.protobuf.ByteString data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse parseFrom( + com.google.protobuf.ByteString data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse parseFrom(byte[] data) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse parseFrom( + byte[] data, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return PARSER.parseFrom(data, extensionRegistry); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse parseFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse 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.admin.AgentOuterClass.ListAgentsResponse parseDelimitedFrom(java.io.InputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseDelimitedWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse 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.admin.AgentOuterClass.ListAgentsResponse parseFrom( + com.google.protobuf.CodedInputStream input) + throws java.io.IOException { + return com.google.protobuf.GeneratedMessageV3 + .parseWithIOException(PARSER, input); + } + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse 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.admin.AgentOuterClass.ListAgentsResponse 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; + } + /** + *
+     * A response containing a list of agents.
+     * 
+ * + * Protobuf type {@code flyteidl.admin.ListAgentsResponse} + */ + public static final class Builder extends + com.google.protobuf.GeneratedMessageV3.Builder implements + // @@protoc_insertion_point(builder_implements:flyteidl.admin.ListAgentsResponse) + flyteidl.admin.AgentOuterClass.ListAgentsResponseOrBuilder { + public static final com.google.protobuf.Descriptors.Descriptor + getDescriptor() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsResponse_descriptor; + } + + @java.lang.Override + protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internalGetFieldAccessorTable() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsResponse_fieldAccessorTable + .ensureFieldAccessorsInitialized( + flyteidl.admin.AgentOuterClass.ListAgentsResponse.class, flyteidl.admin.AgentOuterClass.ListAgentsResponse.Builder.class); + } + + // Construct using flyteidl.admin.AgentOuterClass.ListAgentsResponse.newBuilder() + private Builder() { + maybeForceBuilderInitialization(); + } + + private Builder( + com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { + super(parent); + maybeForceBuilderInitialization(); + } + private void maybeForceBuilderInitialization() { + if (com.google.protobuf.GeneratedMessageV3 + .alwaysUseFieldBuilders) { + getAgentsFieldBuilder(); + } + } + @java.lang.Override + public Builder clear() { + super.clear(); + if (agentsBuilder_ == null) { + agents_ = java.util.Collections.emptyList(); + bitField0_ = (bitField0_ & ~0x00000001); + } else { + agentsBuilder_.clear(); + } + return this; + } + + @java.lang.Override + public com.google.protobuf.Descriptors.Descriptor + getDescriptorForType() { + return flyteidl.admin.AgentOuterClass.internal_static_flyteidl_admin_ListAgentsResponse_descriptor; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.ListAgentsResponse getDefaultInstanceForType() { + return flyteidl.admin.AgentOuterClass.ListAgentsResponse.getDefaultInstance(); + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.ListAgentsResponse build() { + flyteidl.admin.AgentOuterClass.ListAgentsResponse result = buildPartial(); + if (!result.isInitialized()) { + throw newUninitializedMessageException(result); + } + return result; + } + + @java.lang.Override + public flyteidl.admin.AgentOuterClass.ListAgentsResponse buildPartial() { + flyteidl.admin.AgentOuterClass.ListAgentsResponse result = new flyteidl.admin.AgentOuterClass.ListAgentsResponse(this); + int from_bitField0_ = bitField0_; + if (agentsBuilder_ == null) { + if (((bitField0_ & 0x00000001) != 0)) { + agents_ = java.util.Collections.unmodifiableList(agents_); + bitField0_ = (bitField0_ & ~0x00000001); + } + result.agents_ = agents_; + } else { + result.agents_ = agentsBuilder_.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.admin.AgentOuterClass.ListAgentsResponse) { + return mergeFrom((flyteidl.admin.AgentOuterClass.ListAgentsResponse)other); + } else { + super.mergeFrom(other); + return this; + } + } + + public Builder mergeFrom(flyteidl.admin.AgentOuterClass.ListAgentsResponse other) { + if (other == flyteidl.admin.AgentOuterClass.ListAgentsResponse.getDefaultInstance()) return this; + if (agentsBuilder_ == null) { + if (!other.agents_.isEmpty()) { + if (agents_.isEmpty()) { + agents_ = other.agents_; + bitField0_ = (bitField0_ & ~0x00000001); + } else { + ensureAgentsIsMutable(); + agents_.addAll(other.agents_); + } + onChanged(); + } + } else { + if (!other.agents_.isEmpty()) { + if (agentsBuilder_.isEmpty()) { + agentsBuilder_.dispose(); + agentsBuilder_ = null; + agents_ = other.agents_; + bitField0_ = (bitField0_ & ~0x00000001); + agentsBuilder_ = + com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ? + getAgentsFieldBuilder() : null; + } else { + agentsBuilder_.addAllMessages(other.agents_); + } + } + } + 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.admin.AgentOuterClass.ListAgentsResponse parsedMessage = null; + try { + parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry); + } catch (com.google.protobuf.InvalidProtocolBufferException e) { + parsedMessage = (flyteidl.admin.AgentOuterClass.ListAgentsResponse) e.getUnfinishedMessage(); + throw e.unwrapIOException(); + } finally { + if (parsedMessage != null) { + mergeFrom(parsedMessage); + } + } + return this; + } + private int bitField0_; + + private java.util.List agents_ = + java.util.Collections.emptyList(); + private void ensureAgentsIsMutable() { + if (!((bitField0_ & 0x00000001) != 0)) { + agents_ = new java.util.ArrayList(agents_); + bitField0_ |= 0x00000001; + } + } + + private com.google.protobuf.RepeatedFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Agent, flyteidl.admin.AgentOuterClass.Agent.Builder, flyteidl.admin.AgentOuterClass.AgentOrBuilder> agentsBuilder_; + + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public java.util.List getAgentsList() { + if (agentsBuilder_ == null) { + return java.util.Collections.unmodifiableList(agents_); + } else { + return agentsBuilder_.getMessageList(); + } + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public int getAgentsCount() { + if (agentsBuilder_ == null) { + return agents_.size(); + } else { + return agentsBuilder_.getCount(); + } + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public flyteidl.admin.AgentOuterClass.Agent getAgents(int index) { + if (agentsBuilder_ == null) { + return agents_.get(index); + } else { + return agentsBuilder_.getMessage(index); + } + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder setAgents( + int index, flyteidl.admin.AgentOuterClass.Agent value) { + if (agentsBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + ensureAgentsIsMutable(); + agents_.set(index, value); + onChanged(); + } else { + agentsBuilder_.setMessage(index, value); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder setAgents( + int index, flyteidl.admin.AgentOuterClass.Agent.Builder builderForValue) { + if (agentsBuilder_ == null) { + ensureAgentsIsMutable(); + agents_.set(index, builderForValue.build()); + onChanged(); + } else { + agentsBuilder_.setMessage(index, builderForValue.build()); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder addAgents(flyteidl.admin.AgentOuterClass.Agent value) { + if (agentsBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + ensureAgentsIsMutable(); + agents_.add(value); + onChanged(); + } else { + agentsBuilder_.addMessage(value); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder addAgents( + int index, flyteidl.admin.AgentOuterClass.Agent value) { + if (agentsBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + ensureAgentsIsMutable(); + agents_.add(index, value); + onChanged(); + } else { + agentsBuilder_.addMessage(index, value); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder addAgents( + flyteidl.admin.AgentOuterClass.Agent.Builder builderForValue) { + if (agentsBuilder_ == null) { + ensureAgentsIsMutable(); + agents_.add(builderForValue.build()); + onChanged(); + } else { + agentsBuilder_.addMessage(builderForValue.build()); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder addAgents( + int index, flyteidl.admin.AgentOuterClass.Agent.Builder builderForValue) { + if (agentsBuilder_ == null) { + ensureAgentsIsMutable(); + agents_.add(index, builderForValue.build()); + onChanged(); + } else { + agentsBuilder_.addMessage(index, builderForValue.build()); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder addAllAgents( + java.lang.Iterable values) { + if (agentsBuilder_ == null) { + ensureAgentsIsMutable(); + com.google.protobuf.AbstractMessageLite.Builder.addAll( + values, agents_); + onChanged(); + } else { + agentsBuilder_.addAllMessages(values); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder clearAgents() { + if (agentsBuilder_ == null) { + agents_ = java.util.Collections.emptyList(); + bitField0_ = (bitField0_ & ~0x00000001); + onChanged(); + } else { + agentsBuilder_.clear(); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public Builder removeAgents(int index) { + if (agentsBuilder_ == null) { + ensureAgentsIsMutable(); + agents_.remove(index); + onChanged(); + } else { + agentsBuilder_.remove(index); + } + return this; + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public flyteidl.admin.AgentOuterClass.Agent.Builder getAgentsBuilder( + int index) { + return getAgentsFieldBuilder().getBuilder(index); + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public flyteidl.admin.AgentOuterClass.AgentOrBuilder getAgentsOrBuilder( + int index) { + if (agentsBuilder_ == null) { + return agents_.get(index); } else { + return agentsBuilder_.getMessageOrBuilder(index); + } + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public java.util.List + getAgentsOrBuilderList() { + if (agentsBuilder_ != null) { + return agentsBuilder_.getMessageOrBuilderList(); + } else { + return java.util.Collections.unmodifiableList(agents_); + } + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public flyteidl.admin.AgentOuterClass.Agent.Builder addAgentsBuilder() { + return getAgentsFieldBuilder().addBuilder( + flyteidl.admin.AgentOuterClass.Agent.getDefaultInstance()); + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public flyteidl.admin.AgentOuterClass.Agent.Builder addAgentsBuilder( + int index) { + return getAgentsFieldBuilder().addBuilder( + index, flyteidl.admin.AgentOuterClass.Agent.getDefaultInstance()); + } + /** + * repeated .flyteidl.admin.Agent agents = 1; + */ + public java.util.List + getAgentsBuilderList() { + return getAgentsFieldBuilder().getBuilderList(); + } + private com.google.protobuf.RepeatedFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Agent, flyteidl.admin.AgentOuterClass.Agent.Builder, flyteidl.admin.AgentOuterClass.AgentOrBuilder> + getAgentsFieldBuilder() { + if (agentsBuilder_ == null) { + agentsBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Agent, flyteidl.admin.AgentOuterClass.Agent.Builder, flyteidl.admin.AgentOuterClass.AgentOrBuilder>( + agents_, + ((bitField0_ & 0x00000001) != 0), + getParentForChildren(), + isClean()); + agents_ = null; + } + return agentsBuilder_; + } + @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.admin.ListAgentsResponse) + } + + // @@protoc_insertion_point(class_scope:flyteidl.admin.ListAgentsResponse) + private static final flyteidl.admin.AgentOuterClass.ListAgentsResponse DEFAULT_INSTANCE; + static { + DEFAULT_INSTANCE = new flyteidl.admin.AgentOuterClass.ListAgentsResponse(); + } + + public static flyteidl.admin.AgentOuterClass.ListAgentsResponse getDefaultInstance() { + return DEFAULT_INSTANCE; + } + + private static final com.google.protobuf.Parser + PARSER = new com.google.protobuf.AbstractParser() { + @java.lang.Override + public ListAgentsResponse parsePartialFrom( + com.google.protobuf.CodedInputStream input, + com.google.protobuf.ExtensionRegistryLite extensionRegistry) + throws com.google.protobuf.InvalidProtocolBufferException { + return new ListAgentsResponse(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.admin.AgentOuterClass.ListAgentsResponse getDefaultInstanceForType() { return DEFAULT_INSTANCE; } @@ -8045,6 +11315,31 @@ public flyteidl.admin.Agent.DeleteTaskResponse getDefaultInstanceForType() { private static final com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internal_static_flyteidl_admin_DeleteTaskResponse_fieldAccessorTable; + private static final com.google.protobuf.Descriptors.Descriptor + internal_static_flyteidl_admin_Agent_descriptor; + private static final + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internal_static_flyteidl_admin_Agent_fieldAccessorTable; + private static final com.google.protobuf.Descriptors.Descriptor + internal_static_flyteidl_admin_GetAgentRequest_descriptor; + private static final + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internal_static_flyteidl_admin_GetAgentRequest_fieldAccessorTable; + private static final com.google.protobuf.Descriptors.Descriptor + internal_static_flyteidl_admin_GetAgentResponse_descriptor; + private static final + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internal_static_flyteidl_admin_GetAgentResponse_fieldAccessorTable; + private static final com.google.protobuf.Descriptors.Descriptor + internal_static_flyteidl_admin_ListAgentsRequest_descriptor; + private static final + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internal_static_flyteidl_admin_ListAgentsRequest_fieldAccessorTable; + private static final com.google.protobuf.Descriptors.Descriptor + internal_static_flyteidl_admin_ListAgentsResponse_descriptor; + private static final + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable + internal_static_flyteidl_admin_ListAgentsResponse_fieldAccessorTable; public static com.google.protobuf.Descriptors.FileDescriptor getDescriptor() { @@ -8087,11 +11382,17 @@ public flyteidl.admin.Agent.DeleteTaskResponse getDefaultInstanceForType() { "tate\022*\n\007outputs\030\002 \001(\0132\031.flyteidl.core.Li" + "teralMap\022\017\n\007message\030\003 \001(\t\"=\n\021DeleteTaskR" + "equest\022\021\n\ttask_type\030\001 \001(\t\022\025\n\rresource_me" + - "ta\030\002 \001(\014\"\024\n\022DeleteTaskResponse*^\n\005State\022" + - "\025\n\021RETRYABLE_FAILURE\020\000\022\025\n\021PERMANENT_FAIL" + - "URE\020\001\022\013\n\007PENDING\020\002\022\013\n\007RUNNING\020\003\022\r\n\tSUCCE" + - "EDED\020\004B=Z;github.com/flyteorg/flyte/flyt" + - "eidl/gen/pb-go/flyteidl/adminb\006proto3" + "ta\030\002 \001(\014\"\024\n\022DeleteTaskResponse\"3\n\005Agent\022" + + "\014\n\004name\030\001 \001(\t\022\034\n\024supported_task_types\030\002 " + + "\003(\t\"\037\n\017GetAgentRequest\022\014\n\004name\030\001 \001(\t\"8\n\020" + + "GetAgentResponse\022$\n\005agent\030\001 \001(\0132\025.flytei" + + "dl.admin.Agent\"\023\n\021ListAgentsRequest\";\n\022L" + + "istAgentsResponse\022%\n\006agents\030\001 \003(\0132\025.flyt" + + "eidl.admin.Agent*^\n\005State\022\025\n\021RETRYABLE_F" + + "AILURE\020\000\022\025\n\021PERMANENT_FAILURE\020\001\022\013\n\007PENDI" + + "NG\020\002\022\013\n\007RUNNING\020\003\022\r\n\tSUCCEEDED\020\004B=Z;gith" + + "ub.com/flyteorg/flyte/flyteidl/gen/pb-go" + + "/flyteidl/adminb\006proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -8176,6 +11477,36 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_DeleteTaskResponse_descriptor, new java.lang.String[] { }); + internal_static_flyteidl_admin_Agent_descriptor = + getDescriptor().getMessageTypes().get(8); + internal_static_flyteidl_admin_Agent_fieldAccessorTable = new + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( + internal_static_flyteidl_admin_Agent_descriptor, + new java.lang.String[] { "Name", "SupportedTaskTypes", }); + internal_static_flyteidl_admin_GetAgentRequest_descriptor = + getDescriptor().getMessageTypes().get(9); + internal_static_flyteidl_admin_GetAgentRequest_fieldAccessorTable = new + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( + internal_static_flyteidl_admin_GetAgentRequest_descriptor, + new java.lang.String[] { "Name", }); + internal_static_flyteidl_admin_GetAgentResponse_descriptor = + getDescriptor().getMessageTypes().get(10); + internal_static_flyteidl_admin_GetAgentResponse_fieldAccessorTable = new + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( + internal_static_flyteidl_admin_GetAgentResponse_descriptor, + new java.lang.String[] { "Agent", }); + internal_static_flyteidl_admin_ListAgentsRequest_descriptor = + getDescriptor().getMessageTypes().get(11); + internal_static_flyteidl_admin_ListAgentsRequest_fieldAccessorTable = new + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( + internal_static_flyteidl_admin_ListAgentsRequest_descriptor, + new java.lang.String[] { }); + internal_static_flyteidl_admin_ListAgentsResponse_descriptor = + getDescriptor().getMessageTypes().get(12); + internal_static_flyteidl_admin_ListAgentsResponse_fieldAccessorTable = new + com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( + internal_static_flyteidl_admin_ListAgentsResponse_descriptor, + new java.lang.String[] { "Agents", }); flyteidl.core.Literals.getDescriptor(); flyteidl.core.Tasks.getDescriptor(); flyteidl.core.Interface.getDescriptor(); diff --git a/flyteidl/gen/pb-java/flyteidl/service/Agent.java b/flyteidl/gen/pb-java/flyteidl/service/Agent.java index 8d80085901..a4d582fab0 100644 --- a/flyteidl/gen/pb-java/flyteidl/service/Agent.java +++ b/flyteidl/gen/pb-java/flyteidl/service/Agent.java @@ -24,16 +24,23 @@ public static void registerAllExtensions( static { java.lang.String[] descriptorData = { "\n\034flyteidl/service/agent.proto\022\020flyteidl" + - ".service\032\032flyteidl/admin/agent.proto2\217\002\n" + - "\021AsyncAgentService\022U\n\nCreateTask\022!.flyte" + - "idl.admin.CreateTaskRequest\032\".flyteidl.a" + - "dmin.CreateTaskResponse\"\000\022L\n\007GetTask\022\036.f" + - "lyteidl.admin.GetTaskRequest\032\037.flyteidl." + - "admin.GetTaskResponse\"\000\022U\n\nDeleteTask\022!." + - "flyteidl.admin.DeleteTaskRequest\032\".flyte" + - "idl.admin.DeleteTaskResponse\"\000B?Z=github" + - ".com/flyteorg/flyte/flyteidl/gen/pb-go/f" + - "lyteidl/serviceb\006proto3" + ".service\032\034google/api/annotations.proto\032\032" + + "flyteidl/admin/agent.proto2\217\002\n\021AsyncAgen" + + "tService\022U\n\nCreateTask\022!.flyteidl.admin." + + "CreateTaskRequest\032\".flyteidl.admin.Creat" + + "eTaskResponse\"\000\022L\n\007GetTask\022\036.flyteidl.ad" + + "min.GetTaskRequest\032\037.flyteidl.admin.GetT" + + "askResponse\"\000\022U\n\nDeleteTask\022!.flyteidl.a" + + "dmin.DeleteTaskRequest\032\".flyteidl.admin." + + "DeleteTaskResponse\"\0002\360\001\n\024AgentMetadataSe" + + "rvice\022k\n\010GetAgent\022\037.flyteidl.admin.GetAg" + + "entRequest\032 .flyteidl.admin.GetAgentResp" + + "onse\"\034\202\323\344\223\002\026\022\024/api/v1/agent/{name}\022k\n\nLi" + + "stAgents\022!.flyteidl.admin.ListAgentsRequ" + + "est\032\".flyteidl.admin.ListAgentsResponse\"" + + "\026\202\323\344\223\002\020\022\016/api/v1/agentsB?Z=github.com/fl" + + "yteorg/flyte/flyteidl/gen/pb-go/flyteidl" + + "/serviceb\006proto3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -46,9 +53,16 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( com.google.protobuf.Descriptors.FileDescriptor .internalBuildGeneratedFileFrom(descriptorData, new com.google.protobuf.Descriptors.FileDescriptor[] { - flyteidl.admin.Agent.getDescriptor(), + com.google.api.AnnotationsProto.getDescriptor(), + flyteidl.admin.AgentOuterClass.getDescriptor(), }, assigner); - flyteidl.admin.Agent.getDescriptor(); + com.google.protobuf.ExtensionRegistry registry = + com.google.protobuf.ExtensionRegistry.newInstance(); + registry.add(com.google.api.AnnotationsProto.http); + com.google.protobuf.Descriptors.FileDescriptor + .internalUpdateFileDescriptor(descriptor, registry); + com.google.api.AnnotationsProto.getDescriptor(); + flyteidl.admin.AgentOuterClass.getDescriptor(); } // @@protoc_insertion_point(outer_class_scope) diff --git a/flyteidl/gen/pb-js/flyteidl.d.ts b/flyteidl/gen/pb-js/flyteidl.d.ts index 7eabf4c916..2e0ff4e76c 100644 --- a/flyteidl/gen/pb-js/flyteidl.d.ts +++ b/flyteidl/gen/pb-js/flyteidl.d.ts @@ -8359,6 +8359,266 @@ export namespace flyteidl { public static verify(message: { [k: string]: any }): (string|null); } + /** Properties of an Agent. */ + interface IAgent { + + /** Agent name */ + name?: (string|null); + + /** Agent supportedTaskTypes */ + supportedTaskTypes?: (string[]|null); + } + + /** Represents an Agent. */ + class Agent implements IAgent { + + /** + * Constructs a new Agent. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.admin.IAgent); + + /** Agent name. */ + public name: string; + + /** Agent supportedTaskTypes. */ + public supportedTaskTypes: string[]; + + /** + * Creates a new Agent instance using the specified properties. + * @param [properties] Properties to set + * @returns Agent instance + */ + public static create(properties?: flyteidl.admin.IAgent): flyteidl.admin.Agent; + + /** + * Encodes the specified Agent message. Does not implicitly {@link flyteidl.admin.Agent.verify|verify} messages. + * @param message Agent message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.admin.IAgent, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes an Agent message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns Agent + * @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.admin.Agent; + + /** + * Verifies an Agent 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 GetAgentRequest. */ + interface IGetAgentRequest { + + /** GetAgentRequest name */ + name?: (string|null); + } + + /** Represents a GetAgentRequest. */ + class GetAgentRequest implements IGetAgentRequest { + + /** + * Constructs a new GetAgentRequest. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.admin.IGetAgentRequest); + + /** GetAgentRequest name. */ + public name: string; + + /** + * Creates a new GetAgentRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns GetAgentRequest instance + */ + public static create(properties?: flyteidl.admin.IGetAgentRequest): flyteidl.admin.GetAgentRequest; + + /** + * Encodes the specified GetAgentRequest message. Does not implicitly {@link flyteidl.admin.GetAgentRequest.verify|verify} messages. + * @param message GetAgentRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.admin.IGetAgentRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetAgentRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetAgentRequest + * @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.admin.GetAgentRequest; + + /** + * Verifies a GetAgentRequest 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 GetAgentResponse. */ + interface IGetAgentResponse { + + /** GetAgentResponse agent */ + agent?: (flyteidl.admin.IAgent|null); + } + + /** Represents a GetAgentResponse. */ + class GetAgentResponse implements IGetAgentResponse { + + /** + * Constructs a new GetAgentResponse. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.admin.IGetAgentResponse); + + /** GetAgentResponse agent. */ + public agent?: (flyteidl.admin.IAgent|null); + + /** + * Creates a new GetAgentResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns GetAgentResponse instance + */ + public static create(properties?: flyteidl.admin.IGetAgentResponse): flyteidl.admin.GetAgentResponse; + + /** + * Encodes the specified GetAgentResponse message. Does not implicitly {@link flyteidl.admin.GetAgentResponse.verify|verify} messages. + * @param message GetAgentResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.admin.IGetAgentResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a GetAgentResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns GetAgentResponse + * @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.admin.GetAgentResponse; + + /** + * Verifies a GetAgentResponse 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 ListAgentsRequest. */ + interface IListAgentsRequest { + } + + /** Represents a ListAgentsRequest. */ + class ListAgentsRequest implements IListAgentsRequest { + + /** + * Constructs a new ListAgentsRequest. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.admin.IListAgentsRequest); + + /** + * Creates a new ListAgentsRequest instance using the specified properties. + * @param [properties] Properties to set + * @returns ListAgentsRequest instance + */ + public static create(properties?: flyteidl.admin.IListAgentsRequest): flyteidl.admin.ListAgentsRequest; + + /** + * Encodes the specified ListAgentsRequest message. Does not implicitly {@link flyteidl.admin.ListAgentsRequest.verify|verify} messages. + * @param message ListAgentsRequest message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.admin.IListAgentsRequest, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListAgentsRequest message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListAgentsRequest + * @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.admin.ListAgentsRequest; + + /** + * Verifies a ListAgentsRequest 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 ListAgentsResponse. */ + interface IListAgentsResponse { + + /** ListAgentsResponse agents */ + agents?: (flyteidl.admin.IAgent[]|null); + } + + /** Represents a ListAgentsResponse. */ + class ListAgentsResponse implements IListAgentsResponse { + + /** + * Constructs a new ListAgentsResponse. + * @param [properties] Properties to set + */ + constructor(properties?: flyteidl.admin.IListAgentsResponse); + + /** ListAgentsResponse agents. */ + public agents: flyteidl.admin.IAgent[]; + + /** + * Creates a new ListAgentsResponse instance using the specified properties. + * @param [properties] Properties to set + * @returns ListAgentsResponse instance + */ + public static create(properties?: flyteidl.admin.IListAgentsResponse): flyteidl.admin.ListAgentsResponse; + + /** + * Encodes the specified ListAgentsResponse message. Does not implicitly {@link flyteidl.admin.ListAgentsResponse.verify|verify} messages. + * @param message ListAgentsResponse message or plain object to encode + * @param [writer] Writer to encode to + * @returns Writer + */ + public static encode(message: flyteidl.admin.IListAgentsResponse, writer?: $protobuf.Writer): $protobuf.Writer; + + /** + * Decodes a ListAgentsResponse message from the specified reader or buffer. + * @param reader Reader or buffer to decode from + * @param [length] Message length if known beforehand + * @returns ListAgentsResponse + * @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.admin.ListAgentsResponse; + + /** + * Verifies a ListAgentsResponse 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 ClusterAssignment. */ interface IClusterAssignment { @@ -19736,6 +19996,72 @@ export namespace flyteidl { type DeleteTaskCallback = (error: (Error|null), response?: flyteidl.admin.DeleteTaskResponse) => void; } + /** Represents an AgentMetadataService */ + class AgentMetadataService extends $protobuf.rpc.Service { + + /** + * Constructs a new AgentMetadataService service. + * @param rpcImpl RPC implementation + * @param [requestDelimited=false] Whether requests are length-delimited + * @param [responseDelimited=false] Whether responses are length-delimited + */ + constructor(rpcImpl: $protobuf.RPCImpl, requestDelimited?: boolean, responseDelimited?: boolean); + + /** + * Creates new AgentMetadataService service using the specified rpc implementation. + * @param rpcImpl RPC implementation + * @param [requestDelimited=false] Whether requests are length-delimited + * @param [responseDelimited=false] Whether responses are length-delimited + * @returns RPC service. Useful where requests and/or responses are streamed. + */ + public static create(rpcImpl: $protobuf.RPCImpl, requestDelimited?: boolean, responseDelimited?: boolean): AgentMetadataService; + + /** + * Calls GetAgent. + * @param request GetAgentRequest message or plain object + * @param callback Node-style callback called with the error, if any, and GetAgentResponse + */ + public getAgent(request: flyteidl.admin.IGetAgentRequest, callback: flyteidl.service.AgentMetadataService.GetAgentCallback): void; + + /** + * Calls GetAgent. + * @param request GetAgentRequest message or plain object + * @returns Promise + */ + public getAgent(request: flyteidl.admin.IGetAgentRequest): Promise; + + /** + * Calls ListAgents. + * @param request ListAgentsRequest message or plain object + * @param callback Node-style callback called with the error, if any, and ListAgentsResponse + */ + public listAgents(request: flyteidl.admin.IListAgentsRequest, callback: flyteidl.service.AgentMetadataService.ListAgentsCallback): void; + + /** + * Calls ListAgents. + * @param request ListAgentsRequest message or plain object + * @returns Promise + */ + public listAgents(request: flyteidl.admin.IListAgentsRequest): Promise; + } + + namespace AgentMetadataService { + + /** + * Callback as used by {@link flyteidl.service.AgentMetadataService#getAgent}. + * @param error Error, if any + * @param [response] GetAgentResponse + */ + type GetAgentCallback = (error: (Error|null), response?: flyteidl.admin.GetAgentResponse) => void; + + /** + * Callback as used by {@link flyteidl.service.AgentMetadataService#listAgents}. + * @param error Error, if any + * @param [response] ListAgentsResponse + */ + type ListAgentsCallback = (error: (Error|null), response?: flyteidl.admin.ListAgentsResponse) => void; + } + /** Properties of a OAuth2MetadataRequest. */ interface IOAuth2MetadataRequest { } diff --git a/flyteidl/gen/pb-js/flyteidl.js b/flyteidl/gen/pb-js/flyteidl.js index 303991d68e..95f887c3ba 100644 --- a/flyteidl/gen/pb-js/flyteidl.js +++ b/flyteidl/gen/pb-js/flyteidl.js @@ -20406,6 +20406,576 @@ return DeleteTaskResponse; })(); + admin.Agent = (function() { + + /** + * Properties of an Agent. + * @memberof flyteidl.admin + * @interface IAgent + * @property {string|null} [name] Agent name + * @property {Array.|null} [supportedTaskTypes] Agent supportedTaskTypes + */ + + /** + * Constructs a new Agent. + * @memberof flyteidl.admin + * @classdesc Represents an Agent. + * @implements IAgent + * @constructor + * @param {flyteidl.admin.IAgent=} [properties] Properties to set + */ + function Agent(properties) { + this.supportedTaskTypes = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Agent name. + * @member {string} name + * @memberof flyteidl.admin.Agent + * @instance + */ + Agent.prototype.name = ""; + + /** + * Agent supportedTaskTypes. + * @member {Array.} supportedTaskTypes + * @memberof flyteidl.admin.Agent + * @instance + */ + Agent.prototype.supportedTaskTypes = $util.emptyArray; + + /** + * Creates a new Agent instance using the specified properties. + * @function create + * @memberof flyteidl.admin.Agent + * @static + * @param {flyteidl.admin.IAgent=} [properties] Properties to set + * @returns {flyteidl.admin.Agent} Agent instance + */ + Agent.create = function create(properties) { + return new Agent(properties); + }; + + /** + * Encodes the specified Agent message. Does not implicitly {@link flyteidl.admin.Agent.verify|verify} messages. + * @function encode + * @memberof flyteidl.admin.Agent + * @static + * @param {flyteidl.admin.IAgent} message Agent message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + Agent.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && message.hasOwnProperty("name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + if (message.supportedTaskTypes != null && message.supportedTaskTypes.length) + for (var i = 0; i < message.supportedTaskTypes.length; ++i) + writer.uint32(/* id 2, wireType 2 =*/18).string(message.supportedTaskTypes[i]); + return writer; + }; + + /** + * Decodes an Agent message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.admin.Agent + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.admin.Agent} Agent + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + Agent.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.admin.Agent(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: + message.name = reader.string(); + break; + case 2: + if (!(message.supportedTaskTypes && message.supportedTaskTypes.length)) + message.supportedTaskTypes = []; + message.supportedTaskTypes.push(reader.string()); + break; + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Verifies an Agent message. + * @function verify + * @memberof flyteidl.admin.Agent + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + Agent.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + if (message.supportedTaskTypes != null && message.hasOwnProperty("supportedTaskTypes")) { + if (!Array.isArray(message.supportedTaskTypes)) + return "supportedTaskTypes: array expected"; + for (var i = 0; i < message.supportedTaskTypes.length; ++i) + if (!$util.isString(message.supportedTaskTypes[i])) + return "supportedTaskTypes: string[] expected"; + } + return null; + }; + + return Agent; + })(); + + admin.GetAgentRequest = (function() { + + /** + * Properties of a GetAgentRequest. + * @memberof flyteidl.admin + * @interface IGetAgentRequest + * @property {string|null} [name] GetAgentRequest name + */ + + /** + * Constructs a new GetAgentRequest. + * @memberof flyteidl.admin + * @classdesc Represents a GetAgentRequest. + * @implements IGetAgentRequest + * @constructor + * @param {flyteidl.admin.IGetAgentRequest=} [properties] Properties to set + */ + function GetAgentRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetAgentRequest name. + * @member {string} name + * @memberof flyteidl.admin.GetAgentRequest + * @instance + */ + GetAgentRequest.prototype.name = ""; + + /** + * Creates a new GetAgentRequest instance using the specified properties. + * @function create + * @memberof flyteidl.admin.GetAgentRequest + * @static + * @param {flyteidl.admin.IGetAgentRequest=} [properties] Properties to set + * @returns {flyteidl.admin.GetAgentRequest} GetAgentRequest instance + */ + GetAgentRequest.create = function create(properties) { + return new GetAgentRequest(properties); + }; + + /** + * Encodes the specified GetAgentRequest message. Does not implicitly {@link flyteidl.admin.GetAgentRequest.verify|verify} messages. + * @function encode + * @memberof flyteidl.admin.GetAgentRequest + * @static + * @param {flyteidl.admin.IGetAgentRequest} message GetAgentRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetAgentRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.name != null && message.hasOwnProperty("name")) + writer.uint32(/* id 1, wireType 2 =*/10).string(message.name); + return writer; + }; + + /** + * Decodes a GetAgentRequest message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.admin.GetAgentRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.admin.GetAgentRequest} GetAgentRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetAgentRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.admin.GetAgentRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: + message.name = reader.string(); + break; + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Verifies a GetAgentRequest message. + * @function verify + * @memberof flyteidl.admin.GetAgentRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetAgentRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.name != null && message.hasOwnProperty("name")) + if (!$util.isString(message.name)) + return "name: string expected"; + return null; + }; + + return GetAgentRequest; + })(); + + admin.GetAgentResponse = (function() { + + /** + * Properties of a GetAgentResponse. + * @memberof flyteidl.admin + * @interface IGetAgentResponse + * @property {flyteidl.admin.IAgent|null} [agent] GetAgentResponse agent + */ + + /** + * Constructs a new GetAgentResponse. + * @memberof flyteidl.admin + * @classdesc Represents a GetAgentResponse. + * @implements IGetAgentResponse + * @constructor + * @param {flyteidl.admin.IGetAgentResponse=} [properties] Properties to set + */ + function GetAgentResponse(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * GetAgentResponse agent. + * @member {flyteidl.admin.IAgent|null|undefined} agent + * @memberof flyteidl.admin.GetAgentResponse + * @instance + */ + GetAgentResponse.prototype.agent = null; + + /** + * Creates a new GetAgentResponse instance using the specified properties. + * @function create + * @memberof flyteidl.admin.GetAgentResponse + * @static + * @param {flyteidl.admin.IGetAgentResponse=} [properties] Properties to set + * @returns {flyteidl.admin.GetAgentResponse} GetAgentResponse instance + */ + GetAgentResponse.create = function create(properties) { + return new GetAgentResponse(properties); + }; + + /** + * Encodes the specified GetAgentResponse message. Does not implicitly {@link flyteidl.admin.GetAgentResponse.verify|verify} messages. + * @function encode + * @memberof flyteidl.admin.GetAgentResponse + * @static + * @param {flyteidl.admin.IGetAgentResponse} message GetAgentResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + GetAgentResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.agent != null && message.hasOwnProperty("agent")) + $root.flyteidl.admin.Agent.encode(message.agent, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Decodes a GetAgentResponse message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.admin.GetAgentResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.admin.GetAgentResponse} GetAgentResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + GetAgentResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.admin.GetAgentResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: + message.agent = $root.flyteidl.admin.Agent.decode(reader, reader.uint32()); + break; + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Verifies a GetAgentResponse message. + * @function verify + * @memberof flyteidl.admin.GetAgentResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + GetAgentResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.agent != null && message.hasOwnProperty("agent")) { + var error = $root.flyteidl.admin.Agent.verify(message.agent); + if (error) + return "agent." + error; + } + return null; + }; + + return GetAgentResponse; + })(); + + admin.ListAgentsRequest = (function() { + + /** + * Properties of a ListAgentsRequest. + * @memberof flyteidl.admin + * @interface IListAgentsRequest + */ + + /** + * Constructs a new ListAgentsRequest. + * @memberof flyteidl.admin + * @classdesc Represents a ListAgentsRequest. + * @implements IListAgentsRequest + * @constructor + * @param {flyteidl.admin.IListAgentsRequest=} [properties] Properties to set + */ + function ListAgentsRequest(properties) { + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * Creates a new ListAgentsRequest instance using the specified properties. + * @function create + * @memberof flyteidl.admin.ListAgentsRequest + * @static + * @param {flyteidl.admin.IListAgentsRequest=} [properties] Properties to set + * @returns {flyteidl.admin.ListAgentsRequest} ListAgentsRequest instance + */ + ListAgentsRequest.create = function create(properties) { + return new ListAgentsRequest(properties); + }; + + /** + * Encodes the specified ListAgentsRequest message. Does not implicitly {@link flyteidl.admin.ListAgentsRequest.verify|verify} messages. + * @function encode + * @memberof flyteidl.admin.ListAgentsRequest + * @static + * @param {flyteidl.admin.IListAgentsRequest} message ListAgentsRequest message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListAgentsRequest.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + return writer; + }; + + /** + * Decodes a ListAgentsRequest message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.admin.ListAgentsRequest + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.admin.ListAgentsRequest} ListAgentsRequest + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListAgentsRequest.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.admin.ListAgentsRequest(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Verifies a ListAgentsRequest message. + * @function verify + * @memberof flyteidl.admin.ListAgentsRequest + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListAgentsRequest.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + return null; + }; + + return ListAgentsRequest; + })(); + + admin.ListAgentsResponse = (function() { + + /** + * Properties of a ListAgentsResponse. + * @memberof flyteidl.admin + * @interface IListAgentsResponse + * @property {Array.|null} [agents] ListAgentsResponse agents + */ + + /** + * Constructs a new ListAgentsResponse. + * @memberof flyteidl.admin + * @classdesc Represents a ListAgentsResponse. + * @implements IListAgentsResponse + * @constructor + * @param {flyteidl.admin.IListAgentsResponse=} [properties] Properties to set + */ + function ListAgentsResponse(properties) { + this.agents = []; + if (properties) + for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) + if (properties[keys[i]] != null) + this[keys[i]] = properties[keys[i]]; + } + + /** + * ListAgentsResponse agents. + * @member {Array.} agents + * @memberof flyteidl.admin.ListAgentsResponse + * @instance + */ + ListAgentsResponse.prototype.agents = $util.emptyArray; + + /** + * Creates a new ListAgentsResponse instance using the specified properties. + * @function create + * @memberof flyteidl.admin.ListAgentsResponse + * @static + * @param {flyteidl.admin.IListAgentsResponse=} [properties] Properties to set + * @returns {flyteidl.admin.ListAgentsResponse} ListAgentsResponse instance + */ + ListAgentsResponse.create = function create(properties) { + return new ListAgentsResponse(properties); + }; + + /** + * Encodes the specified ListAgentsResponse message. Does not implicitly {@link flyteidl.admin.ListAgentsResponse.verify|verify} messages. + * @function encode + * @memberof flyteidl.admin.ListAgentsResponse + * @static + * @param {flyteidl.admin.IListAgentsResponse} message ListAgentsResponse message or plain object to encode + * @param {$protobuf.Writer} [writer] Writer to encode to + * @returns {$protobuf.Writer} Writer + */ + ListAgentsResponse.encode = function encode(message, writer) { + if (!writer) + writer = $Writer.create(); + if (message.agents != null && message.agents.length) + for (var i = 0; i < message.agents.length; ++i) + $root.flyteidl.admin.Agent.encode(message.agents[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim(); + return writer; + }; + + /** + * Decodes a ListAgentsResponse message from the specified reader or buffer. + * @function decode + * @memberof flyteidl.admin.ListAgentsResponse + * @static + * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from + * @param {number} [length] Message length if known beforehand + * @returns {flyteidl.admin.ListAgentsResponse} ListAgentsResponse + * @throws {Error} If the payload is not a reader or valid buffer + * @throws {$protobuf.util.ProtocolError} If required fields are missing + */ + ListAgentsResponse.decode = function decode(reader, length) { + if (!(reader instanceof $Reader)) + reader = $Reader.create(reader); + var end = length === undefined ? reader.len : reader.pos + length, message = new $root.flyteidl.admin.ListAgentsResponse(); + while (reader.pos < end) { + var tag = reader.uint32(); + switch (tag >>> 3) { + case 1: + if (!(message.agents && message.agents.length)) + message.agents = []; + message.agents.push($root.flyteidl.admin.Agent.decode(reader, reader.uint32())); + break; + default: + reader.skipType(tag & 7); + break; + } + } + return message; + }; + + /** + * Verifies a ListAgentsResponse message. + * @function verify + * @memberof flyteidl.admin.ListAgentsResponse + * @static + * @param {Object.} message Plain object to verify + * @returns {string|null} `null` if valid, otherwise the reason why it is not + */ + ListAgentsResponse.verify = function verify(message) { + if (typeof message !== "object" || message === null) + return "object expected"; + if (message.agents != null && message.hasOwnProperty("agents")) { + if (!Array.isArray(message.agents)) + return "agents: array expected"; + for (var i = 0; i < message.agents.length; ++i) { + var error = $root.flyteidl.admin.Agent.verify(message.agents[i]); + if (error) + return "agents." + error; + } + } + return null; + }; + + return ListAgentsResponse; + })(); + admin.ClusterAssignment = (function() { /** @@ -46174,6 +46744,107 @@ return AsyncAgentService; })(); + service.AgentMetadataService = (function() { + + /** + * Constructs a new AgentMetadataService service. + * @memberof flyteidl.service + * @classdesc Represents an AgentMetadataService + * @extends $protobuf.rpc.Service + * @constructor + * @param {$protobuf.RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + */ + function AgentMetadataService(rpcImpl, requestDelimited, responseDelimited) { + $protobuf.rpc.Service.call(this, rpcImpl, requestDelimited, responseDelimited); + } + + (AgentMetadataService.prototype = Object.create($protobuf.rpc.Service.prototype)).constructor = AgentMetadataService; + + /** + * Creates new AgentMetadataService service using the specified rpc implementation. + * @function create + * @memberof flyteidl.service.AgentMetadataService + * @static + * @param {$protobuf.RPCImpl} rpcImpl RPC implementation + * @param {boolean} [requestDelimited=false] Whether requests are length-delimited + * @param {boolean} [responseDelimited=false] Whether responses are length-delimited + * @returns {AgentMetadataService} RPC service. Useful where requests and/or responses are streamed. + */ + AgentMetadataService.create = function create(rpcImpl, requestDelimited, responseDelimited) { + return new this(rpcImpl, requestDelimited, responseDelimited); + }; + + /** + * Callback as used by {@link flyteidl.service.AgentMetadataService#getAgent}. + * @memberof flyteidl.service.AgentMetadataService + * @typedef GetAgentCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {flyteidl.admin.GetAgentResponse} [response] GetAgentResponse + */ + + /** + * Calls GetAgent. + * @function getAgent + * @memberof flyteidl.service.AgentMetadataService + * @instance + * @param {flyteidl.admin.IGetAgentRequest} request GetAgentRequest message or plain object + * @param {flyteidl.service.AgentMetadataService.GetAgentCallback} callback Node-style callback called with the error, if any, and GetAgentResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(AgentMetadataService.prototype.getAgent = function getAgent(request, callback) { + return this.rpcCall(getAgent, $root.flyteidl.admin.GetAgentRequest, $root.flyteidl.admin.GetAgentResponse, request, callback); + }, "name", { value: "GetAgent" }); + + /** + * Calls GetAgent. + * @function getAgent + * @memberof flyteidl.service.AgentMetadataService + * @instance + * @param {flyteidl.admin.IGetAgentRequest} request GetAgentRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + /** + * Callback as used by {@link flyteidl.service.AgentMetadataService#listAgents}. + * @memberof flyteidl.service.AgentMetadataService + * @typedef ListAgentsCallback + * @type {function} + * @param {Error|null} error Error, if any + * @param {flyteidl.admin.ListAgentsResponse} [response] ListAgentsResponse + */ + + /** + * Calls ListAgents. + * @function listAgents + * @memberof flyteidl.service.AgentMetadataService + * @instance + * @param {flyteidl.admin.IListAgentsRequest} request ListAgentsRequest message or plain object + * @param {flyteidl.service.AgentMetadataService.ListAgentsCallback} callback Node-style callback called with the error, if any, and ListAgentsResponse + * @returns {undefined} + * @variation 1 + */ + Object.defineProperty(AgentMetadataService.prototype.listAgents = function listAgents(request, callback) { + return this.rpcCall(listAgents, $root.flyteidl.admin.ListAgentsRequest, $root.flyteidl.admin.ListAgentsResponse, request, callback); + }, "name", { value: "ListAgents" }); + + /** + * Calls ListAgents. + * @function listAgents + * @memberof flyteidl.service.AgentMetadataService + * @instance + * @param {flyteidl.admin.IListAgentsRequest} request ListAgentsRequest message or plain object + * @returns {Promise} Promise + * @variation 2 + */ + + return AgentMetadataService; + })(); + service.OAuth2MetadataRequest = (function() { /** diff --git a/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.py b/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.py index c16839946c..baceaf16c6 100644 --- a/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.py @@ -18,7 +18,7 @@ from flyteidl.core import execution_pb2 as flyteidl_dot_core_dot_execution__pb2 -DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1a\x66lyteidl/admin/agent.proto\x12\x0e\x66lyteidl.admin\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x19\x66lyteidl/core/tasks.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/execution.proto\"\x98\x05\n\x15TaskExecutionMetadata\x12R\n\x11task_execution_id\x18\x01 \x01(\x0b\x32&.flyteidl.core.TaskExecutionIdentifierR\x0ftaskExecutionId\x12\x1c\n\tnamespace\x18\x02 \x01(\tR\tnamespace\x12I\n\x06labels\x18\x03 \x03(\x0b\x32\x31.flyteidl.admin.TaskExecutionMetadata.LabelsEntryR\x06labels\x12X\n\x0b\x61nnotations\x18\x04 \x03(\x0b\x32\x36.flyteidl.admin.TaskExecutionMetadata.AnnotationsEntryR\x0b\x61nnotations\x12.\n\x13k8s_service_account\x18\x05 \x01(\tR\x11k8sServiceAccount\x12t\n\x15\x65nvironment_variables\x18\x06 \x03(\x0b\x32?.flyteidl.admin.TaskExecutionMetadata.EnvironmentVariablesEntryR\x14\x65nvironmentVariables\x1a\x39\n\x0bLabelsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1a>\n\x10\x41nnotationsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1aG\n\x19\x45nvironmentVariablesEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\"\x83\x02\n\x11\x43reateTaskRequest\x12\x31\n\x06inputs\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapR\x06inputs\x12\x37\n\x08template\x18\x02 \x01(\x0b\x32\x1b.flyteidl.core.TaskTemplateR\x08template\x12#\n\routput_prefix\x18\x03 \x01(\tR\x0coutputPrefix\x12]\n\x17task_execution_metadata\x18\x04 \x01(\x0b\x32%.flyteidl.admin.TaskExecutionMetadataR\x15taskExecutionMetadata\"9\n\x12\x43reateTaskResponse\x12#\n\rresource_meta\x18\x01 \x01(\x0cR\x0cresourceMeta\"R\n\x0eGetTaskRequest\x12\x1b\n\ttask_type\x18\x01 \x01(\tR\x08taskType\x12#\n\rresource_meta\x18\x02 \x01(\x0cR\x0cresourceMeta\"|\n\x0fGetTaskResponse\x12\x34\n\x08resource\x18\x01 \x01(\x0b\x32\x18.flyteidl.admin.ResourceR\x08resource\x12\x33\n\tlog_links\x18\x02 \x03(\x0b\x32\x16.flyteidl.core.TaskLogR\x08logLinks\"\x86\x01\n\x08Resource\x12+\n\x05state\x18\x01 \x01(\x0e\x32\x15.flyteidl.admin.StateR\x05state\x12\x33\n\x07outputs\x18\x02 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapR\x07outputs\x12\x18\n\x07message\x18\x03 \x01(\tR\x07message\"U\n\x11\x44\x65leteTaskRequest\x12\x1b\n\ttask_type\x18\x01 \x01(\tR\x08taskType\x12#\n\rresource_meta\x18\x02 \x01(\x0cR\x0cresourceMeta\"\x14\n\x12\x44\x65leteTaskResponse*^\n\x05State\x12\x15\n\x11RETRYABLE_FAILURE\x10\x00\x12\x15\n\x11PERMANENT_FAILURE\x10\x01\x12\x0b\n\x07PENDING\x10\x02\x12\x0b\n\x07RUNNING\x10\x03\x12\r\n\tSUCCEEDED\x10\x04\x42\xb6\x01\n\x12\x63om.flyteidl.adminB\nAgentProtoP\x01Z;github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin\xa2\x02\x03\x46\x41X\xaa\x02\x0e\x46lyteidl.Admin\xca\x02\x0e\x46lyteidl\\Admin\xe2\x02\x1a\x46lyteidl\\Admin\\GPBMetadata\xea\x02\x0f\x46lyteidl::Adminb\x06proto3') +DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1a\x66lyteidl/admin/agent.proto\x12\x0e\x66lyteidl.admin\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x19\x66lyteidl/core/tasks.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/execution.proto\"\x98\x05\n\x15TaskExecutionMetadata\x12R\n\x11task_execution_id\x18\x01 \x01(\x0b\x32&.flyteidl.core.TaskExecutionIdentifierR\x0ftaskExecutionId\x12\x1c\n\tnamespace\x18\x02 \x01(\tR\tnamespace\x12I\n\x06labels\x18\x03 \x03(\x0b\x32\x31.flyteidl.admin.TaskExecutionMetadata.LabelsEntryR\x06labels\x12X\n\x0b\x61nnotations\x18\x04 \x03(\x0b\x32\x36.flyteidl.admin.TaskExecutionMetadata.AnnotationsEntryR\x0b\x61nnotations\x12.\n\x13k8s_service_account\x18\x05 \x01(\tR\x11k8sServiceAccount\x12t\n\x15\x65nvironment_variables\x18\x06 \x03(\x0b\x32?.flyteidl.admin.TaskExecutionMetadata.EnvironmentVariablesEntryR\x14\x65nvironmentVariables\x1a\x39\n\x0bLabelsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1a>\n\x10\x41nnotationsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1aG\n\x19\x45nvironmentVariablesEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\"\x83\x02\n\x11\x43reateTaskRequest\x12\x31\n\x06inputs\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapR\x06inputs\x12\x37\n\x08template\x18\x02 \x01(\x0b\x32\x1b.flyteidl.core.TaskTemplateR\x08template\x12#\n\routput_prefix\x18\x03 \x01(\tR\x0coutputPrefix\x12]\n\x17task_execution_metadata\x18\x04 \x01(\x0b\x32%.flyteidl.admin.TaskExecutionMetadataR\x15taskExecutionMetadata\"9\n\x12\x43reateTaskResponse\x12#\n\rresource_meta\x18\x01 \x01(\x0cR\x0cresourceMeta\"R\n\x0eGetTaskRequest\x12\x1b\n\ttask_type\x18\x01 \x01(\tR\x08taskType\x12#\n\rresource_meta\x18\x02 \x01(\x0cR\x0cresourceMeta\"|\n\x0fGetTaskResponse\x12\x34\n\x08resource\x18\x01 \x01(\x0b\x32\x18.flyteidl.admin.ResourceR\x08resource\x12\x33\n\tlog_links\x18\x02 \x03(\x0b\x32\x16.flyteidl.core.TaskLogR\x08logLinks\"\x86\x01\n\x08Resource\x12+\n\x05state\x18\x01 \x01(\x0e\x32\x15.flyteidl.admin.StateR\x05state\x12\x33\n\x07outputs\x18\x02 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapR\x07outputs\x12\x18\n\x07message\x18\x03 \x01(\tR\x07message\"U\n\x11\x44\x65leteTaskRequest\x12\x1b\n\ttask_type\x18\x01 \x01(\tR\x08taskType\x12#\n\rresource_meta\x18\x02 \x01(\x0cR\x0cresourceMeta\"\x14\n\x12\x44\x65leteTaskResponse\"M\n\x05\x41gent\x12\x12\n\x04name\x18\x01 \x01(\tR\x04name\x12\x30\n\x14supported_task_types\x18\x02 \x03(\tR\x12supportedTaskTypes\"%\n\x0fGetAgentRequest\x12\x12\n\x04name\x18\x01 \x01(\tR\x04name\"?\n\x10GetAgentResponse\x12+\n\x05\x61gent\x18\x01 \x01(\x0b\x32\x15.flyteidl.admin.AgentR\x05\x61gent\"\x13\n\x11ListAgentsRequest\"C\n\x12ListAgentsResponse\x12-\n\x06\x61gents\x18\x01 \x03(\x0b\x32\x15.flyteidl.admin.AgentR\x06\x61gents*^\n\x05State\x12\x15\n\x11RETRYABLE_FAILURE\x10\x00\x12\x15\n\x11PERMANENT_FAILURE\x10\x01\x12\x0b\n\x07PENDING\x10\x02\x12\x0b\n\x07RUNNING\x10\x03\x12\r\n\tSUCCEEDED\x10\x04\x42\xb6\x01\n\x12\x63om.flyteidl.adminB\nAgentProtoP\x01Z;github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin\xa2\x02\x03\x46\x41X\xaa\x02\x0e\x46lyteidl.Admin\xca\x02\x0e\x46lyteidl\\Admin\xe2\x02\x1a\x46lyteidl\\Admin\\GPBMetadata\xea\x02\x0f\x46lyteidl::Adminb\x06proto3') _globals = globals() _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals) @@ -33,8 +33,8 @@ _TASKEXECUTIONMETADATA_ANNOTATIONSENTRY._serialized_options = b'8\001' _TASKEXECUTIONMETADATA_ENVIRONMENTVARIABLESENTRY._options = None _TASKEXECUTIONMETADATA_ENVIRONMENTVARIABLESENTRY._serialized_options = b'8\001' - _globals['_STATE']._serialized_start=1641 - _globals['_STATE']._serialized_end=1735 + _globals['_STATE']._serialized_start=1914 + _globals['_STATE']._serialized_end=2008 _globals['_TASKEXECUTIONMETADATA']._serialized_start=198 _globals['_TASKEXECUTIONMETADATA']._serialized_end=862 _globals['_TASKEXECUTIONMETADATA_LABELSENTRY']._serialized_start=668 @@ -57,4 +57,14 @@ _globals['_DELETETASKREQUEST']._serialized_end=1617 _globals['_DELETETASKRESPONSE']._serialized_start=1619 _globals['_DELETETASKRESPONSE']._serialized_end=1639 + _globals['_AGENT']._serialized_start=1641 + _globals['_AGENT']._serialized_end=1718 + _globals['_GETAGENTREQUEST']._serialized_start=1720 + _globals['_GETAGENTREQUEST']._serialized_end=1757 + _globals['_GETAGENTRESPONSE']._serialized_start=1759 + _globals['_GETAGENTRESPONSE']._serialized_end=1822 + _globals['_LISTAGENTSREQUEST']._serialized_start=1824 + _globals['_LISTAGENTSREQUEST']._serialized_end=1843 + _globals['_LISTAGENTSRESPONSE']._serialized_start=1845 + _globals['_LISTAGENTSRESPONSE']._serialized_end=1912 # @@protoc_insertion_point(module_scope) diff --git a/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.pyi b/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.pyi index 0fd64d8e10..d184c997b7 100644 --- a/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.pyi +++ b/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.pyi @@ -116,3 +116,33 @@ class DeleteTaskRequest(_message.Message): class DeleteTaskResponse(_message.Message): __slots__ = [] def __init__(self) -> None: ... + +class Agent(_message.Message): + __slots__ = ["name", "supported_task_types"] + NAME_FIELD_NUMBER: _ClassVar[int] + SUPPORTED_TASK_TYPES_FIELD_NUMBER: _ClassVar[int] + name: str + supported_task_types: _containers.RepeatedScalarFieldContainer[str] + def __init__(self, name: _Optional[str] = ..., supported_task_types: _Optional[_Iterable[str]] = ...) -> None: ... + +class GetAgentRequest(_message.Message): + __slots__ = ["name"] + NAME_FIELD_NUMBER: _ClassVar[int] + name: str + def __init__(self, name: _Optional[str] = ...) -> None: ... + +class GetAgentResponse(_message.Message): + __slots__ = ["agent"] + AGENT_FIELD_NUMBER: _ClassVar[int] + agent: Agent + def __init__(self, agent: _Optional[_Union[Agent, _Mapping]] = ...) -> None: ... + +class ListAgentsRequest(_message.Message): + __slots__ = [] + def __init__(self) -> None: ... + +class ListAgentsResponse(_message.Message): + __slots__ = ["agents"] + AGENTS_FIELD_NUMBER: _ClassVar[int] + agents: _containers.RepeatedCompositeFieldContainer[Agent] + def __init__(self, agents: _Optional[_Iterable[_Union[Agent, _Mapping]]] = ...) -> None: ... diff --git a/flyteidl/gen/pb_python/flyteidl/service/agent_pb2.py b/flyteidl/gen/pb_python/flyteidl/service/agent_pb2.py index 8227bdc438..f1234012be 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/agent_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/service/agent_pb2.py @@ -11,10 +11,11 @@ _sym_db = _symbol_database.Default() +from google.api import annotations_pb2 as google_dot_api_dot_annotations__pb2 from flyteidl.admin import agent_pb2 as flyteidl_dot_admin_dot_agent__pb2 -DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1c\x66lyteidl/service/agent.proto\x12\x10\x66lyteidl.service\x1a\x1a\x66lyteidl/admin/agent.proto2\x8f\x02\n\x11\x41syncAgentService\x12U\n\nCreateTask\x12!.flyteidl.admin.CreateTaskRequest\x1a\".flyteidl.admin.CreateTaskResponse\"\x00\x12L\n\x07GetTask\x12\x1e.flyteidl.admin.GetTaskRequest\x1a\x1f.flyteidl.admin.GetTaskResponse\"\x00\x12U\n\nDeleteTask\x12!.flyteidl.admin.DeleteTaskRequest\x1a\".flyteidl.admin.DeleteTaskResponse\"\x00\x42\xc2\x01\n\x14\x63om.flyteidl.serviceB\nAgentProtoP\x01Z=github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/service\xa2\x02\x03\x46SX\xaa\x02\x10\x46lyteidl.Service\xca\x02\x10\x46lyteidl\\Service\xe2\x02\x1c\x46lyteidl\\Service\\GPBMetadata\xea\x02\x11\x46lyteidl::Serviceb\x06proto3') +DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1c\x66lyteidl/service/agent.proto\x12\x10\x66lyteidl.service\x1a\x1cgoogle/api/annotations.proto\x1a\x1a\x66lyteidl/admin/agent.proto2\x8f\x02\n\x11\x41syncAgentService\x12U\n\nCreateTask\x12!.flyteidl.admin.CreateTaskRequest\x1a\".flyteidl.admin.CreateTaskResponse\"\x00\x12L\n\x07GetTask\x12\x1e.flyteidl.admin.GetTaskRequest\x1a\x1f.flyteidl.admin.GetTaskResponse\"\x00\x12U\n\nDeleteTask\x12!.flyteidl.admin.DeleteTaskRequest\x1a\".flyteidl.admin.DeleteTaskResponse\"\x00\x32\xf0\x01\n\x14\x41gentMetadataService\x12k\n\x08GetAgent\x12\x1f.flyteidl.admin.GetAgentRequest\x1a .flyteidl.admin.GetAgentResponse\"\x1c\x82\xd3\xe4\x93\x02\x16\x12\x14/api/v1/agent/{name}\x12k\n\nListAgents\x12!.flyteidl.admin.ListAgentsRequest\x1a\".flyteidl.admin.ListAgentsResponse\"\x16\x82\xd3\xe4\x93\x02\x10\x12\x0e/api/v1/agentsB\xc2\x01\n\x14\x63om.flyteidl.serviceB\nAgentProtoP\x01Z=github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/service\xa2\x02\x03\x46SX\xaa\x02\x10\x46lyteidl.Service\xca\x02\x10\x46lyteidl\\Service\xe2\x02\x1c\x46lyteidl\\Service\\GPBMetadata\xea\x02\x11\x46lyteidl::Serviceb\x06proto3') _globals = globals() _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals) @@ -23,6 +24,12 @@ DESCRIPTOR._options = None DESCRIPTOR._serialized_options = b'\n\024com.flyteidl.serviceB\nAgentProtoP\001Z=github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/service\242\002\003FSX\252\002\020Flyteidl.Service\312\002\020Flyteidl\\Service\342\002\034Flyteidl\\Service\\GPBMetadata\352\002\021Flyteidl::Service' - _globals['_ASYNCAGENTSERVICE']._serialized_start=79 - _globals['_ASYNCAGENTSERVICE']._serialized_end=350 + _AGENTMETADATASERVICE.methods_by_name['GetAgent']._options = None + _AGENTMETADATASERVICE.methods_by_name['GetAgent']._serialized_options = b'\202\323\344\223\002\026\022\024/api/v1/agent/{name}' + _AGENTMETADATASERVICE.methods_by_name['ListAgents']._options = None + _AGENTMETADATASERVICE.methods_by_name['ListAgents']._serialized_options = b'\202\323\344\223\002\020\022\016/api/v1/agents' + _globals['_ASYNCAGENTSERVICE']._serialized_start=109 + _globals['_ASYNCAGENTSERVICE']._serialized_end=380 + _globals['_AGENTMETADATASERVICE']._serialized_start=383 + _globals['_AGENTMETADATASERVICE']._serialized_end=623 # @@protoc_insertion_point(module_scope) diff --git a/flyteidl/gen/pb_python/flyteidl/service/agent_pb2.pyi b/flyteidl/gen/pb_python/flyteidl/service/agent_pb2.pyi index 8c85e57d2d..1d89a831af 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/agent_pb2.pyi +++ b/flyteidl/gen/pb_python/flyteidl/service/agent_pb2.pyi @@ -1,3 +1,4 @@ +from google.api import annotations_pb2 as _annotations_pb2 from flyteidl.admin import agent_pb2 as _agent_pb2 from google.protobuf import descriptor as _descriptor from typing import ClassVar as _ClassVar diff --git a/flyteidl/gen/pb_python/flyteidl/service/agent_pb2_grpc.py b/flyteidl/gen/pb_python/flyteidl/service/agent_pb2_grpc.py index 3ef2af39c4..94f75b1682 100644 --- a/flyteidl/gen/pb_python/flyteidl/service/agent_pb2_grpc.py +++ b/flyteidl/gen/pb_python/flyteidl/service/agent_pb2_grpc.py @@ -6,7 +6,7 @@ class AsyncAgentServiceStub(object): - """AgentService defines an RPC Service that allows propeller to send the request to the agent server. + """AsyncAgentService defines an RPC Service that allows propeller to send the request to the agent server. """ def __init__(self, channel): @@ -33,7 +33,7 @@ def __init__(self, channel): class AsyncAgentServiceServicer(object): - """AgentService defines an RPC Service that allows propeller to send the request to the agent server. + """AsyncAgentService defines an RPC Service that allows propeller to send the request to the agent server. """ def CreateTask(self, request, context): @@ -83,7 +83,7 @@ def add_AsyncAgentServiceServicer_to_server(servicer, server): # This class is part of an EXPERIMENTAL API. class AsyncAgentService(object): - """AgentService defines an RPC Service that allows propeller to send the request to the agent server. + """AsyncAgentService defines an RPC Service that allows propeller to send the request to the agent server. """ @staticmethod @@ -136,3 +136,105 @@ def DeleteTask(request, flyteidl_dot_admin_dot_agent__pb2.DeleteTaskResponse.FromString, options, channel_credentials, insecure, call_credentials, compression, wait_for_ready, timeout, metadata) + + +class AgentMetadataServiceStub(object): + """AgentMetadataService defines an RPC service that is also served over HTTP via grpc-gateway. + This service allows propeller or users to get the metadata of agents. + """ + + def __init__(self, channel): + """Constructor. + + Args: + channel: A grpc.Channel. + """ + self.GetAgent = channel.unary_unary( + '/flyteidl.service.AgentMetadataService/GetAgent', + request_serializer=flyteidl_dot_admin_dot_agent__pb2.GetAgentRequest.SerializeToString, + response_deserializer=flyteidl_dot_admin_dot_agent__pb2.GetAgentResponse.FromString, + ) + self.ListAgents = channel.unary_unary( + '/flyteidl.service.AgentMetadataService/ListAgents', + request_serializer=flyteidl_dot_admin_dot_agent__pb2.ListAgentsRequest.SerializeToString, + response_deserializer=flyteidl_dot_admin_dot_agent__pb2.ListAgentsResponse.FromString, + ) + + +class AgentMetadataServiceServicer(object): + """AgentMetadataService defines an RPC service that is also served over HTTP via grpc-gateway. + This service allows propeller or users to get the metadata of agents. + """ + + def GetAgent(self, request, context): + """Fetch a :ref:`ref_flyteidl.admin.Agent` definition. + """ + context.set_code(grpc.StatusCode.UNIMPLEMENTED) + context.set_details('Method not implemented!') + raise NotImplementedError('Method not implemented!') + + def ListAgents(self, request, context): + """Fetch a list of :ref:`ref_flyteidl.admin.Agent` definitions. + """ + context.set_code(grpc.StatusCode.UNIMPLEMENTED) + context.set_details('Method not implemented!') + raise NotImplementedError('Method not implemented!') + + +def add_AgentMetadataServiceServicer_to_server(servicer, server): + rpc_method_handlers = { + 'GetAgent': grpc.unary_unary_rpc_method_handler( + servicer.GetAgent, + request_deserializer=flyteidl_dot_admin_dot_agent__pb2.GetAgentRequest.FromString, + response_serializer=flyteidl_dot_admin_dot_agent__pb2.GetAgentResponse.SerializeToString, + ), + 'ListAgents': grpc.unary_unary_rpc_method_handler( + servicer.ListAgents, + request_deserializer=flyteidl_dot_admin_dot_agent__pb2.ListAgentsRequest.FromString, + response_serializer=flyteidl_dot_admin_dot_agent__pb2.ListAgentsResponse.SerializeToString, + ), + } + generic_handler = grpc.method_handlers_generic_handler( + 'flyteidl.service.AgentMetadataService', rpc_method_handlers) + server.add_generic_rpc_handlers((generic_handler,)) + + + # This class is part of an EXPERIMENTAL API. +class AgentMetadataService(object): + """AgentMetadataService defines an RPC service that is also served over HTTP via grpc-gateway. + This service allows propeller or users to get the metadata of agents. + """ + + @staticmethod + def GetAgent(request, + target, + options=(), + channel_credentials=None, + call_credentials=None, + insecure=False, + compression=None, + wait_for_ready=None, + timeout=None, + metadata=None): + return grpc.experimental.unary_unary(request, target, '/flyteidl.service.AgentMetadataService/GetAgent', + flyteidl_dot_admin_dot_agent__pb2.GetAgentRequest.SerializeToString, + flyteidl_dot_admin_dot_agent__pb2.GetAgentResponse.FromString, + options, channel_credentials, + insecure, call_credentials, compression, wait_for_ready, timeout, metadata) + + @staticmethod + def ListAgents(request, + target, + options=(), + channel_credentials=None, + call_credentials=None, + insecure=False, + compression=None, + wait_for_ready=None, + timeout=None, + metadata=None): + return grpc.experimental.unary_unary(request, target, '/flyteidl.service.AgentMetadataService/ListAgents', + flyteidl_dot_admin_dot_agent__pb2.ListAgentsRequest.SerializeToString, + flyteidl_dot_admin_dot_agent__pb2.ListAgentsResponse.FromString, + options, channel_credentials, + insecure, call_credentials, compression, wait_for_ready, timeout, metadata) diff --git a/flyteidl/gen/pb_rust/flyteidl.admin.rs b/flyteidl/gen/pb_rust/flyteidl.admin.rs index 66e07b56b1..3758f6d90e 100644 --- a/flyteidl/gen/pb_rust/flyteidl.admin.rs +++ b/flyteidl/gen/pb_rust/flyteidl.admin.rs @@ -66,7 +66,7 @@ pub struct GetTaskRequest { pub struct GetTaskResponse { #[prost(message, optional, tag="1")] pub resource: ::core::option::Option, - /// log information for the task execution. + /// log information for the task execution #[prost(message, repeated, tag="2")] pub log_links: ::prost::alloc::vec::Vec, } @@ -101,6 +101,44 @@ pub struct DeleteTaskRequest { #[derive(Clone, PartialEq, ::prost::Message)] pub struct DeleteTaskResponse { } +/// A message containing the agent metadata. +#[allow(clippy::derive_partial_eq_without_eq)] +#[derive(Clone, PartialEq, ::prost::Message)] +pub struct Agent { + /// Name is the developer-assigned name of the agent. + #[prost(string, tag="1")] + pub name: ::prost::alloc::string::String, + /// SupportedTaskTypes are the types of the tasks that the agent can handle. + #[prost(string, repeated, tag="2")] + pub supported_task_types: ::prost::alloc::vec::Vec<::prost::alloc::string::String>, +} +/// A request to get an agent. +#[allow(clippy::derive_partial_eq_without_eq)] +#[derive(Clone, PartialEq, ::prost::Message)] +pub struct GetAgentRequest { + /// The name of the agent. + #[prost(string, tag="1")] + pub name: ::prost::alloc::string::String, +} +/// A response containing an agent. +#[allow(clippy::derive_partial_eq_without_eq)] +#[derive(Clone, PartialEq, ::prost::Message)] +pub struct GetAgentResponse { + #[prost(message, optional, tag="1")] + pub agent: ::core::option::Option, +} +/// A request to list all agents. +#[allow(clippy::derive_partial_eq_without_eq)] +#[derive(Clone, PartialEq, ::prost::Message)] +pub struct ListAgentsRequest { +} +/// A response containing a list of agents. +#[allow(clippy::derive_partial_eq_without_eq)] +#[derive(Clone, PartialEq, ::prost::Message)] +pub struct ListAgentsResponse { + #[prost(message, repeated, tag="1")] + pub agents: ::prost::alloc::vec::Vec, +} /// The state of the execution is used to control its visibility in the UI/CLI. #[derive(Clone, Copy, Debug, PartialEq, Eq, Hash, PartialOrd, Ord, ::prost::Enumeration)] #[repr(i32)] diff --git a/flyteidl/protos/flyteidl/admin/agent.proto b/flyteidl/protos/flyteidl/admin/agent.proto index a3d1a5a4dd..98ab21cd07 100644 --- a/flyteidl/protos/flyteidl/admin/agent.proto +++ b/flyteidl/protos/flyteidl/admin/agent.proto @@ -65,7 +65,8 @@ message GetTaskRequest { // Response to get an individual task resource. message GetTaskResponse { Resource resource = 1; - // log information for the task execution. + + // log information for the task execution repeated core.TaskLog log_links = 2; } @@ -89,5 +90,32 @@ message DeleteTaskRequest { } // Response to delete a task. -message DeleteTaskResponse { +message DeleteTaskResponse {} + +// A message containing the agent metadata. +message Agent { + // Name is the developer-assigned name of the agent. + string name = 1; + + // SupportedTaskTypes are the types of the tasks that the agent can handle. + repeated string supported_task_types = 2; +} + +// A request to get an agent. +message GetAgentRequest { + // The name of the agent. + string name = 1; +} + +// A response containing an agent. +message GetAgentResponse { + Agent agent = 1; +} + +// A request to list all agents. +message ListAgentsRequest {} + +// A response containing a list of agents. +message ListAgentsResponse { + repeated Agent agents = 1; } diff --git a/flyteidl/protos/flyteidl/service/agent.proto b/flyteidl/protos/flyteidl/service/agent.proto index 6d89bb532e..eba19e496c 100644 --- a/flyteidl/protos/flyteidl/service/agent.proto +++ b/flyteidl/protos/flyteidl/service/agent.proto @@ -2,9 +2,11 @@ syntax = "proto3"; package flyteidl.service; option go_package = "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/service"; + +import "google/api/annotations.proto"; import "flyteidl/admin/agent.proto"; -// AgentService defines an RPC Service that allows propeller to send the request to the agent server. +// AsyncAgentService defines an RPC Service that allows propeller to send the request to the agent server. service AsyncAgentService { // Send a task create request to the agent server. rpc CreateTask (flyteidl.admin.CreateTaskRequest) returns (flyteidl.admin.CreateTaskResponse){}; @@ -13,3 +15,21 @@ service AsyncAgentService { // Delete the task resource. rpc DeleteTask (flyteidl.admin.DeleteTaskRequest) returns (flyteidl.admin.DeleteTaskResponse){}; } + +// AgentMetadataService defines an RPC service that is also served over HTTP via grpc-gateway. +// This service allows propeller or users to get the metadata of agents. +service AgentMetadataService { + // Fetch a :ref:`ref_flyteidl.admin.Agent` definition. + rpc GetAgent (flyteidl.admin.GetAgentRequest) returns (flyteidl.admin.GetAgentResponse){ + option (google.api.http) = { + get: "/api/v1/agent/{name}" + }; + }; + + // Fetch a list of :ref:`ref_flyteidl.admin.Agent` definitions. + rpc ListAgents (flyteidl.admin.ListAgentsRequest) returns (flyteidl.admin.ListAgentsResponse){ + option (google.api.http) = { + get: "/api/v1/agents" + }; + }; +} diff --git a/flyteplugins/go/tasks/pluginmachinery/internal/webapi/core.go b/flyteplugins/go/tasks/pluginmachinery/internal/webapi/core.go index d5e04f7347..d51209a77c 100644 --- a/flyteplugins/go/tasks/pluginmachinery/internal/webapi/core.go +++ b/flyteplugins/go/tasks/pluginmachinery/internal/webapi/core.go @@ -143,6 +143,7 @@ func validateRangeFloat64(fieldName string, min, max, provided float64) error { return nil } + func validateConfig(cfg webapi.PluginConfig) error { errs := stdErrs.ErrorCollection{} errs.Append(validateRangeInt("cache size", minCacheSize, maxCacheSize, cfg.Caching.Size)) diff --git a/flyteplugins/go/tasks/plugins/array/awsbatch/executor.go b/flyteplugins/go/tasks/plugins/array/awsbatch/executor.go index 6c7a858be8..1e98736129 100644 --- a/flyteplugins/go/tasks/plugins/array/awsbatch/executor.go +++ b/flyteplugins/go/tasks/plugins/array/awsbatch/executor.go @@ -78,7 +78,7 @@ func (e Executor) Handle(ctx context.Context, tCtx core.TaskExecutionContext) (c case arrayCore.PhaseAssembleFinalOutput: pluginState.State, err = array.AssembleFinalOutputs(ctx, e.outputAssembler, tCtx, arrayCore.PhaseSuccess, version+1, pluginState.State) - + case arrayCore.PhaseAbortSubTasks: fallthrough diff --git a/flyteplugins/go/tasks/plugins/array/k8s/management.go b/flyteplugins/go/tasks/plugins/array/k8s/management.go index 510f202e1a..d6abaaf74b 100644 --- a/flyteplugins/go/tasks/plugins/array/k8s/management.go +++ b/flyteplugins/go/tasks/plugins/array/k8s/management.go @@ -382,10 +382,10 @@ func TerminateSubTasks(ctx context.Context, tCtx core.TaskExecutionContext, kube messageCollector.Collect(childIdx, err.Error()) } else { externalResources = append(externalResources, &core.ExternalResource{ - ExternalID: stCtx.TaskExecutionMetadata().GetTaskExecutionID().GetGeneratedName(), - Index: uint32(originalIdx), - RetryAttempt: uint32(retryAttempt), - Phase: core.PhaseAborted, + ExternalID: stCtx.TaskExecutionMetadata().GetTaskExecutionID().GetGeneratedName(), + Index: uint32(originalIdx), + RetryAttempt: uint32(retryAttempt), + Phase: core.PhaseAborted, }) } } diff --git a/flyteplugins/go/tasks/plugins/webapi/agent/config.go b/flyteplugins/go/tasks/plugins/webapi/agent/config.go index 1045a7cf80..cb0bd3089f 100644 --- a/flyteplugins/go/tasks/plugins/webapi/agent/config.go +++ b/flyteplugins/go/tasks/plugins/webapi/agent/config.go @@ -40,10 +40,12 @@ var ( }, }, DefaultAgent: Agent{ - Endpoint: "dns:///flyteagent.flyte.svc.cluster.local:80", + Endpoint: "", Insecure: true, DefaultTimeout: config.Duration{Duration: 10 * time.Second}, }, + // AsyncPlugin should be registered to at least one task type. + // Reference: https://github.com/flyteorg/flyte/blob/master/flyteplugins/go/tasks/pluginmachinery/registry.go#L27 SupportedTaskTypes: []string{"task_type_1", "task_type_2"}, } diff --git a/flyteplugins/go/tasks/plugins/webapi/agent/integration_test.go b/flyteplugins/go/tasks/plugins/webapi/agent/integration_test.go index 0aecffdfc7..15375a8580 100644 --- a/flyteplugins/go/tasks/plugins/webapi/agent/integration_test.go +++ b/flyteplugins/go/tasks/plugins/webapi/agent/integration_test.go @@ -161,7 +161,7 @@ func TestEndToEnd(t *testing.T) { tr.OnRead(context.Background()).Return(nil, fmt.Errorf("read fail")) tCtx.OnTaskReader().Return(tr) - agentPlugin := newAgentPlugin() + agentPlugin := newMockAgentPlugin() pluginEntry := pluginmachinery.CreateRemotePlugin(agentPlugin) plugin, err := pluginEntry.LoadPlugin(context.TODO(), newFakeSetupContext("test3")) assert.NoError(t, err) diff --git a/flyteplugins/go/tasks/plugins/webapi/agent/mocks/AgentMetadataServiceClient.go b/flyteplugins/go/tasks/plugins/webapi/agent/mocks/AgentMetadataServiceClient.go new file mode 100644 index 0000000000..d7f40932b7 --- /dev/null +++ b/flyteplugins/go/tasks/plugins/webapi/agent/mocks/AgentMetadataServiceClient.go @@ -0,0 +1,114 @@ +// Code generated by mockery v1.0.1. DO NOT EDIT. + +package mocks + +import ( + context "context" + + admin "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin" + + grpc "google.golang.org/grpc" + + mock "github.com/stretchr/testify/mock" +) + +// AgentMetadataServiceClient is an autogenerated mock type for the AgentMetadataServiceClient type +type AgentMetadataServiceClient struct { + mock.Mock +} + +type AgentMetadataServiceClient_GetAgent struct { + *mock.Call +} + +func (_m AgentMetadataServiceClient_GetAgent) Return(_a0 *admin.GetAgentResponse, _a1 error) *AgentMetadataServiceClient_GetAgent { + return &AgentMetadataServiceClient_GetAgent{Call: _m.Call.Return(_a0, _a1)} +} + +func (_m *AgentMetadataServiceClient) OnGetAgent(ctx context.Context, in *admin.GetAgentRequest, opts ...grpc.CallOption) *AgentMetadataServiceClient_GetAgent { + c_call := _m.On("GetAgent", ctx, in, opts) + return &AgentMetadataServiceClient_GetAgent{Call: c_call} +} + +func (_m *AgentMetadataServiceClient) OnGetAgentMatch(matchers ...interface{}) *AgentMetadataServiceClient_GetAgent { + c_call := _m.On("GetAgent", matchers...) + return &AgentMetadataServiceClient_GetAgent{Call: c_call} +} + +// GetAgent provides a mock function with given fields: ctx, in, opts +func (_m *AgentMetadataServiceClient) GetAgent(ctx context.Context, in *admin.GetAgentRequest, opts ...grpc.CallOption) (*admin.GetAgentResponse, error) { + _va := make([]interface{}, len(opts)) + for _i := range opts { + _va[_i] = opts[_i] + } + var _ca []interface{} + _ca = append(_ca, ctx, in) + _ca = append(_ca, _va...) + ret := _m.Called(_ca...) + + var r0 *admin.GetAgentResponse + if rf, ok := ret.Get(0).(func(context.Context, *admin.GetAgentRequest, ...grpc.CallOption) *admin.GetAgentResponse); ok { + r0 = rf(ctx, in, opts...) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*admin.GetAgentResponse) + } + } + + var r1 error + if rf, ok := ret.Get(1).(func(context.Context, *admin.GetAgentRequest, ...grpc.CallOption) error); ok { + r1 = rf(ctx, in, opts...) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + +type AgentMetadataServiceClient_ListAgents struct { + *mock.Call +} + +func (_m AgentMetadataServiceClient_ListAgents) Return(_a0 *admin.ListAgentsResponse, _a1 error) *AgentMetadataServiceClient_ListAgents { + return &AgentMetadataServiceClient_ListAgents{Call: _m.Call.Return(_a0, _a1)} +} + +func (_m *AgentMetadataServiceClient) OnListAgents(ctx context.Context, in *admin.ListAgentsRequest, opts ...grpc.CallOption) *AgentMetadataServiceClient_ListAgents { + c_call := _m.On("ListAgents", ctx, in, opts) + return &AgentMetadataServiceClient_ListAgents{Call: c_call} +} + +func (_m *AgentMetadataServiceClient) OnListAgentsMatch(matchers ...interface{}) *AgentMetadataServiceClient_ListAgents { + c_call := _m.On("ListAgents", matchers...) + return &AgentMetadataServiceClient_ListAgents{Call: c_call} +} + +// ListAgents provides a mock function with given fields: ctx, in, opts +func (_m *AgentMetadataServiceClient) ListAgents(ctx context.Context, in *admin.ListAgentsRequest, opts ...grpc.CallOption) (*admin.ListAgentsResponse, error) { + _va := make([]interface{}, len(opts)) + for _i := range opts { + _va[_i] = opts[_i] + } + var _ca []interface{} + _ca = append(_ca, ctx, in) + _ca = append(_ca, _va...) + ret := _m.Called(_ca...) + + var r0 *admin.ListAgentsResponse + if rf, ok := ret.Get(0).(func(context.Context, *admin.ListAgentsRequest, ...grpc.CallOption) *admin.ListAgentsResponse); ok { + r0 = rf(ctx, in, opts...) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*admin.ListAgentsResponse) + } + } + + var r1 error + if rf, ok := ret.Get(1).(func(context.Context, *admin.ListAgentsRequest, ...grpc.CallOption) error); ok { + r1 = rf(ctx, in, opts...) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} diff --git a/flyteplugins/go/tasks/plugins/webapi/agent/plugin.go b/flyteplugins/go/tasks/plugins/webapi/agent/plugin.go index 2b3d8dbba9..6230dc14f8 100644 --- a/flyteplugins/go/tasks/plugins/webapi/agent/plugin.go +++ b/flyteplugins/go/tasks/plugins/webapi/agent/plugin.go @@ -7,10 +7,13 @@ import ( "fmt" "time" + "golang.org/x/exp/maps" "google.golang.org/grpc" + "google.golang.org/grpc/codes" "google.golang.org/grpc/credentials" "google.golang.org/grpc/credentials/insecure" "google.golang.org/grpc/grpclog" + "google.golang.org/grpc/status" "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin" flyteIdl "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/core" @@ -28,12 +31,14 @@ import ( ) type GetClientFunc func(ctx context.Context, agent *Agent, connectionCache map[*Agent]*grpc.ClientConn) (service.AsyncAgentServiceClient, error) +type GetAgentMetadataClientFunc func(ctx context.Context, agent *Agent, connCache map[*Agent]*grpc.ClientConn) (service.AgentMetadataServiceClient, error) type Plugin struct { metricScope promutils.Scope cfg *Config getClient GetClientFunc connectionCache map[*Agent]*grpc.ClientConn + agentRegistry map[string]*Agent // map[taskType] => Agent } type ResourceWrapper struct { @@ -89,10 +94,8 @@ func (p Plugin) Create(ctx context.Context, taskCtx webapi.TaskExecutionContextR } outputPrefix := taskCtx.OutputWriter().GetOutputPrefixPath().String() - agent, err := getFinalAgent(taskTemplate.Type, p.cfg) - if err != nil { - return nil, nil, fmt.Errorf("failed to find agent agent with error: %v", err) - } + agent := getFinalAgent(taskTemplate.Type, p.cfg, p.agentRegistry) + client, err := p.getClient(ctx, agent, p.connectionCache) if err != nil { return nil, nil, fmt.Errorf("failed to connect to agent with error: %v", err) @@ -123,10 +126,11 @@ func (p Plugin) Create(ctx context.Context, taskCtx webapi.TaskExecutionContextR func (p Plugin) Get(ctx context.Context, taskCtx webapi.GetContext) (latest webapi.Resource, err error) { metadata := taskCtx.ResourceMeta().(ResourceMetaWrapper) - agent, err := getFinalAgent(metadata.TaskType, p.cfg) + agent := getFinalAgent(metadata.TaskType, p.cfg, p.agentRegistry) if err != nil { return nil, fmt.Errorf("failed to find agent with error: %v", err) } + client, err := p.getClient(ctx, agent, p.connectionCache) if err != nil { return nil, fmt.Errorf("failed to connect to agent with error: %v", err) @@ -154,10 +158,8 @@ func (p Plugin) Delete(ctx context.Context, taskCtx webapi.DeleteContext) error } metadata := taskCtx.ResourceMeta().(ResourceMetaWrapper) - agent, err := getFinalAgent(metadata.TaskType, p.cfg) - if err != nil { - return fmt.Errorf("failed to find agent agent with error: %v", err) - } + agent := getFinalAgent(metadata.TaskType, p.cfg, p.agentRegistry) + client, err := p.getClient(ctx, agent, p.connectionCache) if err != nil { return fmt.Errorf("failed to connect to agent with error: %v", err) @@ -216,23 +218,19 @@ func writeOutput(ctx context.Context, taskCtx webapi.StatusContext, resource Res return taskCtx.OutputWriter().Put(ctx, opReader) } -func getFinalAgent(taskType string, cfg *Config) (*Agent, error) { - if id, exists := cfg.AgentForTaskTypes[taskType]; exists { - if agent, exists := cfg.Agents[id]; exists { - return agent, nil - } - return nil, fmt.Errorf("no agent definition found for ID %s that matches task type %s", id, taskType) +func getFinalAgent(taskType string, cfg *Config, agentRegistry map[string]*Agent) *Agent { + if agent, exists := agentRegistry[taskType]; exists { + return agent } - return &cfg.DefaultAgent, nil + return &cfg.DefaultAgent } -func getClientFunc(ctx context.Context, agent *Agent, connectionCache map[*Agent]*grpc.ClientConn) (service.AsyncAgentServiceClient, error) { +func getGrpcConnection(ctx context.Context, agent *Agent, connectionCache map[*Agent]*grpc.ClientConn) (*grpc.ClientConn, error) { conn, ok := connectionCache[agent] if ok { - return service.NewAsyncAgentServiceClient(conn), nil + return conn, nil } - var opts []grpc.DialOption if agent.Insecure { @@ -271,9 +269,28 @@ func getClientFunc(ctx context.Context, agent *Agent, connectionCache map[*Agent } }() }() + + return conn, nil +} + +func getClientFunc(ctx context.Context, agent *Agent, connectionCache map[*Agent]*grpc.ClientConn) (service.AsyncAgentServiceClient, error) { + conn, err := getGrpcConnection(ctx, agent, connectionCache) + if err != nil { + return nil, err + } + return service.NewAsyncAgentServiceClient(conn), nil } +func getAgentMetadataClientFunc(ctx context.Context, agent *Agent, connectionCache map[*Agent]*grpc.ClientConn) (service.AgentMetadataServiceClient, error) { + conn, err := getGrpcConnection(ctx, agent, connectionCache) + if err != nil { + return nil, err + } + + return service.NewAgentMetadataServiceClient(conn), nil +} + func buildTaskExecutionMetadata(taskExecutionMetadata core.TaskExecutionMetadata) admin.TaskExecutionMetadata { taskExecutionID := taskExecutionMetadata.GetTaskExecutionID().GetID() return admin.TaskExecutionMetadata{ @@ -299,11 +316,71 @@ func getFinalContext(ctx context.Context, operation string, agent *Agent) (conte if timeout == 0 { return ctx, func() {} } + return context.WithTimeout(ctx, timeout) } +func initializeAgentRegistry(cfg *Config, connectionCache map[*Agent]*grpc.ClientConn, getAgentMetadataClientFunc GetAgentMetadataClientFunc) (map[string]*Agent, error) { + agentRegistry := make(map[string]*Agent) + var agentDeployments []*Agent + + // Ensure that the old configuration is backward compatible + for taskType, agentID := range cfg.AgentForTaskTypes { + agentRegistry[taskType] = cfg.Agents[agentID] + } + + if len(cfg.DefaultAgent.Endpoint) != 0 { + agentDeployments = append(agentDeployments, &cfg.DefaultAgent) + } + agentDeployments = append(agentDeployments, maps.Values(cfg.Agents)...) + for _, agentDeployment := range agentDeployments { + client, err := getAgentMetadataClientFunc(context.Background(), agentDeployment, connectionCache) + if err != nil { + return nil, fmt.Errorf("failed to connect to agent [%v] with error: [%v]", agentDeployment, err) + } + + finalCtx, cancel := getFinalContext(context.Background(), "ListAgents", agentDeployment) + defer cancel() + + res, err := client.ListAgents(finalCtx, &admin.ListAgentsRequest{}) + if err != nil { + grpcStatus, ok := status.FromError(err) + if grpcStatus.Code() == codes.Unimplemented { + // we should not panic here, as we want to continue to support old agent settings + logger.Infof(context.Background(), "list agent method not implemented for agent: [%v]", agentDeployment) + continue + } + + if !ok { + return nil, fmt.Errorf("failed to list agent with a non-gRPC error : [%v]", err) + } + + return nil, fmt.Errorf("failed to list agent with error: [%v]", err) + } + + agents := res.GetAgents() + for _, agent := range agents { + supportedTaskTypes := agent.SupportedTaskTypes + for _, supportedTaskType := range supportedTaskTypes { + agentRegistry[supportedTaskType] = agentDeployment + } + } + } + + return agentRegistry, nil +} + func newAgentPlugin() webapi.PluginEntry { - supportedTaskTypes := GetConfig().SupportedTaskTypes + cfg := GetConfig() + connectionCache := make(map[*Agent]*grpc.ClientConn) + agentRegistry, err := initializeAgentRegistry(cfg, connectionCache, getAgentMetadataClientFunc) + if err != nil { + // We should wait for all agents to be up and running before starting the server + panic(err) + } + + supportedTaskTypes := append(maps.Keys(agentRegistry), cfg.SupportedTaskTypes...) + logger.Infof(context.Background(), "Agent supports task types: %v", supportedTaskTypes) return webapi.PluginEntry{ ID: "agent-service", @@ -311,9 +388,10 @@ func newAgentPlugin() webapi.PluginEntry { PluginLoader: func(ctx context.Context, iCtx webapi.PluginSetupContext) (webapi.AsyncPlugin, error) { return &Plugin{ metricScope: iCtx.MetricsScope(), - cfg: GetConfig(), + cfg: cfg, getClient: getClientFunc, - connectionCache: make(map[*Agent]*grpc.ClientConn), + connectionCache: connectionCache, + agentRegistry: agentRegistry, }, nil }, } diff --git a/flyteplugins/go/tasks/plugins/webapi/agent/plugin_test.go b/flyteplugins/go/tasks/plugins/webapi/agent/plugin_test.go index b1fdd61e79..779fb597c1 100644 --- a/flyteplugins/go/tasks/plugins/webapi/agent/plugin_test.go +++ b/flyteplugins/go/tasks/plugins/webapi/agent/plugin_test.go @@ -2,17 +2,22 @@ package agent import ( "context" - flyteidlcore "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/core" + "sort" "testing" "time" "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/mock" + "golang.org/x/exp/maps" "google.golang.org/grpc" "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin" + flyteidlcore "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/core" + "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/service" pluginsCore "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/core" pluginCoreMocks "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/core/mocks" webapiPlugin "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/webapi/mocks" + agentMocks "github.com/flyteorg/flyte/flyteplugins/go/tasks/plugins/webapi/agent/mocks" "github.com/flyteorg/flyte/flytestdlib/config" "github.com/flyteorg/flyte/flytestdlib/promutils" ) @@ -45,19 +50,26 @@ func TestPlugin(t *testing.T) { }) t.Run("test newAgentPlugin", func(t *testing.T) { - p := newAgentPlugin() + p := newMockAgentPlugin() assert.NotNil(t, p) assert.Equal(t, "agent-service", p.ID) assert.NotNil(t, p.PluginLoader) }) t.Run("test getFinalAgent", func(t *testing.T) { - agent, _ := getFinalAgent("spark", &cfg) - assert.Equal(t, cfg.Agents["spark_agent"].Endpoint, agent.Endpoint) - agent, _ = getFinalAgent("foo", &cfg) - assert.Equal(t, cfg.DefaultAgent.Endpoint, agent.Endpoint) - _, err := getFinalAgent("bar", &cfg) - assert.NotNil(t, err) + agentRegistry := map[string]*Agent{"spark": {Endpoint: "localhost:80"}} + agent := getFinalAgent("spark", &cfg, agentRegistry) + assert.Equal(t, agent.Endpoint, "localhost:80") + agent = getFinalAgent("foo", &cfg, agentRegistry) + assert.Equal(t, agent.Endpoint, cfg.DefaultAgent.Endpoint) + agent = getFinalAgent("bar", &cfg, agentRegistry) + assert.Equal(t, agent.Endpoint, cfg.DefaultAgent.Endpoint) + }) + + t.Run("test getAgentMetadataClientFunc", func(t *testing.T) { + client, err := getAgentMetadataClientFunc(context.Background(), &Agent{Endpoint: "localhost:80"}, map[*Agent]*grpc.ClientConn{}) + assert.NoError(t, err) + assert.NotNil(t, client) }) t.Run("test getClientFunc", func(t *testing.T) { @@ -173,3 +185,34 @@ func TestPlugin(t *testing.T) { assert.Equal(t, pluginsCore.PhaseUndefined, phase.Phase()) }) } + +func TestInitializeAgentRegistry(t *testing.T) { + mockClient := new(agentMocks.AgentMetadataServiceClient) + mockRequest := &admin.ListAgentsRequest{} + mockResponse := &admin.ListAgentsResponse{ + Agents: []*admin.Agent{ + { + Name: "test-agent", + SupportedTaskTypes: []string{"task1", "task2", "task3"}, + }, + }, + } + + mockClient.On("ListAgents", mock.Anything, mockRequest).Return(mockResponse, nil) + getAgentMetadataClientFunc := func(ctx context.Context, agent *Agent, connCache map[*Agent]*grpc.ClientConn) (service.AgentMetadataServiceClient, error) { + return mockClient, nil + } + + cfg := defaultConfig + cfg.Agents = map[string]*Agent{"custom_agent": {Endpoint: "localhost:80"}} + cfg.AgentForTaskTypes = map[string]string{"task1": "agent-deployment-1", "task2": "agent-deployment-2"} + connectionCache := make(map[*Agent]*grpc.ClientConn) + agentRegistry, err := initializeAgentRegistry(&cfg, connectionCache, getAgentMetadataClientFunc) + assert.NoError(t, err) + + // In golang, the order of keys in a map is random. So, we sort the keys before asserting. + agentRegistryKeys := maps.Keys(agentRegistry) + sort.Strings(agentRegistryKeys) + + assert.Equal(t, agentRegistryKeys, []string{"task1", "task2", "task3"}) +} diff --git a/flytepropeller/pkg/controller/executors/failure_node_lookup_test.go b/flytepropeller/pkg/controller/executors/failure_node_lookup_test.go index b2dfa32231..e9d6857ec4 100644 --- a/flytepropeller/pkg/controller/executors/failure_node_lookup_test.go +++ b/flytepropeller/pkg/controller/executors/failure_node_lookup_test.go @@ -4,9 +4,10 @@ import ( "context" "testing" + "github.com/stretchr/testify/assert" + "github.com/flyteorg/flyte/flytepropeller/pkg/apis/flyteworkflow/v1alpha1" "github.com/flyteorg/flyte/flytepropeller/pkg/apis/flyteworkflow/v1alpha1/mocks" - "github.com/stretchr/testify/assert" ) type nl struct { From 35016759a3848b27d604d872e9a79bfd89e4ab53 Mon Sep 17 00:00:00 2001 From: Eduardo Apolinario <653394+eapolinario@users.noreply.github.com> Date: Wed, 20 Dec 2023 13:10:59 -0300 Subject: [PATCH 4/8] Add Flyin propeller config (#4610) * Revert "Detect subNode phase updates to reduce evaluation frequency of ArrayNode (#4535)" This reverts commit b50ba877e4632826dd4d5bc0978a41d39c8d172a. Signed-off-by: Eduardo Apolinario * Add flyin pflags Signed-off-by: Eduardo Apolinario * Add taskTemplate as parameter to GetLogsForContainerInPod Signed-off-by: Eduardo Apolinario * Add flyin template scheme and unit tests Signed-off-by: Eduardo Apolinario * Revert unintended change. Signed-off-by: Eduardo Apolinario * Lint Signed-off-by: Eduardo Apolinario * Fix bad refactor due to lint warning Signed-off-by: Eduardo Apolinario * Remove TODOs Signed-off-by: Eduardo Apolinario --------- Signed-off-by: Eduardo Apolinario Co-authored-by: Eduardo Apolinario --- flyteplugins/go/tasks/logs/config.go | 3 + flyteplugins/go/tasks/logs/logconfig_flags.go | 2 + .../go/tasks/logs/logconfig_flags_test.go | 28 ++++ flyteplugins/go/tasks/logs/logging_utils.go | 11 +- .../go/tasks/logs/logging_utils_test.go | 54 +++++-- .../tasks/pluginmachinery/tasklog/plugin.go | 3 + .../tasks/pluginmachinery/tasklog/template.go | 27 ++++ .../pluginmachinery/tasklog/template_test.go | 132 ++++++++++++++++++ .../tasklog/templatescheme_enumer.go | 11 +- .../go/tasks/plugins/k8s/pod/plugin.go | 7 +- 10 files changed, 258 insertions(+), 20 deletions(-) diff --git a/flyteplugins/go/tasks/logs/config.go b/flyteplugins/go/tasks/logs/config.go index ca5a6012a8..b802844a4a 100644 --- a/flyteplugins/go/tasks/logs/config.go +++ b/flyteplugins/go/tasks/logs/config.go @@ -28,6 +28,9 @@ type LogConfig struct { StackdriverLogResourceName string `json:"stackdriver-logresourcename" pflag:",Name of the logresource in stackdriver"` StackDriverTemplateURI tasklog.TemplateURI `json:"stackdriver-template-uri" pflag:",Template Uri to use when building stackdriver log links"` + IsFlyinEnabled bool `json:"flyin-enabled" pflag:",Enable Log-links to flyin logs"` + FlyinTemplateURI tasklog.TemplateURI `json:"flyin-template-uri" pflag:",Template Uri to use when building flyin log links"` + Templates []tasklog.TemplateLogPlugin `json:"templates" pflag:"-,"` } diff --git a/flyteplugins/go/tasks/logs/logconfig_flags.go b/flyteplugins/go/tasks/logs/logconfig_flags.go index 00c08a8a58..de8ba022dc 100755 --- a/flyteplugins/go/tasks/logs/logconfig_flags.go +++ b/flyteplugins/go/tasks/logs/logconfig_flags.go @@ -61,5 +61,7 @@ func (cfg LogConfig) GetPFlagSet(prefix string) *pflag.FlagSet { cmdFlags.String(fmt.Sprintf("%v%v", prefix, "gcp-project"), DefaultConfig.GCPProjectName, "Name of the project in GCP") cmdFlags.String(fmt.Sprintf("%v%v", prefix, "stackdriver-logresourcename"), DefaultConfig.StackdriverLogResourceName, "Name of the logresource in stackdriver") cmdFlags.String(fmt.Sprintf("%v%v", prefix, "stackdriver-template-uri"), DefaultConfig.StackDriverTemplateURI, "Template Uri to use when building stackdriver log links") + cmdFlags.Bool(fmt.Sprintf("%v%v", prefix, "flyin-enabled"), DefaultConfig.IsFlyinEnabled, "Enable Log-links to flyin logs") + cmdFlags.String(fmt.Sprintf("%v%v", prefix, "flyin-template-uri"), DefaultConfig.FlyinTemplateURI, "Template Uri to use when building flyin log links") return cmdFlags } diff --git a/flyteplugins/go/tasks/logs/logconfig_flags_test.go b/flyteplugins/go/tasks/logs/logconfig_flags_test.go index 8bb775df1f..dfbee43c69 100755 --- a/flyteplugins/go/tasks/logs/logconfig_flags_test.go +++ b/flyteplugins/go/tasks/logs/logconfig_flags_test.go @@ -253,4 +253,32 @@ func TestLogConfig_SetFlags(t *testing.T) { } }) }) + t.Run("Test_flyin-enabled", func(t *testing.T) { + + t.Run("Override", func(t *testing.T) { + testValue := "1" + + cmdFlags.Set("flyin-enabled", testValue) + if vBool, err := cmdFlags.GetBool("flyin-enabled"); err == nil { + testDecodeJson_LogConfig(t, fmt.Sprintf("%v", vBool), &actual.IsFlyinEnabled) + + } else { + assert.FailNow(t, err.Error()) + } + }) + }) + t.Run("Test_flyin-template-uri", func(t *testing.T) { + + t.Run("Override", func(t *testing.T) { + testValue := "1" + + cmdFlags.Set("flyin-template-uri", testValue) + if vString, err := cmdFlags.GetString("flyin-template-uri"); err == nil { + testDecodeJson_LogConfig(t, fmt.Sprintf("%v", vString), &actual.FlyinTemplateURI) + + } else { + assert.FailNow(t, err.Error()) + } + }) + }) } diff --git a/flyteplugins/go/tasks/logs/logging_utils.go b/flyteplugins/go/tasks/logs/logging_utils.go index 4978109458..20f3522e27 100644 --- a/flyteplugins/go/tasks/logs/logging_utils.go +++ b/flyteplugins/go/tasks/logs/logging_utils.go @@ -14,7 +14,7 @@ import ( ) // Internal -func GetLogsForContainerInPod(ctx context.Context, logPlugin tasklog.Plugin, taskExecID pluginsCore.TaskExecutionID, pod *v1.Pod, index uint32, nameSuffix string, extraLogTemplateVarsByScheme *tasklog.TemplateVarsByScheme) ([]*core.TaskLog, error) { +func GetLogsForContainerInPod(ctx context.Context, logPlugin tasklog.Plugin, taskExecID pluginsCore.TaskExecutionID, pod *v1.Pod, index uint32, nameSuffix string, extraLogTemplateVarsByScheme *tasklog.TemplateVarsByScheme, taskTemplate *core.TaskTemplate) ([]*core.TaskLog, error) { if logPlugin == nil { return nil, nil } @@ -51,6 +51,7 @@ func GetLogsForContainerInPod(ctx context.Context, logPlugin tasklog.Plugin, tas PodUnixFinishTime: finishTime, TaskExecutionID: taskExecID, ExtraTemplateVarsByScheme: extraLogTemplateVarsByScheme, + TaskTemplate: taskTemplate, }, ) @@ -108,6 +109,14 @@ func InitializeLogPlugins(cfg *LogConfig) (tasklog.Plugin, error) { } } + if cfg.IsFlyinEnabled { + if len(cfg.FlyinTemplateURI) > 0 { + plugins = append(plugins, tasklog.TemplateLogPlugin{DisplayName: "Flyin Logs", Scheme: tasklog.TemplateSchemeFlyin, TemplateURIs: []tasklog.TemplateURI{cfg.FlyinTemplateURI}, MessageFormat: core.TaskLog_JSON}) + } else { + plugins = append(plugins, tasklog.TemplateLogPlugin{DisplayName: "Flyin Logs", Scheme: tasklog.TemplateSchemeFlyin, TemplateURIs: []tasklog.TemplateURI{fmt.Sprintf("https://flyin.%s/logs/{{ .namespace }}/{{ .podName }}/{{ .containerName }}/{{ .containerId }}", cfg.GCPProjectName)}, MessageFormat: core.TaskLog_JSON}) + } + } + plugins = append(plugins, cfg.Templates...) return templateLogPluginCollection{plugins: plugins}, nil } diff --git a/flyteplugins/go/tasks/logs/logging_utils_test.go b/flyteplugins/go/tasks/logs/logging_utils_test.go index 91048eff16..46eb682201 100644 --- a/flyteplugins/go/tasks/logs/logging_utils_test.go +++ b/flyteplugins/go/tasks/logs/logging_utils_test.go @@ -44,7 +44,7 @@ func dummyTaskExecID() pluginCore.TaskExecutionID { func TestGetLogsForContainerInPod_NoPlugins(t *testing.T) { logPlugin, err := InitializeLogPlugins(&LogConfig{}) assert.NoError(t, err) - l, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), nil, 0, " Suffix", nil) + l, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), nil, 0, " Suffix", nil, nil) assert.NoError(t, err) assert.Nil(t, l) } @@ -56,7 +56,7 @@ func TestGetLogsForContainerInPod_NoLogs(t *testing.T) { CloudwatchLogGroup: "/kubernetes/flyte-production", }) assert.NoError(t, err) - p, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), nil, 0, " Suffix", nil) + p, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), nil, 0, " Suffix", nil, nil) assert.NoError(t, err) assert.Nil(t, p) } @@ -87,7 +87,7 @@ func TestGetLogsForContainerInPod_BadIndex(t *testing.T) { } pod.Name = podName - p, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 1, " Suffix", nil) + p, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 1, " Suffix", nil, nil) assert.NoError(t, err) assert.Nil(t, p) } @@ -112,7 +112,7 @@ func TestGetLogsForContainerInPod_MissingStatus(t *testing.T) { } pod.Name = podName - p, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 1, " Suffix", nil) + p, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 1, " Suffix", nil, nil) assert.NoError(t, err) assert.Nil(t, p) } @@ -142,7 +142,7 @@ func TestGetLogsForContainerInPod_Cloudwatch(t *testing.T) { } pod.Name = podName - logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " Suffix", nil) + logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " Suffix", nil, nil) assert.Nil(t, err) assert.Len(t, logs, 1) } @@ -172,7 +172,7 @@ func TestGetLogsForContainerInPod_K8s(t *testing.T) { } pod.Name = podName - logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " Suffix", nil) + logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " Suffix", nil, nil) assert.Nil(t, err) assert.Len(t, logs, 1) } @@ -205,7 +205,7 @@ func TestGetLogsForContainerInPod_All(t *testing.T) { } pod.Name = podName - logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " Suffix", nil) + logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " Suffix", nil, nil) assert.Nil(t, err) assert.Len(t, logs, 2) } @@ -236,7 +236,7 @@ func TestGetLogsForContainerInPod_Stackdriver(t *testing.T) { } pod.Name = podName - logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " Suffix", nil) + logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " Suffix", nil, nil) assert.Nil(t, err) assert.Len(t, logs, 1) } @@ -252,7 +252,7 @@ func TestGetLogsForContainerInPod_LegacyTemplate(t *testing.T) { IsStackDriverEnabled: true, StackDriverTemplateURI: "https://sd-my-log-server/{{ .namespace }}/{{ .podName }}/{{ .containerName }}/{{ .containerId }}", - }, []*core.TaskLog{ + }, nil, []*core.TaskLog{ { Uri: "https://k8s-my-log-server/my-namespace/my-pod/ContainerName/ContainerID", MessageFormat: core.TaskLog_JSON, @@ -275,7 +275,7 @@ func TestGetLogsForContainerInPod_LegacyTemplate(t *testing.T) { assertTestSucceeded(t, &LogConfig{ IsStackDriverEnabled: true, StackDriverTemplateURI: "https://sd-my-log-server/{{ .namespace }}/{{ .podName }}/{{ .containerName }}/{{ .containerId }}", - }, []*core.TaskLog{ + }, nil, []*core.TaskLog{ { Uri: "https://sd-my-log-server/my-namespace/my-pod/ContainerName/ContainerID", MessageFormat: core.TaskLog_JSON, @@ -285,7 +285,7 @@ func TestGetLogsForContainerInPod_LegacyTemplate(t *testing.T) { }) } -func assertTestSucceeded(tb testing.TB, config *LogConfig, expectedTaskLogs []*core.TaskLog) { +func assertTestSucceeded(tb testing.TB, config *LogConfig, taskTemplate *core.TaskTemplate, expectedTaskLogs []*core.TaskLog) { logPlugin, err := InitializeLogPlugins(config) assert.NoError(tb, err) @@ -310,7 +310,7 @@ func assertTestSucceeded(tb testing.TB, config *LogConfig, expectedTaskLogs []*c }, } - logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " my-Suffix", nil) + logs, err := GetLogsForContainerInPod(context.TODO(), logPlugin, dummyTaskExecID(), pod, 0, " my-Suffix", nil, taskTemplate) assert.Nil(tb, err) assert.Len(tb, logs, len(expectedTaskLogs)) if diff := deep.Equal(logs, expectedTaskLogs); len(diff) > 0 { @@ -337,7 +337,7 @@ func TestGetLogsForContainerInPod_Templates(t *testing.T) { Scheme: tasklog.TemplateSchemeTaskExecution, }, }, - }, []*core.TaskLog{ + }, nil, []*core.TaskLog{ { Uri: "https://my-log-server/my-namespace/my-pod/ContainerName/ContainerID", MessageFormat: core.TaskLog_JSON, @@ -350,3 +350,31 @@ func TestGetLogsForContainerInPod_Templates(t *testing.T) { }, }) } + +func TestGetLogsForContainerInPod_Flyin(t *testing.T) { + assertTestSucceeded(t, + &LogConfig{ + IsKubernetesEnabled: true, + KubernetesTemplateURI: "https://k8s.com", + IsFlyinEnabled: true, + FlyinTemplateURI: "https://flyin.mydomain.com:{{ .port }}/{{ .namespace }}/{{ .podName }}/{{ .containerName }}/{{ .containerId }}", + }, + &core.TaskTemplate{ + Config: map[string]string{ + "link_type": "vscode", + "port": "65535", + }, + }, + []*core.TaskLog{ + { + Uri: "https://k8s.com", + MessageFormat: core.TaskLog_JSON, + Name: "Kubernetes Logs my-Suffix", + }, + { + Uri: "https://flyin.mydomain.com:65535/my-namespace/my-pod/ContainerName/ContainerID", + MessageFormat: core.TaskLog_JSON, + Name: "Flyin Logs my-Suffix", + }, + }) +} diff --git a/flyteplugins/go/tasks/pluginmachinery/tasklog/plugin.go b/flyteplugins/go/tasks/pluginmachinery/tasklog/plugin.go index c43da02e58..da2357a6d9 100644 --- a/flyteplugins/go/tasks/pluginmachinery/tasklog/plugin.go +++ b/flyteplugins/go/tasks/pluginmachinery/tasklog/plugin.go @@ -14,6 +14,7 @@ type TemplateScheme int const ( TemplateSchemePod TemplateScheme = iota TemplateSchemeTaskExecution + TemplateSchemeFlyin ) // TemplateURI is a URI that accepts templates. See: go/tasks/pluginmachinery/tasklog/template.go for available templates. @@ -30,6 +31,7 @@ type TemplateVarsByScheme struct { Common TemplateVars Pod TemplateVars TaskExecution TemplateVars + Flyin TemplateVars } // Input contains all available information about task's execution that a log plugin can use to construct task's @@ -48,6 +50,7 @@ type Input struct { PodUID string TaskExecutionID pluginsCore.TaskExecutionID ExtraTemplateVarsByScheme *TemplateVarsByScheme + TaskTemplate *core.TaskTemplate } // Output contains all task logs a plugin generates for a given Input. diff --git a/flyteplugins/go/tasks/pluginmachinery/tasklog/template.go b/flyteplugins/go/tasks/pluginmachinery/tasklog/template.go index 750b1972df..ea5c5f373c 100644 --- a/flyteplugins/go/tasks/pluginmachinery/tasklog/template.go +++ b/flyteplugins/go/tasks/pluginmachinery/tasklog/template.go @@ -35,6 +35,7 @@ type templateRegexes struct { ExecutionProject *regexp.Regexp ExecutionDomain *regexp.Regexp GeneratedName *regexp.Regexp + Port *regexp.Regexp } func initDefaultRegexes() templateRegexes { @@ -60,6 +61,7 @@ func initDefaultRegexes() templateRegexes { MustCreateRegex("executionProject"), MustCreateRegex("executionDomain"), MustCreateRegex("generatedName"), + MustCreateRegex("port"), } } @@ -85,6 +87,16 @@ func (input Input) templateVarsForScheme(scheme TemplateScheme) TemplateVars { } switch scheme { + case TemplateSchemeFlyin: + port := input.TaskTemplate.GetConfig()["port"] + if port == "" { + port = "8080" + } + vars = append( + vars, + TemplateVar{defaultRegexes.Port, port}, + ) + fallthrough case TemplateSchemePod: // Container IDs are prefixed with docker://, cri-o://, etc. which is stripped by fluentd before pushing to a log // stream. Therefore, we must also strip the prefix. @@ -181,7 +193,22 @@ func (input Input) templateVarsForScheme(scheme TemplateScheme) TemplateVars { func (p TemplateLogPlugin) GetTaskLogs(input Input) (Output, error) { templateVars := input.templateVarsForScheme(p.Scheme) taskLogs := make([]*core.TaskLog, 0, len(p.TemplateURIs)) + + // Grab metadata from task template and check if key "link_type" is set to "vscode". + // If so, add a vscode link to the task logs. + isFlyin := false + if input.TaskTemplate != nil && input.TaskTemplate.GetConfig() != nil { + config := input.TaskTemplate.GetConfig() + if config != nil && config["link_type"] == "vscode" { + isFlyin = true + } + } for _, templateURI := range p.TemplateURIs { + // Skip Flyin logs if plugin is enabled but no metadata is defined in input's task template. + // This is to prevent Flyin logs from being generated for tasks that don't have a Flyin metadata section. + if p.DisplayName == "Flyin Logs" && !isFlyin { + continue + } taskLogs = append(taskLogs, &core.TaskLog{ Uri: replaceAll(templateURI, templateVars), Name: p.DisplayName + input.LogName, diff --git a/flyteplugins/go/tasks/pluginmachinery/tasklog/template_test.go b/flyteplugins/go/tasks/pluginmachinery/tasklog/template_test.go index f279707a3b..ad6eef25a3 100644 --- a/flyteplugins/go/tasks/pluginmachinery/tasklog/template_test.go +++ b/flyteplugins/go/tasks/pluginmachinery/tasklog/template_test.go @@ -74,6 +74,24 @@ func Test_Input_templateVarsForScheme(t *testing.T) { LogName: "main_logs", TaskExecutionID: dummyTaskExecID(), } + flyinBase := Input{ + HostName: "my-host", + PodName: "my-pod", + PodUID: "my-pod-uid", + Namespace: "my-namespace", + ContainerName: "my-container", + ContainerID: "docker://containerID", + LogName: "main_logs", + PodRFC3339StartTime: "1970-01-01T01:02:03+01:00", + PodRFC3339FinishTime: "1970-01-01T04:25:45+01:00", + PodUnixStartTime: 123, + PodUnixFinishTime: 12345, + TaskTemplate: &core.TaskTemplate{ + Config: map[string]string{ + "port": "1234", + }, + }, + } tests := []struct { name string @@ -202,6 +220,50 @@ func Test_Input_templateVarsForScheme(t *testing.T) { {testRegexes.Baz, "baz"}, }, }, + { + "flyin happy path", + TemplateSchemeFlyin, + flyinBase, + nil, + nil, + TemplateVars{ + {defaultRegexes.Port, "1234"}, + }, + nil, + }, + { + "flyin and pod happy path", + TemplateSchemeFlyin, + flyinBase, + nil, + TemplateVars{ + {defaultRegexes.LogName, "main_logs"}, + {defaultRegexes.Port, "1234"}, + {defaultRegexes.PodName, "my-pod"}, + {defaultRegexes.PodUID, "my-pod-uid"}, + {defaultRegexes.Namespace, "my-namespace"}, + {defaultRegexes.ContainerName, "my-container"}, + {defaultRegexes.ContainerID, "containerID"}, + {defaultRegexes.Hostname, "my-host"}, + {defaultRegexes.PodRFC3339StartTime, "1970-01-01T01:02:03+01:00"}, + {defaultRegexes.PodRFC3339FinishTime, "1970-01-01T04:25:45+01:00"}, + {defaultRegexes.PodUnixStartTime, "123"}, + {defaultRegexes.PodUnixFinishTime, "12345"}, + }, + nil, + nil, + }, + { + "pod with port not affected", + TemplateSchemePod, + podBase, + nil, + nil, + nil, + TemplateVars{ + {defaultRegexes.Port, "1234"}, + }, + }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { @@ -474,6 +536,76 @@ func TestTemplateLogPlugin(t *testing.T) { }, }, }, + { + "flyin", + TemplateLogPlugin{ + Scheme: TemplateSchemeFlyin, + TemplateURIs: []TemplateURI{"vscode://flyin:{{ .port }}/{{ .podName }}"}, + MessageFormat: core.TaskLog_JSON, + }, + args{ + input: Input{ + PodName: "my-pod-name", + TaskTemplate: &core.TaskTemplate{ + Config: map[string]string{ + "link_type": "vscode", + "port": "1234", + }, + }, + }, + }, + Output{ + TaskLogs: []*core.TaskLog{ + { + Uri: "vscode://flyin:1234/my-pod-name", + MessageFormat: core.TaskLog_JSON, + }, + }, + }, + }, + { + "flyin - default port", + TemplateLogPlugin{ + Scheme: TemplateSchemeFlyin, + TemplateURIs: []TemplateURI{"vscode://flyin:{{ .port }}/{{ .podName }}"}, + MessageFormat: core.TaskLog_JSON, + }, + args{ + input: Input{ + PodName: "my-pod-name", + TaskTemplate: &core.TaskTemplate{ + Config: map[string]string{ + "link_type": "vscode", + }, + }, + }, + }, + Output{ + TaskLogs: []*core.TaskLog{ + { + Uri: "vscode://flyin:8080/my-pod-name", + MessageFormat: core.TaskLog_JSON, + }, + }, + }, + }, + { + "flyin - no link_type in task template", + TemplateLogPlugin{ + Scheme: TemplateSchemeFlyin, + TemplateURIs: []TemplateURI{"vscode://flyin:{{ .port }}/{{ .podName }}"}, + MessageFormat: core.TaskLog_JSON, + DisplayName: "Flyin Logs", + }, + args{ + input: Input{ + PodName: "my-pod-name", + }, + }, + Output{ + TaskLogs: []*core.TaskLog{}, + }, + }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { diff --git a/flyteplugins/go/tasks/pluginmachinery/tasklog/templatescheme_enumer.go b/flyteplugins/go/tasks/pluginmachinery/tasklog/templatescheme_enumer.go index 70f15faf01..c1f4d668c0 100644 --- a/flyteplugins/go/tasks/pluginmachinery/tasklog/templatescheme_enumer.go +++ b/flyteplugins/go/tasks/pluginmachinery/tasklog/templatescheme_enumer.go @@ -7,9 +7,9 @@ import ( "fmt" ) -const _TemplateSchemeName = "PodTaskExecution" +const _TemplateSchemeName = "PodTaskExecutionFlyin" -var _TemplateSchemeIndex = [...]uint8{0, 3, 16} +var _TemplateSchemeIndex = [...]uint8{0, 3, 16, 21} func (i TemplateScheme) String() string { if i < 0 || i >= TemplateScheme(len(_TemplateSchemeIndex)-1) { @@ -18,11 +18,12 @@ func (i TemplateScheme) String() string { return _TemplateSchemeName[_TemplateSchemeIndex[i]:_TemplateSchemeIndex[i+1]] } -var _TemplateSchemeValues = []TemplateScheme{0, 1} +var _TemplateSchemeValues = []TemplateScheme{0, 1, 2} var _TemplateSchemeNameToValueMap = map[string]TemplateScheme{ - _TemplateSchemeName[0:3]: 0, - _TemplateSchemeName[3:16]: 1, + _TemplateSchemeName[0:3]: 0, + _TemplateSchemeName[3:16]: 1, + _TemplateSchemeName[16:21]: 2, } // TemplateSchemeString retrieves an enum value from the enum constants string name. diff --git a/flyteplugins/go/tasks/plugins/k8s/pod/plugin.go b/flyteplugins/go/tasks/plugins/k8s/pod/plugin.go index b266a6f5e8..eae0ac98b7 100644 --- a/flyteplugins/go/tasks/plugins/k8s/pod/plugin.go +++ b/flyteplugins/go/tasks/plugins/k8s/pod/plugin.go @@ -153,6 +153,11 @@ func (plugin) GetTaskPhaseWithLogs(ctx context.Context, pluginContext k8s.Plugin return pluginsCore.PhaseInfoUndefined, err } + taskTemplate, err := pluginContext.TaskReader().Read(ctx) + if err != nil { + return pluginsCore.PhaseInfoUndefined, err + } + pod := r.(*v1.Pod) transitionOccurredAt := flytek8s.GetLastTransitionOccurredAt(pod).Time @@ -168,7 +173,7 @@ func (plugin) GetTaskPhaseWithLogs(ctx context.Context, pluginContext k8s.Plugin taskExecID := pluginContext.TaskExecutionMetadata().GetTaskExecutionID() if pod.Status.Phase != v1.PodPending && pod.Status.Phase != v1.PodUnknown { - taskLogs, err := logs.GetLogsForContainerInPod(ctx, logPlugin, taskExecID, pod, 0, logSuffix, extraLogTemplateVarsByScheme) + taskLogs, err := logs.GetLogsForContainerInPod(ctx, logPlugin, taskExecID, pod, 0, logSuffix, extraLogTemplateVarsByScheme, taskTemplate) if err != nil { return pluginsCore.PhaseInfoUndefined, err } From 1e397e66a344bc85410f8141945c5869e619740c Mon Sep 17 00:00:00 2001 From: Dan Rammer Date: Wed, 20 Dec 2023 15:19:52 -0600 Subject: [PATCH 5/8] Correctly computing ArrayNode maximum attempts and system failures (#4627) * correctly computing the maximum number of attempts and system failures Signed-off-by: Daniel Rammer * added unit tests Signed-off-by: Daniel Rammer * fixed lint Signed-off-by: Daniel Rammer * removed debugging prints Signed-off-by: Daniel Rammer * and again Signed-off-by: Daniel Rammer --------- Signed-off-by: Daniel Rammer --- .../pkg/controller/nodes/array/handler.go | 18 ++- .../controller/nodes/array/handler_test.go | 120 ++++++++++++++++++ 2 files changed, 132 insertions(+), 6 deletions(-) diff --git a/flytepropeller/pkg/controller/nodes/array/handler.go b/flytepropeller/pkg/controller/nodes/array/handler.go index f1e2ef64fc..7dcdef4749 100644 --- a/flytepropeller/pkg/controller/nodes/array/handler.go +++ b/flytepropeller/pkg/controller/nodes/array/handler.go @@ -205,10 +205,16 @@ func (a *arrayNodeHandler) Handle(ctx context.Context, nCtx interfaces.NodeExecu } // initialize ArrayNode state - maxAttempts := int(config.GetConfig().NodeConfig.DefaultMaxAttempts) - subNodeSpec := *arrayNode.GetSubNodeSpec() - if subNodeSpec.GetRetryStrategy() != nil && subNodeSpec.GetRetryStrategy().MinAttempts != nil { - maxAttempts = *subNodeSpec.GetRetryStrategy().MinAttempts + maxSystemFailuresValue := int(config.GetConfig().NodeConfig.MaxNodeRetriesOnSystemFailures) + maxAttemptsValue := int(config.GetConfig().NodeConfig.DefaultMaxAttempts) + if nCtx.Node().GetRetryStrategy() != nil && nCtx.Node().GetRetryStrategy().MinAttempts != nil && *nCtx.Node().GetRetryStrategy().MinAttempts != 1 { + maxAttemptsValue = *nCtx.Node().GetRetryStrategy().MinAttempts + } + + if config.GetConfig().NodeConfig.IgnoreRetryCause { + maxSystemFailuresValue = maxAttemptsValue + } else { + maxAttemptsValue += maxSystemFailuresValue } for _, item := range []struct { @@ -219,8 +225,8 @@ func (a *arrayNodeHandler) Handle(ctx context.Context, nCtx interfaces.NodeExecu // defined as an `iota` so it is impossible to programmatically get largest value {arrayReference: &arrayNodeState.SubNodePhases, maxValue: int(v1alpha1.NodePhaseRecovered)}, {arrayReference: &arrayNodeState.SubNodeTaskPhases, maxValue: len(core.Phases) - 1}, - {arrayReference: &arrayNodeState.SubNodeRetryAttempts, maxValue: maxAttempts}, - {arrayReference: &arrayNodeState.SubNodeSystemFailures, maxValue: maxAttempts}, + {arrayReference: &arrayNodeState.SubNodeRetryAttempts, maxValue: maxAttemptsValue}, + {arrayReference: &arrayNodeState.SubNodeSystemFailures, maxValue: maxSystemFailuresValue}, } { *item.arrayReference, err = bitarray.NewCompactArray(uint(size), bitarray.Item(item.maxValue)) diff --git a/flytepropeller/pkg/controller/nodes/array/handler_test.go b/flytepropeller/pkg/controller/nodes/array/handler_test.go index b2e85c0979..fbb5ae875c 100644 --- a/flytepropeller/pkg/controller/nodes/array/handler_test.go +++ b/flytepropeller/pkg/controller/nodes/array/handler_test.go @@ -654,6 +654,126 @@ func TestHandleArrayNodePhaseExecuting(t *testing.T) { } } +func TestHandleArrayNodePhaseExecutingSubNodeFailures(t *testing.T) { + ctx := context.Background() + + inputValues := map[string][]int64{ + "foo": []int64{1}, + "bar": []int64{2}, + } + literalMap := convertMapToArrayLiterals(inputValues) + + tests := []struct { + name string + defaultMaxAttempts int32 + maxSystemFailures int64 + ignoreRetryCause bool + transition handler.Transition + expectedAttempts int + }{ + { + name: "UserFailure", + defaultMaxAttempts: 3, + maxSystemFailures: 10, + ignoreRetryCause: false, + transition: handler.DoTransition(handler.TransitionTypeEphemeral, + handler.PhaseInfoRetryableFailure(idlcore.ExecutionError_USER, "", "", &handler.ExecutionInfo{})), + expectedAttempts: 3, + }, + { + name: "SystemFailure", + defaultMaxAttempts: 3, + maxSystemFailures: 10, + ignoreRetryCause: false, + transition: handler.DoTransition(handler.TransitionTypeEphemeral, + handler.PhaseInfoRetryableFailure(idlcore.ExecutionError_SYSTEM, "", "", &handler.ExecutionInfo{})), + expectedAttempts: 11, + }, + { + name: "UserFailureIgnoreRetryCause", + defaultMaxAttempts: 3, + maxSystemFailures: 10, + ignoreRetryCause: true, + transition: handler.DoTransition(handler.TransitionTypeEphemeral, + handler.PhaseInfoRetryableFailure(idlcore.ExecutionError_USER, "", "", &handler.ExecutionInfo{})), + expectedAttempts: 3, + }, + { + name: "SystemFailureIgnoreRetryCause", + defaultMaxAttempts: 3, + maxSystemFailures: 10, + ignoreRetryCause: true, + transition: handler.DoTransition(handler.TransitionTypeEphemeral, + handler.PhaseInfoRetryableFailure(idlcore.ExecutionError_SYSTEM, "", "", &handler.ExecutionInfo{})), + expectedAttempts: 3, + }, + } + + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + config.GetConfig().NodeConfig.DefaultMaxAttempts = test.defaultMaxAttempts + config.GetConfig().NodeConfig.MaxNodeRetriesOnSystemFailures = test.maxSystemFailures + config.GetConfig().NodeConfig.IgnoreRetryCause = test.ignoreRetryCause + + // create NodeExecutionContext + scope := promutils.NewTestScope() + dataStore, err := storage.NewDataStore(&storage.Config{ + Type: storage.TypeMemory, + }, scope) + assert.NoError(t, err) + eventRecorder := newBufferedEventRecorder() + arrayNodeState := &handler.ArrayNodeState{ + Phase: v1alpha1.ArrayNodePhaseNone, + } + nCtx := createNodeExecutionContext(dataStore, eventRecorder, nil, literalMap, &arrayNodeSpec, arrayNodeState) + + // initialize ArrayNodeHandler + nodeHandler := &mocks.NodeHandler{} + nodeHandler.OnAbortMatch(mock.Anything, mock.Anything, mock.Anything).Return(nil) + nodeHandler.OnFinalizeMatch(mock.Anything, mock.Anything).Return(nil) + nodeHandler.OnFinalizeRequired().Return(false) + nodeHandler.OnHandleMatch(mock.Anything, mock.Anything).Return(test.transition, nil) + + arrayNodeHandler, err := createArrayNodeHandler(ctx, t, nodeHandler, dataStore, scope) + assert.NoError(t, err) + + // evaluate node to transition to Executing + _, err = arrayNodeHandler.Handle(ctx, nCtx) + assert.NoError(t, err) + assert.Equal(t, v1alpha1.ArrayNodePhaseExecuting, arrayNodeState.Phase) + + for i := 0; i < len(arrayNodeState.SubNodePhases.GetItems()); i++ { + arrayNodeState.SubNodePhases.SetItem(i, bitarray.Item(v1alpha1.NodePhaseRunning)) + } + + for i := 0; i < len(arrayNodeState.SubNodeTaskPhases.GetItems()); i++ { + arrayNodeState.SubNodeTaskPhases.SetItem(i, bitarray.Item(core.PhaseRunning)) + } + + // evaluate node until failure + attempts := 1 + for { + nCtx := createNodeExecutionContext(dataStore, eventRecorder, nil, literalMap, &arrayNodeSpec, arrayNodeState) + _, err = arrayNodeHandler.Handle(ctx, nCtx) + assert.NoError(t, err) + + if arrayNodeState.Phase == v1alpha1.ArrayNodePhaseFailing { + break + } + + // failing a task requires two calls to Handle, the first to return a + // RetryableFailure and the second to abort. therefore, we only increment the + // number of attempts once in this loop. + if arrayNodeState.SubNodePhases.GetItem(0) == bitarray.Item(v1alpha1.NodePhaseRetryableFailure) { + attempts++ + } + } + + assert.Equal(t, test.expectedAttempts, attempts) + }) + } +} + func TestHandleArrayNodePhaseSucceeding(t *testing.T) { ctx := context.Background() scope := promutils.NewTestScope() From 6a7e620949dc1d43dc52c0ec7719572656d1027f Mon Sep 17 00:00:00 2001 From: Future-Outlier Date: Thu, 21 Dec 2023 07:37:01 +0800 Subject: [PATCH 6/8] Agent Sync Plugin (#4107) Signed-off-by: Future Outlier Signed-off-by: Kevin Su Signed-off-by: Future-Outlier Co-authored-by: Future Outlier Co-authored-by: Kevin Su Co-authored-by: Kevin Su --- .../gen/pb-cpp/flyteidl/admin/agent.pb.cc | 306 ++++-- flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h | 202 +++- flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go | 186 ++-- .../pb-go/flyteidl/admin/agent.pb.validate.go | 34 +- .../pb-go/flyteidl/service/agent.swagger.json | 13 +- .../flyteidl/admin/AgentOuterClass.java | 920 ++++++++++++++++-- flyteidl/gen/pb-js/flyteidl.d.ts | 15 + flyteidl/gen/pb-js/flyteidl.js | 70 +- .../gen/pb_python/flyteidl/admin/agent_pb2.py | 48 +- .../pb_python/flyteidl/admin/agent_pb2.pyi | 12 +- flyteidl/gen/pb_rust/flyteidl.admin.rs | 21 +- flyteidl/protos/flyteidl/admin/agent.proto | 8 +- .../pluginmachinery/internal/webapi/core.go | 2 + .../pluginmachinery/webapi/mocks/plugin.go | 45 + .../webapi/mocks/sync_plugin.go | 88 -- .../plugins/webapi/agent/integration_test.go | 84 +- .../go/tasks/plugins/webapi/agent/plugin.go | 18 +- .../tasks/plugins/webapi/agent/plugin_test.go | 47 +- 18 files changed, 1753 insertions(+), 366 deletions(-) create mode 100644 flyteplugins/go/tasks/pluginmachinery/webapi/mocks/plugin.go delete mode 100644 flyteplugins/go/tasks/pluginmachinery/webapi/mocks/sync_plugin.go diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.cc b/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.cc index 84cb28a2fc..490636e25c 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.cc +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.cc @@ -20,7 +20,7 @@ extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::proto extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_TaskExecutionMetadata_AnnotationsEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_TaskExecutionMetadata_EnvironmentVariablesEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_TaskExecutionMetadata_LabelsEntry_DoNotUse_flyteidl_2fadmin_2fagent_2eproto; -extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_Resource_flyteidl_2fadmin_2fagent_2eproto; +extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<2> scc_info_Resource_flyteidl_2fadmin_2fagent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fadmin_2fagent_2eproto ::google::protobuf::internal::SCCInfo<4> scc_info_TaskExecutionMetadata_flyteidl_2fadmin_2fagent_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fexecution_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_TaskLog_flyteidl_2fcore_2fexecution_2eproto; extern PROTOBUF_INTERNAL_EXPORT_flyteidl_2fcore_2fidentifier_2eproto ::google::protobuf::internal::SCCInfo<2> scc_info_TaskExecutionIdentifier_flyteidl_2fcore_2fidentifier_2eproto; @@ -51,6 +51,8 @@ class CreateTaskRequestDefaultTypeInternal { class CreateTaskResponseDefaultTypeInternal { public: ::google::protobuf::internal::ExplicitlyConstructed _instance; + ::google::protobuf::internal::ArenaStringPtr resource_meta_; + const ::flyteidl::admin::Resource* resource_; } _CreateTaskResponse_default_instance_; class GetTaskRequestDefaultTypeInternal { public: @@ -179,8 +181,9 @@ static void InitDefaultsCreateTaskResponse_flyteidl_2fadmin_2fagent_2eproto() { ::flyteidl::admin::CreateTaskResponse::InitAsDefaultInstance(); } -::google::protobuf::internal::SCCInfo<0> scc_info_CreateTaskResponse_flyteidl_2fadmin_2fagent_2eproto = - {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 0, InitDefaultsCreateTaskResponse_flyteidl_2fadmin_2fagent_2eproto}, {}}; +::google::protobuf::internal::SCCInfo<1> scc_info_CreateTaskResponse_flyteidl_2fadmin_2fagent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsCreateTaskResponse_flyteidl_2fadmin_2fagent_2eproto}, { + &scc_info_Resource_flyteidl_2fadmin_2fagent_2eproto.base,}}; static void InitDefaultsGetTaskRequest_flyteidl_2fadmin_2fagent_2eproto() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -223,9 +226,10 @@ static void InitDefaultsResource_flyteidl_2fadmin_2fagent_2eproto() { ::flyteidl::admin::Resource::InitAsDefaultInstance(); } -::google::protobuf::internal::SCCInfo<1> scc_info_Resource_flyteidl_2fadmin_2fagent_2eproto = - {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsResource_flyteidl_2fadmin_2fagent_2eproto}, { - &scc_info_Literal_flyteidl_2fcore_2fliterals_2eproto.base,}}; +::google::protobuf::internal::SCCInfo<2> scc_info_Resource_flyteidl_2fadmin_2fagent_2eproto = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 2, InitDefaultsResource_flyteidl_2fadmin_2fagent_2eproto}, { + &scc_info_Literal_flyteidl_2fcore_2fliterals_2eproto.base, + &scc_info_TaskLog_flyteidl_2fcore_2fexecution_2eproto.base,}}; static void InitDefaultsDeleteTaskRequest_flyteidl_2fadmin_2fagent_2eproto() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -401,9 +405,11 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2fagent_2eproto::o ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::admin::CreateTaskResponse, _internal_metadata_), ~0u, // no _extensions_ - ~0u, // no _oneof_case_ + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::CreateTaskResponse, _oneof_case_[0]), ~0u, // no _weak_field_map_ - PROTOBUF_FIELD_OFFSET(::flyteidl::admin::CreateTaskResponse, resource_meta_), + offsetof(::flyteidl::admin::CreateTaskResponseDefaultTypeInternal, resource_meta_), + offsetof(::flyteidl::admin::CreateTaskResponseDefaultTypeInternal, resource_), + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::CreateTaskResponse, res_), ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::admin::GetTaskRequest, _internal_metadata_), ~0u, // no _extensions_ @@ -426,6 +432,7 @@ const ::google::protobuf::uint32 TableStruct_flyteidl_2fadmin_2fagent_2eproto::o PROTOBUF_FIELD_OFFSET(::flyteidl::admin::Resource, state_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::Resource, outputs_), PROTOBUF_FIELD_OFFSET(::flyteidl::admin::Resource, message_), + PROTOBUF_FIELD_OFFSET(::flyteidl::admin::Resource, log_links_), ~0u, // no _has_bits_ PROTOBUF_FIELD_OFFSET(::flyteidl::admin::DeleteTaskRequest, _internal_metadata_), ~0u, // no _extensions_ @@ -476,16 +483,16 @@ static const ::google::protobuf::internal::MigrationSchema schemas[] PROTOBUF_SE { 27, -1, sizeof(::flyteidl::admin::TaskExecutionMetadata)}, { 38, -1, sizeof(::flyteidl::admin::CreateTaskRequest)}, { 47, -1, sizeof(::flyteidl::admin::CreateTaskResponse)}, - { 53, -1, sizeof(::flyteidl::admin::GetTaskRequest)}, - { 60, -1, sizeof(::flyteidl::admin::GetTaskResponse)}, - { 67, -1, sizeof(::flyteidl::admin::Resource)}, - { 75, -1, sizeof(::flyteidl::admin::DeleteTaskRequest)}, - { 82, -1, sizeof(::flyteidl::admin::DeleteTaskResponse)}, - { 87, -1, sizeof(::flyteidl::admin::Agent)}, - { 94, -1, sizeof(::flyteidl::admin::GetAgentRequest)}, - { 100, -1, sizeof(::flyteidl::admin::GetAgentResponse)}, - { 106, -1, sizeof(::flyteidl::admin::ListAgentsRequest)}, - { 111, -1, sizeof(::flyteidl::admin::ListAgentsResponse)}, + { 55, -1, sizeof(::flyteidl::admin::GetTaskRequest)}, + { 62, -1, sizeof(::flyteidl::admin::GetTaskResponse)}, + { 69, -1, sizeof(::flyteidl::admin::Resource)}, + { 78, -1, sizeof(::flyteidl::admin::DeleteTaskRequest)}, + { 85, -1, sizeof(::flyteidl::admin::DeleteTaskResponse)}, + { 90, -1, sizeof(::flyteidl::admin::Agent)}, + { 97, -1, sizeof(::flyteidl::admin::GetAgentRequest)}, + { 103, -1, sizeof(::flyteidl::admin::GetAgentResponse)}, + { 109, -1, sizeof(::flyteidl::admin::ListAgentsRequest)}, + { 114, -1, sizeof(::flyteidl::admin::ListAgentsResponse)}, }; static ::google::protobuf::Message const * const file_default_instances[] = { @@ -537,32 +544,35 @@ const char descriptor_table_protodef_flyteidl_2fadmin_2fagent_2eproto[] = "p\022-\n\010template\030\002 \001(\0132\033.flyteidl.core.Task" "Template\022\025\n\routput_prefix\030\003 \001(\t\022F\n\027task_" "execution_metadata\030\004 \001(\0132%.flyteidl.admi" - "n.TaskExecutionMetadata\"+\n\022CreateTaskRes" - "ponse\022\025\n\rresource_meta\030\001 \001(\014\":\n\016GetTaskR" - "equest\022\021\n\ttask_type\030\001 \001(\t\022\025\n\rresource_me" - "ta\030\002 \001(\014\"h\n\017GetTaskResponse\022*\n\010resource\030" - "\001 \001(\0132\030.flyteidl.admin.Resource\022)\n\tlog_l" - "inks\030\002 \003(\0132\026.flyteidl.core.TaskLog\"m\n\010Re" - "source\022$\n\005state\030\001 \001(\0162\025.flyteidl.admin.S" - "tate\022*\n\007outputs\030\002 \001(\0132\031.flyteidl.core.Li" - "teralMap\022\017\n\007message\030\003 \001(\t\"=\n\021DeleteTaskR" - "equest\022\021\n\ttask_type\030\001 \001(\t\022\025\n\rresource_me" - "ta\030\002 \001(\014\"\024\n\022DeleteTaskResponse\"3\n\005Agent\022" - "\014\n\004name\030\001 \001(\t\022\034\n\024supported_task_types\030\002 " - "\003(\t\"\037\n\017GetAgentRequest\022\014\n\004name\030\001 \001(\t\"8\n\020" - "GetAgentResponse\022$\n\005agent\030\001 \001(\0132\025.flytei" - "dl.admin.Agent\"\023\n\021ListAgentsRequest\";\n\022L" - "istAgentsResponse\022%\n\006agents\030\001 \003(\0132\025.flyt" - "eidl.admin.Agent*^\n\005State\022\025\n\021RETRYABLE_F" - "AILURE\020\000\022\025\n\021PERMANENT_FAILURE\020\001\022\013\n\007PENDI" - "NG\020\002\022\013\n\007RUNNING\020\003\022\r\n\tSUCCEEDED\020\004B=Z;gith" - "ub.com/flyteorg/flyte/flyteidl/gen/pb-go" - "/flyteidl/adminb\006proto3" + "n.TaskExecutionMetadata\"b\n\022CreateTaskRes" + "ponse\022\027\n\rresource_meta\030\001 \001(\014H\000\022,\n\010resour" + "ce\030\002 \001(\0132\030.flyteidl.admin.ResourceH\000B\005\n\003" + "res\":\n\016GetTaskRequest\022\021\n\ttask_type\030\001 \001(\t" + "\022\025\n\rresource_meta\030\002 \001(\014\"h\n\017GetTaskRespon" + "se\022*\n\010resource\030\001 \001(\0132\030.flyteidl.admin.Re" + "source\022)\n\tlog_links\030\002 \003(\0132\026.flyteidl.cor" + "e.TaskLog\"\230\001\n\010Resource\022$\n\005state\030\001 \001(\0162\025." + "flyteidl.admin.State\022*\n\007outputs\030\002 \001(\0132\031." + "flyteidl.core.LiteralMap\022\017\n\007message\030\003 \001(" + "\t\022)\n\tlog_links\030\004 \003(\0132\026.flyteidl.core.Tas" + "kLog\"=\n\021DeleteTaskRequest\022\021\n\ttask_type\030\001" + " \001(\t\022\025\n\rresource_meta\030\002 \001(\014\"\024\n\022DeleteTas" + "kResponse\"3\n\005Agent\022\014\n\004name\030\001 \001(\t\022\034\n\024supp" + "orted_task_types\030\002 \003(\t\"\037\n\017GetAgentReques" + "t\022\014\n\004name\030\001 \001(\t\"8\n\020GetAgentResponse\022$\n\005a" + "gent\030\001 \001(\0132\025.flyteidl.admin.Agent\"\023\n\021Lis" + "tAgentsRequest\";\n\022ListAgentsResponse\022%\n\006" + "agents\030\001 \003(\0132\025.flyteidl.admin.Agent*^\n\005S" + "tate\022\025\n\021RETRYABLE_FAILURE\020\000\022\025\n\021PERMANENT" + "_FAILURE\020\001\022\013\n\007PENDING\020\002\022\013\n\007RUNNING\020\003\022\r\n\t" + "SUCCEEDED\020\004B=Z;github.com/flyteorg/flyte" + "/flyteidl/gen/pb-go/flyteidl/adminb\006prot" + "o3" ; ::google::protobuf::internal::DescriptorTable descriptor_table_flyteidl_2fadmin_2fagent_2eproto = { false, InitDefaults_flyteidl_2fadmin_2fagent_2eproto, descriptor_table_protodef_flyteidl_2fadmin_2fagent_2eproto, - "flyteidl/admin/agent.proto", &assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto, 1743, + "flyteidl/admin/agent.proto", &assign_descriptors_table_flyteidl_2fadmin_2fagent_2eproto, 1842, }; void AddDescriptors_flyteidl_2fadmin_2fagent_2eproto() { @@ -2164,13 +2174,37 @@ ::google::protobuf::Metadata CreateTaskRequest::GetMetadata() const { // =================================================================== void CreateTaskResponse::InitAsDefaultInstance() { + ::flyteidl::admin::_CreateTaskResponse_default_instance_.resource_meta_.UnsafeSetDefault( + &::google::protobuf::internal::GetEmptyStringAlreadyInited()); + ::flyteidl::admin::_CreateTaskResponse_default_instance_.resource_ = const_cast< ::flyteidl::admin::Resource*>( + ::flyteidl::admin::Resource::internal_default_instance()); } class CreateTaskResponse::HasBitSetters { public: + static const ::flyteidl::admin::Resource& resource(const CreateTaskResponse* msg); }; +const ::flyteidl::admin::Resource& +CreateTaskResponse::HasBitSetters::resource(const CreateTaskResponse* msg) { + return *msg->res_.resource_; +} +void CreateTaskResponse::set_allocated_resource(::flyteidl::admin::Resource* resource) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + clear_res(); + if (resource) { + ::google::protobuf::Arena* submessage_arena = nullptr; + if (message_arena != submessage_arena) { + resource = ::google::protobuf::internal::GetOwnedMessage( + message_arena, resource, submessage_arena); + } + set_has_resource(); + res_.resource_ = resource; + } + // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.CreateTaskResponse.resource) +} #if !defined(_MSC_VER) || _MSC_VER >= 1900 const int CreateTaskResponse::kResourceMetaFieldNumber; +const int CreateTaskResponse::kResourceFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 CreateTaskResponse::CreateTaskResponse() @@ -2182,9 +2216,19 @@ CreateTaskResponse::CreateTaskResponse(const CreateTaskResponse& from) : ::google::protobuf::Message(), _internal_metadata_(nullptr) { _internal_metadata_.MergeFrom(from._internal_metadata_); - resource_meta_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); - if (from.resource_meta().size() > 0) { - resource_meta_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.resource_meta_); + clear_has_res(); + switch (from.res_case()) { + case kResourceMeta: { + set_resource_meta(from.resource_meta()); + break; + } + case kResource: { + mutable_resource()->::flyteidl::admin::Resource::MergeFrom(from.resource()); + break; + } + case RES_NOT_SET: { + break; + } } // @@protoc_insertion_point(copy_constructor:flyteidl.admin.CreateTaskResponse) } @@ -2192,7 +2236,7 @@ CreateTaskResponse::CreateTaskResponse(const CreateTaskResponse& from) void CreateTaskResponse::SharedCtor() { ::google::protobuf::internal::InitSCC( &scc_info_CreateTaskResponse_flyteidl_2fadmin_2fagent_2eproto.base); - resource_meta_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + clear_has_res(); } CreateTaskResponse::~CreateTaskResponse() { @@ -2201,7 +2245,9 @@ CreateTaskResponse::~CreateTaskResponse() { } void CreateTaskResponse::SharedDtor() { - resource_meta_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (has_res()) { + clear_res(); + } } void CreateTaskResponse::SetCachedSize(int size) const { @@ -2213,13 +2259,32 @@ const CreateTaskResponse& CreateTaskResponse::default_instance() { } +void CreateTaskResponse::clear_res() { +// @@protoc_insertion_point(one_of_clear_start:flyteidl.admin.CreateTaskResponse) + switch (res_case()) { + case kResourceMeta: { + res_.resource_meta_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + break; + } + case kResource: { + delete res_.resource_; + break; + } + case RES_NOT_SET: { + break; + } + } + _oneof_case_[0] = RES_NOT_SET; +} + + void CreateTaskResponse::Clear() { // @@protoc_insertion_point(message_clear_start:flyteidl.admin.CreateTaskResponse) ::google::protobuf::uint32 cached_has_bits = 0; // Prevent compiler warnings about cached_has_bits being unused (void) cached_has_bits; - resource_meta_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + clear_res(); _internal_metadata_.Clear(); } @@ -2251,6 +2316,19 @@ const char* CreateTaskResponse::_InternalParse(const char* begin, const char* en ptr += size; break; } + // .flyteidl.admin.Resource resource = 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::admin::Resource::_InternalParse; + object = msg->mutable_resource(); + 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) { @@ -2296,6 +2374,17 @@ bool CreateTaskResponse::MergePartialFromCodedStream( break; } + // .flyteidl.admin.Resource resource = 2; + case 2: { + if (static_cast< ::google::protobuf::uint8>(tag) == (18 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_resource())); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -2324,11 +2413,17 @@ void CreateTaskResponse::SerializeWithCachedSizes( (void) cached_has_bits; // bytes resource_meta = 1; - if (this->resource_meta().size() > 0) { + if (has_resource_meta()) { ::google::protobuf::internal::WireFormatLite::WriteBytesMaybeAliased( 1, this->resource_meta(), output); } + // .flyteidl.admin.Resource resource = 2; + if (has_resource()) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 2, HasBitSetters::resource(this), output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -2343,12 +2438,19 @@ ::google::protobuf::uint8* CreateTaskResponse::InternalSerializeWithCachedSizesT (void) cached_has_bits; // bytes resource_meta = 1; - if (this->resource_meta().size() > 0) { + if (has_resource_meta()) { target = ::google::protobuf::internal::WireFormatLite::WriteBytesToArray( 1, this->resource_meta(), target); } + // .flyteidl.admin.Resource resource = 2; + if (has_resource()) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 2, HasBitSetters::resource(this), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -2370,13 +2472,25 @@ size_t CreateTaskResponse::ByteSizeLong() const { // Prevent compiler warnings about cached_has_bits being unused (void) cached_has_bits; - // bytes resource_meta = 1; - if (this->resource_meta().size() > 0) { - total_size += 1 + - ::google::protobuf::internal::WireFormatLite::BytesSize( - this->resource_meta()); + switch (res_case()) { + // bytes resource_meta = 1; + case kResourceMeta: { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::BytesSize( + this->resource_meta()); + break; + } + // .flyteidl.admin.Resource resource = 2; + case kResource: { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *res_.resource_); + break; + } + case RES_NOT_SET: { + break; + } } - int cached_size = ::google::protobuf::internal::ToCachedSize(total_size); SetCachedSize(cached_size); return total_size; @@ -2404,9 +2518,18 @@ void CreateTaskResponse::MergeFrom(const CreateTaskResponse& from) { ::google::protobuf::uint32 cached_has_bits = 0; (void) cached_has_bits; - if (from.resource_meta().size() > 0) { - - resource_meta_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.resource_meta_); + switch (from.res_case()) { + case kResourceMeta: { + set_resource_meta(from.resource_meta()); + break; + } + case kResource: { + mutable_resource()->::flyteidl::admin::Resource::MergeFrom(from.resource()); + break; + } + case RES_NOT_SET: { + break; + } } } @@ -2435,8 +2558,8 @@ void CreateTaskResponse::Swap(CreateTaskResponse* other) { void CreateTaskResponse::InternalSwap(CreateTaskResponse* other) { using std::swap; _internal_metadata_.Swap(&other->_internal_metadata_); - resource_meta_.Swap(&other->resource_meta_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), - GetArenaNoVirtual()); + swap(res_, other->res_); + swap(_oneof_case_[0], other->_oneof_case_[0]); } ::google::protobuf::Metadata CreateTaskResponse::GetMetadata() const { @@ -3173,10 +3296,14 @@ void Resource::clear_outputs() { } outputs_ = nullptr; } +void Resource::clear_log_links() { + log_links_.Clear(); +} #if !defined(_MSC_VER) || _MSC_VER >= 1900 const int Resource::kStateFieldNumber; const int Resource::kOutputsFieldNumber; const int Resource::kMessageFieldNumber; +const int Resource::kLogLinksFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 Resource::Resource() @@ -3186,7 +3313,8 @@ Resource::Resource() } Resource::Resource(const Resource& from) : ::google::protobuf::Message(), - _internal_metadata_(nullptr) { + _internal_metadata_(nullptr), + log_links_(from.log_links_) { _internal_metadata_.MergeFrom(from._internal_metadata_); message_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); if (from.message().size() > 0) { @@ -3235,6 +3363,7 @@ void Resource::Clear() { // Prevent compiler warnings about cached_has_bits being unused (void) cached_has_bits; + log_links_.Clear(); message_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); if (GetArenaNoVirtual() == nullptr && outputs_ != nullptr) { delete outputs_; @@ -3294,6 +3423,22 @@ const char* Resource::_InternalParse(const char* begin, const char* end, void* o ptr += size; break; } + // repeated .flyteidl.core.TaskLog log_links = 4; + case 4: { + if (static_cast<::google::protobuf::uint8>(tag) != 34) goto handle_unusual; + do { + ptr = ::google::protobuf::io::ReadSize(ptr, &size); + GOOGLE_PROTOBUF_PARSER_ASSERT(ptr); + parser_till_end = ::flyteidl::core::TaskLog::_InternalParse; + object = msg->add_log_links(); + if (size > end - ptr) goto len_delim_till_end; + ptr += size; + GOOGLE_PROTOBUF_PARSER_ASSERT(ctx->ParseExactRange( + {parser_till_end, object}, ptr - size, ptr)); + if (ptr >= end) break; + } while ((::google::protobuf::io::UnalignedLoad<::google::protobuf::uint64>(ptr) & 255) == 34 && (ptr += 1)); + break; + } default: { handle_unusual: if ((tag & 7) == 4 || tag == 0) { @@ -3368,6 +3513,17 @@ bool Resource::MergePartialFromCodedStream( break; } + // repeated .flyteidl.core.TaskLog log_links = 4; + case 4: { + if (static_cast< ::google::protobuf::uint8>(tag) == (34 & 0xFF)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, add_log_links())); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -3417,6 +3573,15 @@ void Resource::SerializeWithCachedSizes( 3, this->message(), output); } + // repeated .flyteidl.core.TaskLog log_links = 4; + for (unsigned int i = 0, + n = static_cast(this->log_links_size()); i < n; i++) { + ::google::protobuf::internal::WireFormatLite::WriteMessageMaybeToArray( + 4, + this->log_links(static_cast(i)), + output); + } + if (_internal_metadata_.have_unknown_fields()) { ::google::protobuf::internal::WireFormat::SerializeUnknownFields( _internal_metadata_.unknown_fields(), output); @@ -3454,6 +3619,14 @@ ::google::protobuf::uint8* Resource::InternalSerializeWithCachedSizesToArray( 3, this->message(), target); } + // repeated .flyteidl.core.TaskLog log_links = 4; + for (unsigned int i = 0, + n = static_cast(this->log_links_size()); i < n; i++) { + target = ::google::protobuf::internal::WireFormatLite:: + InternalWriteMessageToArray( + 4, this->log_links(static_cast(i)), target); + } + if (_internal_metadata_.have_unknown_fields()) { target = ::google::protobuf::internal::WireFormat::SerializeUnknownFieldsToArray( _internal_metadata_.unknown_fields(), target); @@ -3475,6 +3648,17 @@ size_t Resource::ByteSizeLong() const { // Prevent compiler warnings about cached_has_bits being unused (void) cached_has_bits; + // repeated .flyteidl.core.TaskLog log_links = 4; + { + unsigned int count = static_cast(this->log_links_size()); + total_size += 1UL * count; + for (unsigned int i = 0; i < count; i++) { + total_size += + ::google::protobuf::internal::WireFormatLite::MessageSize( + this->log_links(static_cast(i))); + } + } + // string message = 3; if (this->message().size() > 0) { total_size += 1 + @@ -3522,6 +3706,7 @@ void Resource::MergeFrom(const Resource& from) { ::google::protobuf::uint32 cached_has_bits = 0; (void) cached_has_bits; + log_links_.MergeFrom(from.log_links_); if (from.message().size() > 0) { message_.AssignWithDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), from.message_); @@ -3559,6 +3744,7 @@ void Resource::Swap(Resource* other) { void Resource::InternalSwap(Resource* other) { using std::swap; _internal_metadata_.Swap(&other->_internal_metadata_); + CastToBase(&log_links_)->InternalSwap(CastToBase(&other->log_links_)); message_.Swap(&other->message_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), GetArenaNoVirtual()); swap(outputs_, other->outputs_); diff --git a/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h b/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h index 7360e91d06..86aeccc4b2 100644 --- a/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h +++ b/flyteidl/gen/pb-cpp/flyteidl/admin/agent.pb.h @@ -603,6 +603,12 @@ class CreateTaskResponse final : } static const CreateTaskResponse& default_instance(); + enum ResCase { + kResourceMeta = 1, + kResource = 2, + RES_NOT_SET = 0, + }; + static void InitAsDefaultInstance(); // FOR INTERNAL USE ONLY static inline const CreateTaskResponse* internal_default_instance() { return reinterpret_cast( @@ -667,6 +673,9 @@ class CreateTaskResponse final : // accessors ------------------------------------------------------- // bytes resource_meta = 1; + private: + bool has_resource_meta() const; + public: void clear_resource_meta(); static const int kResourceMetaFieldNumber = 1; const ::std::string& resource_meta() const; @@ -680,13 +689,35 @@ class CreateTaskResponse final : ::std::string* release_resource_meta(); void set_allocated_resource_meta(::std::string* resource_meta); + // .flyteidl.admin.Resource resource = 2; + bool has_resource() const; + void clear_resource(); + static const int kResourceFieldNumber = 2; + const ::flyteidl::admin::Resource& resource() const; + ::flyteidl::admin::Resource* release_resource(); + ::flyteidl::admin::Resource* mutable_resource(); + void set_allocated_resource(::flyteidl::admin::Resource* resource); + + void clear_res(); + ResCase res_case() const; // @@protoc_insertion_point(class_scope:flyteidl.admin.CreateTaskResponse) private: class HasBitSetters; + void set_has_resource_meta(); + void set_has_resource(); + + inline bool has_res() const; + inline void clear_has_res(); ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; - ::google::protobuf::internal::ArenaStringPtr resource_meta_; + union ResUnion { + ResUnion() {} + ::google::protobuf::internal::ArenaStringPtr resource_meta_; + ::flyteidl::admin::Resource* resource_; + } res_; mutable ::google::protobuf::internal::CachedSize _cached_size_; + ::google::protobuf::uint32 _oneof_case_[1]; + friend struct ::TableStruct_flyteidl_2fadmin_2fagent_2eproto; }; // ------------------------------------------------------------------- @@ -1049,6 +1080,18 @@ class Resource final : // accessors ------------------------------------------------------- + // repeated .flyteidl.core.TaskLog log_links = 4; + int log_links_size() const; + void clear_log_links(); + static const int kLogLinksFieldNumber = 4; + ::flyteidl::core::TaskLog* mutable_log_links(int index); + ::google::protobuf::RepeatedPtrField< ::flyteidl::core::TaskLog >* + mutable_log_links(); + const ::flyteidl::core::TaskLog& log_links(int index) const; + ::flyteidl::core::TaskLog* add_log_links(); + const ::google::protobuf::RepeatedPtrField< ::flyteidl::core::TaskLog >& + log_links() const; + // string message = 3; void clear_message(); static const int kMessageFieldNumber = 3; @@ -1083,6 +1126,7 @@ class Resource final : class HasBitSetters; ::google::protobuf::internal::InternalMetadataWithArena _internal_metadata_; + ::google::protobuf::RepeatedPtrField< ::flyteidl::core::TaskLog > log_links_; ::google::protobuf::internal::ArenaStringPtr message_; ::flyteidl::core::LiteralMap* outputs_; int state_; @@ -2355,58 +2399,147 @@ inline void CreateTaskRequest::set_allocated_task_execution_metadata(::flyteidl: // CreateTaskResponse // bytes resource_meta = 1; +inline bool CreateTaskResponse::has_resource_meta() const { + return res_case() == kResourceMeta; +} +inline void CreateTaskResponse::set_has_resource_meta() { + _oneof_case_[0] = kResourceMeta; +} inline void CreateTaskResponse::clear_resource_meta() { - resource_meta_.ClearToEmptyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (has_resource_meta()) { + res_.resource_meta_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + clear_has_res(); + } } inline const ::std::string& CreateTaskResponse::resource_meta() const { // @@protoc_insertion_point(field_get:flyteidl.admin.CreateTaskResponse.resource_meta) - return resource_meta_.GetNoArena(); + if (has_resource_meta()) { + return res_.resource_meta_.GetNoArena(); + } + return *&::google::protobuf::internal::GetEmptyStringAlreadyInited(); } inline void CreateTaskResponse::set_resource_meta(const ::std::string& value) { - - resource_meta_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); + // @@protoc_insertion_point(field_set:flyteidl.admin.CreateTaskResponse.resource_meta) + if (!has_resource_meta()) { + clear_res(); + set_has_resource_meta(); + res_.resource_meta_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + } + res_.resource_meta_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), value); // @@protoc_insertion_point(field_set:flyteidl.admin.CreateTaskResponse.resource_meta) } #if LANG_CXX11 inline void CreateTaskResponse::set_resource_meta(::std::string&& value) { - - resource_meta_.SetNoArena( - &::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); + // @@protoc_insertion_point(field_set:flyteidl.admin.CreateTaskResponse.resource_meta) + if (!has_resource_meta()) { + clear_res(); + set_has_resource_meta(); + res_.resource_meta_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + } + res_.resource_meta_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::move(value)); // @@protoc_insertion_point(field_set_rvalue:flyteidl.admin.CreateTaskResponse.resource_meta) } #endif inline void CreateTaskResponse::set_resource_meta(const char* value) { GOOGLE_DCHECK(value != nullptr); - - resource_meta_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string(value)); + if (!has_resource_meta()) { + clear_res(); + set_has_resource_meta(); + res_.resource_meta_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + } + res_.resource_meta_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), + ::std::string(value)); // @@protoc_insertion_point(field_set_char:flyteidl.admin.CreateTaskResponse.resource_meta) } inline void CreateTaskResponse::set_resource_meta(const void* value, size_t size) { - - resource_meta_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), - ::std::string(reinterpret_cast(value), size)); + if (!has_resource_meta()) { + clear_res(); + set_has_resource_meta(); + res_.resource_meta_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + } + res_.resource_meta_.SetNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), ::std::string( + reinterpret_cast(value), size)); // @@protoc_insertion_point(field_set_pointer:flyteidl.admin.CreateTaskResponse.resource_meta) } inline ::std::string* CreateTaskResponse::mutable_resource_meta() { - + if (!has_resource_meta()) { + clear_res(); + set_has_resource_meta(); + res_.resource_meta_.UnsafeSetDefault(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + } // @@protoc_insertion_point(field_mutable:flyteidl.admin.CreateTaskResponse.resource_meta) - return resource_meta_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + return res_.resource_meta_.MutableNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); } inline ::std::string* CreateTaskResponse::release_resource_meta() { // @@protoc_insertion_point(field_release:flyteidl.admin.CreateTaskResponse.resource_meta) - - return resource_meta_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + if (has_resource_meta()) { + clear_has_res(); + return res_.resource_meta_.ReleaseNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); + } else { + return nullptr; + } } inline void CreateTaskResponse::set_allocated_resource_meta(::std::string* resource_meta) { + if (has_res()) { + clear_res(); + } if (resource_meta != nullptr) { - - } else { - + set_has_resource_meta(); + res_.resource_meta_.UnsafeSetDefault(resource_meta); } - resource_meta_.SetAllocatedNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited(), resource_meta); // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.CreateTaskResponse.resource_meta) } +// .flyteidl.admin.Resource resource = 2; +inline bool CreateTaskResponse::has_resource() const { + return res_case() == kResource; +} +inline void CreateTaskResponse::set_has_resource() { + _oneof_case_[0] = kResource; +} +inline void CreateTaskResponse::clear_resource() { + if (has_resource()) { + delete res_.resource_; + clear_has_res(); + } +} +inline ::flyteidl::admin::Resource* CreateTaskResponse::release_resource() { + // @@protoc_insertion_point(field_release:flyteidl.admin.CreateTaskResponse.resource) + if (has_resource()) { + clear_has_res(); + ::flyteidl::admin::Resource* temp = res_.resource_; + res_.resource_ = nullptr; + return temp; + } else { + return nullptr; + } +} +inline const ::flyteidl::admin::Resource& CreateTaskResponse::resource() const { + // @@protoc_insertion_point(field_get:flyteidl.admin.CreateTaskResponse.resource) + return has_resource() + ? *res_.resource_ + : *reinterpret_cast< ::flyteidl::admin::Resource*>(&::flyteidl::admin::_Resource_default_instance_); +} +inline ::flyteidl::admin::Resource* CreateTaskResponse::mutable_resource() { + if (!has_resource()) { + clear_res(); + set_has_resource(); + res_.resource_ = CreateMaybeMessage< ::flyteidl::admin::Resource >( + GetArenaNoVirtual()); + } + // @@protoc_insertion_point(field_mutable:flyteidl.admin.CreateTaskResponse.resource) + return res_.resource_; +} + +inline bool CreateTaskResponse::has_res() const { + return res_case() != RES_NOT_SET; +} +inline void CreateTaskResponse::clear_has_res() { + _oneof_case_[0] = RES_NOT_SET; +} +inline CreateTaskResponse::ResCase CreateTaskResponse::res_case() const { + return CreateTaskResponse::ResCase(_oneof_case_[0]); +} // ------------------------------------------------------------------- // GetTaskRequest @@ -2715,6 +2848,33 @@ inline void Resource::set_allocated_message(::std::string* message) { // @@protoc_insertion_point(field_set_allocated:flyteidl.admin.Resource.message) } +// repeated .flyteidl.core.TaskLog log_links = 4; +inline int Resource::log_links_size() const { + return log_links_.size(); +} +inline ::flyteidl::core::TaskLog* Resource::mutable_log_links(int index) { + // @@protoc_insertion_point(field_mutable:flyteidl.admin.Resource.log_links) + return log_links_.Mutable(index); +} +inline ::google::protobuf::RepeatedPtrField< ::flyteidl::core::TaskLog >* +Resource::mutable_log_links() { + // @@protoc_insertion_point(field_mutable_list:flyteidl.admin.Resource.log_links) + return &log_links_; +} +inline const ::flyteidl::core::TaskLog& Resource::log_links(int index) const { + // @@protoc_insertion_point(field_get:flyteidl.admin.Resource.log_links) + return log_links_.Get(index); +} +inline ::flyteidl::core::TaskLog* Resource::add_log_links() { + // @@protoc_insertion_point(field_add:flyteidl.admin.Resource.log_links) + return log_links_.Add(); +} +inline const ::google::protobuf::RepeatedPtrField< ::flyteidl::core::TaskLog >& +Resource::log_links() const { + // @@protoc_insertion_point(field_list:flyteidl.admin.Resource.log_links) + return log_links_; +} + // ------------------------------------------------------------------- // DeleteTaskRequest diff --git a/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go b/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go index aeb5a70ed1..2e255f5c88 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.go @@ -215,10 +215,15 @@ func (m *CreateTaskRequest) GetTaskExecutionMetadata() *TaskExecutionMetadata { // Represents a create response structure. type CreateTaskResponse struct { // Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata). - ResourceMeta []byte `protobuf:"bytes,1,opt,name=resource_meta,json=resourceMeta,proto3" json:"resource_meta,omitempty"` - XXX_NoUnkeyedLiteral struct{} `json:"-"` - XXX_unrecognized []byte `json:"-"` - XXX_sizecache int32 `json:"-"` + // Resource is for synchronous task execution. + // + // Types that are valid to be assigned to Res: + // *CreateTaskResponse_ResourceMeta + // *CreateTaskResponse_Resource + Res isCreateTaskResponse_Res `protobuf_oneof:"res"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } func (m *CreateTaskResponse) Reset() { *m = CreateTaskResponse{} } @@ -246,13 +251,51 @@ func (m *CreateTaskResponse) XXX_DiscardUnknown() { var xxx_messageInfo_CreateTaskResponse proto.InternalMessageInfo -func (m *CreateTaskResponse) GetResourceMeta() []byte { +type isCreateTaskResponse_Res interface { + isCreateTaskResponse_Res() +} + +type CreateTaskResponse_ResourceMeta struct { + ResourceMeta []byte `protobuf:"bytes,1,opt,name=resource_meta,json=resourceMeta,proto3,oneof"` +} + +type CreateTaskResponse_Resource struct { + Resource *Resource `protobuf:"bytes,2,opt,name=resource,proto3,oneof"` +} + +func (*CreateTaskResponse_ResourceMeta) isCreateTaskResponse_Res() {} + +func (*CreateTaskResponse_Resource) isCreateTaskResponse_Res() {} + +func (m *CreateTaskResponse) GetRes() isCreateTaskResponse_Res { if m != nil { - return m.ResourceMeta + return m.Res } return nil } +func (m *CreateTaskResponse) GetResourceMeta() []byte { + if x, ok := m.GetRes().(*CreateTaskResponse_ResourceMeta); ok { + return x.ResourceMeta + } + return nil +} + +func (m *CreateTaskResponse) GetResource() *Resource { + if x, ok := m.GetRes().(*CreateTaskResponse_Resource); ok { + return x.Resource + } + return nil +} + +// XXX_OneofWrappers is for the internal use of the proto package. +func (*CreateTaskResponse) XXX_OneofWrappers() []interface{} { + return []interface{}{ + (*CreateTaskResponse_ResourceMeta)(nil), + (*CreateTaskResponse_Resource)(nil), + } +} + // A message used to fetch a job resource from flyte agent server. type GetTaskRequest struct { // A predefined yet extensible Task type identifier. @@ -360,10 +403,12 @@ type Resource struct { // +optional Outputs *core.LiteralMap `protobuf:"bytes,2,opt,name=outputs,proto3" json:"outputs,omitempty"` // A descriptive message for the current state. e.g. waiting for cluster. - Message string `protobuf:"bytes,3,opt,name=message,proto3" json:"message,omitempty"` - XXX_NoUnkeyedLiteral struct{} `json:"-"` - XXX_unrecognized []byte `json:"-"` - XXX_sizecache int32 `json:"-"` + Message string `protobuf:"bytes,3,opt,name=message,proto3" json:"message,omitempty"` + // log information for the task execution. + LogLinks []*core.TaskLog `protobuf:"bytes,4,rep,name=log_links,json=logLinks,proto3" json:"log_links,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } func (m *Resource) Reset() { *m = Resource{} } @@ -412,6 +457,13 @@ func (m *Resource) GetMessage() string { return "" } +func (m *Resource) GetLogLinks() []*core.TaskLog { + if m != nil { + return m.LogLinks + } + return nil +} + // A message used to delete a task. type DeleteTaskRequest struct { // A predefined yet extensible Task type identifier. @@ -720,60 +772,62 @@ func init() { func init() { proto.RegisterFile("flyteidl/admin/agent.proto", fileDescriptor_c434e52bb0028071) } var fileDescriptor_c434e52bb0028071 = []byte{ - // 869 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x56, 0xf1, 0x6f, 0xdb, 0x44, - 0x14, 0x26, 0x49, 0xd3, 0x26, 0x2f, 0x5d, 0x97, 0xdc, 0x1a, 0x70, 0xb3, 0x81, 0x2a, 0xa3, 0xa1, - 0x8a, 0x69, 0x0e, 0x6b, 0x11, 0x74, 0x20, 0x98, 0xb2, 0xd6, 0x54, 0x95, 0xd2, 0xa8, 0xba, 0xa6, - 0x08, 0x90, 0xc0, 0xba, 0x38, 0xaf, 0xc6, 0x8a, 0x63, 0x1b, 0xdf, 0xb9, 0x5a, 0x24, 0x7e, 0x43, - 0xe2, 0x6f, 0xe0, 0xcf, 0x45, 0xbe, 0x3b, 0xbb, 0x49, 0xf0, 0x50, 0xa7, 0xfd, 0x66, 0xbf, 0xef, - 0xbb, 0xef, 0x7d, 0x7e, 0xdf, 0x5d, 0x2e, 0xd0, 0xbb, 0x09, 0x16, 0x02, 0xfd, 0x69, 0xd0, 0x67, - 0xd3, 0xb9, 0x1f, 0xf6, 0x99, 0x87, 0xa1, 0xb0, 0xe2, 0x24, 0x12, 0x11, 0xd9, 0xc9, 0x31, 0x4b, - 0x62, 0xbd, 0x27, 0x05, 0xd7, 0x8d, 0x12, 0xec, 0x07, 0xbe, 0xc0, 0x84, 0x05, 0x5c, 0xb1, 0x7b, - 0x7b, 0xab, 0xa8, 0x60, 0x7c, 0x96, 0x43, 0x1f, 0xaf, 0x42, 0x7e, 0x28, 0x30, 0xb9, 0x61, 0x2e, - 0x6a, 0xf8, 0x93, 0x35, 0x78, 0x8a, 0xa1, 0xf0, 0x6f, 0x7c, 0x4c, 0xca, 0x97, 0xe3, 0x1b, 0x74, - 0x53, 0xe1, 0x47, 0xa1, 0x82, 0xcd, 0x7f, 0xea, 0xd0, 0x1d, 0x33, 0x3e, 0xb3, 0xf3, 0xfa, 0x05, - 0x0a, 0x36, 0x65, 0x82, 0x11, 0x0a, 0x9d, 0xcc, 0x86, 0x53, 0xac, 0x70, 0xfc, 0xa9, 0x51, 0xd9, - 0xaf, 0x1c, 0xb4, 0x0e, 0x3f, 0xb3, 0x8a, 0x8f, 0xcb, 0x44, 0xad, 0x15, 0x81, 0xf3, 0xc2, 0x01, - 0x7d, 0x28, 0x56, 0x01, 0xf2, 0x04, 0x9a, 0x21, 0x9b, 0x23, 0x8f, 0x99, 0x8b, 0x46, 0x75, 0xbf, - 0x72, 0xd0, 0xa4, 0x77, 0x05, 0x72, 0x0e, 0x9b, 0x01, 0x9b, 0x60, 0xc0, 0x8d, 0xda, 0x7e, 0xed, - 0xa0, 0x75, 0xf8, 0xc2, 0x5a, 0x9d, 0xa1, 0x55, 0x6a, 0xd4, 0x1a, 0xca, 0x35, 0x76, 0x28, 0x92, - 0x05, 0xd5, 0x02, 0xe4, 0x27, 0x68, 0xb1, 0x30, 0x8c, 0x04, 0xcb, 0x98, 0xdc, 0xd8, 0x90, 0x7a, - 0x5f, 0xdd, 0x4f, 0x6f, 0x70, 0xb7, 0x50, 0x89, 0x2e, 0x4b, 0x11, 0x0b, 0x1e, 0xcd, 0x8e, 0xb9, - 0xc3, 0x31, 0xb9, 0xf5, 0x5d, 0x74, 0x98, 0xeb, 0x46, 0x69, 0x28, 0x8c, 0xba, 0xfc, 0x98, 0xce, - 0xec, 0x98, 0x5f, 0x29, 0x64, 0xa0, 0x00, 0x22, 0xa0, 0x8b, 0xe1, 0xad, 0x9f, 0x44, 0xe1, 0x1c, - 0x43, 0xe1, 0xdc, 0xb2, 0xc4, 0x67, 0x93, 0x00, 0xb9, 0xb1, 0x29, 0x3d, 0xbd, 0xba, 0x9f, 0x27, - 0xfb, 0x4e, 0xe2, 0xc7, 0x5c, 0x41, 0x99, 0xdb, 0xc5, 0x12, 0xa8, 0xf7, 0x12, 0x5a, 0x4b, 0x63, - 0x21, 0x6d, 0xa8, 0xcd, 0x70, 0x21, 0xd3, 0x6b, 0xd2, 0xec, 0x91, 0xec, 0x42, 0xfd, 0x96, 0x05, - 0x69, 0x9e, 0x82, 0x7a, 0xf9, 0xa6, 0x7a, 0x5c, 0xe9, 0x7d, 0x0f, 0xed, 0xf5, 0x09, 0xbc, 0xd3, - 0xfa, 0x33, 0xd8, 0x7b, 0xab, 0xdb, 0x77, 0x11, 0x32, 0xff, 0xaa, 0x42, 0xe7, 0x24, 0x41, 0x26, - 0x30, 0x9b, 0x09, 0xc5, 0x3f, 0x52, 0xe4, 0x82, 0xbc, 0x80, 0x4d, 0x3f, 0x8c, 0x53, 0xc1, 0xf5, - 0x5e, 0xdc, 0x5b, 0xdb, 0x8b, 0x43, 0x75, 0xb0, 0x2e, 0x58, 0x4c, 0x35, 0x91, 0x7c, 0x0d, 0x0d, - 0x81, 0xf3, 0x38, 0x60, 0x42, 0x75, 0x69, 0x1d, 0x3e, 0x2e, 0xd9, 0xc0, 0x63, 0x4d, 0xa1, 0x05, - 0x99, 0x7c, 0x0a, 0x0f, 0xa2, 0x54, 0xc4, 0xa9, 0x70, 0xe2, 0x04, 0x6f, 0xfc, 0x37, 0x46, 0x4d, - 0x7a, 0xdc, 0x56, 0xc5, 0x4b, 0x59, 0x23, 0xbf, 0xc2, 0x47, 0x6b, 0xe7, 0x64, 0xae, 0x53, 0x33, - 0x36, 0x64, 0xb3, 0xa7, 0xf7, 0x8a, 0x98, 0x76, 0x45, 0x59, 0xd9, 0x7c, 0x09, 0x64, 0x79, 0x08, - 0x3c, 0x8e, 0x42, 0x2e, 0x9d, 0x25, 0xc8, 0xa3, 0x34, 0x71, 0x51, 0xb6, 0x93, 0xc3, 0xd8, 0xa6, - 0xdb, 0x79, 0x31, 0x5b, 0x6e, 0x52, 0xd8, 0x39, 0x43, 0xb1, 0x3c, 0xbc, 0xc7, 0xd0, 0x94, 0x5e, - 0xc5, 0x22, 0x46, 0x1d, 0x42, 0x23, 0x2b, 0x8c, 0x17, 0x71, 0x89, 0x66, 0xb5, 0x44, 0xf3, 0x4f, - 0x78, 0x58, 0x68, 0x6a, 0x2f, 0x5f, 0x42, 0x23, 0xa7, 0xe8, 0x4c, 0x8c, 0xf5, 0x2f, 0xa6, 0x1a, - 0xa7, 0x05, 0x93, 0x1c, 0x41, 0x33, 0x88, 0x3c, 0x27, 0xf0, 0xc3, 0x19, 0x37, 0xaa, 0xf2, 0x2c, - 0x7c, 0x58, 0x92, 0xca, 0x30, 0xf2, 0x68, 0x23, 0x88, 0xbc, 0x61, 0xc6, 0x33, 0xff, 0xae, 0x40, - 0x23, 0xd7, 0x22, 0xcf, 0xa0, 0xce, 0x45, 0x96, 0x69, 0xd6, 0x74, 0xe7, 0xb0, 0xbb, 0xde, 0xf4, - 0x2a, 0x03, 0xa9, 0xe2, 0x90, 0x23, 0xd8, 0x52, 0xa9, 0x71, 0xbd, 0x05, 0xfe, 0x67, 0xdf, 0xe4, - 0x4c, 0x62, 0xc0, 0xd6, 0x1c, 0x39, 0x67, 0x1e, 0xea, 0xe4, 0xf3, 0x57, 0xf3, 0x1a, 0x3a, 0xa7, - 0x18, 0xe0, 0xea, 0xd6, 0x7c, 0xff, 0xe9, 0xee, 0x02, 0x59, 0x96, 0x55, 0x03, 0x36, 0x2f, 0xa0, - 0x3e, 0xc8, 0x6e, 0x16, 0x42, 0x60, 0x23, 0xfb, 0xb5, 0xd4, 0xda, 0xf2, 0x99, 0x7c, 0x01, 0xbb, - 0x3c, 0x8d, 0xe3, 0x28, 0x11, 0x38, 0x75, 0x8a, 0xf6, 0x6a, 0xa4, 0x4d, 0x4a, 0x0a, 0x6c, 0xac, - 0x8d, 0x70, 0xf3, 0xa9, 0x8c, 0x50, 0x2a, 0xe6, 0xce, 0x4b, 0x84, 0xcd, 0x57, 0xd0, 0xbe, 0xa3, - 0xe9, 0xa8, 0x9f, 0x41, 0x5d, 0xde, 0x71, 0x3a, 0xe7, 0xff, 0x8c, 0x5c, 0xb1, 0x15, 0xc7, 0x7c, - 0x04, 0x9d, 0xa1, 0xcf, 0x95, 0x02, 0xd7, 0x9d, 0xcc, 0x13, 0x20, 0xcb, 0x45, 0xad, 0xfb, 0x1c, - 0x36, 0xe5, 0x9a, 0xec, 0x50, 0xd7, 0xde, 0x2e, 0xac, 0x49, 0x9f, 0xff, 0x06, 0x75, 0x19, 0x2e, - 0xe9, 0x42, 0x87, 0xda, 0x63, 0xfa, 0xf3, 0xe0, 0xf5, 0xd0, 0x76, 0x7e, 0x18, 0x9c, 0x0f, 0xaf, - 0xa9, 0xdd, 0xfe, 0x20, 0x2b, 0x5f, 0xda, 0xf4, 0x62, 0x30, 0xb2, 0x47, 0xe3, 0xa2, 0x5c, 0x21, - 0x2d, 0xd8, 0xba, 0xb4, 0x47, 0xa7, 0xe7, 0xa3, 0xb3, 0x76, 0x35, 0x7b, 0xa1, 0xd7, 0xa3, 0x51, - 0xf6, 0x52, 0x23, 0x0f, 0xa0, 0x79, 0x75, 0x7d, 0x72, 0x62, 0xdb, 0xa7, 0xf6, 0x69, 0x7b, 0xe3, - 0xf5, 0x77, 0xbf, 0x7c, 0xeb, 0xf9, 0xe2, 0xf7, 0x74, 0x62, 0xb9, 0xd1, 0xbc, 0x2f, 0xad, 0x44, - 0x89, 0xa7, 0x1e, 0xfa, 0xc5, 0x7d, 0xea, 0x61, 0xd8, 0x8f, 0x27, 0xcf, 0xbd, 0xa8, 0xbf, 0xfa, - 0x37, 0x60, 0xb2, 0x29, 0xaf, 0xd6, 0xa3, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0x81, 0xa7, 0x12, - 0x0e, 0x1f, 0x08, 0x00, 0x00, + // 901 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x56, 0x7f, 0x6f, 0xe3, 0x44, + 0x10, 0x6d, 0x7e, 0x36, 0x99, 0xb4, 0xbd, 0x64, 0xaf, 0x01, 0x37, 0x77, 0xa0, 0xca, 0xa8, 0xa8, + 0xe2, 0x74, 0x09, 0xd7, 0xa2, 0xa3, 0x80, 0xe0, 0x94, 0xb6, 0xa6, 0x57, 0x29, 0x8d, 0xaa, 0x6d, + 0x8a, 0x00, 0x09, 0xa2, 0x4d, 0x32, 0x35, 0x56, 0x1c, 0xdb, 0x78, 0xd7, 0xd5, 0x05, 0xf1, 0x1f, + 0x5f, 0x82, 0xef, 0xc2, 0x97, 0x43, 0xde, 0x5d, 0x3b, 0x71, 0xc8, 0x9d, 0x7a, 0xe2, 0x3f, 0xef, + 0xbc, 0xb7, 0x6f, 0xde, 0xce, 0xcc, 0x66, 0x03, 0xad, 0x3b, 0x77, 0x2e, 0xd0, 0x99, 0xb8, 0x1d, + 0x36, 0x99, 0x39, 0x5e, 0x87, 0xd9, 0xe8, 0x89, 0x76, 0x10, 0xfa, 0xc2, 0x27, 0x3b, 0x09, 0xd6, + 0x96, 0x58, 0xeb, 0x69, 0xca, 0x1d, 0xfb, 0x21, 0x76, 0x5c, 0x47, 0x60, 0xc8, 0x5c, 0xae, 0xd8, + 0xad, 0xbd, 0x2c, 0x2a, 0x18, 0x9f, 0x26, 0xd0, 0x47, 0x59, 0xc8, 0xf1, 0x04, 0x86, 0x77, 0x6c, + 0x8c, 0x1a, 0xfe, 0x78, 0x05, 0x9e, 0xa0, 0x27, 0x9c, 0x3b, 0x07, 0xc3, 0xf5, 0xdb, 0xf1, 0x0d, + 0x8e, 0x23, 0xe1, 0xf8, 0x9e, 0x82, 0xcd, 0xbf, 0x4b, 0xd0, 0x1c, 0x30, 0x3e, 0xb5, 0x92, 0xf8, + 0x15, 0x0a, 0x36, 0x61, 0x82, 0x11, 0x0a, 0x8d, 0xd8, 0xc6, 0x30, 0xdd, 0x31, 0x74, 0x26, 0x46, + 0x6e, 0x3f, 0x77, 0x58, 0x3b, 0xfa, 0xb4, 0x9d, 0x1e, 0x2e, 0x16, 0x6d, 0x67, 0x04, 0x2e, 0x53, + 0x07, 0xf4, 0x91, 0xc8, 0x02, 0xe4, 0x29, 0x54, 0x3d, 0x36, 0x43, 0x1e, 0xb0, 0x31, 0x1a, 0xf9, + 0xfd, 0xdc, 0x61, 0x95, 0x2e, 0x02, 0xe4, 0x12, 0xca, 0x2e, 0x1b, 0xa1, 0xcb, 0x8d, 0xc2, 0x7e, + 0xe1, 0xb0, 0x76, 0xf4, 0xa2, 0x9d, 0xad, 0x61, 0x7b, 0xad, 0xd1, 0x76, 0x4f, 0xee, 0xb1, 0x3c, + 0x11, 0xce, 0xa9, 0x16, 0x20, 0x3f, 0x42, 0x8d, 0x79, 0x9e, 0x2f, 0x58, 0xcc, 0xe4, 0x46, 0x51, + 0xea, 0xbd, 0x7c, 0x98, 0x5e, 0x77, 0xb1, 0x51, 0x89, 0x2e, 0x4b, 0x91, 0x36, 0x3c, 0x9e, 0x9e, + 0xf0, 0x21, 0xc7, 0xf0, 0xde, 0x19, 0xe3, 0x90, 0x8d, 0xc7, 0x7e, 0xe4, 0x09, 0xa3, 0x24, 0x0f, + 0xd3, 0x98, 0x9e, 0xf0, 0x1b, 0x85, 0x74, 0x15, 0x40, 0x04, 0x34, 0xd1, 0xbb, 0x77, 0x42, 0xdf, + 0x9b, 0xa1, 0x27, 0x86, 0xf7, 0x2c, 0x74, 0xd8, 0xc8, 0x45, 0x6e, 0x94, 0xa5, 0xa7, 0x57, 0x0f, + 0xf3, 0x64, 0x2d, 0x24, 0x7e, 0x48, 0x14, 0x94, 0xb9, 0x5d, 0x5c, 0x03, 0xb5, 0xbe, 0x82, 0xda, + 0x52, 0x59, 0x48, 0x1d, 0x0a, 0x53, 0x9c, 0xcb, 0xee, 0x55, 0x69, 0xfc, 0x49, 0x76, 0xa1, 0x74, + 0xcf, 0xdc, 0x28, 0xe9, 0x82, 0x5a, 0x7c, 0x9d, 0x3f, 0xc9, 0xb5, 0xbe, 0x83, 0xfa, 0x6a, 0x05, + 0xde, 0x6b, 0xff, 0x05, 0xec, 0xbd, 0xd5, 0xed, 0xfb, 0x08, 0x99, 0x7f, 0xe5, 0xa1, 0x71, 0x16, + 0x22, 0x13, 0x18, 0xd7, 0x84, 0xe2, 0xef, 0x11, 0x72, 0x41, 0x5e, 0x40, 0xd9, 0xf1, 0x82, 0x48, + 0x70, 0x3d, 0x8b, 0x7b, 0x2b, 0xb3, 0xd8, 0x53, 0x17, 0xeb, 0x8a, 0x05, 0x54, 0x13, 0xc9, 0x97, + 0x50, 0x11, 0x38, 0x0b, 0x5c, 0x26, 0x54, 0x96, 0xda, 0xd1, 0x93, 0x35, 0x03, 0x3c, 0xd0, 0x14, + 0x9a, 0x92, 0xc9, 0x27, 0xb0, 0xed, 0x47, 0x22, 0x88, 0xc4, 0x30, 0x08, 0xf1, 0xce, 0x79, 0x63, + 0x14, 0xa4, 0xc7, 0x2d, 0x15, 0xbc, 0x96, 0x31, 0xf2, 0x0b, 0x7c, 0xb8, 0x72, 0x4f, 0x66, 0xba, + 0x6b, 0x46, 0x51, 0x26, 0x3b, 0x78, 0x50, 0x8b, 0x69, 0x53, 0xac, 0x0b, 0x9b, 0x7f, 0x00, 0x59, + 0x2e, 0x02, 0x0f, 0x7c, 0x8f, 0x23, 0x39, 0x80, 0xed, 0x10, 0xb9, 0x1f, 0x85, 0x63, 0x94, 0xe9, + 0x64, 0x31, 0xb6, 0x5e, 0x6f, 0xd0, 0xad, 0x24, 0x1c, 0x0b, 0x90, 0x97, 0x50, 0x49, 0xd6, 0xfa, + 0xe4, 0xc6, 0xaa, 0x19, 0xaa, 0xf1, 0xd7, 0x1b, 0x34, 0xe5, 0x9e, 0x96, 0xa0, 0x10, 0x22, 0x37, + 0x29, 0xec, 0x5c, 0xa0, 0x58, 0xae, 0xfe, 0x13, 0xa8, 0xca, 0xc3, 0x8a, 0x79, 0x80, 0xba, 0x8b, + 0x95, 0x38, 0x30, 0x98, 0x07, 0xb2, 0x5c, 0x59, 0x53, 0x71, 0xca, 0xad, 0xac, 0x25, 0xf3, 0x4f, + 0x78, 0x94, 0x6a, 0xea, 0xc3, 0x7c, 0xb1, 0xe4, 0x32, 0xf7, 0x6e, 0x97, 0x0b, 0x8f, 0xe4, 0x18, + 0xaa, 0xae, 0x6f, 0x0f, 0x5d, 0xc7, 0x9b, 0x72, 0x23, 0x2f, 0x2f, 0xd3, 0x07, 0x6b, 0xda, 0xda, + 0xf3, 0x6d, 0x5a, 0x71, 0x7d, 0xbb, 0x17, 0xf3, 0xcc, 0x7f, 0x72, 0x50, 0x49, 0xb4, 0xc8, 0x33, + 0x28, 0x71, 0x11, 0x0f, 0x45, 0x9c, 0x74, 0xe7, 0xa8, 0xb9, 0x9a, 0xf4, 0x26, 0x06, 0xa9, 0xe2, + 0x90, 0x63, 0xd8, 0x54, 0x6d, 0xe7, 0xba, 0x92, 0xef, 0x18, 0xbc, 0x84, 0x49, 0x0c, 0xd8, 0x9c, + 0x21, 0xe7, 0xcc, 0x46, 0x3d, 0x3a, 0xc9, 0x32, 0xeb, 0xbe, 0xf8, 0x40, 0xf7, 0xb7, 0xd0, 0x38, + 0x47, 0x17, 0xb3, 0x17, 0xe2, 0xff, 0xb7, 0x64, 0x17, 0xc8, 0xb2, 0xac, 0xea, 0x8a, 0x79, 0x05, + 0xa5, 0x6e, 0xfc, 0x9e, 0x11, 0x02, 0xc5, 0xf8, 0x37, 0x5a, 0x6b, 0xcb, 0x6f, 0xf2, 0x39, 0xec, + 0xf2, 0x28, 0x08, 0xfc, 0x50, 0xe0, 0x64, 0x98, 0xa6, 0x57, 0x7d, 0xa8, 0x52, 0x92, 0x62, 0x03, + 0x6d, 0x84, 0x9b, 0x07, 0xb2, 0xef, 0x52, 0x31, 0x71, 0xbe, 0x46, 0xd8, 0x7c, 0x05, 0xf5, 0x05, + 0x4d, 0xcf, 0xc7, 0x33, 0x28, 0xc9, 0x97, 0x55, 0x0f, 0xc7, 0x7f, 0xfa, 0xa4, 0xd8, 0x8a, 0x63, + 0x3e, 0x86, 0x46, 0xcf, 0xe1, 0x4a, 0x81, 0xeb, 0x4c, 0xe6, 0x19, 0x90, 0xe5, 0xa0, 0xd6, 0x7d, + 0x0e, 0x65, 0xb9, 0x27, 0xfe, 0x29, 0x29, 0xbc, 0x5d, 0x58, 0x93, 0x3e, 0xfb, 0x15, 0x4a, 0x72, + 0x22, 0x48, 0x13, 0x1a, 0xd4, 0x1a, 0xd0, 0x9f, 0xba, 0xa7, 0x3d, 0x6b, 0xf8, 0x7d, 0xf7, 0xb2, + 0x77, 0x4b, 0xad, 0xfa, 0x46, 0x1c, 0xbe, 0xb6, 0xe8, 0x55, 0xb7, 0x6f, 0xf5, 0x07, 0x69, 0x38, + 0x47, 0x6a, 0xb0, 0x79, 0x6d, 0xf5, 0xcf, 0x2f, 0xfb, 0x17, 0xf5, 0x7c, 0xbc, 0xa0, 0xb7, 0xfd, + 0x7e, 0xbc, 0x28, 0x90, 0x6d, 0xa8, 0xde, 0xdc, 0x9e, 0x9d, 0x59, 0xd6, 0xb9, 0x75, 0x5e, 0x2f, + 0x9e, 0x7e, 0xfb, 0xf3, 0x37, 0xb6, 0x23, 0x7e, 0x8b, 0x46, 0xed, 0xb1, 0x3f, 0xeb, 0x48, 0x2b, + 0x7e, 0x68, 0xab, 0x8f, 0x4e, 0xfa, 0x8a, 0xdb, 0xe8, 0x75, 0x82, 0xd1, 0x73, 0xdb, 0xef, 0x64, + 0xff, 0x7c, 0x8c, 0xca, 0xf2, 0x41, 0x3f, 0xfe, 0x37, 0x00, 0x00, 0xff, 0xff, 0x3c, 0x11, 0x18, + 0x7d, 0x95, 0x08, 0x00, 0x00, } diff --git a/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.validate.go b/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.validate.go index c4767d006c..8bdff082f3 100644 --- a/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.validate.go +++ b/flyteidl/gen/pb-go/flyteidl/admin/agent.pb.validate.go @@ -230,7 +230,24 @@ func (m *CreateTaskResponse) Validate() error { return nil } - // no validation rules for ResourceMeta + switch m.Res.(type) { + + case *CreateTaskResponse_ResourceMeta: + // no validation rules for ResourceMeta + + case *CreateTaskResponse_Resource: + + if v, ok := interface{}(m.GetResource()).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return CreateTaskResponseValidationError{ + field: "Resource", + reason: "embedded message failed validation", + cause: err, + } + } + } + + } return nil } @@ -471,6 +488,21 @@ func (m *Resource) Validate() error { // no validation rules for Message + for idx, item := range m.GetLogLinks() { + _, _ = idx, item + + if v, ok := interface{}(item).(interface{ Validate() error }); ok { + if err := v.Validate(); err != nil { + return ResourceValidationError{ + field: fmt.Sprintf("LogLinks[%v]", idx), + reason: "embedded message failed validation", + cause: err, + } + } + } + + } + return nil } diff --git a/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json b/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json index b9cb5d6b5b..623a3ecd94 100644 --- a/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json +++ b/flyteidl/gen/pb-go/flyteidl/service/agent.swagger.json @@ -238,8 +238,10 @@ "properties": { "resource_meta": { "type": "string", - "format": "byte", - "description": "Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata)." + "format": "byte" + }, + "resource": { + "$ref": "#/definitions/adminResource" } }, "description": "Represents a create response structure." @@ -299,6 +301,13 @@ "message": { "type": "string", "description": "A descriptive message for the current state. e.g. waiting for cluster." + }, + "log_links": { + "type": "array", + "items": { + "$ref": "#/definitions/coreTaskLog" + }, + "description": "log information for the task execution." } } }, diff --git a/flyteidl/gen/pb-java/flyteidl/admin/AgentOuterClass.java b/flyteidl/gen/pb-java/flyteidl/admin/AgentOuterClass.java index a6fa424d2a..f71d1743ff 100644 --- a/flyteidl/gen/pb-java/flyteidl/admin/AgentOuterClass.java +++ b/flyteidl/gen/pb-java/flyteidl/admin/AgentOuterClass.java @@ -3615,13 +3615,24 @@ public interface CreateTaskResponseOrBuilder extends com.google.protobuf.MessageOrBuilder { /** - *
-     * Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata).
-     * 
- * * bytes resource_meta = 1; */ com.google.protobuf.ByteString getResourceMeta(); + + /** + * .flyteidl.admin.Resource resource = 2; + */ + boolean hasResource(); + /** + * .flyteidl.admin.Resource resource = 2; + */ + flyteidl.admin.AgentOuterClass.Resource getResource(); + /** + * .flyteidl.admin.Resource resource = 2; + */ + flyteidl.admin.AgentOuterClass.ResourceOrBuilder getResourceOrBuilder(); + + public flyteidl.admin.AgentOuterClass.CreateTaskResponse.ResCase getResCase(); } /** *
@@ -3640,7 +3651,6 @@ private CreateTaskResponse(com.google.protobuf.GeneratedMessageV3.Builder bui
       super(builder);
     }
     private CreateTaskResponse() {
-      resourceMeta_ = com.google.protobuf.ByteString.EMPTY;
     }
 
     @java.lang.Override
@@ -3668,8 +3678,22 @@ private CreateTaskResponse(
               done = true;
               break;
             case 10: {
-
-              resourceMeta_ = input.readBytes();
+              resCase_ = 1;
+              res_ = input.readBytes();
+              break;
+            }
+            case 18: {
+              flyteidl.admin.AgentOuterClass.Resource.Builder subBuilder = null;
+              if (resCase_ == 2) {
+                subBuilder = ((flyteidl.admin.AgentOuterClass.Resource) res_).toBuilder();
+              }
+              res_ =
+                  input.readMessage(flyteidl.admin.AgentOuterClass.Resource.parser(), extensionRegistry);
+              if (subBuilder != null) {
+                subBuilder.mergeFrom((flyteidl.admin.AgentOuterClass.Resource) res_);
+                res_ = subBuilder.buildPartial();
+              }
+              resCase_ = 2;
               break;
             }
             default: {
@@ -3704,17 +3728,79 @@ private CreateTaskResponse(
               flyteidl.admin.AgentOuterClass.CreateTaskResponse.class, flyteidl.admin.AgentOuterClass.CreateTaskResponse.Builder.class);
     }
 
+    private int resCase_ = 0;
+    private java.lang.Object res_;
+    public enum ResCase
+        implements com.google.protobuf.Internal.EnumLite {
+      RESOURCE_META(1),
+      RESOURCE(2),
+      RES_NOT_SET(0);
+      private final int value;
+      private ResCase(int value) {
+        this.value = value;
+      }
+      /**
+       * @deprecated Use {@link #forNumber(int)} instead.
+       */
+      @java.lang.Deprecated
+      public static ResCase valueOf(int value) {
+        return forNumber(value);
+      }
+
+      public static ResCase forNumber(int value) {
+        switch (value) {
+          case 1: return RESOURCE_META;
+          case 2: return RESOURCE;
+          case 0: return RES_NOT_SET;
+          default: return null;
+        }
+      }
+      public int getNumber() {
+        return this.value;
+      }
+    };
+
+    public ResCase
+    getResCase() {
+      return ResCase.forNumber(
+          resCase_);
+    }
+
     public static final int RESOURCE_META_FIELD_NUMBER = 1;
-    private com.google.protobuf.ByteString resourceMeta_;
     /**
-     * 
-     * Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata).
-     * 
- * * bytes resource_meta = 1; */ public com.google.protobuf.ByteString getResourceMeta() { - return resourceMeta_; + if (resCase_ == 1) { + return (com.google.protobuf.ByteString) res_; + } + return com.google.protobuf.ByteString.EMPTY; + } + + public static final int RESOURCE_FIELD_NUMBER = 2; + /** + * .flyteidl.admin.Resource resource = 2; + */ + public boolean hasResource() { + return resCase_ == 2; + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public flyteidl.admin.AgentOuterClass.Resource getResource() { + if (resCase_ == 2) { + return (flyteidl.admin.AgentOuterClass.Resource) res_; + } + return flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance(); + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public flyteidl.admin.AgentOuterClass.ResourceOrBuilder getResourceOrBuilder() { + if (resCase_ == 2) { + return (flyteidl.admin.AgentOuterClass.Resource) res_; + } + return flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance(); } private byte memoizedIsInitialized = -1; @@ -3731,8 +3817,12 @@ public final boolean isInitialized() { @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { - if (!resourceMeta_.isEmpty()) { - output.writeBytes(1, resourceMeta_); + if (resCase_ == 1) { + output.writeBytes( + 1, (com.google.protobuf.ByteString) res_); + } + if (resCase_ == 2) { + output.writeMessage(2, (flyteidl.admin.AgentOuterClass.Resource) res_); } unknownFields.writeTo(output); } @@ -3743,9 +3833,14 @@ public int getSerializedSize() { if (size != -1) return size; size = 0; - if (!resourceMeta_.isEmpty()) { + if (resCase_ == 1) { + size += com.google.protobuf.CodedOutputStream + .computeBytesSize( + 1, (com.google.protobuf.ByteString) res_); + } + if (resCase_ == 2) { size += com.google.protobuf.CodedOutputStream - .computeBytesSize(1, resourceMeta_); + .computeMessageSize(2, (flyteidl.admin.AgentOuterClass.Resource) res_); } size += unknownFields.getSerializedSize(); memoizedSize = size; @@ -3762,8 +3857,19 @@ public boolean equals(final java.lang.Object obj) { } flyteidl.admin.AgentOuterClass.CreateTaskResponse other = (flyteidl.admin.AgentOuterClass.CreateTaskResponse) obj; - if (!getResourceMeta() - .equals(other.getResourceMeta())) return false; + if (!getResCase().equals(other.getResCase())) return false; + switch (resCase_) { + case 1: + if (!getResourceMeta() + .equals(other.getResourceMeta())) return false; + break; + case 2: + if (!getResource() + .equals(other.getResource())) return false; + break; + case 0: + default: + } if (!unknownFields.equals(other.unknownFields)) return false; return true; } @@ -3775,8 +3881,18 @@ public int hashCode() { } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); - hash = (37 * hash) + RESOURCE_META_FIELD_NUMBER; - hash = (53 * hash) + getResourceMeta().hashCode(); + switch (resCase_) { + case 1: + hash = (37 * hash) + RESOURCE_META_FIELD_NUMBER; + hash = (53 * hash) + getResourceMeta().hashCode(); + break; + case 2: + hash = (37 * hash) + RESOURCE_FIELD_NUMBER; + hash = (53 * hash) + getResource().hashCode(); + break; + case 0: + default: + } hash = (29 * hash) + unknownFields.hashCode(); memoizedHashCode = hash; return hash; @@ -3914,8 +4030,8 @@ private void maybeForceBuilderInitialization() { @java.lang.Override public Builder clear() { super.clear(); - resourceMeta_ = com.google.protobuf.ByteString.EMPTY; - + resCase_ = 0; + res_ = null; return this; } @@ -3942,7 +4058,17 @@ public flyteidl.admin.AgentOuterClass.CreateTaskResponse build() { @java.lang.Override public flyteidl.admin.AgentOuterClass.CreateTaskResponse buildPartial() { flyteidl.admin.AgentOuterClass.CreateTaskResponse result = new flyteidl.admin.AgentOuterClass.CreateTaskResponse(this); - result.resourceMeta_ = resourceMeta_; + if (resCase_ == 1) { + result.res_ = res_; + } + if (resCase_ == 2) { + if (resourceBuilder_ == null) { + result.res_ = res_; + } else { + result.res_ = resourceBuilder_.build(); + } + } + result.resCase_ = resCase_; onBuilt(); return result; } @@ -3991,8 +4117,18 @@ public Builder mergeFrom(com.google.protobuf.Message other) { public Builder mergeFrom(flyteidl.admin.AgentOuterClass.CreateTaskResponse other) { if (other == flyteidl.admin.AgentOuterClass.CreateTaskResponse.getDefaultInstance()) return this; - if (other.getResourceMeta() != com.google.protobuf.ByteString.EMPTY) { - setResourceMeta(other.getResourceMeta()); + switch (other.getResCase()) { + case RESOURCE_META: { + setResourceMeta(other.getResourceMeta()); + break; + } + case RESOURCE: { + mergeResource(other.getResource()); + break; + } + case RES_NOT_SET: { + break; + } } this.mergeUnknownFields(other.unknownFields); onChanged(); @@ -4022,47 +4158,190 @@ public Builder mergeFrom( } return this; } + private int resCase_ = 0; + private java.lang.Object res_; + public ResCase + getResCase() { + return ResCase.forNumber( + resCase_); + } + + public Builder clearRes() { + resCase_ = 0; + res_ = null; + onChanged(); + return this; + } + - private com.google.protobuf.ByteString resourceMeta_ = com.google.protobuf.ByteString.EMPTY; /** - *
-       * Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata).
-       * 
- * * bytes resource_meta = 1; */ public com.google.protobuf.ByteString getResourceMeta() { - return resourceMeta_; + if (resCase_ == 1) { + return (com.google.protobuf.ByteString) res_; + } + return com.google.protobuf.ByteString.EMPTY; } /** - *
-       * Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata).
-       * 
- * * bytes resource_meta = 1; */ public Builder setResourceMeta(com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } - - resourceMeta_ = value; + resCase_ = 1; + res_ = value; onChanged(); return this; } /** - *
-       * Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata).
-       * 
- * * bytes resource_meta = 1; */ public Builder clearResourceMeta() { - - resourceMeta_ = getDefaultInstance().getResourceMeta(); - onChanged(); + if (resCase_ == 1) { + resCase_ = 0; + res_ = null; + onChanged(); + } + return this; + } + + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Resource, flyteidl.admin.AgentOuterClass.Resource.Builder, flyteidl.admin.AgentOuterClass.ResourceOrBuilder> resourceBuilder_; + /** + * .flyteidl.admin.Resource resource = 2; + */ + public boolean hasResource() { + return resCase_ == 2; + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public flyteidl.admin.AgentOuterClass.Resource getResource() { + if (resourceBuilder_ == null) { + if (resCase_ == 2) { + return (flyteidl.admin.AgentOuterClass.Resource) res_; + } + return flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance(); + } else { + if (resCase_ == 2) { + return resourceBuilder_.getMessage(); + } + return flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance(); + } + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public Builder setResource(flyteidl.admin.AgentOuterClass.Resource value) { + if (resourceBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + res_ = value; + onChanged(); + } else { + resourceBuilder_.setMessage(value); + } + resCase_ = 2; + return this; + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public Builder setResource( + flyteidl.admin.AgentOuterClass.Resource.Builder builderForValue) { + if (resourceBuilder_ == null) { + res_ = builderForValue.build(); + onChanged(); + } else { + resourceBuilder_.setMessage(builderForValue.build()); + } + resCase_ = 2; + return this; + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public Builder mergeResource(flyteidl.admin.AgentOuterClass.Resource value) { + if (resourceBuilder_ == null) { + if (resCase_ == 2 && + res_ != flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance()) { + res_ = flyteidl.admin.AgentOuterClass.Resource.newBuilder((flyteidl.admin.AgentOuterClass.Resource) res_) + .mergeFrom(value).buildPartial(); + } else { + res_ = value; + } + onChanged(); + } else { + if (resCase_ == 2) { + resourceBuilder_.mergeFrom(value); + } + resourceBuilder_.setMessage(value); + } + resCase_ = 2; + return this; + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public Builder clearResource() { + if (resourceBuilder_ == null) { + if (resCase_ == 2) { + resCase_ = 0; + res_ = null; + onChanged(); + } + } else { + if (resCase_ == 2) { + resCase_ = 0; + res_ = null; + } + resourceBuilder_.clear(); + } return this; } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public flyteidl.admin.AgentOuterClass.Resource.Builder getResourceBuilder() { + return getResourceFieldBuilder().getBuilder(); + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + public flyteidl.admin.AgentOuterClass.ResourceOrBuilder getResourceOrBuilder() { + if ((resCase_ == 2) && (resourceBuilder_ != null)) { + return resourceBuilder_.getMessageOrBuilder(); + } else { + if (resCase_ == 2) { + return (flyteidl.admin.AgentOuterClass.Resource) res_; + } + return flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance(); + } + } + /** + * .flyteidl.admin.Resource resource = 2; + */ + private com.google.protobuf.SingleFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Resource, flyteidl.admin.AgentOuterClass.Resource.Builder, flyteidl.admin.AgentOuterClass.ResourceOrBuilder> + getResourceFieldBuilder() { + if (resourceBuilder_ == null) { + if (!(resCase_ == 2)) { + res_ = flyteidl.admin.AgentOuterClass.Resource.getDefaultInstance(); + } + resourceBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< + flyteidl.admin.AgentOuterClass.Resource, flyteidl.admin.AgentOuterClass.Resource.Builder, flyteidl.admin.AgentOuterClass.ResourceOrBuilder>( + (flyteidl.admin.AgentOuterClass.Resource) res_, + getParentForChildren(), + isClean()); + res_ = null; + } + resCase_ = 2; + onChanged();; + return resourceBuilder_; + } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { @@ -5962,6 +6241,50 @@ public interface ResourceOrBuilder extends */ com.google.protobuf.ByteString getMessageBytes(); + + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + java.util.List + getLogLinksList(); + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + flyteidl.core.Execution.TaskLog getLogLinks(int index); + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + int getLogLinksCount(); + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + java.util.List + getLogLinksOrBuilderList(); + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + flyteidl.core.Execution.TaskLogOrBuilder getLogLinksOrBuilder( + int index); } /** * Protobuf type {@code flyteidl.admin.Resource} @@ -5978,6 +6301,7 @@ private Resource(com.google.protobuf.GeneratedMessageV3.Builder builder) { private Resource() { state_ = 0; message_ = ""; + logLinks_ = java.util.Collections.emptyList(); } @java.lang.Override @@ -6029,6 +6353,15 @@ private Resource( message_ = s; break; } + case 34: { + if (!((mutable_bitField0_ & 0x00000008) != 0)) { + logLinks_ = new java.util.ArrayList(); + mutable_bitField0_ |= 0x00000008; + } + logLinks_.add( + input.readMessage(flyteidl.core.Execution.TaskLog.parser(), extensionRegistry)); + break; + } default: { if (!parseUnknownField( input, unknownFields, extensionRegistry, tag)) { @@ -6044,6 +6377,9 @@ private Resource( throw new com.google.protobuf.InvalidProtocolBufferException( e).setUnfinishedMessage(this); } finally { + if (((mutable_bitField0_ & 0x00000008) != 0)) { + logLinks_ = java.util.Collections.unmodifiableList(logLinks_); + } this.unknownFields = unknownFields.build(); makeExtensionsImmutable(); } @@ -6061,6 +6397,7 @@ private Resource( flyteidl.admin.AgentOuterClass.Resource.class, flyteidl.admin.AgentOuterClass.Resource.Builder.class); } + private int bitField0_; public static final int STATE_FIELD_NUMBER = 1; private int state_; /** @@ -6167,15 +6504,70 @@ public java.lang.String getMessage() { } } - 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; + public static final int LOG_LINKS_FIELD_NUMBER = 4; + private java.util.List logLinks_; + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public java.util.List getLogLinksList() { + return logLinks_; + } + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public java.util.List + getLogLinksOrBuilderList() { + return logLinks_; + } + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public int getLogLinksCount() { + return logLinks_.size(); + } + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public flyteidl.core.Execution.TaskLog getLogLinks(int index) { + return logLinks_.get(index); + } + /** + *
+     * log information for the task execution.
+     * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public flyteidl.core.Execution.TaskLogOrBuilder getLogLinksOrBuilder( + int index) { + return logLinks_.get(index); + } + + 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 @@ -6190,6 +6582,9 @@ public void writeTo(com.google.protobuf.CodedOutputStream output) if (!getMessageBytes().isEmpty()) { com.google.protobuf.GeneratedMessageV3.writeString(output, 3, message_); } + for (int i = 0; i < logLinks_.size(); i++) { + output.writeMessage(4, logLinks_.get(i)); + } unknownFields.writeTo(output); } @@ -6210,6 +6605,10 @@ public int getSerializedSize() { if (!getMessageBytes().isEmpty()) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(3, message_); } + for (int i = 0; i < logLinks_.size(); i++) { + size += com.google.protobuf.CodedOutputStream + .computeMessageSize(4, logLinks_.get(i)); + } size += unknownFields.getSerializedSize(); memoizedSize = size; return size; @@ -6233,6 +6632,8 @@ public boolean equals(final java.lang.Object obj) { } if (!getMessage() .equals(other.getMessage())) return false; + if (!getLogLinksList() + .equals(other.getLogLinksList())) return false; if (!unknownFields.equals(other.unknownFields)) return false; return true; } @@ -6252,6 +6653,10 @@ public int hashCode() { } hash = (37 * hash) + MESSAGE_FIELD_NUMBER; hash = (53 * hash) + getMessage().hashCode(); + if (getLogLinksCount() > 0) { + hash = (37 * hash) + LOG_LINKS_FIELD_NUMBER; + hash = (53 * hash) + getLogLinksList().hashCode(); + } hash = (29 * hash) + unknownFields.hashCode(); memoizedHashCode = hash; return hash; @@ -6380,6 +6785,7 @@ private Builder( private void maybeForceBuilderInitialization() { if (com.google.protobuf.GeneratedMessageV3 .alwaysUseFieldBuilders) { + getLogLinksFieldBuilder(); } } @java.lang.Override @@ -6395,6 +6801,12 @@ public Builder clear() { } message_ = ""; + if (logLinksBuilder_ == null) { + logLinks_ = java.util.Collections.emptyList(); + bitField0_ = (bitField0_ & ~0x00000008); + } else { + logLinksBuilder_.clear(); + } return this; } @@ -6421,6 +6833,8 @@ public flyteidl.admin.AgentOuterClass.Resource build() { @java.lang.Override public flyteidl.admin.AgentOuterClass.Resource buildPartial() { flyteidl.admin.AgentOuterClass.Resource result = new flyteidl.admin.AgentOuterClass.Resource(this); + int from_bitField0_ = bitField0_; + int to_bitField0_ = 0; result.state_ = state_; if (outputsBuilder_ == null) { result.outputs_ = outputs_; @@ -6428,6 +6842,16 @@ public flyteidl.admin.AgentOuterClass.Resource buildPartial() { result.outputs_ = outputsBuilder_.build(); } result.message_ = message_; + if (logLinksBuilder_ == null) { + if (((bitField0_ & 0x00000008) != 0)) { + logLinks_ = java.util.Collections.unmodifiableList(logLinks_); + bitField0_ = (bitField0_ & ~0x00000008); + } + result.logLinks_ = logLinks_; + } else { + result.logLinks_ = logLinksBuilder_.build(); + } + result.bitField0_ = to_bitField0_; onBuilt(); return result; } @@ -6486,6 +6910,32 @@ public Builder mergeFrom(flyteidl.admin.AgentOuterClass.Resource other) { message_ = other.message_; onChanged(); } + if (logLinksBuilder_ == null) { + if (!other.logLinks_.isEmpty()) { + if (logLinks_.isEmpty()) { + logLinks_ = other.logLinks_; + bitField0_ = (bitField0_ & ~0x00000008); + } else { + ensureLogLinksIsMutable(); + logLinks_.addAll(other.logLinks_); + } + onChanged(); + } + } else { + if (!other.logLinks_.isEmpty()) { + if (logLinksBuilder_.isEmpty()) { + logLinksBuilder_.dispose(); + logLinksBuilder_ = null; + logLinks_ = other.logLinks_; + bitField0_ = (bitField0_ & ~0x00000008); + logLinksBuilder_ = + com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ? + getLogLinksFieldBuilder() : null; + } else { + logLinksBuilder_.addAllMessages(other.logLinks_); + } + } + } this.mergeUnknownFields(other.unknownFields); onChanged(); return this; @@ -6514,6 +6964,7 @@ public Builder mergeFrom( } return this; } + private int bitField0_; private int state_ = 0; /** @@ -6839,6 +7290,318 @@ public Builder setMessageBytes( onChanged(); return this; } + + private java.util.List logLinks_ = + java.util.Collections.emptyList(); + private void ensureLogLinksIsMutable() { + if (!((bitField0_ & 0x00000008) != 0)) { + logLinks_ = new java.util.ArrayList(logLinks_); + bitField0_ |= 0x00000008; + } + } + + private com.google.protobuf.RepeatedFieldBuilderV3< + flyteidl.core.Execution.TaskLog, flyteidl.core.Execution.TaskLog.Builder, flyteidl.core.Execution.TaskLogOrBuilder> logLinksBuilder_; + + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public java.util.List getLogLinksList() { + if (logLinksBuilder_ == null) { + return java.util.Collections.unmodifiableList(logLinks_); + } else { + return logLinksBuilder_.getMessageList(); + } + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public int getLogLinksCount() { + if (logLinksBuilder_ == null) { + return logLinks_.size(); + } else { + return logLinksBuilder_.getCount(); + } + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public flyteidl.core.Execution.TaskLog getLogLinks(int index) { + if (logLinksBuilder_ == null) { + return logLinks_.get(index); + } else { + return logLinksBuilder_.getMessage(index); + } + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder setLogLinks( + int index, flyteidl.core.Execution.TaskLog value) { + if (logLinksBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + ensureLogLinksIsMutable(); + logLinks_.set(index, value); + onChanged(); + } else { + logLinksBuilder_.setMessage(index, value); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder setLogLinks( + int index, flyteidl.core.Execution.TaskLog.Builder builderForValue) { + if (logLinksBuilder_ == null) { + ensureLogLinksIsMutable(); + logLinks_.set(index, builderForValue.build()); + onChanged(); + } else { + logLinksBuilder_.setMessage(index, builderForValue.build()); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder addLogLinks(flyteidl.core.Execution.TaskLog value) { + if (logLinksBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + ensureLogLinksIsMutable(); + logLinks_.add(value); + onChanged(); + } else { + logLinksBuilder_.addMessage(value); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder addLogLinks( + int index, flyteidl.core.Execution.TaskLog value) { + if (logLinksBuilder_ == null) { + if (value == null) { + throw new NullPointerException(); + } + ensureLogLinksIsMutable(); + logLinks_.add(index, value); + onChanged(); + } else { + logLinksBuilder_.addMessage(index, value); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder addLogLinks( + flyteidl.core.Execution.TaskLog.Builder builderForValue) { + if (logLinksBuilder_ == null) { + ensureLogLinksIsMutable(); + logLinks_.add(builderForValue.build()); + onChanged(); + } else { + logLinksBuilder_.addMessage(builderForValue.build()); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder addLogLinks( + int index, flyteidl.core.Execution.TaskLog.Builder builderForValue) { + if (logLinksBuilder_ == null) { + ensureLogLinksIsMutable(); + logLinks_.add(index, builderForValue.build()); + onChanged(); + } else { + logLinksBuilder_.addMessage(index, builderForValue.build()); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder addAllLogLinks( + java.lang.Iterable values) { + if (logLinksBuilder_ == null) { + ensureLogLinksIsMutable(); + com.google.protobuf.AbstractMessageLite.Builder.addAll( + values, logLinks_); + onChanged(); + } else { + logLinksBuilder_.addAllMessages(values); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder clearLogLinks() { + if (logLinksBuilder_ == null) { + logLinks_ = java.util.Collections.emptyList(); + bitField0_ = (bitField0_ & ~0x00000008); + onChanged(); + } else { + logLinksBuilder_.clear(); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public Builder removeLogLinks(int index) { + if (logLinksBuilder_ == null) { + ensureLogLinksIsMutable(); + logLinks_.remove(index); + onChanged(); + } else { + logLinksBuilder_.remove(index); + } + return this; + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public flyteidl.core.Execution.TaskLog.Builder getLogLinksBuilder( + int index) { + return getLogLinksFieldBuilder().getBuilder(index); + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public flyteidl.core.Execution.TaskLogOrBuilder getLogLinksOrBuilder( + int index) { + if (logLinksBuilder_ == null) { + return logLinks_.get(index); } else { + return logLinksBuilder_.getMessageOrBuilder(index); + } + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public java.util.List + getLogLinksOrBuilderList() { + if (logLinksBuilder_ != null) { + return logLinksBuilder_.getMessageOrBuilderList(); + } else { + return java.util.Collections.unmodifiableList(logLinks_); + } + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public flyteidl.core.Execution.TaskLog.Builder addLogLinksBuilder() { + return getLogLinksFieldBuilder().addBuilder( + flyteidl.core.Execution.TaskLog.getDefaultInstance()); + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public flyteidl.core.Execution.TaskLog.Builder addLogLinksBuilder( + int index) { + return getLogLinksFieldBuilder().addBuilder( + index, flyteidl.core.Execution.TaskLog.getDefaultInstance()); + } + /** + *
+       * log information for the task execution.
+       * 
+ * + * repeated .flyteidl.core.TaskLog log_links = 4; + */ + public java.util.List + getLogLinksBuilderList() { + return getLogLinksFieldBuilder().getBuilderList(); + } + private com.google.protobuf.RepeatedFieldBuilderV3< + flyteidl.core.Execution.TaskLog, flyteidl.core.Execution.TaskLog.Builder, flyteidl.core.Execution.TaskLogOrBuilder> + getLogLinksFieldBuilder() { + if (logLinksBuilder_ == null) { + logLinksBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3< + flyteidl.core.Execution.TaskLog, flyteidl.core.Execution.TaskLog.Builder, flyteidl.core.Execution.TaskLogOrBuilder>( + logLinks_, + ((bitField0_ & 0x00000008) != 0), + getParentForChildren(), + isClean()); + logLinks_ = null; + } + return logLinksBuilder_; + } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { @@ -11372,27 +12135,30 @@ public flyteidl.admin.AgentOuterClass.ListAgentsResponse getDefaultInstanceForTy "p\022-\n\010template\030\002 \001(\0132\033.flyteidl.core.Task" + "Template\022\025\n\routput_prefix\030\003 \001(\t\022F\n\027task_" + "execution_metadata\030\004 \001(\0132%.flyteidl.admi" + - "n.TaskExecutionMetadata\"+\n\022CreateTaskRes" + - "ponse\022\025\n\rresource_meta\030\001 \001(\014\":\n\016GetTaskR" + - "equest\022\021\n\ttask_type\030\001 \001(\t\022\025\n\rresource_me" + - "ta\030\002 \001(\014\"h\n\017GetTaskResponse\022*\n\010resource\030" + - "\001 \001(\0132\030.flyteidl.admin.Resource\022)\n\tlog_l" + - "inks\030\002 \003(\0132\026.flyteidl.core.TaskLog\"m\n\010Re" + - "source\022$\n\005state\030\001 \001(\0162\025.flyteidl.admin.S" + - "tate\022*\n\007outputs\030\002 \001(\0132\031.flyteidl.core.Li" + - "teralMap\022\017\n\007message\030\003 \001(\t\"=\n\021DeleteTaskR" + - "equest\022\021\n\ttask_type\030\001 \001(\t\022\025\n\rresource_me" + - "ta\030\002 \001(\014\"\024\n\022DeleteTaskResponse\"3\n\005Agent\022" + - "\014\n\004name\030\001 \001(\t\022\034\n\024supported_task_types\030\002 " + - "\003(\t\"\037\n\017GetAgentRequest\022\014\n\004name\030\001 \001(\t\"8\n\020" + - "GetAgentResponse\022$\n\005agent\030\001 \001(\0132\025.flytei" + - "dl.admin.Agent\"\023\n\021ListAgentsRequest\";\n\022L" + - "istAgentsResponse\022%\n\006agents\030\001 \003(\0132\025.flyt" + - "eidl.admin.Agent*^\n\005State\022\025\n\021RETRYABLE_F" + - "AILURE\020\000\022\025\n\021PERMANENT_FAILURE\020\001\022\013\n\007PENDI" + - "NG\020\002\022\013\n\007RUNNING\020\003\022\r\n\tSUCCEEDED\020\004B=Z;gith" + - "ub.com/flyteorg/flyte/flyteidl/gen/pb-go" + - "/flyteidl/adminb\006proto3" + "n.TaskExecutionMetadata\"b\n\022CreateTaskRes" + + "ponse\022\027\n\rresource_meta\030\001 \001(\014H\000\022,\n\010resour" + + "ce\030\002 \001(\0132\030.flyteidl.admin.ResourceH\000B\005\n\003" + + "res\":\n\016GetTaskRequest\022\021\n\ttask_type\030\001 \001(\t" + + "\022\025\n\rresource_meta\030\002 \001(\014\"h\n\017GetTaskRespon" + + "se\022*\n\010resource\030\001 \001(\0132\030.flyteidl.admin.Re" + + "source\022)\n\tlog_links\030\002 \003(\0132\026.flyteidl.cor" + + "e.TaskLog\"\230\001\n\010Resource\022$\n\005state\030\001 \001(\0162\025." + + "flyteidl.admin.State\022*\n\007outputs\030\002 \001(\0132\031." + + "flyteidl.core.LiteralMap\022\017\n\007message\030\003 \001(" + + "\t\022)\n\tlog_links\030\004 \003(\0132\026.flyteidl.core.Tas" + + "kLog\"=\n\021DeleteTaskRequest\022\021\n\ttask_type\030\001" + + " \001(\t\022\025\n\rresource_meta\030\002 \001(\014\"\024\n\022DeleteTas" + + "kResponse\"3\n\005Agent\022\014\n\004name\030\001 \001(\t\022\034\n\024supp" + + "orted_task_types\030\002 \003(\t\"\037\n\017GetAgentReques" + + "t\022\014\n\004name\030\001 \001(\t\"8\n\020GetAgentResponse\022$\n\005a" + + "gent\030\001 \001(\0132\025.flyteidl.admin.Agent\"\023\n\021Lis" + + "tAgentsRequest\";\n\022ListAgentsResponse\022%\n\006" + + "agents\030\001 \003(\0132\025.flyteidl.admin.Agent*^\n\005S" + + "tate\022\025\n\021RETRYABLE_FAILURE\020\000\022\025\n\021PERMANENT" + + "_FAILURE\020\001\022\013\n\007PENDING\020\002\022\013\n\007RUNNING\020\003\022\r\n\t" + + "SUCCEEDED\020\004B=Z;github.com/flyteorg/flyte" + + "/flyteidl/gen/pb-go/flyteidl/adminb\006prot" + + "o3" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -11446,7 +12212,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_admin_CreateTaskResponse_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_CreateTaskResponse_descriptor, - new java.lang.String[] { "ResourceMeta", }); + new java.lang.String[] { "ResourceMeta", "Resource", "Res", }); internal_static_flyteidl_admin_GetTaskRequest_descriptor = getDescriptor().getMessageTypes().get(3); internal_static_flyteidl_admin_GetTaskRequest_fieldAccessorTable = new @@ -11464,7 +12230,7 @@ public com.google.protobuf.ExtensionRegistry assignDescriptors( internal_static_flyteidl_admin_Resource_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_flyteidl_admin_Resource_descriptor, - new java.lang.String[] { "State", "Outputs", "Message", }); + new java.lang.String[] { "State", "Outputs", "Message", "LogLinks", }); internal_static_flyteidl_admin_DeleteTaskRequest_descriptor = getDescriptor().getMessageTypes().get(6); internal_static_flyteidl_admin_DeleteTaskRequest_fieldAccessorTable = new diff --git a/flyteidl/gen/pb-js/flyteidl.d.ts b/flyteidl/gen/pb-js/flyteidl.d.ts index 2e0ff4e76c..9570d8dc7b 100644 --- a/flyteidl/gen/pb-js/flyteidl.d.ts +++ b/flyteidl/gen/pb-js/flyteidl.d.ts @@ -8028,6 +8028,9 @@ export namespace flyteidl { /** CreateTaskResponse resourceMeta */ resourceMeta?: (Uint8Array|null); + + /** CreateTaskResponse resource */ + resource?: (flyteidl.admin.IResource|null); } /** Represents a CreateTaskResponse. */ @@ -8042,6 +8045,12 @@ export namespace flyteidl { /** CreateTaskResponse resourceMeta. */ public resourceMeta: Uint8Array; + /** CreateTaskResponse resource. */ + public resource?: (flyteidl.admin.IResource|null); + + /** CreateTaskResponse res. */ + public res?: ("resourceMeta"|"resource"); + /** * Creates a new CreateTaskResponse instance using the specified properties. * @param [properties] Properties to set @@ -8202,6 +8211,9 @@ export namespace flyteidl { /** Resource message */ message?: (string|null); + + /** Resource logLinks */ + logLinks?: (flyteidl.core.ITaskLog[]|null); } /** Represents a Resource. */ @@ -8222,6 +8234,9 @@ export namespace flyteidl { /** Resource message. */ public message: string; + /** Resource logLinks. */ + public logLinks: flyteidl.core.ITaskLog[]; + /** * Creates a new Resource instance using the specified properties. * @param [properties] Properties to set diff --git a/flyteidl/gen/pb-js/flyteidl.js b/flyteidl/gen/pb-js/flyteidl.js index 95f887c3ba..ff88e85cd1 100644 --- a/flyteidl/gen/pb-js/flyteidl.js +++ b/flyteidl/gen/pb-js/flyteidl.js @@ -19663,6 +19663,7 @@ * @memberof flyteidl.admin * @interface ICreateTaskResponse * @property {Uint8Array|null} [resourceMeta] CreateTaskResponse resourceMeta + * @property {flyteidl.admin.IResource|null} [resource] CreateTaskResponse resource */ /** @@ -19688,6 +19689,28 @@ */ CreateTaskResponse.prototype.resourceMeta = $util.newBuffer([]); + /** + * CreateTaskResponse resource. + * @member {flyteidl.admin.IResource|null|undefined} resource + * @memberof flyteidl.admin.CreateTaskResponse + * @instance + */ + CreateTaskResponse.prototype.resource = null; + + // OneOf field names bound to virtual getters and setters + var $oneOfFields; + + /** + * CreateTaskResponse res. + * @member {"resourceMeta"|"resource"|undefined} res + * @memberof flyteidl.admin.CreateTaskResponse + * @instance + */ + Object.defineProperty(CreateTaskResponse.prototype, "res", { + get: $util.oneOfGetter($oneOfFields = ["resourceMeta", "resource"]), + set: $util.oneOfSetter($oneOfFields) + }); + /** * Creates a new CreateTaskResponse instance using the specified properties. * @function create @@ -19714,6 +19737,8 @@ writer = $Writer.create(); if (message.resourceMeta != null && message.hasOwnProperty("resourceMeta")) writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.resourceMeta); + if (message.resource != null && message.hasOwnProperty("resource")) + $root.flyteidl.admin.Resource.encode(message.resource, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); return writer; }; @@ -19738,6 +19763,9 @@ case 1: message.resourceMeta = reader.bytes(); break; + case 2: + message.resource = $root.flyteidl.admin.Resource.decode(reader, reader.uint32()); + break; default: reader.skipType(tag & 7); break; @@ -19757,9 +19785,22 @@ CreateTaskResponse.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; - if (message.resourceMeta != null && message.hasOwnProperty("resourceMeta")) + var properties = {}; + if (message.resourceMeta != null && message.hasOwnProperty("resourceMeta")) { + properties.res = 1; if (!(message.resourceMeta && typeof message.resourceMeta.length === "number" || $util.isString(message.resourceMeta))) return "resourceMeta: buffer expected"; + } + if (message.resource != null && message.hasOwnProperty("resource")) { + if (properties.res === 1) + return "res: multiple values"; + properties.res = 1; + { + var error = $root.flyteidl.admin.Resource.verify(message.resource); + if (error) + return "resource." + error; + } + } return null; }; @@ -20041,6 +20082,7 @@ * @property {flyteidl.admin.State|null} [state] Resource state * @property {flyteidl.core.ILiteralMap|null} [outputs] Resource outputs * @property {string|null} [message] Resource message + * @property {Array.|null} [logLinks] Resource logLinks */ /** @@ -20052,6 +20094,7 @@ * @param {flyteidl.admin.IResource=} [properties] Properties to set */ function Resource(properties) { + this.logLinks = []; if (properties) for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i) if (properties[keys[i]] != null) @@ -20082,6 +20125,14 @@ */ Resource.prototype.message = ""; + /** + * Resource logLinks. + * @member {Array.} logLinks + * @memberof flyteidl.admin.Resource + * @instance + */ + Resource.prototype.logLinks = $util.emptyArray; + /** * Creates a new Resource instance using the specified properties. * @function create @@ -20112,6 +20163,9 @@ $root.flyteidl.core.LiteralMap.encode(message.outputs, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim(); if (message.message != null && message.hasOwnProperty("message")) writer.uint32(/* id 3, wireType 2 =*/26).string(message.message); + if (message.logLinks != null && message.logLinks.length) + for (var i = 0; i < message.logLinks.length; ++i) + $root.flyteidl.core.TaskLog.encode(message.logLinks[i], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim(); return writer; }; @@ -20142,6 +20196,11 @@ case 3: message.message = reader.string(); break; + case 4: + if (!(message.logLinks && message.logLinks.length)) + message.logLinks = []; + message.logLinks.push($root.flyteidl.core.TaskLog.decode(reader, reader.uint32())); + break; default: reader.skipType(tag & 7); break; @@ -20180,6 +20239,15 @@ if (message.message != null && message.hasOwnProperty("message")) if (!$util.isString(message.message)) return "message: string expected"; + if (message.logLinks != null && message.hasOwnProperty("logLinks")) { + if (!Array.isArray(message.logLinks)) + return "logLinks: array expected"; + for (var i = 0; i < message.logLinks.length; ++i) { + var error = $root.flyteidl.core.TaskLog.verify(message.logLinks[i]); + if (error) + return "logLinks." + error; + } + } return null; }; diff --git a/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.py b/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.py index baceaf16c6..5d515cb0c4 100644 --- a/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.py +++ b/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.py @@ -18,7 +18,7 @@ from flyteidl.core import execution_pb2 as flyteidl_dot_core_dot_execution__pb2 -DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1a\x66lyteidl/admin/agent.proto\x12\x0e\x66lyteidl.admin\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x19\x66lyteidl/core/tasks.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/execution.proto\"\x98\x05\n\x15TaskExecutionMetadata\x12R\n\x11task_execution_id\x18\x01 \x01(\x0b\x32&.flyteidl.core.TaskExecutionIdentifierR\x0ftaskExecutionId\x12\x1c\n\tnamespace\x18\x02 \x01(\tR\tnamespace\x12I\n\x06labels\x18\x03 \x03(\x0b\x32\x31.flyteidl.admin.TaskExecutionMetadata.LabelsEntryR\x06labels\x12X\n\x0b\x61nnotations\x18\x04 \x03(\x0b\x32\x36.flyteidl.admin.TaskExecutionMetadata.AnnotationsEntryR\x0b\x61nnotations\x12.\n\x13k8s_service_account\x18\x05 \x01(\tR\x11k8sServiceAccount\x12t\n\x15\x65nvironment_variables\x18\x06 \x03(\x0b\x32?.flyteidl.admin.TaskExecutionMetadata.EnvironmentVariablesEntryR\x14\x65nvironmentVariables\x1a\x39\n\x0bLabelsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1a>\n\x10\x41nnotationsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1aG\n\x19\x45nvironmentVariablesEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\"\x83\x02\n\x11\x43reateTaskRequest\x12\x31\n\x06inputs\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapR\x06inputs\x12\x37\n\x08template\x18\x02 \x01(\x0b\x32\x1b.flyteidl.core.TaskTemplateR\x08template\x12#\n\routput_prefix\x18\x03 \x01(\tR\x0coutputPrefix\x12]\n\x17task_execution_metadata\x18\x04 \x01(\x0b\x32%.flyteidl.admin.TaskExecutionMetadataR\x15taskExecutionMetadata\"9\n\x12\x43reateTaskResponse\x12#\n\rresource_meta\x18\x01 \x01(\x0cR\x0cresourceMeta\"R\n\x0eGetTaskRequest\x12\x1b\n\ttask_type\x18\x01 \x01(\tR\x08taskType\x12#\n\rresource_meta\x18\x02 \x01(\x0cR\x0cresourceMeta\"|\n\x0fGetTaskResponse\x12\x34\n\x08resource\x18\x01 \x01(\x0b\x32\x18.flyteidl.admin.ResourceR\x08resource\x12\x33\n\tlog_links\x18\x02 \x03(\x0b\x32\x16.flyteidl.core.TaskLogR\x08logLinks\"\x86\x01\n\x08Resource\x12+\n\x05state\x18\x01 \x01(\x0e\x32\x15.flyteidl.admin.StateR\x05state\x12\x33\n\x07outputs\x18\x02 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapR\x07outputs\x12\x18\n\x07message\x18\x03 \x01(\tR\x07message\"U\n\x11\x44\x65leteTaskRequest\x12\x1b\n\ttask_type\x18\x01 \x01(\tR\x08taskType\x12#\n\rresource_meta\x18\x02 \x01(\x0cR\x0cresourceMeta\"\x14\n\x12\x44\x65leteTaskResponse\"M\n\x05\x41gent\x12\x12\n\x04name\x18\x01 \x01(\tR\x04name\x12\x30\n\x14supported_task_types\x18\x02 \x03(\tR\x12supportedTaskTypes\"%\n\x0fGetAgentRequest\x12\x12\n\x04name\x18\x01 \x01(\tR\x04name\"?\n\x10GetAgentResponse\x12+\n\x05\x61gent\x18\x01 \x01(\x0b\x32\x15.flyteidl.admin.AgentR\x05\x61gent\"\x13\n\x11ListAgentsRequest\"C\n\x12ListAgentsResponse\x12-\n\x06\x61gents\x18\x01 \x03(\x0b\x32\x15.flyteidl.admin.AgentR\x06\x61gents*^\n\x05State\x12\x15\n\x11RETRYABLE_FAILURE\x10\x00\x12\x15\n\x11PERMANENT_FAILURE\x10\x01\x12\x0b\n\x07PENDING\x10\x02\x12\x0b\n\x07RUNNING\x10\x03\x12\r\n\tSUCCEEDED\x10\x04\x42\xb6\x01\n\x12\x63om.flyteidl.adminB\nAgentProtoP\x01Z;github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin\xa2\x02\x03\x46\x41X\xaa\x02\x0e\x46lyteidl.Admin\xca\x02\x0e\x46lyteidl\\Admin\xe2\x02\x1a\x46lyteidl\\Admin\\GPBMetadata\xea\x02\x0f\x46lyteidl::Adminb\x06proto3') +DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1a\x66lyteidl/admin/agent.proto\x12\x0e\x66lyteidl.admin\x1a\x1c\x66lyteidl/core/literals.proto\x1a\x19\x66lyteidl/core/tasks.proto\x1a\x1d\x66lyteidl/core/interface.proto\x1a\x1e\x66lyteidl/core/identifier.proto\x1a\x1d\x66lyteidl/core/execution.proto\"\x98\x05\n\x15TaskExecutionMetadata\x12R\n\x11task_execution_id\x18\x01 \x01(\x0b\x32&.flyteidl.core.TaskExecutionIdentifierR\x0ftaskExecutionId\x12\x1c\n\tnamespace\x18\x02 \x01(\tR\tnamespace\x12I\n\x06labels\x18\x03 \x03(\x0b\x32\x31.flyteidl.admin.TaskExecutionMetadata.LabelsEntryR\x06labels\x12X\n\x0b\x61nnotations\x18\x04 \x03(\x0b\x32\x36.flyteidl.admin.TaskExecutionMetadata.AnnotationsEntryR\x0b\x61nnotations\x12.\n\x13k8s_service_account\x18\x05 \x01(\tR\x11k8sServiceAccount\x12t\n\x15\x65nvironment_variables\x18\x06 \x03(\x0b\x32?.flyteidl.admin.TaskExecutionMetadata.EnvironmentVariablesEntryR\x14\x65nvironmentVariables\x1a\x39\n\x0bLabelsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1a>\n\x10\x41nnotationsEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\x1aG\n\x19\x45nvironmentVariablesEntry\x12\x10\n\x03key\x18\x01 \x01(\tR\x03key\x12\x14\n\x05value\x18\x02 \x01(\tR\x05value:\x02\x38\x01\"\x83\x02\n\x11\x43reateTaskRequest\x12\x31\n\x06inputs\x18\x01 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapR\x06inputs\x12\x37\n\x08template\x18\x02 \x01(\x0b\x32\x1b.flyteidl.core.TaskTemplateR\x08template\x12#\n\routput_prefix\x18\x03 \x01(\tR\x0coutputPrefix\x12]\n\x17task_execution_metadata\x18\x04 \x01(\x0b\x32%.flyteidl.admin.TaskExecutionMetadataR\x15taskExecutionMetadata\"z\n\x12\x43reateTaskResponse\x12%\n\rresource_meta\x18\x01 \x01(\x0cH\x00R\x0cresourceMeta\x12\x36\n\x08resource\x18\x02 \x01(\x0b\x32\x18.flyteidl.admin.ResourceH\x00R\x08resourceB\x05\n\x03res\"R\n\x0eGetTaskRequest\x12\x1b\n\ttask_type\x18\x01 \x01(\tR\x08taskType\x12#\n\rresource_meta\x18\x02 \x01(\x0cR\x0cresourceMeta\"|\n\x0fGetTaskResponse\x12\x34\n\x08resource\x18\x01 \x01(\x0b\x32\x18.flyteidl.admin.ResourceR\x08resource\x12\x33\n\tlog_links\x18\x02 \x03(\x0b\x32\x16.flyteidl.core.TaskLogR\x08logLinks\"\xbb\x01\n\x08Resource\x12+\n\x05state\x18\x01 \x01(\x0e\x32\x15.flyteidl.admin.StateR\x05state\x12\x33\n\x07outputs\x18\x02 \x01(\x0b\x32\x19.flyteidl.core.LiteralMapR\x07outputs\x12\x18\n\x07message\x18\x03 \x01(\tR\x07message\x12\x33\n\tlog_links\x18\x04 \x03(\x0b\x32\x16.flyteidl.core.TaskLogR\x08logLinks\"U\n\x11\x44\x65leteTaskRequest\x12\x1b\n\ttask_type\x18\x01 \x01(\tR\x08taskType\x12#\n\rresource_meta\x18\x02 \x01(\x0cR\x0cresourceMeta\"\x14\n\x12\x44\x65leteTaskResponse\"M\n\x05\x41gent\x12\x12\n\x04name\x18\x01 \x01(\tR\x04name\x12\x30\n\x14supported_task_types\x18\x02 \x03(\tR\x12supportedTaskTypes\"%\n\x0fGetAgentRequest\x12\x12\n\x04name\x18\x01 \x01(\tR\x04name\"?\n\x10GetAgentResponse\x12+\n\x05\x61gent\x18\x01 \x01(\x0b\x32\x15.flyteidl.admin.AgentR\x05\x61gent\"\x13\n\x11ListAgentsRequest\"C\n\x12ListAgentsResponse\x12-\n\x06\x61gents\x18\x01 \x03(\x0b\x32\x15.flyteidl.admin.AgentR\x06\x61gents*^\n\x05State\x12\x15\n\x11RETRYABLE_FAILURE\x10\x00\x12\x15\n\x11PERMANENT_FAILURE\x10\x01\x12\x0b\n\x07PENDING\x10\x02\x12\x0b\n\x07RUNNING\x10\x03\x12\r\n\tSUCCEEDED\x10\x04\x42\xb6\x01\n\x12\x63om.flyteidl.adminB\nAgentProtoP\x01Z;github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin\xa2\x02\x03\x46\x41X\xaa\x02\x0e\x46lyteidl.Admin\xca\x02\x0e\x46lyteidl\\Admin\xe2\x02\x1a\x46lyteidl\\Admin\\GPBMetadata\xea\x02\x0f\x46lyteidl::Adminb\x06proto3') _globals = globals() _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals) @@ -33,8 +33,8 @@ _TASKEXECUTIONMETADATA_ANNOTATIONSENTRY._serialized_options = b'8\001' _TASKEXECUTIONMETADATA_ENVIRONMENTVARIABLESENTRY._options = None _TASKEXECUTIONMETADATA_ENVIRONMENTVARIABLESENTRY._serialized_options = b'8\001' - _globals['_STATE']._serialized_start=1914 - _globals['_STATE']._serialized_end=2008 + _globals['_STATE']._serialized_start=2032 + _globals['_STATE']._serialized_end=2126 _globals['_TASKEXECUTIONMETADATA']._serialized_start=198 _globals['_TASKEXECUTIONMETADATA']._serialized_end=862 _globals['_TASKEXECUTIONMETADATA_LABELSENTRY']._serialized_start=668 @@ -46,25 +46,25 @@ _globals['_CREATETASKREQUEST']._serialized_start=865 _globals['_CREATETASKREQUEST']._serialized_end=1124 _globals['_CREATETASKRESPONSE']._serialized_start=1126 - _globals['_CREATETASKRESPONSE']._serialized_end=1183 - _globals['_GETTASKREQUEST']._serialized_start=1185 - _globals['_GETTASKREQUEST']._serialized_end=1267 - _globals['_GETTASKRESPONSE']._serialized_start=1269 - _globals['_GETTASKRESPONSE']._serialized_end=1393 - _globals['_RESOURCE']._serialized_start=1396 - _globals['_RESOURCE']._serialized_end=1530 - _globals['_DELETETASKREQUEST']._serialized_start=1532 - _globals['_DELETETASKREQUEST']._serialized_end=1617 - _globals['_DELETETASKRESPONSE']._serialized_start=1619 - _globals['_DELETETASKRESPONSE']._serialized_end=1639 - _globals['_AGENT']._serialized_start=1641 - _globals['_AGENT']._serialized_end=1718 - _globals['_GETAGENTREQUEST']._serialized_start=1720 - _globals['_GETAGENTREQUEST']._serialized_end=1757 - _globals['_GETAGENTRESPONSE']._serialized_start=1759 - _globals['_GETAGENTRESPONSE']._serialized_end=1822 - _globals['_LISTAGENTSREQUEST']._serialized_start=1824 - _globals['_LISTAGENTSREQUEST']._serialized_end=1843 - _globals['_LISTAGENTSRESPONSE']._serialized_start=1845 - _globals['_LISTAGENTSRESPONSE']._serialized_end=1912 + _globals['_CREATETASKRESPONSE']._serialized_end=1248 + _globals['_GETTASKREQUEST']._serialized_start=1250 + _globals['_GETTASKREQUEST']._serialized_end=1332 + _globals['_GETTASKRESPONSE']._serialized_start=1334 + _globals['_GETTASKRESPONSE']._serialized_end=1458 + _globals['_RESOURCE']._serialized_start=1461 + _globals['_RESOURCE']._serialized_end=1648 + _globals['_DELETETASKREQUEST']._serialized_start=1650 + _globals['_DELETETASKREQUEST']._serialized_end=1735 + _globals['_DELETETASKRESPONSE']._serialized_start=1737 + _globals['_DELETETASKRESPONSE']._serialized_end=1757 + _globals['_AGENT']._serialized_start=1759 + _globals['_AGENT']._serialized_end=1836 + _globals['_GETAGENTREQUEST']._serialized_start=1838 + _globals['_GETAGENTREQUEST']._serialized_end=1875 + _globals['_GETAGENTRESPONSE']._serialized_start=1877 + _globals['_GETAGENTRESPONSE']._serialized_end=1940 + _globals['_LISTAGENTSREQUEST']._serialized_start=1942 + _globals['_LISTAGENTSREQUEST']._serialized_end=1961 + _globals['_LISTAGENTSRESPONSE']._serialized_start=1963 + _globals['_LISTAGENTSRESPONSE']._serialized_end=2030 # @@protoc_insertion_point(module_scope) diff --git a/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.pyi b/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.pyi index d184c997b7..3b80e41b58 100644 --- a/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.pyi +++ b/flyteidl/gen/pb_python/flyteidl/admin/agent_pb2.pyi @@ -74,10 +74,12 @@ class CreateTaskRequest(_message.Message): def __init__(self, inputs: _Optional[_Union[_literals_pb2.LiteralMap, _Mapping]] = ..., template: _Optional[_Union[_tasks_pb2.TaskTemplate, _Mapping]] = ..., output_prefix: _Optional[str] = ..., task_execution_metadata: _Optional[_Union[TaskExecutionMetadata, _Mapping]] = ...) -> None: ... class CreateTaskResponse(_message.Message): - __slots__ = ["resource_meta"] + __slots__ = ["resource_meta", "resource"] RESOURCE_META_FIELD_NUMBER: _ClassVar[int] + RESOURCE_FIELD_NUMBER: _ClassVar[int] resource_meta: bytes - def __init__(self, resource_meta: _Optional[bytes] = ...) -> None: ... + resource: Resource + def __init__(self, resource_meta: _Optional[bytes] = ..., resource: _Optional[_Union[Resource, _Mapping]] = ...) -> None: ... class GetTaskRequest(_message.Message): __slots__ = ["task_type", "resource_meta"] @@ -96,14 +98,16 @@ class GetTaskResponse(_message.Message): def __init__(self, resource: _Optional[_Union[Resource, _Mapping]] = ..., log_links: _Optional[_Iterable[_Union[_execution_pb2.TaskLog, _Mapping]]] = ...) -> None: ... class Resource(_message.Message): - __slots__ = ["state", "outputs", "message"] + __slots__ = ["state", "outputs", "message", "log_links"] STATE_FIELD_NUMBER: _ClassVar[int] OUTPUTS_FIELD_NUMBER: _ClassVar[int] MESSAGE_FIELD_NUMBER: _ClassVar[int] + LOG_LINKS_FIELD_NUMBER: _ClassVar[int] state: State outputs: _literals_pb2.LiteralMap message: str - def __init__(self, state: _Optional[_Union[State, str]] = ..., outputs: _Optional[_Union[_literals_pb2.LiteralMap, _Mapping]] = ..., message: _Optional[str] = ...) -> None: ... + log_links: _containers.RepeatedCompositeFieldContainer[_execution_pb2.TaskLog] + def __init__(self, state: _Optional[_Union[State, str]] = ..., outputs: _Optional[_Union[_literals_pb2.LiteralMap, _Mapping]] = ..., message: _Optional[str] = ..., log_links: _Optional[_Iterable[_Union[_execution_pb2.TaskLog, _Mapping]]] = ...) -> None: ... class DeleteTaskRequest(_message.Message): __slots__ = ["task_type", "resource_meta"] diff --git a/flyteidl/gen/pb_rust/flyteidl.admin.rs b/flyteidl/gen/pb_rust/flyteidl.admin.rs index 3758f6d90e..692a1ee5e7 100644 --- a/flyteidl/gen/pb_rust/flyteidl.admin.rs +++ b/flyteidl/gen/pb_rust/flyteidl.admin.rs @@ -46,8 +46,22 @@ pub struct CreateTaskRequest { #[derive(Clone, PartialEq, ::prost::Message)] pub struct CreateTaskResponse { /// Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata). - #[prost(bytes="vec", tag="1")] - pub resource_meta: ::prost::alloc::vec::Vec, + /// Resource is for synchronous task execution. + #[prost(oneof="create_task_response::Res", tags="1, 2")] + pub res: ::core::option::Option, +} +/// Nested message and enum types in `CreateTaskResponse`. +pub mod create_task_response { + /// Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata). + /// Resource is for synchronous task execution. + #[allow(clippy::derive_partial_eq_without_eq)] +#[derive(Clone, PartialEq, ::prost::Oneof)] + pub enum Res { + #[prost(bytes, tag="1")] + ResourceMeta(::prost::alloc::vec::Vec), + #[prost(message, tag="2")] + Resource(super::Resource), + } } /// A message used to fetch a job resource from flyte agent server. #[allow(clippy::derive_partial_eq_without_eq)] @@ -84,6 +98,9 @@ pub struct Resource { /// A descriptive message for the current state. e.g. waiting for cluster. #[prost(string, tag="3")] pub message: ::prost::alloc::string::String, + /// log information for the task execution. + #[prost(message, repeated, tag="4")] + pub log_links: ::prost::alloc::vec::Vec, } /// A message used to delete a task. #[allow(clippy::derive_partial_eq_without_eq)] diff --git a/flyteidl/protos/flyteidl/admin/agent.proto b/flyteidl/protos/flyteidl/admin/agent.proto index 98ab21cd07..778fcc99d0 100644 --- a/flyteidl/protos/flyteidl/admin/agent.proto +++ b/flyteidl/protos/flyteidl/admin/agent.proto @@ -51,7 +51,11 @@ message CreateTaskRequest { // Represents a create response structure. message CreateTaskResponse { // Metadata is created by the agent. It could be a string (jobId) or a dict (more complex metadata). - bytes resource_meta = 1; + // Resource is for synchronous task execution. + oneof res { + bytes resource_meta = 1; + Resource resource = 2; + } } // A message used to fetch a job resource from flyte agent server. @@ -79,6 +83,8 @@ message Resource { core.LiteralMap outputs = 2; // A descriptive message for the current state. e.g. waiting for cluster. string message = 3; + // log information for the task execution. + repeated core.TaskLog log_links = 4; } // A message used to delete a task. diff --git a/flyteplugins/go/tasks/pluginmachinery/internal/webapi/core.go b/flyteplugins/go/tasks/pluginmachinery/internal/webapi/core.go index d51209a77c..a23f985fc6 100644 --- a/flyteplugins/go/tasks/pluginmachinery/internal/webapi/core.go +++ b/flyteplugins/go/tasks/pluginmachinery/internal/webapi/core.go @@ -73,6 +73,7 @@ func (c CorePlugin) Handle(ctx context.Context, tCtx core.TaskExecutionContext) var nextState *State var phaseInfo core.PhaseInfo + switch incomingState.Phase { case PhaseNotStarted: if len(c.p.GetConfig().ResourceQuotas) > 0 { @@ -123,6 +124,7 @@ func (c CorePlugin) Finalize(ctx context.Context, tCtx core.TaskExecutionContext logger.Infof(ctx, "Attempting to finalize resource [%v].", tCtx.TaskExecutionMetadata().GetTaskExecutionID().GetGeneratedName()) + return c.tokenAllocator.releaseToken(ctx, c.p, tCtx, c.metrics) } diff --git a/flyteplugins/go/tasks/pluginmachinery/webapi/mocks/plugin.go b/flyteplugins/go/tasks/pluginmachinery/webapi/mocks/plugin.go new file mode 100644 index 0000000000..1e255ca1fa --- /dev/null +++ b/flyteplugins/go/tasks/pluginmachinery/webapi/mocks/plugin.go @@ -0,0 +1,45 @@ +// Code generated by mockery v1.0.1. DO NOT EDIT. + +package mocks + +import ( + webapi "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/webapi" + mock "github.com/stretchr/testify/mock" +) + +// Plugin is an autogenerated mock type for the Plugin type +type Plugin struct { + mock.Mock +} + +type Plugin_GetConfig struct { + *mock.Call +} + +func (_m Plugin_GetConfig) Return(_a0 webapi.PluginConfig) *Plugin_GetConfig { + return &Plugin_GetConfig{Call: _m.Call.Return(_a0)} +} + +func (_m *Plugin) OnGetConfig() *Plugin_GetConfig { + c_call := _m.On("GetConfig") + return &Plugin_GetConfig{Call: c_call} +} + +func (_m *Plugin) OnGetConfigMatch(matchers ...interface{}) *Plugin_GetConfig { + c_call := _m.On("GetConfig", matchers...) + return &Plugin_GetConfig{Call: c_call} +} + +// GetConfig provides a mock function with given fields: +func (_m *Plugin) GetConfig() webapi.PluginConfig { + ret := _m.Called() + + var r0 webapi.PluginConfig + if rf, ok := ret.Get(0).(func() webapi.PluginConfig); ok { + r0 = rf() + } else { + r0 = ret.Get(0).(webapi.PluginConfig) + } + + return r0 +} diff --git a/flyteplugins/go/tasks/pluginmachinery/webapi/mocks/sync_plugin.go b/flyteplugins/go/tasks/pluginmachinery/webapi/mocks/sync_plugin.go deleted file mode 100644 index cfe5d38090..0000000000 --- a/flyteplugins/go/tasks/pluginmachinery/webapi/mocks/sync_plugin.go +++ /dev/null @@ -1,88 +0,0 @@ -// Code generated by mockery v1.0.1. DO NOT EDIT. - -package mocks - -import ( - context "context" - - core "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/core" - mock "github.com/stretchr/testify/mock" - - webapi "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/webapi" -) - -// SyncPlugin is an autogenerated mock type for the SyncPlugin type -type SyncPlugin struct { - mock.Mock -} - -type SyncPlugin_Do struct { - *mock.Call -} - -func (_m SyncPlugin_Do) Return(phase core.PhaseInfo, err error) *SyncPlugin_Do { - return &SyncPlugin_Do{Call: _m.Call.Return(phase, err)} -} - -func (_m *SyncPlugin) OnDo(ctx context.Context, tCtx webapi.TaskExecutionContext) *SyncPlugin_Do { - c_call := _m.On("Do", ctx, tCtx) - return &SyncPlugin_Do{Call: c_call} -} - -func (_m *SyncPlugin) OnDoMatch(matchers ...interface{}) *SyncPlugin_Do { - c_call := _m.On("Do", matchers...) - return &SyncPlugin_Do{Call: c_call} -} - -// Do provides a mock function with given fields: ctx, tCtx -func (_m *SyncPlugin) Do(ctx context.Context, tCtx webapi.TaskExecutionContext) (core.PhaseInfo, error) { - ret := _m.Called(ctx, tCtx) - - var r0 core.PhaseInfo - if rf, ok := ret.Get(0).(func(context.Context, webapi.TaskExecutionContext) core.PhaseInfo); ok { - r0 = rf(ctx, tCtx) - } else { - r0 = ret.Get(0).(core.PhaseInfo) - } - - var r1 error - if rf, ok := ret.Get(1).(func(context.Context, webapi.TaskExecutionContext) error); ok { - r1 = rf(ctx, tCtx) - } else { - r1 = ret.Error(1) - } - - return r0, r1 -} - -type SyncPlugin_GetConfig struct { - *mock.Call -} - -func (_m SyncPlugin_GetConfig) Return(_a0 webapi.PluginConfig) *SyncPlugin_GetConfig { - return &SyncPlugin_GetConfig{Call: _m.Call.Return(_a0)} -} - -func (_m *SyncPlugin) OnGetConfig() *SyncPlugin_GetConfig { - c_call := _m.On("GetConfig") - return &SyncPlugin_GetConfig{Call: c_call} -} - -func (_m *SyncPlugin) OnGetConfigMatch(matchers ...interface{}) *SyncPlugin_GetConfig { - c_call := _m.On("GetConfig", matchers...) - return &SyncPlugin_GetConfig{Call: c_call} -} - -// GetConfig provides a mock function with given fields: -func (_m *SyncPlugin) GetConfig() webapi.PluginConfig { - ret := _m.Called() - - var r0 webapi.PluginConfig - if rf, ok := ret.Get(0).(func() webapi.PluginConfig); ok { - r0 = rf() - } else { - r0 = ret.Get(0).(webapi.PluginConfig) - } - - return r0 -} diff --git a/flyteplugins/go/tasks/plugins/webapi/agent/integration_test.go b/flyteplugins/go/tasks/plugins/webapi/agent/integration_test.go index 15375a8580..827af0d907 100644 --- a/flyteplugins/go/tasks/plugins/webapi/agent/integration_test.go +++ b/flyteplugins/go/tasks/plugins/webapi/agent/integration_test.go @@ -37,18 +37,24 @@ type MockPlugin struct { Plugin } -type MockClient struct { +type MockAsyncTask struct { } -func (m *MockClient) CreateTask(_ context.Context, createTaskRequest *admin.CreateTaskRequest, _ ...grpc.CallOption) (*admin.CreateTaskResponse, error) { +type MockSyncTask struct { +} + +func (m *MockAsyncTask) CreateTask(_ context.Context, createTaskRequest *admin.CreateTaskRequest, _ ...grpc.CallOption) (*admin.CreateTaskResponse, error) { expectedArgs := []string{"pyflyte-fast-execute", "--output-prefix", "fake://bucket/prefix/nhv"} if slices.Equal(createTaskRequest.Template.GetContainer().Args, expectedArgs) { return nil, fmt.Errorf("args not as expected") } - return &admin.CreateTaskResponse{ResourceMeta: []byte{1, 2, 3, 4}}, nil + return &admin.CreateTaskResponse{ + Res: &admin.CreateTaskResponse_ResourceMeta{ + ResourceMeta: []byte{1, 2, 3, 4}, + }}, nil } -func (m *MockClient) GetTask(_ context.Context, req *admin.GetTaskRequest, _ ...grpc.CallOption) (*admin.GetTaskResponse, error) { +func (m *MockAsyncTask) GetTask(_ context.Context, req *admin.GetTaskRequest, _ ...grpc.CallOption) (*admin.GetTaskResponse, error) { if req.GetTaskType() == "bigquery_query_job_task" { return &admin.GetTaskResponse{Resource: &admin.Resource{State: admin.State_SUCCEEDED, Outputs: &flyteIdlCore.LiteralMap{ Literals: map[string]*flyteIdlCore.Literal{ @@ -59,15 +65,50 @@ func (m *MockClient) GetTask(_ context.Context, req *admin.GetTaskRequest, _ ... return &admin.GetTaskResponse{Resource: &admin.Resource{State: admin.State_SUCCEEDED}}, nil } -func (m *MockClient) DeleteTask(_ context.Context, _ *admin.DeleteTaskRequest, _ ...grpc.CallOption) (*admin.DeleteTaskResponse, error) { +func (m *MockAsyncTask) DeleteTask(_ context.Context, _ *admin.DeleteTaskRequest, _ ...grpc.CallOption) (*admin.DeleteTaskResponse, error) { return &admin.DeleteTaskResponse{}, nil } -func mockGetClientFunc(_ context.Context, _ *Agent, _ map[*Agent]*grpc.ClientConn) (service.AsyncAgentServiceClient, error) { - return &MockClient{}, nil +func (m *MockSyncTask) CreateTask(_ context.Context, createTaskRequest *admin.CreateTaskRequest, _ ...grpc.CallOption) (*admin.CreateTaskResponse, error) { + return &admin.CreateTaskResponse{ + Res: &admin.CreateTaskResponse_Resource{ + Resource: &admin.Resource{ + State: admin.State_SUCCEEDED, + Outputs: &flyteIdlCore.LiteralMap{ + Literals: map[string]*flyteIdlCore.Literal{}, + }, + Message: "Sync task finished", + LogLinks: []*flyteIdlCore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, + }, + }, + }, nil + +} + +func (m *MockSyncTask) GetTask(_ context.Context, req *admin.GetTaskRequest, _ ...grpc.CallOption) (*admin.GetTaskResponse, error) { + if req.GetTaskType() == "fake_task" { + return &admin.GetTaskResponse{Resource: &admin.Resource{State: admin.State_SUCCEEDED, Outputs: &flyteIdlCore.LiteralMap{ + Literals: map[string]*flyteIdlCore.Literal{ + "arr": coreutils.MustMakeLiteral([]interface{}{[]interface{}{"a", "b"}, []interface{}{1, 2}}), + }, + }}}, nil + } + return &admin.GetTaskResponse{Resource: &admin.Resource{State: admin.State_SUCCEEDED}}, nil +} + +func (m *MockSyncTask) DeleteTask(_ context.Context, _ *admin.DeleteTaskRequest, _ ...grpc.CallOption) (*admin.DeleteTaskResponse, error) { + return &admin.DeleteTaskResponse{}, nil } -func mockGetBadClientFunc(_ context.Context, _ *Agent, _ map[*Agent]*grpc.ClientConn) (service.AsyncAgentServiceClient, error) { +func mockAsyncTaskClientFunc(_ context.Context, _ *Agent, _ map[*Agent]*grpc.ClientConn) (service.AsyncAgentServiceClient, error) { + return &MockAsyncTask{}, nil +} + +func mockSyncTaskClientFunc(_ context.Context, _ *Agent, _ map[*Agent]*grpc.ClientConn) (service.AsyncAgentServiceClient, error) { + return &MockSyncTask{}, nil +} + +func mockGetBadAsyncClientFunc(_ context.Context, _ *Agent, _ map[*Agent]*grpc.ClientConn) (service.AsyncAgentServiceClient, error) { return nil, fmt.Errorf("error") } @@ -130,7 +171,7 @@ func TestEndToEnd(t *testing.T) { Plugin{ metricScope: iCtx.MetricsScope(), cfg: GetConfig(), - getClient: mockGetBadClientFunc, + getClient: mockGetBadAsyncClientFunc, }, }, nil } @@ -234,6 +275,11 @@ func getTaskContext(t *testing.T) *pluginCoreMocks.TaskExecutionContext { }) tMeta := &pluginCoreMocks.TaskExecutionMetadata{} tMeta.OnGetTaskExecutionID().Return(tID) + tMeta.OnGetNamespace().Return("test-namespace") + tMeta.OnGetLabels().Return(map[string]string{"foo": "bar"}) + tMeta.OnGetAnnotations().Return(map[string]string{"foo": "bar"}) + tMeta.OnGetK8sServiceAccount().Return("k8s-account") + tMeta.OnGetEnvironmentVariables().Return(map[string]string{"foo": "bar"}) resourceManager := &pluginCoreMocks.ResourceManager{} resourceManager.OnAllocateResourceMatch(mock.Anything, mock.Anything, mock.Anything, mock.Anything).Return(pluginCore.AllocationStatusGranted, nil) resourceManager.OnReleaseResourceMatch(mock.Anything, mock.Anything, mock.Anything).Return(nil) @@ -259,13 +305,29 @@ func getTaskContext(t *testing.T) *pluginCoreMocks.TaskExecutionContext { func newMockAgentPlugin() webapi.PluginEntry { return webapi.PluginEntry{ ID: "agent-service", - SupportedTaskTypes: []core.TaskType{"bigquery_query_job_task", "spark_job"}, + SupportedTaskTypes: []core.TaskType{"bigquery_query_job_task", "spark_job", "api_task"}, + PluginLoader: func(ctx context.Context, iCtx webapi.PluginSetupContext) (webapi.AsyncPlugin, error) { + return &MockPlugin{ + Plugin{ + metricScope: iCtx.MetricsScope(), + cfg: GetConfig(), + getClient: mockAsyncTaskClientFunc, + }, + }, nil + }, + } +} + +func newMockSyncAgentPlugin() webapi.PluginEntry { + return webapi.PluginEntry{ + ID: "agent-service", + SupportedTaskTypes: []core.TaskType{"bigquery_query_job_task", "spark_job", "api_task"}, PluginLoader: func(ctx context.Context, iCtx webapi.PluginSetupContext) (webapi.AsyncPlugin, error) { return &MockPlugin{ Plugin{ metricScope: iCtx.MetricsScope(), cfg: GetConfig(), - getClient: mockGetClientFunc, + getClient: mockSyncTaskClientFunc, }, }, nil }, diff --git a/flyteplugins/go/tasks/plugins/webapi/agent/plugin.go b/flyteplugins/go/tasks/plugins/webapi/agent/plugin.go index 6230dc14f8..73a98782bc 100644 --- a/flyteplugins/go/tasks/plugins/webapi/agent/plugin.go +++ b/flyteplugins/go/tasks/plugins/webapi/agent/plugin.go @@ -115,12 +115,26 @@ func (p Plugin) Create(ctx context.Context, taskCtx webapi.TaskExecutionContextR taskTemplate.GetContainer().Args = argTemplate } + // If the agent returned a resource, we assume this is a synchronous task. + // The state should be a terminal state, for example, SUCCEEDED, PERMANENT_FAILURE, or RETRYABLE_FAILURE. + if res.GetResource() != nil { + logger.Infof(ctx, "Agent is executing a synchronous task.") + return nil, + ResourceWrapper{ + State: res.GetResource().State, + Outputs: res.GetResource().Outputs, + Message: res.GetResource().Message, + LogLinks: res.GetResource().LogLinks, + }, nil + } + + logger.Infof(ctx, "Agent is executing an asynchronous task.") return ResourceMetaWrapper{ OutputPrefix: outputPrefix, AgentResourceMeta: res.GetResourceMeta(), Token: "", TaskType: taskTemplate.Type, - }, ResourceWrapper{State: admin.State_RUNNING}, nil + }, nil, nil } func (p Plugin) Get(ctx context.Context, taskCtx webapi.GetContext) (latest webapi.Resource, err error) { @@ -209,7 +223,7 @@ func writeOutput(ctx context.Context, taskCtx webapi.StatusContext, resource Res var opReader io.OutputReader if resource.Outputs != nil { - logger.Debugf(ctx, "Agent returned an output") + logger.Debugf(ctx, "Agent returned an output.") opReader = ioutils.NewInMemoryOutputReader(resource.Outputs, nil, nil) } else { logger.Debugf(ctx, "Agent didn't return any output, assuming file based outputs.") diff --git a/flyteplugins/go/tasks/plugins/webapi/agent/plugin_test.go b/flyteplugins/go/tasks/plugins/webapi/agent/plugin_test.go index 779fb597c1..b9fd7e1b35 100644 --- a/flyteplugins/go/tasks/plugins/webapi/agent/plugin_test.go +++ b/flyteplugins/go/tasks/plugins/webapi/agent/plugin_test.go @@ -11,17 +11,52 @@ import ( "golang.org/x/exp/maps" "google.golang.org/grpc" + "github.com/flyteorg/flyte/flyteidl/clients/go/coreutils" "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/admin" - flyteidlcore "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/core" + flyteIdlCore "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/core" "github.com/flyteorg/flyte/flyteidl/gen/pb-go/flyteidl/service" + "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery" pluginsCore "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/core" pluginCoreMocks "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/core/mocks" + ioMocks "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/io/mocks" webapiPlugin "github.com/flyteorg/flyte/flyteplugins/go/tasks/pluginmachinery/webapi/mocks" agentMocks "github.com/flyteorg/flyte/flyteplugins/go/tasks/plugins/webapi/agent/mocks" + "github.com/flyteorg/flyte/flyteplugins/tests" "github.com/flyteorg/flyte/flytestdlib/config" "github.com/flyteorg/flyte/flytestdlib/promutils" + "github.com/flyteorg/flyte/flytestdlib/storage" ) +func TestSyncTask(t *testing.T) { + tCtx := getTaskContext(t) + taskReader := new(pluginCoreMocks.TaskReader) + + template := flyteIdlCore.TaskTemplate{ + Type: "api_task", + } + + taskReader.On("Read", mock.Anything).Return(&template, nil) + + tCtx.OnTaskReader().Return(taskReader) + + agentPlugin := newMockSyncAgentPlugin() + pluginEntry := pluginmachinery.CreateRemotePlugin(agentPlugin) + plugin, err := pluginEntry.LoadPlugin(context.TODO(), newFakeSetupContext("create_task_sync_test")) + assert.NoError(t, err) + + inputs, err := coreutils.MakeLiteralMap(map[string]interface{}{"x": 1}) + assert.NoError(t, err) + basePrefix := storage.DataReference("fake://bucket/prefix/") + inputReader := &ioMocks.InputReader{} + inputReader.OnGetInputPrefixPath().Return(basePrefix) + inputReader.OnGetInputPath().Return(basePrefix + "/inputs.pb") + inputReader.OnGetMatch(mock.Anything).Return(inputs, nil) + tCtx.OnInputReader().Return(inputReader) + + phase := tests.RunPluginEndToEndTest(t, plugin, &template, inputs, nil, nil, nil) + assert.Equal(t, true, phase.Phase().IsSuccess()) +} + func TestPlugin(t *testing.T) { fakeSetupContext := pluginCoreMocks.SetupContext{} fakeSetupContext.OnMetricsScope().Return(promutils.NewScope("test")) @@ -120,7 +155,7 @@ func TestPlugin(t *testing.T) { State: admin.State_PENDING, Outputs: nil, Message: "Waiting for cluster", - LogLinks: []*flyteidlcore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, + LogLinks: []*flyteIdlCore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, }) phase, err := plugin.Status(context.Background(), taskContext) @@ -135,7 +170,7 @@ func TestPlugin(t *testing.T) { State: admin.State_RUNNING, Outputs: nil, Message: "Job is running", - LogLinks: []*flyteidlcore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, + LogLinks: []*flyteIdlCore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, }) phase, err := plugin.Status(context.Background(), taskContext) @@ -149,7 +184,7 @@ func TestPlugin(t *testing.T) { State: admin.State_PERMANENT_FAILURE, Outputs: nil, Message: "", - LogLinks: []*flyteidlcore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, + LogLinks: []*flyteIdlCore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, }) phase, err := plugin.Status(context.Background(), taskContext) @@ -163,7 +198,7 @@ func TestPlugin(t *testing.T) { State: admin.State_RETRYABLE_FAILURE, Outputs: nil, Message: "", - LogLinks: []*flyteidlcore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, + LogLinks: []*flyteIdlCore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, }) phase, err := plugin.Status(context.Background(), taskContext) @@ -177,7 +212,7 @@ func TestPlugin(t *testing.T) { State: 5, Outputs: nil, Message: "", - LogLinks: []*flyteidlcore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, + LogLinks: []*flyteIdlCore.TaskLog{{Uri: "http://localhost:3000/log", Name: "Log Link"}}, }) phase, err := plugin.Status(context.Background(), taskContext) From 5890c3cc139b8d59a99d8c3fe42bf68dbf516448 Mon Sep 17 00:00:00 2001 From: Eduardo Apolinario <653394+eapolinario@users.noreply.github.com> Date: Wed, 20 Dec 2023 21:16:58 -0300 Subject: [PATCH 7/8] Add github token in buf gh action (#4626) Signed-off-by: Eduardo Apolinario Co-authored-by: Eduardo Apolinario --- .github/workflows/go_generate.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/go_generate.yml b/.github/workflows/go_generate.yml index 5bb93ffc63..66d3db9a62 100644 --- a/.github/workflows/go_generate.yml +++ b/.github/workflows/go_generate.yml @@ -25,6 +25,8 @@ jobs: with: repo-token: ${{ secrets.FLYTE_BOT_PAT }} - uses: bufbuild/buf-setup-action@v1 + with: + github_token: ${{ secrets.FLYTE_BOT_PAT }} - uses: actions/setup-go@v3 with: go-version: ${{ inputs.go-version }} From 5d199a881b8805ed67a018405dd87eec1b9ddaf6 Mon Sep 17 00:00:00 2001 From: David Espejo <82604841+davidmirror-ops@users.noreply.github.com> Date: Thu, 21 Dec 2023 07:58:22 -0500 Subject: [PATCH 8/8] Update flyte-binary values (#4604) * Comment and address missing info in values file Signed-off-by: davidmirror-ops * Remove Spark-specific extra RBAC rules Signed-off-by: davidmirror-ops * Update references to Ingress annotations Signed-off-by: davidmirror-ops * Fix typo Signed-off-by: davidmirror-ops * Fix reference to YAML config Signed-off-by: davidmirror-ops * Unify default db name Signed-off-by: davidmirror-ops * Unify values files Signed-off-by: davidmirror-ops * Update reference to values file Signed-off-by: davidmirror-ops --------- Signed-off-by: davidmirror-ops --- charts/flyte-binary/eks-production.yaml | 140 ++++++------------ charts/flyte-binary/eks-starter.yaml | 103 ++++++++++++- .../deployment/cloud_production.rst | 28 +--- .../deployment/cloud_production.rst | 23 +-- 4 files changed, 154 insertions(+), 140 deletions(-) diff --git a/charts/flyte-binary/eks-production.yaml b/charts/flyte-binary/eks-production.yaml index 2db827b804..b73da0278a 100644 --- a/charts/flyte-binary/eks-production.yaml +++ b/charts/flyte-binary/eks-production.yaml @@ -1,35 +1,42 @@ configuration: database: + username: postgres password: host: - dbname: app + dbname: flyte storage: + #Learn more about how Flyte handles data: https://docs.flyte.org/en/latest/concepts/data_management.html metadataContainer: userDataContainer: provider: s3 providerConfig: s3: - region: "us-east-2" + region: "" authType: "iam" + #For logging to work, you need to setup an agent. + # Learn more: https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/Container-Insights-EKS-logs.html logging: level: 5 plugins: cloudwatch: enabled: true templateUri: |- - https://console.aws.amazon.com/cloudwatch/home?region=#logEventViewer:group=/eks/opta-development/cluster;stream=var.log.containers.{{ .podName }}_{{ .namespace }}_{{ .containerName }}-{{ .containerId }}.log + https://console.aws.amazon.com/cloudwatch/home?region=#logEventViewer:group=/aws/eks//cluster;stream=var.log.containers.{{ .podName }}_{{ .namespace }}_{{ .containerName }}-{{ .containerId }}.log + # To configure auth, refer to https://docs.flyte.org/en/latest/deployment/configuration/auth_setup.html auth: - enabled: true + enabled: false oidc: - baseUrl: https://signin.hosted.unionai.cloud/oauth2/default + baseUrl: clientId: clientSecret: internal: clientSecret: clientSecretHash: authorizedUris: - - https://flyte.company.com + - https://flyte.company.com #change to your authorized URI inline: + #This section automates the IAM Role annotation for the default KSA on each project namespace to enable IRSA + #Learn more: https://docs.aws.amazon.com/eks/latest/userguide/iam-roles-for-service-accounts.html cluster_resources: customData: - production: @@ -49,22 +56,8 @@ configuration: default-env-vars: - AWS_METADATA_SERVICE_TIMEOUT: 5 - AWS_METADATA_SERVICE_NUM_ATTEMPTS: 20 - spark: - spark-config-default: - - spark.hadoop.fs.s3a.aws.credentials.provider: com.amazonaws.auth.DefaultAWSCredentialsProviderChain - - spark.hadoop.mapreduce.fileoutputcommitter.algorithm.version: "2" - - spark.kubernetes.allocation.batch.size: "50" - - spark.hadoop.fs.s3a.acl.default: BucketOwnerFullControl - - spark.hadoop.fs.s3n.impl: org.apache.hadoop.fs.s3a.S3AFileSystem - - spark.hadoop.fs.AbstractFileSystem.s3n.impl: org.apache.hadoop.fs.s3a.S3A - - spark.hadoop.fs.s3.impl: org.apache.hadoop.fs.s3a.S3AFileSystem - - spark.hadoop.fs.AbstractFileSystem.s3.impl: org.apache.hadoop.fs.s3a.S3A - - spark.hadoop.fs.s3a.impl: org.apache.hadoop.fs.s3a.S3AFileSystem - - spark.hadoop.fs.AbstractFileSystem.s3a.impl: org.apache.hadoop.fs.s3a.S3A - - spark.hadoop.fs.s3a.multipart.threshold: "536870912" - - spark.blacklist.enabled: "true" - - spark.blacklist.timeout: 5m - - spark.task.maxfailures: "8" + # Configuration for the Datacatalog engine, used when caching is enabled + # Learn more: https://docs.flyte.org/en/latest/deployment/configuration/generated/datacatalog_config.html storage: cache: max_size_mbs: 10 @@ -74,102 +67,55 @@ configuration: enabled-plugins: - container - sidecar - - K8S-ARRAY - - spark + - K8S-ARRAY #used for MapTasks default-for-task-types: - container: container - container_array: K8S-ARRAY - - spark: spark clusterResourceTemplates: inline: + #This section automates the creation of the project-domain namespaces 001_namespace.yaml: | apiVersion: v1 kind: Namespace metadata: name: '{{ namespace }}' - 010_spark_role.yaml: | - apiVersion: rbac.authorization.k8s.io/v1 - kind: Role - metadata: - name: spark-role - namespace: '{{ namespace }}' - rules: - - apiGroups: - - "" - resources: - - pods - - services - - configmaps - verbs: - - '*' - 011_spark_service_account.yaml: | + # This block performs the automated annotation of KSAs across all project-domain namespaces + 002_serviceaccount.yaml: | apiVersion: v1 kind: ServiceAccount metadata: - name: spark + name: default namespace: '{{ namespace }}' annotations: eks.amazonaws.com/role-arn: '{{ defaultIamRole }}' - 012_spark_role_binding.yaml: | - apiVersion: rbac.authorization.k8s.io/v1 - kind: RoleBinding - metadata: - name: spark-role-binding - namespace: '{{ namespace }}' - roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: spark-role - subjects: - - kind: ServiceAccount - name: spark - namespace: '{{ namespace }}' ingress: create: true + ##-- Uncomment the following section if you plan to use NGINX Ingress Controller + #ingressClassName: nginx + #commonAnnotations: + # ingress.kubernetes.io/rewrite-target: / + # nginx.ingress.kubernetes.io/ssl-redirect: "true" + #httpAnnotations: + # nginx.ingress.kubernetes.io/app-root: /console + #grpcAnnotations: + # nginx.ingress.kubernetes.io/backend-protocol: GRPC + #host: # change for the URL you'll use to connect to Flyte + ## --- + + #This section assumes you are using the ALB Ingress controller. + ingressClassName: alb commonAnnotations: - kubernetes.io/ingress.class: nginx + alb.ingress.kubernetes.io/certificate-arn: 'arn:aws:acm:::certificate/' + alb.ingress.kubernetes.io/group.name: flyte + alb.ingress.kubernetes.io/listen-ports: '[{"HTTP": 80}, {"HTTPS":443}]' + alb.ingress.kubernetes.io/scheme: internet-facing + alb.ingress.kubernetes.io/ssl-redirect: '443' + alb.ingress.kubernetes.io/target-type: ip httpAnnotations: - nginx.ingress.kubernetes.io/app-root: /console + alb.ingress.kubernetes.io/actions.app-root: '{"Type": "redirect", "RedirectConfig": {"Path": "/console", "StatusCode": "HTTP_302"}}' grpcAnnotations: - nginx.ingress.kubernetes.io/backend-protocol: GRPC - host: # change for the URL you'll use to connect to Flyte -rbac: - extraRules: - - apiGroups: - - "" - resources: - - pods - - services - - configmaps - verbs: - - "*" - - apiGroups: - - "" - resources: - - serviceaccounts - verbs: - - create - - get - - list - - patch - - update - - apiGroups: - - rbac.authorization.k8s.io - resources: - - rolebindings - - roles - verbs: - - create - - get - - list - - patch - - update - - apiGroups: - - sparkoperator.k8s.io - resources: - - sparkapplications - verbs: - - "*" + alb.ingress.kubernetes.io/backend-protocol-version: GRPC + host: flyte.mydomain.com #replace with your fully-qualified domain name serviceAccount: create: true annotations: diff --git a/charts/flyte-binary/eks-starter.yaml b/charts/flyte-binary/eks-starter.yaml index c7ca135340..51fd15f112 100644 --- a/charts/flyte-binary/eks-starter.yaml +++ b/charts/flyte-binary/eks-starter.yaml @@ -1,29 +1,122 @@ configuration: database: - username: + username: postgres password: host: - dbname: flyteadmin () + dbname: flyteadmin storage: + #Learn more about how Flyte handles data: https://docs.flyte.org/en/latest/concepts/data_management.html metadataContainer: userDataContainer: provider: s3 providerConfig: s3: - region: "" + region: "" authType: "iam" + #For logging to work, you need to setup an agent. + # Learn more: https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/Container-Insights-EKS-logs.html + logging: + level: 5 + plugins: + cloudwatch: + enabled: true + templateUri: |- + https://console.aws.amazon.com/cloudwatch/home?region=#logEventViewer:group=/aws/eks//cluster;stream=var.log.containers.{{ .podName }}_{{ .namespace }}_{{ .containerName }}-{{ .containerId }}.log + # To configure auth, refer to https://docs.flyte.org/en/latest/deployment/configuration/auth_setup.html + auth: + enabled: false + oidc: + baseUrl: + clientId: + clientSecret: + internal: + clientSecret: + clientSecretHash: + authorizedUris: + - https://flyte.company.com #change to your authorized URI inline: + #This section automates the IAM Role annotation for the default KSA on each project namespace to enable IRSA + #Learn more: https://docs.aws.amazon.com/eks/latest/userguide/iam-roles-for-service-accounts.html + cluster_resources: + customData: + - production: + - defaultIamRole: + value: + - staging: + - defaultIamRole: + value: + - development: + - defaultIamRole: + value: + flyteadmin: + roleNameKey: "iam.amazonaws.com/role" plugins: k8s: inject-finalizer: true default-env-vars: - AWS_METADATA_SERVICE_TIMEOUT: 5 - AWS_METADATA_SERVICE_NUM_ATTEMPTS: 20 + # Configuration for the Datacatalog engine, used when caching is enabled + # Learn more: https://docs.flyte.org/en/latest/deployment/configuration/generated/datacatalog_config.html storage: cache: - max_size_mbs: 100 + max_size_mbs: 10 target_gc_percent: 100 + tasks: + task-plugins: + enabled-plugins: + - container + - sidecar + - K8S-ARRAY #used for MapTasks + default-for-task-types: + - container: container + - container_array: K8S-ARRAY +clusterResourceTemplates: + inline: + #This section automates the creation of the project-domain namespaces + 001_namespace.yaml: | + apiVersion: v1 + kind: Namespace + metadata: + name: '{{ namespace }}' + # This block performs the automated annotation of KSAs across all project-domain namespaces + 002_serviceaccount.yaml: | + apiVersion: v1 + kind: ServiceAccount + metadata: + name: default + namespace: '{{ namespace }}' + annotations: + eks.amazonaws.com/role-arn: '{{ defaultIamRole }}' +ingress: + create: true + ##-- Uncomment the following section if you plan to use NGINX Ingress Controller + #ingressClassName: nginx + #commonAnnotations: + # ingress.kubernetes.io/rewrite-target: / + # nginx.ingress.kubernetes.io/ssl-redirect: "true" + #httpAnnotations: + # nginx.ingress.kubernetes.io/app-root: /console + #grpcAnnotations: + # nginx.ingress.kubernetes.io/backend-protocol: GRPC + #host: # change for the URL you'll use to connect to Flyte + ## --- + + #This section assumes you are using the ALB Ingress controller. + ingressClassName: alb + commonAnnotations: + alb.ingress.kubernetes.io/certificate-arn: 'arn:aws:acm:::certificate/' + alb.ingress.kubernetes.io/group.name: flyte + alb.ingress.kubernetes.io/listen-ports: '[{"HTTP": 80}, {"HTTPS":443}]' + alb.ingress.kubernetes.io/scheme: internet-facing + alb.ingress.kubernetes.io/ssl-redirect: '443' + alb.ingress.kubernetes.io/target-type: ip + httpAnnotations: + alb.ingress.kubernetes.io/actions.app-root: '{"Type": "redirect", "RedirectConfig": {"Path": "/console", "StatusCode": "HTTP_302"}}' + grpcAnnotations: + alb.ingress.kubernetes.io/backend-protocol-version: GRPC + host: flyte.mydomain.com #replace with your fully-qualified domain name serviceAccount: create: true annotations: - eks.amazonaws.com/role-arn: "" + eks.amazonaws.com/role-arn: "" \ No newline at end of file diff --git a/docs/deployment/deployment/cloud_production.rst b/docs/deployment/deployment/cloud_production.rst index 1736f1eb4c..dce2d2d085 100644 --- a/docs/deployment/deployment/cloud_production.rst +++ b/docs/deployment/deployment/cloud_production.rst @@ -27,30 +27,18 @@ To turn on ingress, update your ``values.yaml`` file to include the following bl .. group-tab:: ``flyte-binary`` on EKS using NGINX - .. literalinclude:: ../../../charts/flyte-binary/eks-production.yaml - :caption: charts/flyte-binary/eks-production.yaml + .. literalinclude:: ../../../charts/flyte-binary/eks-starter.yaml + :caption: charts/flyte-binary/eks-starter.yaml :language: yaml - :lines: 127-135 + :lines: 94-102 .. group-tab:: ``flyte-binary``/ on EKS using ALB - .. code-block:: yaml - - ingress: - create: true - commonAnnotations: - alb.ingress.kubernetes.io/certificate-arn: '' - alb.ingress.kubernetes.io/group.name: flyte - alb.ingress.kubernetes.io/listen-ports: '[{"HTTP": 80}, {"HTTPS":443}]' - alb.ingress.kubernetes.io/scheme: internet-facing - alb.ingress.kubernetes.io/ssl-redirect: '443' - alb.ingress.kubernetes.io/target-type: ip - kubernetes.io/ingress.class: alb - httpAnnotations: - alb.ingress.kubernetes.io/actions.app-root: '{"Type": "redirect", "RedirectConfig": {"Path": "/console", "StatusCode": "HTTP_302"}}' - grpcAnnotations: - alb.ingress.kubernetes.io/backend-protocol-version: GRPC - host: #use a DNS CNAME pointing to your ALB + .. literalinclude:: ../../../charts/flyte-binary/eks-starter.yaml + :caption: charts/flyte-binary/eks-starter.yaml + :language: yaml + :lines: 106-118 + .. group-tab:: ``flyte-core`` on GCP using NGINX diff --git a/rsts/deployment/deployment/cloud_production.rst b/rsts/deployment/deployment/cloud_production.rst index 1736f1eb4c..c5993dbe53 100644 --- a/rsts/deployment/deployment/cloud_production.rst +++ b/rsts/deployment/deployment/cloud_production.rst @@ -30,27 +30,14 @@ To turn on ingress, update your ``values.yaml`` file to include the following bl .. literalinclude:: ../../../charts/flyte-binary/eks-production.yaml :caption: charts/flyte-binary/eks-production.yaml :language: yaml - :lines: 127-135 + :lines: 93-102 .. group-tab:: ``flyte-binary``/ on EKS using ALB - .. code-block:: yaml - - ingress: - create: true - commonAnnotations: - alb.ingress.kubernetes.io/certificate-arn: '' - alb.ingress.kubernetes.io/group.name: flyte - alb.ingress.kubernetes.io/listen-ports: '[{"HTTP": 80}, {"HTTPS":443}]' - alb.ingress.kubernetes.io/scheme: internet-facing - alb.ingress.kubernetes.io/ssl-redirect: '443' - alb.ingress.kubernetes.io/target-type: ip - kubernetes.io/ingress.class: alb - httpAnnotations: - alb.ingress.kubernetes.io/actions.app-root: '{"Type": "redirect", "RedirectConfig": {"Path": "/console", "StatusCode": "HTTP_302"}}' - grpcAnnotations: - alb.ingress.kubernetes.io/backend-protocol-version: GRPC - host: #use a DNS CNAME pointing to your ALB + .. literalinclude:: ../../../charts/flyte-binary/eks-production.yaml + :caption: charts/flyte-binary/eks-production.yaml + :language: yaml + :lines: 106-118 .. group-tab:: ``flyte-core`` on GCP using NGINX