diff --git a/client/src/lib/connect/buf/validate/validate_pb.ts b/client/src/lib/connect/buf/validate/validate_pb.ts
new file mode 100644
index 0000000..dc86ba1
--- /dev/null
+++ b/client/src/lib/connect/buf/validate/validate_pb.ts
@@ -0,0 +1,4678 @@
+// Copyright 2023-2025 Buf Technologies, Inc.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+// @generated by protoc-gen-es v2.2.5 with parameter "target=ts"
+// @generated from file buf/validate/validate.proto (package buf.validate, syntax proto2)
+/* eslint-disable */
+
+import type { GenEnum, GenExtension, GenFile, GenMessage } from "@bufbuild/protobuf/codegenv1";
+import { enumDesc, extDesc, fileDesc, messageDesc } from "@bufbuild/protobuf/codegenv1";
+import type { Duration, FieldDescriptorProto_Type, FieldOptions, MessageOptions, OneofOptions, Timestamp } from "@bufbuild/protobuf/wkt";
+import { file_google_protobuf_descriptor, file_google_protobuf_duration, file_google_protobuf_timestamp } from "@bufbuild/protobuf/wkt";
+import type { Message } from "@bufbuild/protobuf";
+
+/**
+ * Describes the file buf/validate/validate.proto.
+ */
+export const file_buf_validate_validate: GenFile = /*@__PURE__*/
+ fileDesc("ChtidWYvdmFsaWRhdGUvdmFsaWRhdGUucHJvdG8SDGJ1Zi52YWxpZGF0ZSI3CgRSdWxlEgoKAmlkGAEgASgJEg8KB21lc3NhZ2UYAiABKAkSEgoKZXhwcmVzc2lvbhgDIAEoCSJBCgxNZXNzYWdlUnVsZXMSEAoIZGlzYWJsZWQYASABKAgSHwoDY2VsGAMgAygLMhIuYnVmLnZhbGlkYXRlLlJ1bGUiHgoKT25lb2ZSdWxlcxIQCghyZXF1aXJlZBgBIAEoCCK/CAoKRmllbGRSdWxlcxIfCgNjZWwYFyADKAsyEi5idWYudmFsaWRhdGUuUnVsZRIQCghyZXF1aXJlZBgZIAEoCBIkCgZpZ25vcmUYGyABKA4yFC5idWYudmFsaWRhdGUuSWdub3JlEikKBWZsb2F0GAEgASgLMhguYnVmLnZhbGlkYXRlLkZsb2F0UnVsZXNIABIrCgZkb3VibGUYAiABKAsyGS5idWYudmFsaWRhdGUuRG91YmxlUnVsZXNIABIpCgVpbnQzMhgDIAEoCzIYLmJ1Zi52YWxpZGF0ZS5JbnQzMlJ1bGVzSAASKQoFaW50NjQYBCABKAsyGC5idWYudmFsaWRhdGUuSW50NjRSdWxlc0gAEisKBnVpbnQzMhgFIAEoCzIZLmJ1Zi52YWxpZGF0ZS5VSW50MzJSdWxlc0gAEisKBnVpbnQ2NBgGIAEoCzIZLmJ1Zi52YWxpZGF0ZS5VSW50NjRSdWxlc0gAEisKBnNpbnQzMhgHIAEoCzIZLmJ1Zi52YWxpZGF0ZS5TSW50MzJSdWxlc0gAEisKBnNpbnQ2NBgIIAEoCzIZLmJ1Zi52YWxpZGF0ZS5TSW50NjRSdWxlc0gAEi0KB2ZpeGVkMzIYCSABKAsyGi5idWYudmFsaWRhdGUuRml4ZWQzMlJ1bGVzSAASLQoHZml4ZWQ2NBgKIAEoCzIaLmJ1Zi52YWxpZGF0ZS5GaXhlZDY0UnVsZXNIABIvCghzZml4ZWQzMhgLIAEoCzIbLmJ1Zi52YWxpZGF0ZS5TRml4ZWQzMlJ1bGVzSAASLwoIc2ZpeGVkNjQYDCABKAsyGy5idWYudmFsaWRhdGUuU0ZpeGVkNjRSdWxlc0gAEicKBGJvb2wYDSABKAsyFy5idWYudmFsaWRhdGUuQm9vbFJ1bGVzSAASKwoGc3RyaW5nGA4gASgLMhkuYnVmLnZhbGlkYXRlLlN0cmluZ1J1bGVzSAASKQoFYnl0ZXMYDyABKAsyGC5idWYudmFsaWRhdGUuQnl0ZXNSdWxlc0gAEicKBGVudW0YECABKAsyFy5idWYudmFsaWRhdGUuRW51bVJ1bGVzSAASLwoIcmVwZWF0ZWQYEiABKAsyGy5idWYudmFsaWRhdGUuUmVwZWF0ZWRSdWxlc0gAEiUKA21hcBgTIAEoCzIWLmJ1Zi52YWxpZGF0ZS5NYXBSdWxlc0gAEiUKA2FueRgUIAEoCzIWLmJ1Zi52YWxpZGF0ZS5BbnlSdWxlc0gAEi8KCGR1cmF0aW9uGBUgASgLMhsuYnVmLnZhbGlkYXRlLkR1cmF0aW9uUnVsZXNIABIxCgl0aW1lc3RhbXAYFiABKAsyHC5idWYudmFsaWRhdGUuVGltZXN0YW1wUnVsZXNIAEIGCgR0eXBlSgQIGBAZSgQIGhAbUgdza2lwcGVkUgxpZ25vcmVfZW1wdHkiUwoPUHJlZGVmaW5lZFJ1bGVzEh8KA2NlbBgBIAMoCzISLmJ1Zi52YWxpZGF0ZS5SdWxlSgQIGBAZSgQIGhAbUhNza2lwcGVkaWdub3JlX2VtcHR5ItoXCgpGbG9hdFJ1bGVzEoMBCgVjb25zdBgBIAEoAkJ0wkhxCm8KC2Zsb2F0LmNvbnN0GmB0aGlzICE9IGdldEZpZWxkKHJ1bGVzLCAnY29uc3QnKSA/ICd2YWx1ZSBtdXN0IGVxdWFsICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnY29uc3QnKV0pIDogJycSnwEKAmx0GAIgASgCQpABwkiMAQqJAQoIZmxvYXQubHQafSFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiAodGhpcy5pc05hbigpIHx8IHRoaXMgPj0gcnVsZXMubHQpPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASrwEKA2x0ZRgDIAEoAkKfAcJImwEKmAEKCWZsb2F0Lmx0ZRqKASFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiAodGhpcy5pc05hbigpIHx8IHRoaXMgPiBydWxlcy5sdGUpPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMubHRlXSkgOiAnJ0gAEu8HCgJndBgEIAEoAkLgB8JI3AcKjQEKCGZsb2F0Lmd0GoABIWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmICh0aGlzLmlzTmFuKCkgfHwgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndF0pIDogJycKwwEKC2Zsb2F0Lmd0X2x0GrMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcy5pc05hbigpIHx8IHRoaXMgPj0gcnVsZXMubHQgfHwgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcyBhbmQgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdF0pIDogJycKzQEKFWZsb2F0Lmd0X2x0X2V4Y2x1c2l2ZRqzAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndCAmJiAodGhpcy5pc05hbigpIHx8IChydWxlcy5sdCA8PSB0aGlzICYmIHRoaXMgPD0gcnVsZXMuZ3QpKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCtMBCgxmbG9hdC5ndF9sdGUawgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3QgJiYgKHRoaXMuaXNOYW4oKSB8fCB0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJwrdAQoWZmxvYXQuZ3RfbHRlX2V4Y2x1c2l2ZRrCAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ICYmICh0aGlzLmlzTmFuKCkgfHwgKHJ1bGVzLmx0ZSA8IHRoaXMgJiYgdGhpcyA8PSBydWxlcy5ndCkpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgb3IgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdGVdKSA6ICcnSAESuggKA2d0ZRgFIAEoAkKqCMJIpggKmwEKCWZsb2F0Lmd0ZRqNASFoYXMocnVsZXMubHQpICYmICFoYXMocnVsZXMubHRlKSAmJiAodGhpcy5pc05hbigpIHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlXSkgOiAnJwrSAQoMZmxvYXQuZ3RlX2x0GsEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndGUgJiYgKHRoaXMuaXNOYW4oKSB8fCB0aGlzID49IHJ1bGVzLmx0IHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrcAQoWZmxvYXQuZ3RlX2x0X2V4Y2x1c2l2ZRrBAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndGUgJiYgKHRoaXMuaXNOYW4oKSB8fCAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBvciBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdF0pIDogJycK4gEKDWZsb2F0Lmd0ZV9sdGUa0AFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3RlICYmICh0aGlzLmlzTmFuKCkgfHwgdGhpcyA+IHJ1bGVzLmx0ZSB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnCuwBChdmbG9hdC5ndGVfbHRlX2V4Y2x1c2l2ZRrQAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ZSAmJiAodGhpcy5pc05hbigpIHx8IChydWxlcy5sdGUgPCB0aGlzICYmIHRoaXMgPCBydWxlcy5ndGUpKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJydIARJ/CgJpbhgGIAMoAkJzwkhwCm4KCGZsb2F0LmluGmIhKHRoaXMgaW4gZ2V0RmllbGQocnVsZXMsICdpbicpKSA/ICd2YWx1ZSBtdXN0IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdpbicpXSkgOiAnJxJ2CgZub3RfaW4YByADKAJCZsJIYwphCgxmbG9hdC5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxJ1CgZmaW5pdGUYCCABKAhCZcJIYgpgCgxmbG9hdC5maW5pdGUaUHJ1bGVzLmZpbml0ZSA/ICh0aGlzLmlzTmFuKCkgfHwgdGhpcy5pc0luZigpID8gJ3ZhbHVlIG11c3QgYmUgZmluaXRlJyA6ICcnKSA6ICcnEisKB2V4YW1wbGUYCSADKAJCGsJIFwoVCg1mbG9hdC5leGFtcGxlGgR0cnVlKgkI6AcQgICAgAJCCwoJbGVzc190aGFuQg4KDGdyZWF0ZXJfdGhhbiLtFwoLRG91YmxlUnVsZXMShAEKBWNvbnN0GAEgASgBQnXCSHIKcAoMZG91YmxlLmNvbnN0GmB0aGlzICE9IGdldEZpZWxkKHJ1bGVzLCAnY29uc3QnKSA/ICd2YWx1ZSBtdXN0IGVxdWFsICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnY29uc3QnKV0pIDogJycSoAEKAmx0GAIgASgBQpEBwkiNAQqKAQoJZG91YmxlLmx0Gn0haGFzKHJ1bGVzLmd0ZSkgJiYgIWhhcyhydWxlcy5ndCkgJiYgKHRoaXMuaXNOYW4oKSB8fCB0aGlzID49IHJ1bGVzLmx0KT8gJ3ZhbHVlIG11c3QgYmUgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmx0XSkgOiAnJ0gAErABCgNsdGUYAyABKAFCoAHCSJwBCpkBCgpkb3VibGUubHRlGooBIWhhcyhydWxlcy5ndGUpICYmICFoYXMocnVsZXMuZ3QpICYmICh0aGlzLmlzTmFuKCkgfHwgdGhpcyA+IHJ1bGVzLmx0ZSk/ICd2YWx1ZSBtdXN0IGJlIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5sdGVdKSA6ICcnSAAS9AcKAmd0GAQgASgBQuUHwkjhBwqOAQoJZG91YmxlLmd0GoABIWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmICh0aGlzLmlzTmFuKCkgfHwgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndF0pIDogJycKxAEKDGRvdWJsZS5ndF9sdBqzAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPj0gcnVsZXMuZ3QgJiYgKHRoaXMuaXNOYW4oKSB8fCB0aGlzID49IHJ1bGVzLmx0IHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCs4BChZkb3VibGUuZ3RfbHRfZXhjbHVzaXZlGrMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ICYmICh0aGlzLmlzTmFuKCkgfHwgKHJ1bGVzLmx0IDw9IHRoaXMgJiYgdGhpcyA8PSBydWxlcy5ndCkpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgb3IgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdF0pIDogJycK1AEKDWRvdWJsZS5ndF9sdGUawgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3QgJiYgKHRoaXMuaXNOYW4oKSB8fCB0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJwreAQoXZG91YmxlLmd0X2x0ZV9leGNsdXNpdmUawgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAodGhpcy5pc05hbigpIHx8IChydWxlcy5sdGUgPCB0aGlzICYmIHRoaXMgPD0gcnVsZXMuZ3QpKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEr8ICgNndGUYBSABKAFCrwjCSKsICpwBCgpkb3VibGUuZ3RlGo0BIWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmICh0aGlzLmlzTmFuKCkgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGVdKSA6ICcnCtMBCg1kb3VibGUuZ3RlX2x0GsEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndGUgJiYgKHRoaXMuaXNOYW4oKSB8fCB0aGlzID49IHJ1bGVzLmx0IHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrdAQoXZG91YmxlLmd0ZV9sdF9leGNsdXNpdmUawQFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0IDwgcnVsZXMuZ3RlICYmICh0aGlzLmlzTmFuKCkgfHwgKHJ1bGVzLmx0IDw9IHRoaXMgJiYgdGhpcyA8IHJ1bGVzLmd0ZSkpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgb3IgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRdKSA6ICcnCuMBCg5kb3VibGUuZ3RlX2x0ZRrQAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA+PSBydWxlcy5ndGUgJiYgKHRoaXMuaXNOYW4oKSB8fCB0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJycK7QEKGGRvdWJsZS5ndGVfbHRlX2V4Y2x1c2l2ZRrQAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ZSAmJiAodGhpcy5pc05hbigpIHx8IChydWxlcy5sdGUgPCB0aGlzICYmIHRoaXMgPCBydWxlcy5ndGUpKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJydIARKAAQoCaW4YBiADKAFCdMJIcQpvCglkb3VibGUuaW4aYiEodGhpcyBpbiBnZXRGaWVsZChydWxlcywgJ2luJykpID8gJ3ZhbHVlIG11c3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2luJyldKSA6ICcnEncKBm5vdF9pbhgHIAMoAUJnwkhkCmIKDWRvdWJsZS5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxJ2CgZmaW5pdGUYCCABKAhCZsJIYwphCg1kb3VibGUuZmluaXRlGlBydWxlcy5maW5pdGUgPyAodGhpcy5pc05hbigpIHx8IHRoaXMuaXNJbmYoKSA/ICd2YWx1ZSBtdXN0IGJlIGZpbml0ZScgOiAnJykgOiAnJxIsCgdleGFtcGxlGAkgAygBQhvCSBgKFgoOZG91YmxlLmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAkILCglsZXNzX3RoYW5CDgoMZ3JlYXRlcl90aGFuIowVCgpJbnQzMlJ1bGVzEoMBCgVjb25zdBgBIAEoBUJ0wkhxCm8KC2ludDMyLmNvbnN0GmB0aGlzICE9IGdldEZpZWxkKHJ1bGVzLCAnY29uc3QnKSA/ICd2YWx1ZSBtdXN0IGVxdWFsICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnY29uc3QnKV0pIDogJycSigEKAmx0GAIgASgFQnzCSHkKdwoIaW50MzIubHQaayFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID49IHJ1bGVzLmx0PyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASnAEKA2x0ZRgDIAEoBUKMAcJIiAEKhQEKCWludDMyLmx0ZRp4IWhhcyhydWxlcy5ndGUpICYmICFoYXMocnVsZXMuZ3QpICYmIHRoaXMgPiBydWxlcy5sdGU/ICd2YWx1ZSBtdXN0IGJlIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5sdGVdKSA6ICcnSAASlwcKAmd0GAQgASgFQogHwkiEBwp6CghpbnQzMi5ndBpuIWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmIHRoaXMgPD0gcnVsZXMuZ3Q/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndF0pIDogJycKswEKC2ludDMyLmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq7AQoVaW50MzIuZ3RfbHRfZXhjbHVzaXZlGqEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ICYmIChydWxlcy5sdCA8PSB0aGlzICYmIHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgb3IgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdF0pIDogJycKwwEKDGludDMyLmd0X2x0ZRqyAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA+PSBydWxlcy5ndCAmJiAodGhpcyA+IHJ1bGVzLmx0ZSB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0ZV0pIDogJycKywEKFmludDMyLmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEuMHCgNndGUYBSABKAVC0wfCSM8HCogBCglpbnQzMi5ndGUaeyFoYXMocnVsZXMubHQpICYmICFoYXMocnVsZXMubHRlKSAmJiB0aGlzIDwgcnVsZXMuZ3RlPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlXSkgOiAnJwrCAQoMaW50MzIuZ3RlX2x0GrEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndGUgJiYgKHRoaXMgPj0gcnVsZXMubHQgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBhbmQgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRdKSA6ICcnCsoBChZpbnQzMi5ndGVfbHRfZXhjbHVzaXZlGq8BaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrSAQoNaW50MzIuZ3RlX2x0ZRrAAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA+PSBydWxlcy5ndGUgJiYgKHRoaXMgPiBydWxlcy5sdGUgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBhbmQgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRlXSkgOiAnJwraAQoXaW50MzIuZ3RlX2x0ZV9leGNsdXNpdmUavgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndGUgJiYgKHJ1bGVzLmx0ZSA8IHRoaXMgJiYgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBvciBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnSAESfwoCaW4YBiADKAVCc8JIcApuCghpbnQzMi5pbhpiISh0aGlzIGluIGdldEZpZWxkKHJ1bGVzLCAnaW4nKSkgPyAndmFsdWUgbXVzdCBiZSBpbiBsaXN0ICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnaW4nKV0pIDogJycSdgoGbm90X2luGAcgAygFQmbCSGMKYQoMaW50MzIubm90X2luGlF0aGlzIGluIHJ1bGVzLm5vdF9pbiA/ICd2YWx1ZSBtdXN0IG5vdCBiZSBpbiBsaXN0ICVzJy5mb3JtYXQoW3J1bGVzLm5vdF9pbl0pIDogJycSKwoHZXhhbXBsZRgIIAMoBUIawkgXChUKDWludDMyLmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAkILCglsZXNzX3RoYW5CDgoMZ3JlYXRlcl90aGFuIowVCgpJbnQ2NFJ1bGVzEoMBCgVjb25zdBgBIAEoA0J0wkhxCm8KC2ludDY0LmNvbnN0GmB0aGlzICE9IGdldEZpZWxkKHJ1bGVzLCAnY29uc3QnKSA/ICd2YWx1ZSBtdXN0IGVxdWFsICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnY29uc3QnKV0pIDogJycSigEKAmx0GAIgASgDQnzCSHkKdwoIaW50NjQubHQaayFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID49IHJ1bGVzLmx0PyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASnAEKA2x0ZRgDIAEoA0KMAcJIiAEKhQEKCWludDY0Lmx0ZRp4IWhhcyhydWxlcy5ndGUpICYmICFoYXMocnVsZXMuZ3QpICYmIHRoaXMgPiBydWxlcy5sdGU/ICd2YWx1ZSBtdXN0IGJlIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5sdGVdKSA6ICcnSAASlwcKAmd0GAQgASgDQogHwkiEBwp6CghpbnQ2NC5ndBpuIWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmIHRoaXMgPD0gcnVsZXMuZ3Q/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndF0pIDogJycKswEKC2ludDY0Lmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq7AQoVaW50NjQuZ3RfbHRfZXhjbHVzaXZlGqEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ICYmIChydWxlcy5sdCA8PSB0aGlzICYmIHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgb3IgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdF0pIDogJycKwwEKDGludDY0Lmd0X2x0ZRqyAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA+PSBydWxlcy5ndCAmJiAodGhpcyA+IHJ1bGVzLmx0ZSB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0ZV0pIDogJycKywEKFmludDY0Lmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEuMHCgNndGUYBSABKANC0wfCSM8HCogBCglpbnQ2NC5ndGUaeyFoYXMocnVsZXMubHQpICYmICFoYXMocnVsZXMubHRlKSAmJiB0aGlzIDwgcnVsZXMuZ3RlPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlXSkgOiAnJwrCAQoMaW50NjQuZ3RlX2x0GrEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndGUgJiYgKHRoaXMgPj0gcnVsZXMubHQgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBhbmQgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRdKSA6ICcnCsoBChZpbnQ2NC5ndGVfbHRfZXhjbHVzaXZlGq8BaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrSAQoNaW50NjQuZ3RlX2x0ZRrAAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA+PSBydWxlcy5ndGUgJiYgKHRoaXMgPiBydWxlcy5sdGUgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBhbmQgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRlXSkgOiAnJwraAQoXaW50NjQuZ3RlX2x0ZV9leGNsdXNpdmUavgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndGUgJiYgKHJ1bGVzLmx0ZSA8IHRoaXMgJiYgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBvciBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnSAESfwoCaW4YBiADKANCc8JIcApuCghpbnQ2NC5pbhpiISh0aGlzIGluIGdldEZpZWxkKHJ1bGVzLCAnaW4nKSkgPyAndmFsdWUgbXVzdCBiZSBpbiBsaXN0ICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnaW4nKV0pIDogJycSdgoGbm90X2luGAcgAygDQmbCSGMKYQoMaW50NjQubm90X2luGlF0aGlzIGluIHJ1bGVzLm5vdF9pbiA/ICd2YWx1ZSBtdXN0IG5vdCBiZSBpbiBsaXN0ICVzJy5mb3JtYXQoW3J1bGVzLm5vdF9pbl0pIDogJycSKwoHZXhhbXBsZRgJIAMoA0IawkgXChUKDWludDY0LmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAkILCglsZXNzX3RoYW5CDgoMZ3JlYXRlcl90aGFuIp4VCgtVSW50MzJSdWxlcxKEAQoFY29uc3QYASABKA1CdcJIcgpwCgx1aW50MzIuY29uc3QaYHRoaXMgIT0gZ2V0RmllbGQocnVsZXMsICdjb25zdCcpID8gJ3ZhbHVlIG11c3QgZXF1YWwgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdjb25zdCcpXSkgOiAnJxKLAQoCbHQYAiABKA1CfcJIegp4Cgl1aW50MzIubHQaayFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID49IHJ1bGVzLmx0PyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASnQEKA2x0ZRgDIAEoDUKNAcJIiQEKhgEKCnVpbnQzMi5sdGUaeCFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID4gcnVsZXMubHRlPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMubHRlXSkgOiAnJ0gAEpwHCgJndBgEIAEoDUKNB8JIiQcKewoJdWludDMyLmd0Gm4haGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8PSBydWxlcy5ndD8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0XSkgOiAnJwq0AQoMdWludDMyLmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq8AQoWdWludDMyLmd0X2x0X2V4Y2x1c2l2ZRqhAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndCAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCsQBCg11aW50MzIuZ3RfbHRlGrIBaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJwrMAQoXdWludDMyLmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEugHCgNndGUYBSABKA1C2AfCSNQHCokBCgp1aW50MzIuZ3RlGnshaGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8IHJ1bGVzLmd0ZT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZV0pIDogJycKwwEKDXVpbnQzMi5ndGVfbHQasQFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0ID49IHJ1bGVzLmd0ZSAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdF0pIDogJycKywEKF3VpbnQzMi5ndGVfbHRfZXhjbHVzaXZlGq8BaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrTAQoOdWludDMyLmd0ZV9sdGUawAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3RlICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJycK2wEKGHVpbnQzMi5ndGVfbHRlX2V4Y2x1c2l2ZRq+AWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJydIARKAAQoCaW4YBiADKA1CdMJIcQpvCgl1aW50MzIuaW4aYiEodGhpcyBpbiBnZXRGaWVsZChydWxlcywgJ2luJykpID8gJ3ZhbHVlIG11c3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2luJyldKSA6ICcnEncKBm5vdF9pbhgHIAMoDUJnwkhkCmIKDXVpbnQzMi5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxIsCgdleGFtcGxlGAggAygNQhvCSBgKFgoOdWludDMyLmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAkILCglsZXNzX3RoYW5CDgoMZ3JlYXRlcl90aGFuIp4VCgtVSW50NjRSdWxlcxKEAQoFY29uc3QYASABKARCdcJIcgpwCgx1aW50NjQuY29uc3QaYHRoaXMgIT0gZ2V0RmllbGQocnVsZXMsICdjb25zdCcpID8gJ3ZhbHVlIG11c3QgZXF1YWwgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdjb25zdCcpXSkgOiAnJxKLAQoCbHQYAiABKARCfcJIegp4Cgl1aW50NjQubHQaayFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID49IHJ1bGVzLmx0PyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASnQEKA2x0ZRgDIAEoBEKNAcJIiQEKhgEKCnVpbnQ2NC5sdGUaeCFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID4gcnVsZXMubHRlPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMubHRlXSkgOiAnJ0gAEpwHCgJndBgEIAEoBEKNB8JIiQcKewoJdWludDY0Lmd0Gm4haGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8PSBydWxlcy5ndD8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0XSkgOiAnJwq0AQoMdWludDY0Lmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq8AQoWdWludDY0Lmd0X2x0X2V4Y2x1c2l2ZRqhAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndCAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCsQBCg11aW50NjQuZ3RfbHRlGrIBaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJwrMAQoXdWludDY0Lmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEugHCgNndGUYBSABKARC2AfCSNQHCokBCgp1aW50NjQuZ3RlGnshaGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8IHJ1bGVzLmd0ZT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZV0pIDogJycKwwEKDXVpbnQ2NC5ndGVfbHQasQFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0ID49IHJ1bGVzLmd0ZSAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdF0pIDogJycKywEKF3VpbnQ2NC5ndGVfbHRfZXhjbHVzaXZlGq8BaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrTAQoOdWludDY0Lmd0ZV9sdGUawAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3RlICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJycK2wEKGHVpbnQ2NC5ndGVfbHRlX2V4Y2x1c2l2ZRq+AWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJydIARKAAQoCaW4YBiADKARCdMJIcQpvCgl1aW50NjQuaW4aYiEodGhpcyBpbiBnZXRGaWVsZChydWxlcywgJ2luJykpID8gJ3ZhbHVlIG11c3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2luJyldKSA6ICcnEncKBm5vdF9pbhgHIAMoBEJnwkhkCmIKDXVpbnQ2NC5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxIsCgdleGFtcGxlGAggAygEQhvCSBgKFgoOdWludDY0LmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAkILCglsZXNzX3RoYW5CDgoMZ3JlYXRlcl90aGFuIp4VCgtTSW50MzJSdWxlcxKEAQoFY29uc3QYASABKBFCdcJIcgpwCgxzaW50MzIuY29uc3QaYHRoaXMgIT0gZ2V0RmllbGQocnVsZXMsICdjb25zdCcpID8gJ3ZhbHVlIG11c3QgZXF1YWwgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdjb25zdCcpXSkgOiAnJxKLAQoCbHQYAiABKBFCfcJIegp4CglzaW50MzIubHQaayFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID49IHJ1bGVzLmx0PyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASnQEKA2x0ZRgDIAEoEUKNAcJIiQEKhgEKCnNpbnQzMi5sdGUaeCFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID4gcnVsZXMubHRlPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMubHRlXSkgOiAnJ0gAEpwHCgJndBgEIAEoEUKNB8JIiQcKewoJc2ludDMyLmd0Gm4haGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8PSBydWxlcy5ndD8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0XSkgOiAnJwq0AQoMc2ludDMyLmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq8AQoWc2ludDMyLmd0X2x0X2V4Y2x1c2l2ZRqhAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndCAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCsQBCg1zaW50MzIuZ3RfbHRlGrIBaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJwrMAQoXc2ludDMyLmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEugHCgNndGUYBSABKBFC2AfCSNQHCokBCgpzaW50MzIuZ3RlGnshaGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8IHJ1bGVzLmd0ZT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZV0pIDogJycKwwEKDXNpbnQzMi5ndGVfbHQasQFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0ID49IHJ1bGVzLmd0ZSAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdF0pIDogJycKywEKF3NpbnQzMi5ndGVfbHRfZXhjbHVzaXZlGq8BaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrTAQoOc2ludDMyLmd0ZV9sdGUawAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3RlICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJycK2wEKGHNpbnQzMi5ndGVfbHRlX2V4Y2x1c2l2ZRq+AWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJydIARKAAQoCaW4YBiADKBFCdMJIcQpvCglzaW50MzIuaW4aYiEodGhpcyBpbiBnZXRGaWVsZChydWxlcywgJ2luJykpID8gJ3ZhbHVlIG11c3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2luJyldKSA6ICcnEncKBm5vdF9pbhgHIAMoEUJnwkhkCmIKDXNpbnQzMi5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxIsCgdleGFtcGxlGAggAygRQhvCSBgKFgoOc2ludDMyLmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAkILCglsZXNzX3RoYW5CDgoMZ3JlYXRlcl90aGFuIp4VCgtTSW50NjRSdWxlcxKEAQoFY29uc3QYASABKBJCdcJIcgpwCgxzaW50NjQuY29uc3QaYHRoaXMgIT0gZ2V0RmllbGQocnVsZXMsICdjb25zdCcpID8gJ3ZhbHVlIG11c3QgZXF1YWwgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdjb25zdCcpXSkgOiAnJxKLAQoCbHQYAiABKBJCfcJIegp4CglzaW50NjQubHQaayFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID49IHJ1bGVzLmx0PyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASnQEKA2x0ZRgDIAEoEkKNAcJIiQEKhgEKCnNpbnQ2NC5sdGUaeCFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID4gcnVsZXMubHRlPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMubHRlXSkgOiAnJ0gAEpwHCgJndBgEIAEoEkKNB8JIiQcKewoJc2ludDY0Lmd0Gm4haGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8PSBydWxlcy5ndD8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0XSkgOiAnJwq0AQoMc2ludDY0Lmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq8AQoWc2ludDY0Lmd0X2x0X2V4Y2x1c2l2ZRqhAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndCAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCsQBCg1zaW50NjQuZ3RfbHRlGrIBaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJwrMAQoXc2ludDY0Lmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEugHCgNndGUYBSABKBJC2AfCSNQHCokBCgpzaW50NjQuZ3RlGnshaGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8IHJ1bGVzLmd0ZT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZV0pIDogJycKwwEKDXNpbnQ2NC5ndGVfbHQasQFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0ID49IHJ1bGVzLmd0ZSAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdF0pIDogJycKywEKF3NpbnQ2NC5ndGVfbHRfZXhjbHVzaXZlGq8BaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrTAQoOc2ludDY0Lmd0ZV9sdGUawAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3RlICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJycK2wEKGHNpbnQ2NC5ndGVfbHRlX2V4Y2x1c2l2ZRq+AWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJydIARKAAQoCaW4YBiADKBJCdMJIcQpvCglzaW50NjQuaW4aYiEodGhpcyBpbiBnZXRGaWVsZChydWxlcywgJ2luJykpID8gJ3ZhbHVlIG11c3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2luJyldKSA6ICcnEncKBm5vdF9pbhgHIAMoEkJnwkhkCmIKDXNpbnQ2NC5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxIsCgdleGFtcGxlGAggAygSQhvCSBgKFgoOc2ludDY0LmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAkILCglsZXNzX3RoYW5CDgoMZ3JlYXRlcl90aGFuIq8VCgxGaXhlZDMyUnVsZXMShQEKBWNvbnN0GAEgASgHQnbCSHMKcQoNZml4ZWQzMi5jb25zdBpgdGhpcyAhPSBnZXRGaWVsZChydWxlcywgJ2NvbnN0JykgPyAndmFsdWUgbXVzdCBlcXVhbCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2NvbnN0JyldKSA6ICcnEowBCgJsdBgCIAEoB0J+wkh7CnkKCmZpeGVkMzIubHQaayFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID49IHJ1bGVzLmx0PyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASngEKA2x0ZRgDIAEoB0KOAcJIigEKhwEKC2ZpeGVkMzIubHRlGnghaGFzKHJ1bGVzLmd0ZSkgJiYgIWhhcyhydWxlcy5ndCkgJiYgdGhpcyA+IHJ1bGVzLmx0ZT8gJ3ZhbHVlIG11c3QgYmUgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmx0ZV0pIDogJydIABKhBwoCZ3QYBCABKAdCkgfCSI4HCnwKCmZpeGVkMzIuZ3QabiFoYXMocnVsZXMubHQpICYmICFoYXMocnVsZXMubHRlKSAmJiB0aGlzIDw9IHJ1bGVzLmd0PyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RdKSA6ICcnCrUBCg1maXhlZDMyLmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq9AQoXZml4ZWQzMi5ndF9sdF9leGNsdXNpdmUaoQFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0IDwgcnVsZXMuZ3QgJiYgKHJ1bGVzLmx0IDw9IHRoaXMgJiYgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcyBvciBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwrFAQoOZml4ZWQzMi5ndF9sdGUasgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3QgJiYgKHRoaXMgPiBydWxlcy5sdGUgfHwgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcyBhbmQgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdGVdKSA6ICcnCs0BChhmaXhlZDMyLmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEu0HCgNndGUYBSABKAdC3QfCSNkHCooBCgtmaXhlZDMyLmd0ZRp7IWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmIHRoaXMgPCBydWxlcy5ndGU/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGVdKSA6ICcnCsQBCg5maXhlZDMyLmd0ZV9sdBqxAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPj0gcnVsZXMuZ3RlICYmICh0aGlzID49IHJ1bGVzLmx0IHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrMAQoYZml4ZWQzMi5ndGVfbHRfZXhjbHVzaXZlGq8BaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrUAQoPZml4ZWQzMi5ndGVfbHRlGsABaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ZSAmJiAodGhpcyA+IHJ1bGVzLmx0ZSB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnCtwBChlmaXhlZDMyLmd0ZV9sdGVfZXhjbHVzaXZlGr4BaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlIDwgcnVsZXMuZ3RlICYmIChydWxlcy5sdGUgPCB0aGlzICYmIHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgb3IgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRlXSkgOiAnJ0gBEoEBCgJpbhgGIAMoB0J1wkhyCnAKCmZpeGVkMzIuaW4aYiEodGhpcyBpbiBnZXRGaWVsZChydWxlcywgJ2luJykpID8gJ3ZhbHVlIG11c3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2luJyldKSA6ICcnEngKBm5vdF9pbhgHIAMoB0JowkhlCmMKDmZpeGVkMzIubm90X2luGlF0aGlzIGluIHJ1bGVzLm5vdF9pbiA/ICd2YWx1ZSBtdXN0IG5vdCBiZSBpbiBsaXN0ICVzJy5mb3JtYXQoW3J1bGVzLm5vdF9pbl0pIDogJycSLQoHZXhhbXBsZRgIIAMoB0IcwkgZChcKD2ZpeGVkMzIuZXhhbXBsZRoEdHJ1ZSoJCOgHEICAgIACQgsKCWxlc3NfdGhhbkIOCgxncmVhdGVyX3RoYW4irxUKDEZpeGVkNjRSdWxlcxKFAQoFY29uc3QYASABKAZCdsJIcwpxCg1maXhlZDY0LmNvbnN0GmB0aGlzICE9IGdldEZpZWxkKHJ1bGVzLCAnY29uc3QnKSA/ICd2YWx1ZSBtdXN0IGVxdWFsICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnY29uc3QnKV0pIDogJycSjAEKAmx0GAIgASgGQn7CSHsKeQoKZml4ZWQ2NC5sdBprIWhhcyhydWxlcy5ndGUpICYmICFoYXMocnVsZXMuZ3QpICYmIHRoaXMgPj0gcnVsZXMubHQ/ICd2YWx1ZSBtdXN0IGJlIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5sdF0pIDogJydIABKeAQoDbHRlGAMgASgGQo4BwkiKAQqHAQoLZml4ZWQ2NC5sdGUaeCFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID4gcnVsZXMubHRlPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMubHRlXSkgOiAnJ0gAEqEHCgJndBgEIAEoBkKSB8JIjgcKfAoKZml4ZWQ2NC5ndBpuIWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmIHRoaXMgPD0gcnVsZXMuZ3Q/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndF0pIDogJycKtQEKDWZpeGVkNjQuZ3RfbHQaowFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0ID49IHJ1bGVzLmd0ICYmICh0aGlzID49IHJ1bGVzLmx0IHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCr0BChdmaXhlZDY0Lmd0X2x0X2V4Y2x1c2l2ZRqhAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndCAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCsUBCg5maXhlZDY0Lmd0X2x0ZRqyAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA+PSBydWxlcy5ndCAmJiAodGhpcyA+IHJ1bGVzLmx0ZSB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0ZV0pIDogJycKzQEKGGZpeGVkNjQuZ3RfbHRlX2V4Y2x1c2l2ZRqwAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ICYmIChydWxlcy5sdGUgPCB0aGlzICYmIHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgb3IgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdGVdKSA6ICcnSAES7QcKA2d0ZRgFIAEoBkLdB8JI2QcKigEKC2ZpeGVkNjQuZ3RlGnshaGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8IHJ1bGVzLmd0ZT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZV0pIDogJycKxAEKDmZpeGVkNjQuZ3RlX2x0GrEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndGUgJiYgKHRoaXMgPj0gcnVsZXMubHQgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBhbmQgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRdKSA6ICcnCswBChhmaXhlZDY0Lmd0ZV9sdF9leGNsdXNpdmUarwFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0IDwgcnVsZXMuZ3RlICYmIChydWxlcy5sdCA8PSB0aGlzICYmIHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgb3IgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRdKSA6ICcnCtQBCg9maXhlZDY0Lmd0ZV9sdGUawAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3RlICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJycK3AEKGWZpeGVkNjQuZ3RlX2x0ZV9leGNsdXNpdmUavgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndGUgJiYgKHJ1bGVzLmx0ZSA8IHRoaXMgJiYgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBvciBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnSAESgQEKAmluGAYgAygGQnXCSHIKcAoKZml4ZWQ2NC5pbhpiISh0aGlzIGluIGdldEZpZWxkKHJ1bGVzLCAnaW4nKSkgPyAndmFsdWUgbXVzdCBiZSBpbiBsaXN0ICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnaW4nKV0pIDogJycSeAoGbm90X2luGAcgAygGQmjCSGUKYwoOZml4ZWQ2NC5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxItCgdleGFtcGxlGAggAygGQhzCSBkKFwoPZml4ZWQ2NC5leGFtcGxlGgR0cnVlKgkI6AcQgICAgAJCCwoJbGVzc190aGFuQg4KDGdyZWF0ZXJfdGhhbiLAFQoNU0ZpeGVkMzJSdWxlcxKGAQoFY29uc3QYASABKA9Cd8JIdApyCg5zZml4ZWQzMi5jb25zdBpgdGhpcyAhPSBnZXRGaWVsZChydWxlcywgJ2NvbnN0JykgPyAndmFsdWUgbXVzdCBlcXVhbCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2NvbnN0JyldKSA6ICcnEo0BCgJsdBgCIAEoD0J/wkh8CnoKC3NmaXhlZDMyLmx0GmshaGFzKHJ1bGVzLmd0ZSkgJiYgIWhhcyhydWxlcy5ndCkgJiYgdGhpcyA+PSBydWxlcy5sdD8gJ3ZhbHVlIG11c3QgYmUgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmx0XSkgOiAnJ0gAEp8BCgNsdGUYAyABKA9CjwHCSIsBCogBCgxzZml4ZWQzMi5sdGUaeCFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID4gcnVsZXMubHRlPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMubHRlXSkgOiAnJ0gAEqYHCgJndBgEIAEoD0KXB8JIkwcKfQoLc2ZpeGVkMzIuZ3QabiFoYXMocnVsZXMubHQpICYmICFoYXMocnVsZXMubHRlKSAmJiB0aGlzIDw9IHJ1bGVzLmd0PyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RdKSA6ICcnCrYBCg5zZml4ZWQzMi5ndF9sdBqjAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPj0gcnVsZXMuZ3QgJiYgKHRoaXMgPj0gcnVsZXMubHQgfHwgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcyBhbmQgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdF0pIDogJycKvgEKGHNmaXhlZDMyLmd0X2x0X2V4Y2x1c2l2ZRqhAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndCAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCsYBCg9zZml4ZWQzMi5ndF9sdGUasgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3QgJiYgKHRoaXMgPiBydWxlcy5sdGUgfHwgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcyBhbmQgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdGVdKSA6ICcnCs4BChlzZml4ZWQzMi5ndF9sdGVfZXhjbHVzaXZlGrABaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlIDwgcnVsZXMuZ3QgJiYgKHJ1bGVzLmx0ZSA8IHRoaXMgJiYgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcyBvciBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0ZV0pIDogJydIARLyBwoDZ3RlGAUgASgPQuIHwkjeBwqLAQoMc2ZpeGVkMzIuZ3RlGnshaGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8IHJ1bGVzLmd0ZT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZV0pIDogJycKxQEKD3NmaXhlZDMyLmd0ZV9sdBqxAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPj0gcnVsZXMuZ3RlICYmICh0aGlzID49IHJ1bGVzLmx0IHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrNAQoZc2ZpeGVkMzIuZ3RlX2x0X2V4Y2x1c2l2ZRqvAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndGUgJiYgKHJ1bGVzLmx0IDw9IHRoaXMgJiYgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBvciBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdF0pIDogJycK1QEKEHNmaXhlZDMyLmd0ZV9sdGUawAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPj0gcnVsZXMuZ3RlICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJycK3QEKGnNmaXhlZDMyLmd0ZV9sdGVfZXhjbHVzaXZlGr4BaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlIDwgcnVsZXMuZ3RlICYmIChydWxlcy5sdGUgPCB0aGlzICYmIHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgb3IgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRlXSkgOiAnJ0gBEoIBCgJpbhgGIAMoD0J2wkhzCnEKC3NmaXhlZDMyLmluGmIhKHRoaXMgaW4gZ2V0RmllbGQocnVsZXMsICdpbicpKSA/ICd2YWx1ZSBtdXN0IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdpbicpXSkgOiAnJxJ5CgZub3RfaW4YByADKA9CacJIZgpkCg9zZml4ZWQzMi5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxIuCgdleGFtcGxlGAggAygPQh3CSBoKGAoQc2ZpeGVkMzIuZXhhbXBsZRoEdHJ1ZSoJCOgHEICAgIACQgsKCWxlc3NfdGhhbkIOCgxncmVhdGVyX3RoYW4iwBUKDVNGaXhlZDY0UnVsZXMShgEKBWNvbnN0GAEgASgQQnfCSHQKcgoOc2ZpeGVkNjQuY29uc3QaYHRoaXMgIT0gZ2V0RmllbGQocnVsZXMsICdjb25zdCcpID8gJ3ZhbHVlIG11c3QgZXF1YWwgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdjb25zdCcpXSkgOiAnJxKNAQoCbHQYAiABKBBCf8JIfAp6CgtzZml4ZWQ2NC5sdBprIWhhcyhydWxlcy5ndGUpICYmICFoYXMocnVsZXMuZ3QpICYmIHRoaXMgPj0gcnVsZXMubHQ/ICd2YWx1ZSBtdXN0IGJlIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5sdF0pIDogJydIABKfAQoDbHRlGAMgASgQQo8BwkiLAQqIAQoMc2ZpeGVkNjQubHRlGnghaGFzKHJ1bGVzLmd0ZSkgJiYgIWhhcyhydWxlcy5ndCkgJiYgdGhpcyA+IHJ1bGVzLmx0ZT8gJ3ZhbHVlIG11c3QgYmUgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmx0ZV0pIDogJydIABKmBwoCZ3QYBCABKBBClwfCSJMHCn0KC3NmaXhlZDY0Lmd0Gm4haGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8PSBydWxlcy5ndD8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0XSkgOiAnJwq2AQoOc2ZpeGVkNjQuZ3RfbHQaowFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0ID49IHJ1bGVzLmd0ICYmICh0aGlzID49IHJ1bGVzLmx0IHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCr4BChhzZml4ZWQ2NC5ndF9sdF9leGNsdXNpdmUaoQFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0IDwgcnVsZXMuZ3QgJiYgKHJ1bGVzLmx0IDw9IHRoaXMgJiYgdGhpcyA8PSBydWxlcy5ndCk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcyBvciBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwrGAQoPc2ZpeGVkNjQuZ3RfbHRlGrIBaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJwrOAQoZc2ZpeGVkNjQuZ3RfbHRlX2V4Y2x1c2l2ZRqwAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ICYmIChydWxlcy5sdGUgPCB0aGlzICYmIHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgb3IgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdGVdKSA6ICcnSAES8gcKA2d0ZRgFIAEoEELiB8JI3gcKiwEKDHNmaXhlZDY0Lmd0ZRp7IWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmIHRoaXMgPCBydWxlcy5ndGU/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGVdKSA6ICcnCsUBCg9zZml4ZWQ2NC5ndGVfbHQasQFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0ID49IHJ1bGVzLmd0ZSAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdF0pIDogJycKzQEKGXNmaXhlZDY0Lmd0ZV9sdF9leGNsdXNpdmUarwFoYXMocnVsZXMubHQpICYmIHJ1bGVzLmx0IDwgcnVsZXMuZ3RlICYmIChydWxlcy5sdCA8PSB0aGlzICYmIHRoaXMgPCBydWxlcy5ndGUpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMgb3IgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRdKSA6ICcnCtUBChBzZml4ZWQ2NC5ndGVfbHRlGsABaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ZSAmJiAodGhpcyA+IHJ1bGVzLmx0ZSB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnCt0BChpzZml4ZWQ2NC5ndGVfbHRlX2V4Y2x1c2l2ZRq+AWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0ZV0pIDogJydIARKCAQoCaW4YBiADKBBCdsJIcwpxCgtzZml4ZWQ2NC5pbhpiISh0aGlzIGluIGdldEZpZWxkKHJ1bGVzLCAnaW4nKSkgPyAndmFsdWUgbXVzdCBiZSBpbiBsaXN0ICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnaW4nKV0pIDogJycSeQoGbm90X2luGAcgAygQQmnCSGYKZAoPc2ZpeGVkNjQubm90X2luGlF0aGlzIGluIHJ1bGVzLm5vdF9pbiA/ICd2YWx1ZSBtdXN0IG5vdCBiZSBpbiBsaXN0ICVzJy5mb3JtYXQoW3J1bGVzLm5vdF9pbl0pIDogJycSLgoHZXhhbXBsZRgIIAMoEEIdwkgaChgKEHNmaXhlZDY0LmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAkILCglsZXNzX3RoYW5CDgoMZ3JlYXRlcl90aGFuIscBCglCb29sUnVsZXMSggEKBWNvbnN0GAEgASgIQnPCSHAKbgoKYm9vbC5jb25zdBpgdGhpcyAhPSBnZXRGaWVsZChydWxlcywgJ2NvbnN0JykgPyAndmFsdWUgbXVzdCBlcXVhbCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2NvbnN0JyldKSA6ICcnEioKB2V4YW1wbGUYAiADKAhCGcJIFgoUCgxib29sLmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAiKQNwoLU3RyaW5nUnVsZXMShgEKBWNvbnN0GAEgASgJQnfCSHQKcgoMc3RyaW5nLmNvbnN0GmJ0aGlzICE9IGdldEZpZWxkKHJ1bGVzLCAnY29uc3QnKSA/ICd2YWx1ZSBtdXN0IGVxdWFsIGAlc2AnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdjb25zdCcpXSkgOiAnJxJ+CgNsZW4YEyABKARCccJIbgpsCgpzdHJpbmcubGVuGl51aW50KHRoaXMuc2l6ZSgpKSAhPSBydWxlcy5sZW4gPyAndmFsdWUgbGVuZ3RoIG11c3QgYmUgJXMgY2hhcmFjdGVycycuZm9ybWF0KFtydWxlcy5sZW5dKSA6ICcnEpkBCgdtaW5fbGVuGAIgASgEQocBwkiDAQqAAQoOc3RyaW5nLm1pbl9sZW4abnVpbnQodGhpcy5zaXplKCkpIDwgcnVsZXMubWluX2xlbiA/ICd2YWx1ZSBsZW5ndGggbXVzdCBiZSBhdCBsZWFzdCAlcyBjaGFyYWN0ZXJzJy5mb3JtYXQoW3J1bGVzLm1pbl9sZW5dKSA6ICcnEpcBCgdtYXhfbGVuGAMgASgEQoUBwkiBAQp/Cg5zdHJpbmcubWF4X2xlbhptdWludCh0aGlzLnNpemUoKSkgPiBydWxlcy5tYXhfbGVuID8gJ3ZhbHVlIGxlbmd0aCBtdXN0IGJlIGF0IG1vc3QgJXMgY2hhcmFjdGVycycuZm9ybWF0KFtydWxlcy5tYXhfbGVuXSkgOiAnJxKbAQoJbGVuX2J5dGVzGBQgASgEQocBwkiDAQqAAQoQc3RyaW5nLmxlbl9ieXRlcxpsdWludChieXRlcyh0aGlzKS5zaXplKCkpICE9IHJ1bGVzLmxlbl9ieXRlcyA/ICd2YWx1ZSBsZW5ndGggbXVzdCBiZSAlcyBieXRlcycuZm9ybWF0KFtydWxlcy5sZW5fYnl0ZXNdKSA6ICcnEqMBCgltaW5fYnl0ZXMYBCABKARCjwHCSIsBCogBChBzdHJpbmcubWluX2J5dGVzGnR1aW50KGJ5dGVzKHRoaXMpLnNpemUoKSkgPCBydWxlcy5taW5fYnl0ZXMgPyAndmFsdWUgbGVuZ3RoIG11c3QgYmUgYXQgbGVhc3QgJXMgYnl0ZXMnLmZvcm1hdChbcnVsZXMubWluX2J5dGVzXSkgOiAnJxKiAQoJbWF4X2J5dGVzGAUgASgEQo4BwkiKAQqHAQoQc3RyaW5nLm1heF9ieXRlcxpzdWludChieXRlcyh0aGlzKS5zaXplKCkpID4gcnVsZXMubWF4X2J5dGVzID8gJ3ZhbHVlIGxlbmd0aCBtdXN0IGJlIGF0IG1vc3QgJXMgYnl0ZXMnLmZvcm1hdChbcnVsZXMubWF4X2J5dGVzXSkgOiAnJxKNAQoHcGF0dGVybhgGIAEoCUJ8wkh5CncKDnN0cmluZy5wYXR0ZXJuGmUhdGhpcy5tYXRjaGVzKHJ1bGVzLnBhdHRlcm4pID8gJ3ZhbHVlIGRvZXMgbm90IG1hdGNoIHJlZ2V4IHBhdHRlcm4gYCVzYCcuZm9ybWF0KFtydWxlcy5wYXR0ZXJuXSkgOiAnJxKEAQoGcHJlZml4GAcgASgJQnTCSHEKbwoNc3RyaW5nLnByZWZpeBpeIXRoaXMuc3RhcnRzV2l0aChydWxlcy5wcmVmaXgpID8gJ3ZhbHVlIGRvZXMgbm90IGhhdmUgcHJlZml4IGAlc2AnLmZvcm1hdChbcnVsZXMucHJlZml4XSkgOiAnJxKCAQoGc3VmZml4GAggASgJQnLCSG8KbQoNc3RyaW5nLnN1ZmZpeBpcIXRoaXMuZW5kc1dpdGgocnVsZXMuc3VmZml4KSA/ICd2YWx1ZSBkb2VzIG5vdCBoYXZlIHN1ZmZpeCBgJXNgJy5mb3JtYXQoW3J1bGVzLnN1ZmZpeF0pIDogJycSkAEKCGNvbnRhaW5zGAkgASgJQn7CSHsKeQoPc3RyaW5nLmNvbnRhaW5zGmYhdGhpcy5jb250YWlucyhydWxlcy5jb250YWlucykgPyAndmFsdWUgZG9lcyBub3QgY29udGFpbiBzdWJzdHJpbmcgYCVzYCcuZm9ybWF0KFtydWxlcy5jb250YWluc10pIDogJycSmAEKDG5vdF9jb250YWlucxgXIAEoCUKBAcJIfgp8ChNzdHJpbmcubm90X2NvbnRhaW5zGmV0aGlzLmNvbnRhaW5zKHJ1bGVzLm5vdF9jb250YWlucykgPyAndmFsdWUgY29udGFpbnMgc3Vic3RyaW5nIGAlc2AnLmZvcm1hdChbcnVsZXMubm90X2NvbnRhaW5zXSkgOiAnJxKAAQoCaW4YCiADKAlCdMJIcQpvCglzdHJpbmcuaW4aYiEodGhpcyBpbiBnZXRGaWVsZChydWxlcywgJ2luJykpID8gJ3ZhbHVlIG11c3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2luJyldKSA6ICcnEncKBm5vdF9pbhgLIAMoCUJnwkhkCmIKDXN0cmluZy5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxLfAQoFZW1haWwYDCABKAhCzQHCSMkBCmEKDHN0cmluZy5lbWFpbBIjdmFsdWUgbXVzdCBiZSBhIHZhbGlkIGVtYWlsIGFkZHJlc3MaLCFydWxlcy5lbWFpbCB8fCB0aGlzID09ICcnIHx8IHRoaXMuaXNFbWFpbCgpCmQKEnN0cmluZy5lbWFpbF9lbXB0eRIydmFsdWUgaXMgZW1wdHksIHdoaWNoIGlzIG5vdCBhIHZhbGlkIGVtYWlsIGFkZHJlc3MaGiFydWxlcy5lbWFpbCB8fCB0aGlzICE9ICcnSAAS5wEKCGhvc3RuYW1lGA0gASgIQtIBwkjOAQplCg9zdHJpbmcuaG9zdG5hbWUSHnZhbHVlIG11c3QgYmUgYSB2YWxpZCBob3N0bmFtZRoyIXJ1bGVzLmhvc3RuYW1lIHx8IHRoaXMgPT0gJycgfHwgdGhpcy5pc0hvc3RuYW1lKCkKZQoVc3RyaW5nLmhvc3RuYW1lX2VtcHR5Ei12YWx1ZSBpcyBlbXB0eSwgd2hpY2ggaXMgbm90IGEgdmFsaWQgaG9zdG5hbWUaHSFydWxlcy5ob3N0bmFtZSB8fCB0aGlzICE9ICcnSAASxwEKAmlwGA4gASgIQrgBwki0AQpVCglzdHJpbmcuaXASIHZhbHVlIG11c3QgYmUgYSB2YWxpZCBJUCBhZGRyZXNzGiYhcnVsZXMuaXAgfHwgdGhpcyA9PSAnJyB8fCB0aGlzLmlzSXAoKQpbCg9zdHJpbmcuaXBfZW1wdHkSL3ZhbHVlIGlzIGVtcHR5LCB3aGljaCBpcyBub3QgYSB2YWxpZCBJUCBhZGRyZXNzGhchcnVsZXMuaXAgfHwgdGhpcyAhPSAnJ0gAEtYBCgRpcHY0GA8gASgIQsUBwkjBAQpcCgtzdHJpbmcuaXB2NBIidmFsdWUgbXVzdCBiZSBhIHZhbGlkIElQdjQgYWRkcmVzcxopIXJ1bGVzLmlwdjQgfHwgdGhpcyA9PSAnJyB8fCB0aGlzLmlzSXAoNCkKYQoRc3RyaW5nLmlwdjRfZW1wdHkSMXZhbHVlIGlzIGVtcHR5LCB3aGljaCBpcyBub3QgYSB2YWxpZCBJUHY0IGFkZHJlc3MaGSFydWxlcy5pcHY0IHx8IHRoaXMgIT0gJydIABLWAQoEaXB2NhgQIAEoCELFAcJIwQEKXAoLc3RyaW5nLmlwdjYSInZhbHVlIG11c3QgYmUgYSB2YWxpZCBJUHY2IGFkZHJlc3MaKSFydWxlcy5pcHY2IHx8IHRoaXMgPT0gJycgfHwgdGhpcy5pc0lwKDYpCmEKEXN0cmluZy5pcHY2X2VtcHR5EjF2YWx1ZSBpcyBlbXB0eSwgd2hpY2ggaXMgbm90IGEgdmFsaWQgSVB2NiBhZGRyZXNzGhkhcnVsZXMuaXB2NiB8fCB0aGlzICE9ICcnSAASvwEKA3VyaRgRIAEoCEKvAcJIqwEKUQoKc3RyaW5nLnVyaRIZdmFsdWUgbXVzdCBiZSBhIHZhbGlkIFVSSRooIXJ1bGVzLnVyaSB8fCB0aGlzID09ICcnIHx8IHRoaXMuaXNVcmkoKQpWChBzdHJpbmcudXJpX2VtcHR5Eih2YWx1ZSBpcyBlbXB0eSwgd2hpY2ggaXMgbm90IGEgdmFsaWQgVVJJGhghcnVsZXMudXJpIHx8IHRoaXMgIT0gJydIABJwCgd1cmlfcmVmGBIgASgIQl3CSFoKWAoOc3RyaW5nLnVyaV9yZWYSI3ZhbHVlIG11c3QgYmUgYSB2YWxpZCBVUkkgUmVmZXJlbmNlGiEhcnVsZXMudXJpX3JlZiB8fCB0aGlzLmlzVXJpUmVmKClIABKQAgoHYWRkcmVzcxgVIAEoCEL8AcJI+AEKgQEKDnN0cmluZy5hZGRyZXNzEi12YWx1ZSBtdXN0IGJlIGEgdmFsaWQgaG9zdG5hbWUsIG9yIGlwIGFkZHJlc3MaQCFydWxlcy5hZGRyZXNzIHx8IHRoaXMgPT0gJycgfHwgdGhpcy5pc0hvc3RuYW1lKCkgfHwgdGhpcy5pc0lwKCkKcgoUc3RyaW5nLmFkZHJlc3NfZW1wdHkSPHZhbHVlIGlzIGVtcHR5LCB3aGljaCBpcyBub3QgYSB2YWxpZCBob3N0bmFtZSwgb3IgaXAgYWRkcmVzcxocIXJ1bGVzLmFkZHJlc3MgfHwgdGhpcyAhPSAnJ0gAEpgCCgR1dWlkGBYgASgIQocCwkiDAgqlAQoLc3RyaW5nLnV1aWQSGnZhbHVlIG11c3QgYmUgYSB2YWxpZCBVVUlEGnohcnVsZXMudXVpZCB8fCB0aGlzID09ICcnIHx8IHRoaXMubWF0Y2hlcygnXlswLTlhLWZBLUZdezh9LVswLTlhLWZBLUZdezR9LVswLTlhLWZBLUZdezR9LVswLTlhLWZBLUZdezR9LVswLTlhLWZBLUZdezEyfSQnKQpZChFzdHJpbmcudXVpZF9lbXB0eRIpdmFsdWUgaXMgZW1wdHksIHdoaWNoIGlzIG5vdCBhIHZhbGlkIFVVSUQaGSFydWxlcy51dWlkIHx8IHRoaXMgIT0gJydIABLwAQoFdHV1aWQYISABKAhC3gHCSNoBCnMKDHN0cmluZy50dXVpZBIidmFsdWUgbXVzdCBiZSBhIHZhbGlkIHRyaW1tZWQgVVVJRBo/IXJ1bGVzLnR1dWlkIHx8IHRoaXMgPT0gJycgfHwgdGhpcy5tYXRjaGVzKCdeWzAtOWEtZkEtRl17MzJ9JCcpCmMKEnN0cmluZy50dXVpZF9lbXB0eRIxdmFsdWUgaXMgZW1wdHksIHdoaWNoIGlzIG5vdCBhIHZhbGlkIHRyaW1tZWQgVVVJRBoaIXJ1bGVzLnR1dWlkIHx8IHRoaXMgIT0gJydIABKWAgoRaXBfd2l0aF9wcmVmaXhsZW4YGiABKAhC+AHCSPQBCngKGHN0cmluZy5pcF93aXRoX3ByZWZpeGxlbhIfdmFsdWUgbXVzdCBiZSBhIHZhbGlkIElQIHByZWZpeBo7IXJ1bGVzLmlwX3dpdGhfcHJlZml4bGVuIHx8IHRoaXMgPT0gJycgfHwgdGhpcy5pc0lwUHJlZml4KCkKeAoec3RyaW5nLmlwX3dpdGhfcHJlZml4bGVuX2VtcHR5Ei52YWx1ZSBpcyBlbXB0eSwgd2hpY2ggaXMgbm90IGEgdmFsaWQgSVAgcHJlZml4GiYhcnVsZXMuaXBfd2l0aF9wcmVmaXhsZW4gfHwgdGhpcyAhPSAnJ0gAEs8CChNpcHY0X3dpdGhfcHJlZml4bGVuGBsgASgIQq8CwkirAgqTAQoac3RyaW5nLmlwdjRfd2l0aF9wcmVmaXhsZW4SNXZhbHVlIG11c3QgYmUgYSB2YWxpZCBJUHY0IGFkZHJlc3Mgd2l0aCBwcmVmaXggbGVuZ3RoGj4hcnVsZXMuaXB2NF93aXRoX3ByZWZpeGxlbiB8fCB0aGlzID09ICcnIHx8IHRoaXMuaXNJcFByZWZpeCg0KQqSAQogc3RyaW5nLmlwdjRfd2l0aF9wcmVmaXhsZW5fZW1wdHkSRHZhbHVlIGlzIGVtcHR5LCB3aGljaCBpcyBub3QgYSB2YWxpZCBJUHY0IGFkZHJlc3Mgd2l0aCBwcmVmaXggbGVuZ3RoGighcnVsZXMuaXB2NF93aXRoX3ByZWZpeGxlbiB8fCB0aGlzICE9ICcnSAASzwIKE2lwdjZfd2l0aF9wcmVmaXhsZW4YHCABKAhCrwLCSKsCCpMBChpzdHJpbmcuaXB2Nl93aXRoX3ByZWZpeGxlbhI1dmFsdWUgbXVzdCBiZSBhIHZhbGlkIElQdjYgYWRkcmVzcyB3aXRoIHByZWZpeCBsZW5ndGgaPiFydWxlcy5pcHY2X3dpdGhfcHJlZml4bGVuIHx8IHRoaXMgPT0gJycgfHwgdGhpcy5pc0lwUHJlZml4KDYpCpIBCiBzdHJpbmcuaXB2Nl93aXRoX3ByZWZpeGxlbl9lbXB0eRJEdmFsdWUgaXMgZW1wdHksIHdoaWNoIGlzIG5vdCBhIHZhbGlkIElQdjYgYWRkcmVzcyB3aXRoIHByZWZpeCBsZW5ndGgaKCFydWxlcy5pcHY2X3dpdGhfcHJlZml4bGVuIHx8IHRoaXMgIT0gJydIABLyAQoJaXBfcHJlZml4GB0gASgIQtwBwkjYAQpsChBzdHJpbmcuaXBfcHJlZml4Eh92YWx1ZSBtdXN0IGJlIGEgdmFsaWQgSVAgcHJlZml4GjchcnVsZXMuaXBfcHJlZml4IHx8IHRoaXMgPT0gJycgfHwgdGhpcy5pc0lwUHJlZml4KHRydWUpCmgKFnN0cmluZy5pcF9wcmVmaXhfZW1wdHkSLnZhbHVlIGlzIGVtcHR5LCB3aGljaCBpcyBub3QgYSB2YWxpZCBJUCBwcmVmaXgaHiFydWxlcy5pcF9wcmVmaXggfHwgdGhpcyAhPSAnJ0gAEoMCCgtpcHY0X3ByZWZpeBgeIAEoCELrAcJI5wEKdQoSc3RyaW5nLmlwdjRfcHJlZml4EiF2YWx1ZSBtdXN0IGJlIGEgdmFsaWQgSVB2NCBwcmVmaXgaPCFydWxlcy5pcHY0X3ByZWZpeCB8fCB0aGlzID09ICcnIHx8IHRoaXMuaXNJcFByZWZpeCg0LCB0cnVlKQpuChhzdHJpbmcuaXB2NF9wcmVmaXhfZW1wdHkSMHZhbHVlIGlzIGVtcHR5LCB3aGljaCBpcyBub3QgYSB2YWxpZCBJUHY0IHByZWZpeBogIXJ1bGVzLmlwdjRfcHJlZml4IHx8IHRoaXMgIT0gJydIABKDAgoLaXB2Nl9wcmVmaXgYHyABKAhC6wHCSOcBCnUKEnN0cmluZy5pcHY2X3ByZWZpeBIhdmFsdWUgbXVzdCBiZSBhIHZhbGlkIElQdjYgcHJlZml4GjwhcnVsZXMuaXB2Nl9wcmVmaXggfHwgdGhpcyA9PSAnJyB8fCB0aGlzLmlzSXBQcmVmaXgoNiwgdHJ1ZSkKbgoYc3RyaW5nLmlwdjZfcHJlZml4X2VtcHR5EjB2YWx1ZSBpcyBlbXB0eSwgd2hpY2ggaXMgbm90IGEgdmFsaWQgSVB2NiBwcmVmaXgaICFydWxlcy5pcHY2X3ByZWZpeCB8fCB0aGlzICE9ICcnSAAStQIKDWhvc3RfYW5kX3BvcnQYICABKAhCmwLCSJcCCpkBChRzdHJpbmcuaG9zdF9hbmRfcG9ydBJBdmFsdWUgbXVzdCBiZSBhIHZhbGlkIGhvc3QgKGhvc3RuYW1lIG9yIElQIGFkZHJlc3MpIGFuZCBwb3J0IHBhaXIaPiFydWxlcy5ob3N0X2FuZF9wb3J0IHx8IHRoaXMgPT0gJycgfHwgdGhpcy5pc0hvc3RBbmRQb3J0KHRydWUpCnkKGnN0cmluZy5ob3N0X2FuZF9wb3J0X2VtcHR5Ejd2YWx1ZSBpcyBlbXB0eSwgd2hpY2ggaXMgbm90IGEgdmFsaWQgaG9zdCBhbmQgcG9ydCBwYWlyGiIhcnVsZXMuaG9zdF9hbmRfcG9ydCB8fCB0aGlzICE9ICcnSAASqAUKEHdlbGxfa25vd25fcmVnZXgYGCABKA4yGC5idWYudmFsaWRhdGUuS25vd25SZWdleELxBMJI7QQK8AEKI3N0cmluZy53ZWxsX2tub3duX3JlZ2V4LmhlYWRlcl9uYW1lEiZ2YWx1ZSBtdXN0IGJlIGEgdmFsaWQgSFRUUCBoZWFkZXIgbmFtZRqgAXJ1bGVzLndlbGxfa25vd25fcmVnZXggIT0gMSB8fCB0aGlzID09ICcnIHx8IHRoaXMubWF0Y2hlcyghaGFzKHJ1bGVzLnN0cmljdCkgfHwgcnVsZXMuc3RyaWN0ID8nXjo/WzAtOWEtekEtWiEjJCUmXCcqKy0uXl98flx4NjBdKyQnIDonXlteXHUwMDAwXHUwMDBBXHUwMDBEXSskJykKjQEKKXN0cmluZy53ZWxsX2tub3duX3JlZ2V4LmhlYWRlcl9uYW1lX2VtcHR5EjV2YWx1ZSBpcyBlbXB0eSwgd2hpY2ggaXMgbm90IGEgdmFsaWQgSFRUUCBoZWFkZXIgbmFtZRopcnVsZXMud2VsbF9rbm93bl9yZWdleCAhPSAxIHx8IHRoaXMgIT0gJycK5wEKJHN0cmluZy53ZWxsX2tub3duX3JlZ2V4LmhlYWRlcl92YWx1ZRIndmFsdWUgbXVzdCBiZSBhIHZhbGlkIEhUVFAgaGVhZGVyIHZhbHVlGpUBcnVsZXMud2VsbF9rbm93bl9yZWdleCAhPSAyIHx8IHRoaXMubWF0Y2hlcyghaGFzKHJ1bGVzLnN0cmljdCkgfHwgcnVsZXMuc3RyaWN0ID8nXlteXHUwMDAwLVx1MDAwOFx1MDAwQS1cdTAwMUZcdTAwN0ZdKiQnIDonXlteXHUwMDAwXHUwMDBBXHUwMDBEXSokJylIABIOCgZzdHJpY3QYGSABKAgSLAoHZXhhbXBsZRgiIAMoCUIbwkgYChYKDnN0cmluZy5leGFtcGxlGgR0cnVlKgkI6AcQgICAgAJCDAoKd2VsbF9rbm93biLqEAoKQnl0ZXNSdWxlcxKAAQoFY29uc3QYASABKAxCccJIbgpsCgtieXRlcy5jb25zdBpddGhpcyAhPSBnZXRGaWVsZChydWxlcywgJ2NvbnN0JykgPyAndmFsdWUgbXVzdCBiZSAleCcuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2NvbnN0JyldKSA6ICcnEngKA2xlbhgNIAEoBEJrwkhoCmYKCWJ5dGVzLmxlbhpZdWludCh0aGlzLnNpemUoKSkgIT0gcnVsZXMubGVuID8gJ3ZhbHVlIGxlbmd0aCBtdXN0IGJlICVzIGJ5dGVzJy5mb3JtYXQoW3J1bGVzLmxlbl0pIDogJycSkAEKB21pbl9sZW4YAiABKARCf8JIfAp6Cg1ieXRlcy5taW5fbGVuGml1aW50KHRoaXMuc2l6ZSgpKSA8IHJ1bGVzLm1pbl9sZW4gPyAndmFsdWUgbGVuZ3RoIG11c3QgYmUgYXQgbGVhc3QgJXMgYnl0ZXMnLmZvcm1hdChbcnVsZXMubWluX2xlbl0pIDogJycSiAEKB21heF9sZW4YAyABKARCd8JIdApyCg1ieXRlcy5tYXhfbGVuGmF1aW50KHRoaXMuc2l6ZSgpKSA+IHJ1bGVzLm1heF9sZW4gPyAndmFsdWUgbXVzdCBiZSBhdCBtb3N0ICVzIGJ5dGVzJy5mb3JtYXQoW3J1bGVzLm1heF9sZW5dKSA6ICcnEpABCgdwYXR0ZXJuGAQgASgJQn/CSHwKegoNYnl0ZXMucGF0dGVybhppIXN0cmluZyh0aGlzKS5tYXRjaGVzKHJ1bGVzLnBhdHRlcm4pID8gJ3ZhbHVlIG11c3QgbWF0Y2ggcmVnZXggcGF0dGVybiBgJXNgJy5mb3JtYXQoW3J1bGVzLnBhdHRlcm5dKSA6ICcnEoEBCgZwcmVmaXgYBSABKAxCccJIbgpsCgxieXRlcy5wcmVmaXgaXCF0aGlzLnN0YXJ0c1dpdGgocnVsZXMucHJlZml4KSA/ICd2YWx1ZSBkb2VzIG5vdCBoYXZlIHByZWZpeCAleCcuZm9ybWF0KFtydWxlcy5wcmVmaXhdKSA6ICcnEn8KBnN1ZmZpeBgGIAEoDEJvwkhsCmoKDGJ5dGVzLnN1ZmZpeBpaIXRoaXMuZW5kc1dpdGgocnVsZXMuc3VmZml4KSA/ICd2YWx1ZSBkb2VzIG5vdCBoYXZlIHN1ZmZpeCAleCcuZm9ybWF0KFtydWxlcy5zdWZmaXhdKSA6ICcnEoMBCghjb250YWlucxgHIAEoDEJxwkhuCmwKDmJ5dGVzLmNvbnRhaW5zGlohdGhpcy5jb250YWlucyhydWxlcy5jb250YWlucykgPyAndmFsdWUgZG9lcyBub3QgY29udGFpbiAleCcuZm9ybWF0KFtydWxlcy5jb250YWluc10pIDogJycSpwEKAmluGAggAygMQpoBwkiWAQqTAQoIYnl0ZXMuaW4ahgFnZXRGaWVsZChydWxlcywgJ2luJykuc2l6ZSgpID4gMCAmJiAhKHRoaXMgaW4gZ2V0RmllbGQocnVsZXMsICdpbicpKSA/ICd2YWx1ZSBtdXN0IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdpbicpXSkgOiAnJxJ2CgZub3RfaW4YCSADKAxCZsJIYwphCgxieXRlcy5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxLrAQoCaXAYCiABKAhC3AHCSNgBCnQKCGJ5dGVzLmlwEiB2YWx1ZSBtdXN0IGJlIGEgdmFsaWQgSVAgYWRkcmVzcxpGIXJ1bGVzLmlwIHx8IHRoaXMuc2l6ZSgpID09IDAgfHwgdGhpcy5zaXplKCkgPT0gNCB8fCB0aGlzLnNpemUoKSA9PSAxNgpgCg5ieXRlcy5pcF9lbXB0eRIvdmFsdWUgaXMgZW1wdHksIHdoaWNoIGlzIG5vdCBhIHZhbGlkIElQIGFkZHJlc3MaHSFydWxlcy5pcCB8fCB0aGlzLnNpemUoKSAhPSAwSAAS5AEKBGlwdjQYCyABKAhC0wHCSM8BCmUKCmJ5dGVzLmlwdjQSInZhbHVlIG11c3QgYmUgYSB2YWxpZCBJUHY0IGFkZHJlc3MaMyFydWxlcy5pcHY0IHx8IHRoaXMuc2l6ZSgpID09IDAgfHwgdGhpcy5zaXplKCkgPT0gNApmChBieXRlcy5pcHY0X2VtcHR5EjF2YWx1ZSBpcyBlbXB0eSwgd2hpY2ggaXMgbm90IGEgdmFsaWQgSVB2NCBhZGRyZXNzGh8hcnVsZXMuaXB2NCB8fCB0aGlzLnNpemUoKSAhPSAwSAAS5QEKBGlwdjYYDCABKAhC1AHCSNABCmYKCmJ5dGVzLmlwdjYSInZhbHVlIG11c3QgYmUgYSB2YWxpZCBJUHY2IGFkZHJlc3MaNCFydWxlcy5pcHY2IHx8IHRoaXMuc2l6ZSgpID09IDAgfHwgdGhpcy5zaXplKCkgPT0gMTYKZgoQYnl0ZXMuaXB2Nl9lbXB0eRIxdmFsdWUgaXMgZW1wdHksIHdoaWNoIGlzIG5vdCBhIHZhbGlkIElQdjYgYWRkcmVzcxofIXJ1bGVzLmlwdjYgfHwgdGhpcy5zaXplKCkgIT0gMEgAEisKB2V4YW1wbGUYDiADKAxCGsJIFwoVCg1ieXRlcy5leGFtcGxlGgR0cnVlKgkI6AcQgICAgAJCDAoKd2VsbF9rbm93biLUAwoJRW51bVJ1bGVzEoIBCgVjb25zdBgBIAEoBUJzwkhwCm4KCmVudW0uY29uc3QaYHRoaXMgIT0gZ2V0RmllbGQocnVsZXMsICdjb25zdCcpID8gJ3ZhbHVlIG11c3QgZXF1YWwgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdjb25zdCcpXSkgOiAnJxIUCgxkZWZpbmVkX29ubHkYAiABKAgSfgoCaW4YAyADKAVCcsJIbwptCgdlbnVtLmluGmIhKHRoaXMgaW4gZ2V0RmllbGQocnVsZXMsICdpbicpKSA/ICd2YWx1ZSBtdXN0IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdpbicpXSkgOiAnJxJ1CgZub3RfaW4YBCADKAVCZcJIYgpgCgtlbnVtLm5vdF9pbhpRdGhpcyBpbiBydWxlcy5ub3RfaW4gPyAndmFsdWUgbXVzdCBub3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtydWxlcy5ub3RfaW5dKSA6ICcnEioKB2V4YW1wbGUYBSADKAVCGcJIFgoUCgxlbnVtLmV4YW1wbGUaBHRydWUqCQjoBxCAgICAAiL7AwoNUmVwZWF0ZWRSdWxlcxKeAQoJbWluX2l0ZW1zGAEgASgEQooBwkiGAQqDAQoScmVwZWF0ZWQubWluX2l0ZW1zGm11aW50KHRoaXMuc2l6ZSgpKSA8IHJ1bGVzLm1pbl9pdGVtcyA/ICd2YWx1ZSBtdXN0IGNvbnRhaW4gYXQgbGVhc3QgJWQgaXRlbShzKScuZm9ybWF0KFtydWxlcy5taW5faXRlbXNdKSA6ICcnEqIBCgltYXhfaXRlbXMYAiABKARCjgHCSIoBCocBChJyZXBlYXRlZC5tYXhfaXRlbXMacXVpbnQodGhpcy5zaXplKCkpID4gcnVsZXMubWF4X2l0ZW1zID8gJ3ZhbHVlIG11c3QgY29udGFpbiBubyBtb3JlIHRoYW4gJXMgaXRlbShzKScuZm9ybWF0KFtydWxlcy5tYXhfaXRlbXNdKSA6ICcnEnAKBnVuaXF1ZRgDIAEoCEJgwkhdClsKD3JlcGVhdGVkLnVuaXF1ZRIocmVwZWF0ZWQgdmFsdWUgbXVzdCBjb250YWluIHVuaXF1ZSBpdGVtcxoeIXJ1bGVzLnVuaXF1ZSB8fCB0aGlzLnVuaXF1ZSgpEicKBWl0ZW1zGAQgASgLMhguYnVmLnZhbGlkYXRlLkZpZWxkUnVsZXMqCQjoBxCAgICAAiKKAwoITWFwUnVsZXMSjwEKCW1pbl9wYWlycxgBIAEoBEJ8wkh5CncKDW1hcC5taW5fcGFpcnMaZnVpbnQodGhpcy5zaXplKCkpIDwgcnVsZXMubWluX3BhaXJzID8gJ21hcCBtdXN0IGJlIGF0IGxlYXN0ICVkIGVudHJpZXMnLmZvcm1hdChbcnVsZXMubWluX3BhaXJzXSkgOiAnJxKOAQoJbWF4X3BhaXJzGAIgASgEQnvCSHgKdgoNbWFwLm1heF9wYWlycxpldWludCh0aGlzLnNpemUoKSkgPiBydWxlcy5tYXhfcGFpcnMgPyAnbWFwIG11c3QgYmUgYXQgbW9zdCAlZCBlbnRyaWVzJy5mb3JtYXQoW3J1bGVzLm1heF9wYWlyc10pIDogJycSJgoEa2V5cxgEIAEoCzIYLmJ1Zi52YWxpZGF0ZS5GaWVsZFJ1bGVzEigKBnZhbHVlcxgFIAEoCzIYLmJ1Zi52YWxpZGF0ZS5GaWVsZFJ1bGVzKgkI6AcQgICAgAIiJgoIQW55UnVsZXMSCgoCaW4YAiADKAkSDgoGbm90X2luGAMgAygJIpkXCg1EdXJhdGlvblJ1bGVzEqEBCgVjb25zdBgCIAEoCzIZLmdvb2dsZS5wcm90b2J1Zi5EdXJhdGlvbkJ3wkh0CnIKDmR1cmF0aW9uLmNvbnN0GmB0aGlzICE9IGdldEZpZWxkKHJ1bGVzLCAnY29uc3QnKSA/ICd2YWx1ZSBtdXN0IGVxdWFsICVzJy5mb3JtYXQoW2dldEZpZWxkKHJ1bGVzLCAnY29uc3QnKV0pIDogJycSqAEKAmx0GAMgASgLMhkuZ29vZ2xlLnByb3RvYnVmLkR1cmF0aW9uQn/CSHwKegoLZHVyYXRpb24ubHQaayFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID49IHJ1bGVzLmx0PyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMubHRdKSA6ICcnSAASugEKA2x0ZRgEIAEoCzIZLmdvb2dsZS5wcm90b2J1Zi5EdXJhdGlvbkKPAcJIiwEKiAEKDGR1cmF0aW9uLmx0ZRp4IWhhcyhydWxlcy5ndGUpICYmICFoYXMocnVsZXMuZ3QpICYmIHRoaXMgPiBydWxlcy5sdGU/ICd2YWx1ZSBtdXN0IGJlIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5sdGVdKSA6ICcnSAASwQcKAmd0GAUgASgLMhkuZ29vZ2xlLnByb3RvYnVmLkR1cmF0aW9uQpcHwkiTBwp9CgtkdXJhdGlvbi5ndBpuIWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmIHRoaXMgPD0gcnVsZXMuZ3Q/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndF0pIDogJycKtgEKDmR1cmF0aW9uLmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq+AQoYZHVyYXRpb24uZ3RfbHRfZXhjbHVzaXZlGqEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ICYmIChydWxlcy5sdCA8PSB0aGlzICYmIHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgb3IgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0LCBydWxlcy5sdF0pIDogJycKxgEKD2R1cmF0aW9uLmd0X2x0ZRqyAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA+PSBydWxlcy5ndCAmJiAodGhpcyA+IHJ1bGVzLmx0ZSB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0ZV0pIDogJycKzgEKGWR1cmF0aW9uLmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEo0ICgNndGUYBiABKAsyGS5nb29nbGUucHJvdG9idWYuRHVyYXRpb25C4gfCSN4HCosBCgxkdXJhdGlvbi5ndGUaeyFoYXMocnVsZXMubHQpICYmICFoYXMocnVsZXMubHRlKSAmJiB0aGlzIDwgcnVsZXMuZ3RlPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlXSkgOiAnJwrFAQoPZHVyYXRpb24uZ3RlX2x0GrEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndGUgJiYgKHRoaXMgPj0gcnVsZXMubHQgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBhbmQgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRdKSA6ICcnCs0BChlkdXJhdGlvbi5ndGVfbHRfZXhjbHVzaXZlGq8BaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA8IHJ1bGVzLmd0ZSAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndGUsIHJ1bGVzLmx0XSkgOiAnJwrVAQoQZHVyYXRpb24uZ3RlX2x0ZRrAAWhhcyhydWxlcy5sdGUpICYmIHJ1bGVzLmx0ZSA+PSBydWxlcy5ndGUgJiYgKHRoaXMgPiBydWxlcy5sdGUgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBhbmQgbGVzcyB0aGFuIG9yIGVxdWFsIHRvICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRlXSkgOiAnJwrdAQoaZHVyYXRpb24uZ3RlX2x0ZV9leGNsdXNpdmUavgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndGUgJiYgKHJ1bGVzLmx0ZSA8IHRoaXMgJiYgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBvciBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnSAESnQEKAmluGAcgAygLMhkuZ29vZ2xlLnByb3RvYnVmLkR1cmF0aW9uQnbCSHMKcQoLZHVyYXRpb24uaW4aYiEodGhpcyBpbiBnZXRGaWVsZChydWxlcywgJ2luJykpID8gJ3ZhbHVlIG11c3QgYmUgaW4gbGlzdCAlcycuZm9ybWF0KFtnZXRGaWVsZChydWxlcywgJ2luJyldKSA6ICcnEpQBCgZub3RfaW4YCCADKAsyGS5nb29nbGUucHJvdG9idWYuRHVyYXRpb25CacJIZgpkCg9kdXJhdGlvbi5ub3RfaW4aUXRoaXMgaW4gcnVsZXMubm90X2luID8gJ3ZhbHVlIG11c3Qgbm90IGJlIGluIGxpc3QgJXMnLmZvcm1hdChbcnVsZXMubm90X2luXSkgOiAnJxJJCgdleGFtcGxlGAkgAygLMhkuZ29vZ2xlLnByb3RvYnVmLkR1cmF0aW9uQh3CSBoKGAoQZHVyYXRpb24uZXhhbXBsZRoEdHJ1ZSoJCOgHEICAgIACQgsKCWxlc3NfdGhhbkIOCgxncmVhdGVyX3RoYW4ikhgKDlRpbWVzdGFtcFJ1bGVzEqMBCgVjb25zdBgCIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBCeMJIdQpzCg90aW1lc3RhbXAuY29uc3QaYHRoaXMgIT0gZ2V0RmllbGQocnVsZXMsICdjb25zdCcpID8gJ3ZhbHVlIG11c3QgZXF1YWwgJXMnLmZvcm1hdChbZ2V0RmllbGQocnVsZXMsICdjb25zdCcpXSkgOiAnJxKrAQoCbHQYAyABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wQoABwkh9CnsKDHRpbWVzdGFtcC5sdBprIWhhcyhydWxlcy5ndGUpICYmICFoYXMocnVsZXMuZ3QpICYmIHRoaXMgPj0gcnVsZXMubHQ/ICd2YWx1ZSBtdXN0IGJlIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5sdF0pIDogJydIABK8AQoDbHRlGAQgASgLMhouZ29vZ2xlLnByb3RvYnVmLlRpbWVzdGFtcEKQAcJIjAEKiQEKDXRpbWVzdGFtcC5sdGUaeCFoYXMocnVsZXMuZ3RlKSAmJiAhaGFzKHJ1bGVzLmd0KSAmJiB0aGlzID4gcnVsZXMubHRlPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMubHRlXSkgOiAnJ0gAEmwKBmx0X25vdxgHIAEoCEJawkhXClUKEHRpbWVzdGFtcC5sdF9ub3caQShydWxlcy5sdF9ub3cgJiYgdGhpcyA+IG5vdykgPyAndmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gbm93JyA6ICcnSAASxwcKAmd0GAUgASgLMhouZ29vZ2xlLnByb3RvYnVmLlRpbWVzdGFtcEKcB8JImAcKfgoMdGltZXN0YW1wLmd0Gm4haGFzKHJ1bGVzLmx0KSAmJiAhaGFzKHJ1bGVzLmx0ZSkgJiYgdGhpcyA8PSBydWxlcy5ndD8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0XSkgOiAnJwq3AQoPdGltZXN0YW1wLmd0X2x0GqMBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndCAmJiAodGhpcyA+PSBydWxlcy5sdCB8fCB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIGFuZCBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3QsIHJ1bGVzLmx0XSkgOiAnJwq/AQoZdGltZXN0YW1wLmd0X2x0X2V4Y2x1c2l2ZRqhAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndCAmJiAocnVsZXMubHQgPD0gdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRdKSA6ICcnCscBChB0aW1lc3RhbXAuZ3RfbHRlGrIBaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ICYmICh0aGlzID4gcnVsZXMubHRlIHx8IHRoaXMgPD0gcnVsZXMuZ3QpPyAndmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gJXMgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJwrPAQoadGltZXN0YW1wLmd0X2x0ZV9leGNsdXNpdmUasAFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndCAmJiAocnVsZXMubHRlIDwgdGhpcyAmJiB0aGlzIDw9IHJ1bGVzLmd0KT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuICVzIG9yIGxlc3MgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndCwgcnVsZXMubHRlXSkgOiAnJ0gBEpMICgNndGUYBiABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wQucHwkjjBwqMAQoNdGltZXN0YW1wLmd0ZRp7IWhhcyhydWxlcy5sdCkgJiYgIWhhcyhydWxlcy5sdGUpICYmIHRoaXMgPCBydWxlcy5ndGU/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcycuZm9ybWF0KFtydWxlcy5ndGVdKSA6ICcnCsYBChB0aW1lc3RhbXAuZ3RlX2x0GrEBaGFzKHJ1bGVzLmx0KSAmJiBydWxlcy5sdCA+PSBydWxlcy5ndGUgJiYgKHRoaXMgPj0gcnVsZXMubHQgfHwgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBhbmQgbGVzcyB0aGFuICVzJy5mb3JtYXQoW3J1bGVzLmd0ZSwgcnVsZXMubHRdKSA6ICcnCs4BChp0aW1lc3RhbXAuZ3RlX2x0X2V4Y2x1c2l2ZRqvAWhhcyhydWxlcy5sdCkgJiYgcnVsZXMubHQgPCBydWxlcy5ndGUgJiYgKHJ1bGVzLmx0IDw9IHRoaXMgJiYgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBvciBsZXNzIHRoYW4gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdF0pIDogJycK1gEKEXRpbWVzdGFtcC5ndGVfbHRlGsABaGFzKHJ1bGVzLmx0ZSkgJiYgcnVsZXMubHRlID49IHJ1bGVzLmd0ZSAmJiAodGhpcyA+IHJ1bGVzLmx0ZSB8fCB0aGlzIDwgcnVsZXMuZ3RlKT8gJ3ZhbHVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIG9yIGVxdWFsIHRvICVzIGFuZCBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnCt4BCht0aW1lc3RhbXAuZ3RlX2x0ZV9leGNsdXNpdmUavgFoYXMocnVsZXMubHRlKSAmJiBydWxlcy5sdGUgPCBydWxlcy5ndGUgJiYgKHJ1bGVzLmx0ZSA8IHRoaXMgJiYgdGhpcyA8IHJ1bGVzLmd0ZSk/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byAlcyBvciBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJXMnLmZvcm1hdChbcnVsZXMuZ3RlLCBydWxlcy5sdGVdKSA6ICcnSAESbwoGZ3Rfbm93GAggASgIQl3CSFoKWAoQdGltZXN0YW1wLmd0X25vdxpEKHJ1bGVzLmd0X25vdyAmJiB0aGlzIDwgbm93KSA/ICd2YWx1ZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBub3cnIDogJydIARK4AQoGd2l0aGluGAkgASgLMhkuZ29vZ2xlLnByb3RvYnVmLkR1cmF0aW9uQowBwkiIAQqFAQoQdGltZXN0YW1wLndpdGhpbhpxdGhpcyA8IG5vdy1ydWxlcy53aXRoaW4gfHwgdGhpcyA+IG5vdytydWxlcy53aXRoaW4gPyAndmFsdWUgbXVzdCBiZSB3aXRoaW4gJXMgb2Ygbm93Jy5mb3JtYXQoW3J1bGVzLndpdGhpbl0pIDogJycSSwoHZXhhbXBsZRgKIAMoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBCHsJIGwoZChF0aW1lc3RhbXAuZXhhbXBsZRoEdHJ1ZSoJCOgHEICAgIACQgsKCWxlc3NfdGhhbkIOCgxncmVhdGVyX3RoYW4iOQoKVmlvbGF0aW9ucxIrCgp2aW9sYXRpb25zGAEgAygLMhcuYnVmLnZhbGlkYXRlLlZpb2xhdGlvbiKfAQoJVmlvbGF0aW9uEiYKBWZpZWxkGAUgASgLMhcuYnVmLnZhbGlkYXRlLkZpZWxkUGF0aBIlCgRydWxlGAYgASgLMhcuYnVmLnZhbGlkYXRlLkZpZWxkUGF0aBIPCgdydWxlX2lkGAIgASgJEg8KB21lc3NhZ2UYAyABKAkSDwoHZm9yX2tleRgEIAEoCEoECAEQAlIKZmllbGRfcGF0aCI9CglGaWVsZFBhdGgSMAoIZWxlbWVudHMYASADKAsyHi5idWYudmFsaWRhdGUuRmllbGRQYXRoRWxlbWVudCLpAgoQRmllbGRQYXRoRWxlbWVudBIUCgxmaWVsZF9udW1iZXIYASABKAUSEgoKZmllbGRfbmFtZRgCIAEoCRI+CgpmaWVsZF90eXBlGAMgASgOMiouZ29vZ2xlLnByb3RvYnVmLkZpZWxkRGVzY3JpcHRvclByb3RvLlR5cGUSPAoIa2V5X3R5cGUYBCABKA4yKi5nb29nbGUucHJvdG9idWYuRmllbGREZXNjcmlwdG9yUHJvdG8uVHlwZRI+Cgp2YWx1ZV90eXBlGAUgASgOMiouZ29vZ2xlLnByb3RvYnVmLkZpZWxkRGVzY3JpcHRvclByb3RvLlR5cGUSDwoFaW5kZXgYBiABKARIABISCghib29sX2tleRgHIAEoCEgAEhEKB2ludF9rZXkYCCABKANIABISCgh1aW50X2tleRgJIAEoBEgAEhQKCnN0cmluZ19rZXkYCiABKAlIAEILCglzdWJzY3JpcHQqhwEKBklnbm9yZRIWChJJR05PUkVfVU5TUEVDSUZJRUQQABIZChVJR05PUkVfSUZfVU5QT1BVTEFURUQQARIbChdJR05PUkVfSUZfREVGQVVMVF9WQUxVRRACEhEKDUlHTk9SRV9BTFdBWVMQAyoaSUdOT1JFX0VNUFRZSUdOT1JFX0RFRkFVTFQqbgoKS25vd25SZWdleBIbChdLTk9XTl9SRUdFWF9VTlNQRUNJRklFRBAAEiAKHEtOT1dOX1JFR0VYX0hUVFBfSEVBREVSX05BTUUQARIhCh1LTk9XTl9SRUdFWF9IVFRQX0hFQURFUl9WQUxVRRACOlYKB21lc3NhZ2USHy5nb29nbGUucHJvdG9idWYuTWVzc2FnZU9wdGlvbnMYhwkgASgLMhouYnVmLnZhbGlkYXRlLk1lc3NhZ2VSdWxlc1IHbWVzc2FnZTpOCgVvbmVvZhIdLmdvb2dsZS5wcm90b2J1Zi5PbmVvZk9wdGlvbnMYhwkgASgLMhguYnVmLnZhbGlkYXRlLk9uZW9mUnVsZXNSBW9uZW9mOk4KBWZpZWxkEh0uZ29vZ2xlLnByb3RvYnVmLkZpZWxkT3B0aW9ucxiHCSABKAsyGC5idWYudmFsaWRhdGUuRmllbGRSdWxlc1IFZmllbGQ6XQoKcHJlZGVmaW5lZBIdLmdvb2dsZS5wcm90b2J1Zi5GaWVsZE9wdGlvbnMYiAkgASgLMh0uYnVmLnZhbGlkYXRlLlByZWRlZmluZWRSdWxlc1IKcHJlZGVmaW5lZEK7AQoQY29tLmJ1Zi52YWxpZGF0ZUINVmFsaWRhdGVQcm90b1ABWkdidWYuYnVpbGQvZ2VuL2dvL2J1ZmJ1aWxkL3Byb3RvdmFsaWRhdGUvcHJvdG9jb2xidWZmZXJzL2dvL2J1Zi92YWxpZGF0ZaICA0JWWKoCDEJ1Zi5WYWxpZGF0ZcoCDEJ1ZlxWYWxpZGF0ZeICGEJ1ZlxWYWxpZGF0ZVxHUEJNZXRhZGF0YeoCDUJ1Zjo6VmFsaWRhdGU", [file_google_protobuf_descriptor, file_google_protobuf_duration, file_google_protobuf_timestamp]);
+
+/**
+ * `Rule` represents a validation rule written in the Common Expression
+ * Language (CEL) syntax. Each Rule includes a unique identifier, an
+ * optional error message, and the CEL expression to evaluate. For more
+ * information on CEL, [see our documentation](https://github.com/bufbuild/protovalidate/blob/main/docs/cel.md).
+ *
+ * ```proto
+ * message Foo {
+ * option (buf.validate.message).cel = {
+ * id: "foo.bar"
+ * message: "bar must be greater than 0"
+ * expression: "this.bar > 0"
+ * };
+ * int32 bar = 1;
+ * }
+ * ```
+ *
+ * @generated from message buf.validate.Rule
+ */
+export type Rule = Message<"buf.validate.Rule"> & {
+ /**
+ * `id` is a string that serves as a machine-readable name for this Rule.
+ * It should be unique within its scope, which could be either a message or a field.
+ *
+ * @generated from field: optional string id = 1;
+ */
+ id: string;
+
+ /**
+ * `message` is an optional field that provides a human-readable error message
+ * for this Rule when the CEL expression evaluates to false. If a
+ * non-empty message is provided, any strings resulting from the CEL
+ * expression evaluation are ignored.
+ *
+ * @generated from field: optional string message = 2;
+ */
+ message: string;
+
+ /**
+ * `expression` is the actual CEL expression that will be evaluated for
+ * validation. This string must resolve to either a boolean or a string
+ * value. If the expression evaluates to false or a non-empty string, the
+ * validation is considered failed, and the message is rejected.
+ *
+ * @generated from field: optional string expression = 3;
+ */
+ expression: string;
+};
+
+/**
+ * Describes the message buf.validate.Rule.
+ * Use `create(RuleSchema)` to create a new message.
+ */
+export const RuleSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 0);
+
+/**
+ * MessageRules represents validation rules that are applied to the entire message.
+ * It includes disabling options and a list of Rule messages representing Common Expression Language (CEL) validation rules.
+ *
+ * @generated from message buf.validate.MessageRules
+ */
+export type MessageRules = Message<"buf.validate.MessageRules"> & {
+ /**
+ * `disabled` is a boolean flag that, when set to true, nullifies any validation rules for this message.
+ * This includes any fields within the message that would otherwise support validation.
+ *
+ * ```proto
+ * message MyMessage {
+ * // validation will be bypassed for this message
+ * option (buf.validate.message).disabled = true;
+ * }
+ * ```
+ *
+ * @generated from field: optional bool disabled = 1;
+ */
+ disabled: boolean;
+
+ /**
+ * `cel` is a repeated field of type Rule. Each Rule specifies a validation rule to be applied to this message.
+ * These rules are written in Common Expression Language (CEL) syntax. For more information on
+ * CEL, [see our documentation](https://github.com/bufbuild/protovalidate/blob/main/docs/cel.md).
+ *
+ *
+ * ```proto
+ * message MyMessage {
+ * // The field `foo` must be greater than 42.
+ * option (buf.validate.message).cel = {
+ * id: "my_message.value",
+ * message: "value must be greater than 42",
+ * expression: "this.foo > 42",
+ * };
+ * optional int32 foo = 1;
+ * }
+ * ```
+ *
+ * @generated from field: repeated buf.validate.Rule cel = 3;
+ */
+ cel: Rule[];
+};
+
+/**
+ * Describes the message buf.validate.MessageRules.
+ * Use `create(MessageRulesSchema)` to create a new message.
+ */
+export const MessageRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 1);
+
+/**
+ * The `OneofRules` message type enables you to manage rules for
+ * oneof fields in your protobuf messages.
+ *
+ * @generated from message buf.validate.OneofRules
+ */
+export type OneofRules = Message<"buf.validate.OneofRules"> & {
+ /**
+ * If `required` is true, exactly one field of the oneof must be present. A
+ * validation error is returned if no fields in the oneof are present. The
+ * field itself may still be a default value; further rules
+ * should be placed on the fields themselves to ensure they are valid values,
+ * such as `min_len` or `gt`.
+ *
+ * ```proto
+ * message MyMessage {
+ * oneof value {
+ * // Either `a` or `b` must be set. If `a` is set, it must also be
+ * // non-empty; whereas if `b` is set, it can still be an empty string.
+ * option (buf.validate.oneof).required = true;
+ * string a = 1 [(buf.validate.field).string.min_len = 1];
+ * string b = 2;
+ * }
+ * }
+ * ```
+ *
+ * @generated from field: optional bool required = 1;
+ */
+ required: boolean;
+};
+
+/**
+ * Describes the message buf.validate.OneofRules.
+ * Use `create(OneofRulesSchema)` to create a new message.
+ */
+export const OneofRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 2);
+
+/**
+ * FieldRules encapsulates the rules for each type of field. Depending on
+ * the field, the correct set should be used to ensure proper validations.
+ *
+ * @generated from message buf.validate.FieldRules
+ */
+export type FieldRules = Message<"buf.validate.FieldRules"> & {
+ /**
+ * `cel` is a repeated field used to represent a textual expression
+ * in the Common Expression Language (CEL) syntax. For more information on
+ * CEL, [see our documentation](https://github.com/bufbuild/protovalidate/blob/main/docs/cel.md).
+ *
+ * ```proto
+ * message MyMessage {
+ * // The field `value` must be greater than 42.
+ * optional int32 value = 1 [(buf.validate.field).cel = {
+ * id: "my_message.value",
+ * message: "value must be greater than 42",
+ * expression: "this > 42",
+ * }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated buf.validate.Rule cel = 23;
+ */
+ cel: Rule[];
+
+ /**
+ * If `required` is true, the field must be populated. A populated field can be
+ * described as "serialized in the wire format," which includes:
+ *
+ * - the following "nullable" fields must be explicitly set to be considered populated:
+ * - singular message fields (whose fields may be unpopulated / default values)
+ * - member fields of a oneof (may be their default value)
+ * - proto3 optional fields (may be their default value)
+ * - proto2 scalar fields (both optional and required)
+ * - proto3 scalar fields must be non-zero to be considered populated
+ * - repeated and map fields must be non-empty to be considered populated
+ *
+ * ```proto
+ * message MyMessage {
+ * // The field `value` must be set to a non-null value.
+ * optional MyOtherMessage value = 1 [(buf.validate.field).required = true];
+ * }
+ * ```
+ *
+ * @generated from field: optional bool required = 25;
+ */
+ required: boolean;
+
+ /**
+ * Skip validation on the field if its value matches the specified criteria.
+ * See Ignore enum for details.
+ *
+ * ```proto
+ * message UpdateRequest {
+ * // The uri rule only applies if the field is populated and not an empty
+ * // string.
+ * optional string url = 1 [
+ * (buf.validate.field).ignore = IGNORE_IF_DEFAULT_VALUE,
+ * (buf.validate.field).string.uri = true,
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: optional buf.validate.Ignore ignore = 27;
+ */
+ ignore: Ignore;
+
+ /**
+ * @generated from oneof buf.validate.FieldRules.type
+ */
+ type: {
+ /**
+ * Scalar Field Types
+ *
+ * @generated from field: buf.validate.FloatRules float = 1;
+ */
+ value: FloatRules;
+ case: "float";
+ } | {
+ /**
+ * @generated from field: buf.validate.DoubleRules double = 2;
+ */
+ value: DoubleRules;
+ case: "double";
+ } | {
+ /**
+ * @generated from field: buf.validate.Int32Rules int32 = 3;
+ */
+ value: Int32Rules;
+ case: "int32";
+ } | {
+ /**
+ * @generated from field: buf.validate.Int64Rules int64 = 4;
+ */
+ value: Int64Rules;
+ case: "int64";
+ } | {
+ /**
+ * @generated from field: buf.validate.UInt32Rules uint32 = 5;
+ */
+ value: UInt32Rules;
+ case: "uint32";
+ } | {
+ /**
+ * @generated from field: buf.validate.UInt64Rules uint64 = 6;
+ */
+ value: UInt64Rules;
+ case: "uint64";
+ } | {
+ /**
+ * @generated from field: buf.validate.SInt32Rules sint32 = 7;
+ */
+ value: SInt32Rules;
+ case: "sint32";
+ } | {
+ /**
+ * @generated from field: buf.validate.SInt64Rules sint64 = 8;
+ */
+ value: SInt64Rules;
+ case: "sint64";
+ } | {
+ /**
+ * @generated from field: buf.validate.Fixed32Rules fixed32 = 9;
+ */
+ value: Fixed32Rules;
+ case: "fixed32";
+ } | {
+ /**
+ * @generated from field: buf.validate.Fixed64Rules fixed64 = 10;
+ */
+ value: Fixed64Rules;
+ case: "fixed64";
+ } | {
+ /**
+ * @generated from field: buf.validate.SFixed32Rules sfixed32 = 11;
+ */
+ value: SFixed32Rules;
+ case: "sfixed32";
+ } | {
+ /**
+ * @generated from field: buf.validate.SFixed64Rules sfixed64 = 12;
+ */
+ value: SFixed64Rules;
+ case: "sfixed64";
+ } | {
+ /**
+ * @generated from field: buf.validate.BoolRules bool = 13;
+ */
+ value: BoolRules;
+ case: "bool";
+ } | {
+ /**
+ * @generated from field: buf.validate.StringRules string = 14;
+ */
+ value: StringRules;
+ case: "string";
+ } | {
+ /**
+ * @generated from field: buf.validate.BytesRules bytes = 15;
+ */
+ value: BytesRules;
+ case: "bytes";
+ } | {
+ /**
+ * Complex Field Types
+ *
+ * @generated from field: buf.validate.EnumRules enum = 16;
+ */
+ value: EnumRules;
+ case: "enum";
+ } | {
+ /**
+ * @generated from field: buf.validate.RepeatedRules repeated = 18;
+ */
+ value: RepeatedRules;
+ case: "repeated";
+ } | {
+ /**
+ * @generated from field: buf.validate.MapRules map = 19;
+ */
+ value: MapRules;
+ case: "map";
+ } | {
+ /**
+ * Well-Known Field Types
+ *
+ * @generated from field: buf.validate.AnyRules any = 20;
+ */
+ value: AnyRules;
+ case: "any";
+ } | {
+ /**
+ * @generated from field: buf.validate.DurationRules duration = 21;
+ */
+ value: DurationRules;
+ case: "duration";
+ } | {
+ /**
+ * @generated from field: buf.validate.TimestampRules timestamp = 22;
+ */
+ value: TimestampRules;
+ case: "timestamp";
+ } | { case: undefined; value?: undefined };
+};
+
+/**
+ * Describes the message buf.validate.FieldRules.
+ * Use `create(FieldRulesSchema)` to create a new message.
+ */
+export const FieldRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 3);
+
+/**
+ * PredefinedRules are custom rules that can be re-used with
+ * multiple fields.
+ *
+ * @generated from message buf.validate.PredefinedRules
+ */
+export type PredefinedRules = Message<"buf.validate.PredefinedRules"> & {
+ /**
+ * `cel` is a repeated field used to represent a textual expression
+ * in the Common Expression Language (CEL) syntax. For more information on
+ * CEL, [see our documentation](https://github.com/bufbuild/protovalidate/blob/main/docs/cel.md).
+ *
+ * ```proto
+ * message MyMessage {
+ * // The field `value` must be greater than 42.
+ * optional int32 value = 1 [(buf.validate.predefined).cel = {
+ * id: "my_message.value",
+ * message: "value must be greater than 42",
+ * expression: "this > 42",
+ * }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated buf.validate.Rule cel = 1;
+ */
+ cel: Rule[];
+};
+
+/**
+ * Describes the message buf.validate.PredefinedRules.
+ * Use `create(PredefinedRulesSchema)` to create a new message.
+ */
+export const PredefinedRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 4);
+
+/**
+ * FloatRules describes the rules applied to `float` values. These
+ * rules may also be applied to the `google.protobuf.FloatValue` Well-Known-Type.
+ *
+ * @generated from message buf.validate.FloatRules
+ */
+export type FloatRules = Message<"buf.validate.FloatRules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyFloat {
+ * // value must equal 42.0
+ * float value = 1 [(buf.validate.field).float.const = 42.0];
+ * }
+ * ```
+ *
+ * @generated from field: optional float const = 1;
+ */
+ const: number;
+
+ /**
+ * @generated from oneof buf.validate.FloatRules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFloat {
+ * // value must be less than 10.0
+ * float value = 1 [(buf.validate.field).float.lt = 10.0];
+ * }
+ * ```
+ *
+ * @generated from field: float lt = 2;
+ */
+ value: number;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyFloat {
+ * // value must be less than or equal to 10.0
+ * float value = 1 [(buf.validate.field).float.lte = 10.0];
+ * }
+ * ```
+ *
+ * @generated from field: float lte = 3;
+ */
+ value: number;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.FloatRules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFloat {
+ * // value must be greater than 5.0 [float.gt]
+ * float value = 1 [(buf.validate.field).float.gt = 5.0];
+ *
+ * // value must be greater than 5 and less than 10.0 [float.gt_lt]
+ * float other_value = 2 [(buf.validate.field).float = { gt: 5.0, lt: 10.0 }];
+ *
+ * // value must be greater than 10 or less than 5.0 [float.gt_lt_exclusive]
+ * float another_value = 3 [(buf.validate.field).float = { gt: 10.0, lt: 5.0 }];
+ * }
+ * ```
+ *
+ * @generated from field: float gt = 4;
+ */
+ value: number;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFloat {
+ * // value must be greater than or equal to 5.0 [float.gte]
+ * float value = 1 [(buf.validate.field).float.gte = 5.0];
+ *
+ * // value must be greater than or equal to 5.0 and less than 10.0 [float.gte_lt]
+ * float other_value = 2 [(buf.validate.field).float = { gte: 5.0, lt: 10.0 }];
+ *
+ * // value must be greater than or equal to 10.0 or less than 5.0 [float.gte_lt_exclusive]
+ * float another_value = 3 [(buf.validate.field).float = { gte: 10.0, lt: 5.0 }];
+ * }
+ * ```
+ *
+ * @generated from field: float gte = 5;
+ */
+ value: number;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message
+ * is generated.
+ *
+ * ```proto
+ * message MyFloat {
+ * // value must be in list [1.0, 2.0, 3.0]
+ * float value = 1 [(buf.validate.field).float = { in: [1.0, 2.0, 3.0] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated float in = 6;
+ */
+ in: number[];
+
+ /**
+ * `in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyFloat {
+ * // value must not be in list [1.0, 2.0, 3.0]
+ * float value = 1 [(buf.validate.field).float = { not_in: [1.0, 2.0, 3.0] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated float not_in = 7;
+ */
+ notIn: number[];
+
+ /**
+ * `finite` requires the field value to be finite. If the field value is
+ * infinite or NaN, an error message is generated.
+ *
+ * @generated from field: optional bool finite = 8;
+ */
+ finite: boolean;
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyFloat {
+ * float value = 1 [
+ * (buf.validate.field).float.example = 1.0,
+ * (buf.validate.field).float.example = "Infinity"
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated float example = 9;
+ */
+ example: number[];
+};
+
+/**
+ * Describes the message buf.validate.FloatRules.
+ * Use `create(FloatRulesSchema)` to create a new message.
+ */
+export const FloatRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 5);
+
+/**
+ * DoubleRules describes the rules applied to `double` values. These
+ * rules may also be applied to the `google.protobuf.DoubleValue` Well-Known-Type.
+ *
+ * @generated from message buf.validate.DoubleRules
+ */
+export type DoubleRules = Message<"buf.validate.DoubleRules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyDouble {
+ * // value must equal 42.0
+ * double value = 1 [(buf.validate.field).double.const = 42.0];
+ * }
+ * ```
+ *
+ * @generated from field: optional double const = 1;
+ */
+ const: number;
+
+ /**
+ * @generated from oneof buf.validate.DoubleRules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyDouble {
+ * // value must be less than 10.0
+ * double value = 1 [(buf.validate.field).double.lt = 10.0];
+ * }
+ * ```
+ *
+ * @generated from field: double lt = 2;
+ */
+ value: number;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified value
+ * (field <= value). If the field value is greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyDouble {
+ * // value must be less than or equal to 10.0
+ * double value = 1 [(buf.validate.field).double.lte = 10.0];
+ * }
+ * ```
+ *
+ * @generated from field: double lte = 3;
+ */
+ value: number;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.DoubleRules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or `lte`,
+ * the range is reversed, and the field value must be outside the specified
+ * range. If the field value doesn't meet the required conditions, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyDouble {
+ * // value must be greater than 5.0 [double.gt]
+ * double value = 1 [(buf.validate.field).double.gt = 5.0];
+ *
+ * // value must be greater than 5 and less than 10.0 [double.gt_lt]
+ * double other_value = 2 [(buf.validate.field).double = { gt: 5.0, lt: 10.0 }];
+ *
+ * // value must be greater than 10 or less than 5.0 [double.gt_lt_exclusive]
+ * double another_value = 3 [(buf.validate.field).double = { gt: 10.0, lt: 5.0 }];
+ * }
+ * ```
+ *
+ * @generated from field: double gt = 4;
+ */
+ value: number;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyDouble {
+ * // value must be greater than or equal to 5.0 [double.gte]
+ * double value = 1 [(buf.validate.field).double.gte = 5.0];
+ *
+ * // value must be greater than or equal to 5.0 and less than 10.0 [double.gte_lt]
+ * double other_value = 2 [(buf.validate.field).double = { gte: 5.0, lt: 10.0 }];
+ *
+ * // value must be greater than or equal to 10.0 or less than 5.0 [double.gte_lt_exclusive]
+ * double another_value = 3 [(buf.validate.field).double = { gte: 10.0, lt: 5.0 }];
+ * }
+ * ```
+ *
+ * @generated from field: double gte = 5;
+ */
+ value: number;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MyDouble {
+ * // value must be in list [1.0, 2.0, 3.0]
+ * double value = 1 [(buf.validate.field).double = { in: [1.0, 2.0, 3.0] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated double in = 6;
+ */
+ in: number[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyDouble {
+ * // value must not be in list [1.0, 2.0, 3.0]
+ * double value = 1 [(buf.validate.field).double = { not_in: [1.0, 2.0, 3.0] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated double not_in = 7;
+ */
+ notIn: number[];
+
+ /**
+ * `finite` requires the field value to be finite. If the field value is
+ * infinite or NaN, an error message is generated.
+ *
+ * @generated from field: optional bool finite = 8;
+ */
+ finite: boolean;
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyDouble {
+ * double value = 1 [
+ * (buf.validate.field).double.example = 1.0,
+ * (buf.validate.field).double.example = "Infinity"
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated double example = 9;
+ */
+ example: number[];
+};
+
+/**
+ * Describes the message buf.validate.DoubleRules.
+ * Use `create(DoubleRulesSchema)` to create a new message.
+ */
+export const DoubleRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 6);
+
+/**
+ * Int32Rules describes the rules applied to `int32` values. These
+ * rules may also be applied to the `google.protobuf.Int32Value` Well-Known-Type.
+ *
+ * @generated from message buf.validate.Int32Rules
+ */
+export type Int32Rules = Message<"buf.validate.Int32Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyInt32 {
+ * // value must equal 42
+ * int32 value = 1 [(buf.validate.field).int32.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional int32 const = 1;
+ */
+ const: number;
+
+ /**
+ * @generated from oneof buf.validate.Int32Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field
+ * < value). If the field value is equal to or greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyInt32 {
+ * // value must be less than 10
+ * int32 value = 1 [(buf.validate.field).int32.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: int32 lt = 2;
+ */
+ value: number;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyInt32 {
+ * // value must be less than or equal to 10
+ * int32 value = 1 [(buf.validate.field).int32.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: int32 lte = 3;
+ */
+ value: number;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.Int32Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyInt32 {
+ * // value must be greater than 5 [int32.gt]
+ * int32 value = 1 [(buf.validate.field).int32.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [int32.gt_lt]
+ * int32 other_value = 2 [(buf.validate.field).int32 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [int32.gt_lt_exclusive]
+ * int32 another_value = 3 [(buf.validate.field).int32 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: int32 gt = 4;
+ */
+ value: number;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified value
+ * (exclusive). If the value of `gte` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyInt32 {
+ * // value must be greater than or equal to 5 [int32.gte]
+ * int32 value = 1 [(buf.validate.field).int32.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [int32.gte_lt]
+ * int32 other_value = 2 [(buf.validate.field).int32 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [int32.gte_lt_exclusive]
+ * int32 another_value = 3 [(buf.validate.field).int32 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: int32 gte = 5;
+ */
+ value: number;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MyInt32 {
+ * // value must be in list [1, 2, 3]
+ * int32 value = 1 [(buf.validate.field).int32 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated int32 in = 6;
+ */
+ in: number[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error message
+ * is generated.
+ *
+ * ```proto
+ * message MyInt32 {
+ * // value must not be in list [1, 2, 3]
+ * int32 value = 1 [(buf.validate.field).int32 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated int32 not_in = 7;
+ */
+ notIn: number[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyInt32 {
+ * int32 value = 1 [
+ * (buf.validate.field).int32.example = 1,
+ * (buf.validate.field).int32.example = -10
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated int32 example = 8;
+ */
+ example: number[];
+};
+
+/**
+ * Describes the message buf.validate.Int32Rules.
+ * Use `create(Int32RulesSchema)` to create a new message.
+ */
+export const Int32RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 7);
+
+/**
+ * Int64Rules describes the rules applied to `int64` values. These
+ * rules may also be applied to the `google.protobuf.Int64Value` Well-Known-Type.
+ *
+ * @generated from message buf.validate.Int64Rules
+ */
+export type Int64Rules = Message<"buf.validate.Int64Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyInt64 {
+ * // value must equal 42
+ * int64 value = 1 [(buf.validate.field).int64.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional int64 const = 1;
+ */
+ const: bigint;
+
+ /**
+ * @generated from oneof buf.validate.Int64Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyInt64 {
+ * // value must be less than 10
+ * int64 value = 1 [(buf.validate.field).int64.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: int64 lt = 2;
+ */
+ value: bigint;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyInt64 {
+ * // value must be less than or equal to 10
+ * int64 value = 1 [(buf.validate.field).int64.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: int64 lte = 3;
+ */
+ value: bigint;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.Int64Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyInt64 {
+ * // value must be greater than 5 [int64.gt]
+ * int64 value = 1 [(buf.validate.field).int64.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [int64.gt_lt]
+ * int64 other_value = 2 [(buf.validate.field).int64 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [int64.gt_lt_exclusive]
+ * int64 another_value = 3 [(buf.validate.field).int64 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: int64 gt = 4;
+ */
+ value: bigint;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyInt64 {
+ * // value must be greater than or equal to 5 [int64.gte]
+ * int64 value = 1 [(buf.validate.field).int64.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [int64.gte_lt]
+ * int64 other_value = 2 [(buf.validate.field).int64 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [int64.gte_lt_exclusive]
+ * int64 another_value = 3 [(buf.validate.field).int64 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: int64 gte = 5;
+ */
+ value: bigint;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MyInt64 {
+ * // value must be in list [1, 2, 3]
+ * int64 value = 1 [(buf.validate.field).int64 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated int64 in = 6;
+ */
+ in: bigint[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyInt64 {
+ * // value must not be in list [1, 2, 3]
+ * int64 value = 1 [(buf.validate.field).int64 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated int64 not_in = 7;
+ */
+ notIn: bigint[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyInt64 {
+ * int64 value = 1 [
+ * (buf.validate.field).int64.example = 1,
+ * (buf.validate.field).int64.example = -10
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated int64 example = 9;
+ */
+ example: bigint[];
+};
+
+/**
+ * Describes the message buf.validate.Int64Rules.
+ * Use `create(Int64RulesSchema)` to create a new message.
+ */
+export const Int64RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 8);
+
+/**
+ * UInt32Rules describes the rules applied to `uint32` values. These
+ * rules may also be applied to the `google.protobuf.UInt32Value` Well-Known-Type.
+ *
+ * @generated from message buf.validate.UInt32Rules
+ */
+export type UInt32Rules = Message<"buf.validate.UInt32Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyUInt32 {
+ * // value must equal 42
+ * uint32 value = 1 [(buf.validate.field).uint32.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint32 const = 1;
+ */
+ const: number;
+
+ /**
+ * @generated from oneof buf.validate.UInt32Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyUInt32 {
+ * // value must be less than 10
+ * uint32 value = 1 [(buf.validate.field).uint32.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: uint32 lt = 2;
+ */
+ value: number;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyUInt32 {
+ * // value must be less than or equal to 10
+ * uint32 value = 1 [(buf.validate.field).uint32.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: uint32 lte = 3;
+ */
+ value: number;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.UInt32Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyUInt32 {
+ * // value must be greater than 5 [uint32.gt]
+ * uint32 value = 1 [(buf.validate.field).uint32.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [uint32.gt_lt]
+ * uint32 other_value = 2 [(buf.validate.field).uint32 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [uint32.gt_lt_exclusive]
+ * uint32 another_value = 3 [(buf.validate.field).uint32 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: uint32 gt = 4;
+ */
+ value: number;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyUInt32 {
+ * // value must be greater than or equal to 5 [uint32.gte]
+ * uint32 value = 1 [(buf.validate.field).uint32.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [uint32.gte_lt]
+ * uint32 other_value = 2 [(buf.validate.field).uint32 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [uint32.gte_lt_exclusive]
+ * uint32 another_value = 3 [(buf.validate.field).uint32 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: uint32 gte = 5;
+ */
+ value: number;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MyUInt32 {
+ * // value must be in list [1, 2, 3]
+ * uint32 value = 1 [(buf.validate.field).uint32 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated uint32 in = 6;
+ */
+ in: number[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyUInt32 {
+ * // value must not be in list [1, 2, 3]
+ * uint32 value = 1 [(buf.validate.field).uint32 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated uint32 not_in = 7;
+ */
+ notIn: number[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyUInt32 {
+ * uint32 value = 1 [
+ * (buf.validate.field).uint32.example = 1,
+ * (buf.validate.field).uint32.example = 10
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated uint32 example = 8;
+ */
+ example: number[];
+};
+
+/**
+ * Describes the message buf.validate.UInt32Rules.
+ * Use `create(UInt32RulesSchema)` to create a new message.
+ */
+export const UInt32RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 9);
+
+/**
+ * UInt64Rules describes the rules applied to `uint64` values. These
+ * rules may also be applied to the `google.protobuf.UInt64Value` Well-Known-Type.
+ *
+ * @generated from message buf.validate.UInt64Rules
+ */
+export type UInt64Rules = Message<"buf.validate.UInt64Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyUInt64 {
+ * // value must equal 42
+ * uint64 value = 1 [(buf.validate.field).uint64.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 const = 1;
+ */
+ const: bigint;
+
+ /**
+ * @generated from oneof buf.validate.UInt64Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyUInt64 {
+ * // value must be less than 10
+ * uint64 value = 1 [(buf.validate.field).uint64.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: uint64 lt = 2;
+ */
+ value: bigint;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyUInt64 {
+ * // value must be less than or equal to 10
+ * uint64 value = 1 [(buf.validate.field).uint64.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: uint64 lte = 3;
+ */
+ value: bigint;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.UInt64Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyUInt64 {
+ * // value must be greater than 5 [uint64.gt]
+ * uint64 value = 1 [(buf.validate.field).uint64.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [uint64.gt_lt]
+ * uint64 other_value = 2 [(buf.validate.field).uint64 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [uint64.gt_lt_exclusive]
+ * uint64 another_value = 3 [(buf.validate.field).uint64 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: uint64 gt = 4;
+ */
+ value: bigint;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyUInt64 {
+ * // value must be greater than or equal to 5 [uint64.gte]
+ * uint64 value = 1 [(buf.validate.field).uint64.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [uint64.gte_lt]
+ * uint64 other_value = 2 [(buf.validate.field).uint64 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [uint64.gte_lt_exclusive]
+ * uint64 another_value = 3 [(buf.validate.field).uint64 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: uint64 gte = 5;
+ */
+ value: bigint;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MyUInt64 {
+ * // value must be in list [1, 2, 3]
+ * uint64 value = 1 [(buf.validate.field).uint64 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated uint64 in = 6;
+ */
+ in: bigint[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyUInt64 {
+ * // value must not be in list [1, 2, 3]
+ * uint64 value = 1 [(buf.validate.field).uint64 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated uint64 not_in = 7;
+ */
+ notIn: bigint[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyUInt64 {
+ * uint64 value = 1 [
+ * (buf.validate.field).uint64.example = 1,
+ * (buf.validate.field).uint64.example = -10
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated uint64 example = 8;
+ */
+ example: bigint[];
+};
+
+/**
+ * Describes the message buf.validate.UInt64Rules.
+ * Use `create(UInt64RulesSchema)` to create a new message.
+ */
+export const UInt64RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 10);
+
+/**
+ * SInt32Rules describes the rules applied to `sint32` values.
+ *
+ * @generated from message buf.validate.SInt32Rules
+ */
+export type SInt32Rules = Message<"buf.validate.SInt32Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MySInt32 {
+ * // value must equal 42
+ * sint32 value = 1 [(buf.validate.field).sint32.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional sint32 const = 1;
+ */
+ const: number;
+
+ /**
+ * @generated from oneof buf.validate.SInt32Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field
+ * < value). If the field value is equal to or greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MySInt32 {
+ * // value must be less than 10
+ * sint32 value = 1 [(buf.validate.field).sint32.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: sint32 lt = 2;
+ */
+ value: number;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MySInt32 {
+ * // value must be less than or equal to 10
+ * sint32 value = 1 [(buf.validate.field).sint32.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: sint32 lte = 3;
+ */
+ value: number;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.SInt32Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySInt32 {
+ * // value must be greater than 5 [sint32.gt]
+ * sint32 value = 1 [(buf.validate.field).sint32.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [sint32.gt_lt]
+ * sint32 other_value = 2 [(buf.validate.field).sint32 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [sint32.gt_lt_exclusive]
+ * sint32 another_value = 3 [(buf.validate.field).sint32 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: sint32 gt = 4;
+ */
+ value: number;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySInt32 {
+ * // value must be greater than or equal to 5 [sint32.gte]
+ * sint32 value = 1 [(buf.validate.field).sint32.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [sint32.gte_lt]
+ * sint32 other_value = 2 [(buf.validate.field).sint32 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [sint32.gte_lt_exclusive]
+ * sint32 another_value = 3 [(buf.validate.field).sint32 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: sint32 gte = 5;
+ */
+ value: number;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MySInt32 {
+ * // value must be in list [1, 2, 3]
+ * sint32 value = 1 [(buf.validate.field).sint32 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sint32 in = 6;
+ */
+ in: number[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MySInt32 {
+ * // value must not be in list [1, 2, 3]
+ * sint32 value = 1 [(buf.validate.field).sint32 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sint32 not_in = 7;
+ */
+ notIn: number[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MySInt32 {
+ * sint32 value = 1 [
+ * (buf.validate.field).sint32.example = 1,
+ * (buf.validate.field).sint32.example = -10
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sint32 example = 8;
+ */
+ example: number[];
+};
+
+/**
+ * Describes the message buf.validate.SInt32Rules.
+ * Use `create(SInt32RulesSchema)` to create a new message.
+ */
+export const SInt32RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 11);
+
+/**
+ * SInt64Rules describes the rules applied to `sint64` values.
+ *
+ * @generated from message buf.validate.SInt64Rules
+ */
+export type SInt64Rules = Message<"buf.validate.SInt64Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MySInt64 {
+ * // value must equal 42
+ * sint64 value = 1 [(buf.validate.field).sint64.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional sint64 const = 1;
+ */
+ const: bigint;
+
+ /**
+ * @generated from oneof buf.validate.SInt64Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field
+ * < value). If the field value is equal to or greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MySInt64 {
+ * // value must be less than 10
+ * sint64 value = 1 [(buf.validate.field).sint64.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: sint64 lt = 2;
+ */
+ value: bigint;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MySInt64 {
+ * // value must be less than or equal to 10
+ * sint64 value = 1 [(buf.validate.field).sint64.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: sint64 lte = 3;
+ */
+ value: bigint;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.SInt64Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySInt64 {
+ * // value must be greater than 5 [sint64.gt]
+ * sint64 value = 1 [(buf.validate.field).sint64.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [sint64.gt_lt]
+ * sint64 other_value = 2 [(buf.validate.field).sint64 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [sint64.gt_lt_exclusive]
+ * sint64 another_value = 3 [(buf.validate.field).sint64 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: sint64 gt = 4;
+ */
+ value: bigint;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySInt64 {
+ * // value must be greater than or equal to 5 [sint64.gte]
+ * sint64 value = 1 [(buf.validate.field).sint64.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [sint64.gte_lt]
+ * sint64 other_value = 2 [(buf.validate.field).sint64 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [sint64.gte_lt_exclusive]
+ * sint64 another_value = 3 [(buf.validate.field).sint64 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: sint64 gte = 5;
+ */
+ value: bigint;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message
+ * is generated.
+ *
+ * ```proto
+ * message MySInt64 {
+ * // value must be in list [1, 2, 3]
+ * sint64 value = 1 [(buf.validate.field).sint64 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sint64 in = 6;
+ */
+ in: bigint[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MySInt64 {
+ * // value must not be in list [1, 2, 3]
+ * sint64 value = 1 [(buf.validate.field).sint64 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sint64 not_in = 7;
+ */
+ notIn: bigint[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MySInt64 {
+ * sint64 value = 1 [
+ * (buf.validate.field).sint64.example = 1,
+ * (buf.validate.field).sint64.example = -10
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sint64 example = 8;
+ */
+ example: bigint[];
+};
+
+/**
+ * Describes the message buf.validate.SInt64Rules.
+ * Use `create(SInt64RulesSchema)` to create a new message.
+ */
+export const SInt64RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 12);
+
+/**
+ * Fixed32Rules describes the rules applied to `fixed32` values.
+ *
+ * @generated from message buf.validate.Fixed32Rules
+ */
+export type Fixed32Rules = Message<"buf.validate.Fixed32Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value.
+ * If the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyFixed32 {
+ * // value must equal 42
+ * fixed32 value = 1 [(buf.validate.field).fixed32.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional fixed32 const = 1;
+ */
+ const: number;
+
+ /**
+ * @generated from oneof buf.validate.Fixed32Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFixed32 {
+ * // value must be less than 10
+ * fixed32 value = 1 [(buf.validate.field).fixed32.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: fixed32 lt = 2;
+ */
+ value: number;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyFixed32 {
+ * // value must be less than or equal to 10
+ * fixed32 value = 1 [(buf.validate.field).fixed32.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: fixed32 lte = 3;
+ */
+ value: number;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.Fixed32Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFixed32 {
+ * // value must be greater than 5 [fixed32.gt]
+ * fixed32 value = 1 [(buf.validate.field).fixed32.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [fixed32.gt_lt]
+ * fixed32 other_value = 2 [(buf.validate.field).fixed32 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [fixed32.gt_lt_exclusive]
+ * fixed32 another_value = 3 [(buf.validate.field).fixed32 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: fixed32 gt = 4;
+ */
+ value: number;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFixed32 {
+ * // value must be greater than or equal to 5 [fixed32.gte]
+ * fixed32 value = 1 [(buf.validate.field).fixed32.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [fixed32.gte_lt]
+ * fixed32 other_value = 2 [(buf.validate.field).fixed32 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [fixed32.gte_lt_exclusive]
+ * fixed32 another_value = 3 [(buf.validate.field).fixed32 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: fixed32 gte = 5;
+ */
+ value: number;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message
+ * is generated.
+ *
+ * ```proto
+ * message MyFixed32 {
+ * // value must be in list [1, 2, 3]
+ * fixed32 value = 1 [(buf.validate.field).fixed32 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated fixed32 in = 6;
+ */
+ in: number[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyFixed32 {
+ * // value must not be in list [1, 2, 3]
+ * fixed32 value = 1 [(buf.validate.field).fixed32 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated fixed32 not_in = 7;
+ */
+ notIn: number[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyFixed32 {
+ * fixed32 value = 1 [
+ * (buf.validate.field).fixed32.example = 1,
+ * (buf.validate.field).fixed32.example = 2
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated fixed32 example = 8;
+ */
+ example: number[];
+};
+
+/**
+ * Describes the message buf.validate.Fixed32Rules.
+ * Use `create(Fixed32RulesSchema)` to create a new message.
+ */
+export const Fixed32RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 13);
+
+/**
+ * Fixed64Rules describes the rules applied to `fixed64` values.
+ *
+ * @generated from message buf.validate.Fixed64Rules
+ */
+export type Fixed64Rules = Message<"buf.validate.Fixed64Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyFixed64 {
+ * // value must equal 42
+ * fixed64 value = 1 [(buf.validate.field).fixed64.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional fixed64 const = 1;
+ */
+ const: bigint;
+
+ /**
+ * @generated from oneof buf.validate.Fixed64Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFixed64 {
+ * // value must be less than 10
+ * fixed64 value = 1 [(buf.validate.field).fixed64.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: fixed64 lt = 2;
+ */
+ value: bigint;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MyFixed64 {
+ * // value must be less than or equal to 10
+ * fixed64 value = 1 [(buf.validate.field).fixed64.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: fixed64 lte = 3;
+ */
+ value: bigint;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.Fixed64Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFixed64 {
+ * // value must be greater than 5 [fixed64.gt]
+ * fixed64 value = 1 [(buf.validate.field).fixed64.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [fixed64.gt_lt]
+ * fixed64 other_value = 2 [(buf.validate.field).fixed64 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [fixed64.gt_lt_exclusive]
+ * fixed64 another_value = 3 [(buf.validate.field).fixed64 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: fixed64 gt = 4;
+ */
+ value: bigint;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyFixed64 {
+ * // value must be greater than or equal to 5 [fixed64.gte]
+ * fixed64 value = 1 [(buf.validate.field).fixed64.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [fixed64.gte_lt]
+ * fixed64 other_value = 2 [(buf.validate.field).fixed64 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [fixed64.gte_lt_exclusive]
+ * fixed64 another_value = 3 [(buf.validate.field).fixed64 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: fixed64 gte = 5;
+ */
+ value: bigint;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MyFixed64 {
+ * // value must be in list [1, 2, 3]
+ * fixed64 value = 1 [(buf.validate.field).fixed64 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated fixed64 in = 6;
+ */
+ in: bigint[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyFixed64 {
+ * // value must not be in list [1, 2, 3]
+ * fixed64 value = 1 [(buf.validate.field).fixed64 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated fixed64 not_in = 7;
+ */
+ notIn: bigint[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyFixed64 {
+ * fixed64 value = 1 [
+ * (buf.validate.field).fixed64.example = 1,
+ * (buf.validate.field).fixed64.example = 2
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated fixed64 example = 8;
+ */
+ example: bigint[];
+};
+
+/**
+ * Describes the message buf.validate.Fixed64Rules.
+ * Use `create(Fixed64RulesSchema)` to create a new message.
+ */
+export const Fixed64RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 14);
+
+/**
+ * SFixed32Rules describes the rules applied to `fixed32` values.
+ *
+ * @generated from message buf.validate.SFixed32Rules
+ */
+export type SFixed32Rules = Message<"buf.validate.SFixed32Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MySFixed32 {
+ * // value must equal 42
+ * sfixed32 value = 1 [(buf.validate.field).sfixed32.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional sfixed32 const = 1;
+ */
+ const: number;
+
+ /**
+ * @generated from oneof buf.validate.SFixed32Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySFixed32 {
+ * // value must be less than 10
+ * sfixed32 value = 1 [(buf.validate.field).sfixed32.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: sfixed32 lt = 2;
+ */
+ value: number;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MySFixed32 {
+ * // value must be less than or equal to 10
+ * sfixed32 value = 1 [(buf.validate.field).sfixed32.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: sfixed32 lte = 3;
+ */
+ value: number;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.SFixed32Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySFixed32 {
+ * // value must be greater than 5 [sfixed32.gt]
+ * sfixed32 value = 1 [(buf.validate.field).sfixed32.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [sfixed32.gt_lt]
+ * sfixed32 other_value = 2 [(buf.validate.field).sfixed32 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [sfixed32.gt_lt_exclusive]
+ * sfixed32 another_value = 3 [(buf.validate.field).sfixed32 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: sfixed32 gt = 4;
+ */
+ value: number;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySFixed32 {
+ * // value must be greater than or equal to 5 [sfixed32.gte]
+ * sfixed32 value = 1 [(buf.validate.field).sfixed32.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [sfixed32.gte_lt]
+ * sfixed32 other_value = 2 [(buf.validate.field).sfixed32 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [sfixed32.gte_lt_exclusive]
+ * sfixed32 another_value = 3 [(buf.validate.field).sfixed32 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: sfixed32 gte = 5;
+ */
+ value: number;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MySFixed32 {
+ * // value must be in list [1, 2, 3]
+ * sfixed32 value = 1 [(buf.validate.field).sfixed32 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sfixed32 in = 6;
+ */
+ in: number[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MySFixed32 {
+ * // value must not be in list [1, 2, 3]
+ * sfixed32 value = 1 [(buf.validate.field).sfixed32 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sfixed32 not_in = 7;
+ */
+ notIn: number[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MySFixed32 {
+ * sfixed32 value = 1 [
+ * (buf.validate.field).sfixed32.example = 1,
+ * (buf.validate.field).sfixed32.example = 2
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sfixed32 example = 8;
+ */
+ example: number[];
+};
+
+/**
+ * Describes the message buf.validate.SFixed32Rules.
+ * Use `create(SFixed32RulesSchema)` to create a new message.
+ */
+export const SFixed32RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 15);
+
+/**
+ * SFixed64Rules describes the rules applied to `fixed64` values.
+ *
+ * @generated from message buf.validate.SFixed64Rules
+ */
+export type SFixed64Rules = Message<"buf.validate.SFixed64Rules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MySFixed64 {
+ * // value must equal 42
+ * sfixed64 value = 1 [(buf.validate.field).sfixed64.const = 42];
+ * }
+ * ```
+ *
+ * @generated from field: optional sfixed64 const = 1;
+ */
+ const: bigint;
+
+ /**
+ * @generated from oneof buf.validate.SFixed64Rules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` requires the field value to be less than the specified value (field <
+ * value). If the field value is equal to or greater than the specified value,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySFixed64 {
+ * // value must be less than 10
+ * sfixed64 value = 1 [(buf.validate.field).sfixed64.lt = 10];
+ * }
+ * ```
+ *
+ * @generated from field: sfixed64 lt = 2;
+ */
+ value: bigint;
+ case: "lt";
+ } | {
+ /**
+ * `lte` requires the field value to be less than or equal to the specified
+ * value (field <= value). If the field value is greater than the specified
+ * value, an error message is generated.
+ *
+ * ```proto
+ * message MySFixed64 {
+ * // value must be less than or equal to 10
+ * sfixed64 value = 1 [(buf.validate.field).sfixed64.lte = 10];
+ * }
+ * ```
+ *
+ * @generated from field: sfixed64 lte = 3;
+ */
+ value: bigint;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.SFixed64Rules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the field value to be greater than the specified value
+ * (exclusive). If the value of `gt` is larger than a specified `lt` or
+ * `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySFixed64 {
+ * // value must be greater than 5 [sfixed64.gt]
+ * sfixed64 value = 1 [(buf.validate.field).sfixed64.gt = 5];
+ *
+ * // value must be greater than 5 and less than 10 [sfixed64.gt_lt]
+ * sfixed64 other_value = 2 [(buf.validate.field).sfixed64 = { gt: 5, lt: 10 }];
+ *
+ * // value must be greater than 10 or less than 5 [sfixed64.gt_lt_exclusive]
+ * sfixed64 another_value = 3 [(buf.validate.field).sfixed64 = { gt: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: sfixed64 gt = 4;
+ */
+ value: bigint;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the field value to be greater than or equal to the specified
+ * value (exclusive). If the value of `gte` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MySFixed64 {
+ * // value must be greater than or equal to 5 [sfixed64.gte]
+ * sfixed64 value = 1 [(buf.validate.field).sfixed64.gte = 5];
+ *
+ * // value must be greater than or equal to 5 and less than 10 [sfixed64.gte_lt]
+ * sfixed64 other_value = 2 [(buf.validate.field).sfixed64 = { gte: 5, lt: 10 }];
+ *
+ * // value must be greater than or equal to 10 or less than 5 [sfixed64.gte_lt_exclusive]
+ * sfixed64 another_value = 3 [(buf.validate.field).sfixed64 = { gte: 10, lt: 5 }];
+ * }
+ * ```
+ *
+ * @generated from field: sfixed64 gte = 5;
+ */
+ value: bigint;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` requires the field value to be equal to one of the specified values.
+ * If the field value isn't one of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MySFixed64 {
+ * // value must be in list [1, 2, 3]
+ * sfixed64 value = 1 [(buf.validate.field).sfixed64 = { in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sfixed64 in = 6;
+ */
+ in: bigint[];
+
+ /**
+ * `not_in` requires the field value to not be equal to any of the specified
+ * values. If the field value is one of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MySFixed64 {
+ * // value must not be in list [1, 2, 3]
+ * sfixed64 value = 1 [(buf.validate.field).sfixed64 = { not_in: [1, 2, 3] }];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sfixed64 not_in = 7;
+ */
+ notIn: bigint[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MySFixed64 {
+ * sfixed64 value = 1 [
+ * (buf.validate.field).sfixed64.example = 1,
+ * (buf.validate.field).sfixed64.example = 2
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated sfixed64 example = 8;
+ */
+ example: bigint[];
+};
+
+/**
+ * Describes the message buf.validate.SFixed64Rules.
+ * Use `create(SFixed64RulesSchema)` to create a new message.
+ */
+export const SFixed64RulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 16);
+
+/**
+ * BoolRules describes the rules applied to `bool` values. These rules
+ * may also be applied to the `google.protobuf.BoolValue` Well-Known-Type.
+ *
+ * @generated from message buf.validate.BoolRules
+ */
+export type BoolRules = Message<"buf.validate.BoolRules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified boolean value.
+ * If the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyBool {
+ * // value must equal true
+ * bool value = 1 [(buf.validate.field).bool.const = true];
+ * }
+ * ```
+ *
+ * @generated from field: optional bool const = 1;
+ */
+ const: boolean;
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyBool {
+ * bool value = 1 [
+ * (buf.validate.field).bool.example = 1,
+ * (buf.validate.field).bool.example = 2
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated bool example = 2;
+ */
+ example: boolean[];
+};
+
+/**
+ * Describes the message buf.validate.BoolRules.
+ * Use `create(BoolRulesSchema)` to create a new message.
+ */
+export const BoolRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 17);
+
+/**
+ * StringRules describes the rules applied to `string` values These
+ * rules may also be applied to the `google.protobuf.StringValue` Well-Known-Type.
+ *
+ * @generated from message buf.validate.StringRules
+ */
+export type StringRules = Message<"buf.validate.StringRules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified value. If
+ * the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must equal `hello`
+ * string value = 1 [(buf.validate.field).string.const = "hello"];
+ * }
+ * ```
+ *
+ * @generated from field: optional string const = 1;
+ */
+ const: string;
+
+ /**
+ * `len` dictates that the field value must have the specified
+ * number of characters (Unicode code points), which may differ from the number
+ * of bytes in the string. If the field value does not meet the specified
+ * length, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value length must be 5 characters
+ * string value = 1 [(buf.validate.field).string.len = 5];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 len = 19;
+ */
+ len: bigint;
+
+ /**
+ * `min_len` specifies that the field value must have at least the specified
+ * number of characters (Unicode code points), which may differ from the number
+ * of bytes in the string. If the field value contains fewer characters, an error
+ * message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value length must be at least 3 characters
+ * string value = 1 [(buf.validate.field).string.min_len = 3];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 min_len = 2;
+ */
+ minLen: bigint;
+
+ /**
+ * `max_len` specifies that the field value must have no more than the specified
+ * number of characters (Unicode code points), which may differ from the
+ * number of bytes in the string. If the field value contains more characters,
+ * an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value length must be at most 10 characters
+ * string value = 1 [(buf.validate.field).string.max_len = 10];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 max_len = 3;
+ */
+ maxLen: bigint;
+
+ /**
+ * `len_bytes` dictates that the field value must have the specified number of
+ * bytes. If the field value does not match the specified length in bytes,
+ * an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value length must be 6 bytes
+ * string value = 1 [(buf.validate.field).string.len_bytes = 6];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 len_bytes = 20;
+ */
+ lenBytes: bigint;
+
+ /**
+ * `min_bytes` specifies that the field value must have at least the specified
+ * number of bytes. If the field value contains fewer bytes, an error message
+ * will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value length must be at least 4 bytes
+ * string value = 1 [(buf.validate.field).string.min_bytes = 4];
+ * }
+ *
+ * ```
+ *
+ * @generated from field: optional uint64 min_bytes = 4;
+ */
+ minBytes: bigint;
+
+ /**
+ * `max_bytes` specifies that the field value must have no more than the
+ * specified number of bytes. If the field value contains more bytes, an
+ * error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value length must be at most 8 bytes
+ * string value = 1 [(buf.validate.field).string.max_bytes = 8];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 max_bytes = 5;
+ */
+ maxBytes: bigint;
+
+ /**
+ * `pattern` specifies that the field value must match the specified
+ * regular expression (RE2 syntax), with the expression provided without any
+ * delimiters. If the field value doesn't match the regular expression, an
+ * error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value does not match regex pattern `^[a-zA-Z]//$`
+ * string value = 1 [(buf.validate.field).string.pattern = "^[a-zA-Z]//$"];
+ * }
+ * ```
+ *
+ * @generated from field: optional string pattern = 6;
+ */
+ pattern: string;
+
+ /**
+ * `prefix` specifies that the field value must have the
+ * specified substring at the beginning of the string. If the field value
+ * doesn't start with the specified prefix, an error message will be
+ * generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value does not have prefix `pre`
+ * string value = 1 [(buf.validate.field).string.prefix = "pre"];
+ * }
+ * ```
+ *
+ * @generated from field: optional string prefix = 7;
+ */
+ prefix: string;
+
+ /**
+ * `suffix` specifies that the field value must have the
+ * specified substring at the end of the string. If the field value doesn't
+ * end with the specified suffix, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value does not have suffix `post`
+ * string value = 1 [(buf.validate.field).string.suffix = "post"];
+ * }
+ * ```
+ *
+ * @generated from field: optional string suffix = 8;
+ */
+ suffix: string;
+
+ /**
+ * `contains` specifies that the field value must have the
+ * specified substring anywhere in the string. If the field value doesn't
+ * contain the specified substring, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value does not contain substring `inside`.
+ * string value = 1 [(buf.validate.field).string.contains = "inside"];
+ * }
+ * ```
+ *
+ * @generated from field: optional string contains = 9;
+ */
+ contains: string;
+
+ /**
+ * `not_contains` specifies that the field value must not have the
+ * specified substring anywhere in the string. If the field value contains
+ * the specified substring, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value contains substring `inside`.
+ * string value = 1 [(buf.validate.field).string.not_contains = "inside"];
+ * }
+ * ```
+ *
+ * @generated from field: optional string not_contains = 23;
+ */
+ notContains: string;
+
+ /**
+ * `in` specifies that the field value must be equal to one of the specified
+ * values. If the field value isn't one of the specified values, an error
+ * message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be in list ["apple", "banana"]
+ * string value = 1 [(buf.validate.field).string.in = "apple", (buf.validate.field).string.in = "banana"];
+ * }
+ * ```
+ *
+ * @generated from field: repeated string in = 10;
+ */
+ in: string[];
+
+ /**
+ * `not_in` specifies that the field value cannot be equal to any
+ * of the specified values. If the field value is one of the specified values,
+ * an error message will be generated.
+ * ```proto
+ * message MyString {
+ * // value must not be in list ["orange", "grape"]
+ * string value = 1 [(buf.validate.field).string.not_in = "orange", (buf.validate.field).string.not_in = "grape"];
+ * }
+ * ```
+ *
+ * @generated from field: repeated string not_in = 11;
+ */
+ notIn: string[];
+
+ /**
+ * `WellKnown` rules provide advanced rules against common string
+ * patterns.
+ *
+ * @generated from oneof buf.validate.StringRules.well_known
+ */
+ wellKnown: {
+ /**
+ * `email` specifies that the field value must be a valid email address, for
+ * example "foo@example.com".
+ *
+ * Conforms to the definition for a valid email address from the [HTML standard](https://html.spec.whatwg.org/multipage/input.html#valid-e-mail-address).
+ * Note that this standard willfully deviates from [RFC 5322](https://datatracker.ietf.org/doc/html/rfc5322),
+ * which allows many unexpected forms of email addresses and will easily match
+ * a typographical error.
+ *
+ * If the field value isn't a valid email address, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid email address
+ * string value = 1 [(buf.validate.field).string.email = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool email = 12;
+ */
+ value: boolean;
+ case: "email";
+ } | {
+ /**
+ * `hostname` specifies that the field value must be a valid hostname, for
+ * example "foo.example.com".
+ *
+ * A valid hostname follows the rules below:
+ * - The name consists of one or more labels, separated by a dot (".").
+ * - Each label can be 1 to 63 alphanumeric characters.
+ * - A label can contain hyphens ("-"), but must not start or end with a hyphen.
+ * - The right-most label must not be digits only.
+ * - The name can have a trailing dot—for example, "foo.example.com.".
+ * - The name can be 253 characters at most, excluding the optional trailing dot.
+ *
+ * If the field value isn't a valid hostname, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid hostname
+ * string value = 1 [(buf.validate.field).string.hostname = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool hostname = 13;
+ */
+ value: boolean;
+ case: "hostname";
+ } | {
+ /**
+ * `ip` specifies that the field value must be a valid IP (v4 or v6) address.
+ *
+ * IPv4 addresses are expected in the dotted decimal format—for example, "192.168.5.21".
+ * IPv6 addresses are expected in their text representation—for example, "::1",
+ * or "2001:0DB8:ABCD:0012::0".
+ *
+ * Both formats are well-defined in the internet standard [RFC 3986](https://datatracker.ietf.org/doc/html/rfc3986).
+ * Zone identifiers for IPv6 addresses (for example, "fe80::a%en1") are supported.
+ *
+ * If the field value isn't a valid IP address, an error message will be
+ * generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IP address
+ * string value = 1 [(buf.validate.field).string.ip = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ip = 14;
+ */
+ value: boolean;
+ case: "ip";
+ } | {
+ /**
+ * `ipv4` specifies that the field value must be a valid IPv4 address—for
+ * example "192.168.5.21". If the field value isn't a valid IPv4 address, an
+ * error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IPv4 address
+ * string value = 1 [(buf.validate.field).string.ipv4 = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ipv4 = 15;
+ */
+ value: boolean;
+ case: "ipv4";
+ } | {
+ /**
+ * `ipv6` specifies that the field value must be a valid IPv6 address—for
+ * example "::1", or "d7a:115c:a1e0:ab12:4843:cd96:626b:430b". If the field
+ * value is not a valid IPv6 address, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IPv6 address
+ * string value = 1 [(buf.validate.field).string.ipv6 = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ipv6 = 16;
+ */
+ value: boolean;
+ case: "ipv6";
+ } | {
+ /**
+ * `uri` specifies that the field value must be a valid URI, for example
+ * "https://example.com/foo/bar?baz=quux#frag".
+ *
+ * URI is defined in the internet standard [RFC 3986](https://datatracker.ietf.org/doc/html/rfc3986).
+ * Zone Identifiers in IPv6 address literals are supported ([RFC 6874](https://datatracker.ietf.org/doc/html/rfc6874)).
+ *
+ * If the field value isn't a valid URI, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid URI
+ * string value = 1 [(buf.validate.field).string.uri = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool uri = 17;
+ */
+ value: boolean;
+ case: "uri";
+ } | {
+ /**
+ * `uri_ref` specifies that the field value must be a valid URI Reference—either
+ * a URI such as "https://example.com/foo/bar?baz=quux#frag", or a Relative
+ * Reference such as "./foo/bar?query".
+ *
+ * URI, URI Reference, and Relative Reference are defined in the internet
+ * standard [RFC 3986](https://datatracker.ietf.org/doc/html/rfc3986). Zone
+ * Identifiers in IPv6 address literals are supported ([RFC 6874](https://datatracker.ietf.org/doc/html/rfc6874)).
+ *
+ * If the field value isn't a valid URI Reference, an error message will be
+ * generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid URI Reference
+ * string value = 1 [(buf.validate.field).string.uri_ref = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool uri_ref = 18;
+ */
+ value: boolean;
+ case: "uriRef";
+ } | {
+ /**
+ * `address` specifies that the field value must be either a valid hostname
+ * (for example, "example.com"), or a valid IP (v4 or v6) address (for example,
+ * "192.168.0.1", or "::1"). If the field value isn't a valid hostname or IP,
+ * an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid hostname, or ip address
+ * string value = 1 [(buf.validate.field).string.address = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool address = 21;
+ */
+ value: boolean;
+ case: "address";
+ } | {
+ /**
+ * `uuid` specifies that the field value must be a valid UUID as defined by
+ * [RFC 4122](https://datatracker.ietf.org/doc/html/rfc4122#section-4.1.2). If the
+ * field value isn't a valid UUID, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid UUID
+ * string value = 1 [(buf.validate.field).string.uuid = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool uuid = 22;
+ */
+ value: boolean;
+ case: "uuid";
+ } | {
+ /**
+ * `tuuid` (trimmed UUID) specifies that the field value must be a valid UUID as
+ * defined by [RFC 4122](https://datatracker.ietf.org/doc/html/rfc4122#section-4.1.2) with all dashes
+ * omitted. If the field value isn't a valid UUID without dashes, an error message
+ * will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid trimmed UUID
+ * string value = 1 [(buf.validate.field).string.tuuid = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool tuuid = 33;
+ */
+ value: boolean;
+ case: "tuuid";
+ } | {
+ /**
+ * `ip_with_prefixlen` specifies that the field value must be a valid IP
+ * (v4 or v6) address with prefix length—for example, "192.168.5.21/16" or
+ * "2001:0DB8:ABCD:0012::F1/64". If the field value isn't a valid IP with
+ * prefix length, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IP with prefix length
+ * string value = 1 [(buf.validate.field).string.ip_with_prefixlen = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ip_with_prefixlen = 26;
+ */
+ value: boolean;
+ case: "ipWithPrefixlen";
+ } | {
+ /**
+ * `ipv4_with_prefixlen` specifies that the field value must be a valid
+ * IPv4 address with prefix length—for example, "192.168.5.21/16". If the
+ * field value isn't a valid IPv4 address with prefix length, an error
+ * message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IPv4 address with prefix length
+ * string value = 1 [(buf.validate.field).string.ipv4_with_prefixlen = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ipv4_with_prefixlen = 27;
+ */
+ value: boolean;
+ case: "ipv4WithPrefixlen";
+ } | {
+ /**
+ * `ipv6_with_prefixlen` specifies that the field value must be a valid
+ * IPv6 address with prefix length—for example, "2001:0DB8:ABCD:0012::F1/64".
+ * If the field value is not a valid IPv6 address with prefix length,
+ * an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IPv6 address prefix length
+ * string value = 1 [(buf.validate.field).string.ipv6_with_prefixlen = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ipv6_with_prefixlen = 28;
+ */
+ value: boolean;
+ case: "ipv6WithPrefixlen";
+ } | {
+ /**
+ * `ip_prefix` specifies that the field value must be a valid IP (v4 or v6)
+ * prefix—for example, "192.168.0.0/16" or "2001:0DB8:ABCD:0012::0/64".
+ *
+ * The prefix must have all zeros for the unmasked bits. For example,
+ * "2001:0DB8:ABCD:0012::0/64" designates the left-most 64 bits for the
+ * prefix, and the remaining 64 bits must be zero.
+ *
+ * If the field value isn't a valid IP prefix, an error message will be
+ * generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IP prefix
+ * string value = 1 [(buf.validate.field).string.ip_prefix = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ip_prefix = 29;
+ */
+ value: boolean;
+ case: "ipPrefix";
+ } | {
+ /**
+ * `ipv4_prefix` specifies that the field value must be a valid IPv4
+ * prefix, for example "192.168.0.0/16".
+ *
+ * The prefix must have all zeros for the unmasked bits. For example,
+ * "192.168.0.0/16" designates the left-most 16 bits for the prefix,
+ * and the remaining 16 bits must be zero.
+ *
+ * If the field value isn't a valid IPv4 prefix, an error message
+ * will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IPv4 prefix
+ * string value = 1 [(buf.validate.field).string.ipv4_prefix = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ipv4_prefix = 30;
+ */
+ value: boolean;
+ case: "ipv4Prefix";
+ } | {
+ /**
+ * `ipv6_prefix` specifies that the field value must be a valid IPv6 prefix—for
+ * example, "2001:0DB8:ABCD:0012::0/64".
+ *
+ * The prefix must have all zeros for the unmasked bits. For example,
+ * "2001:0DB8:ABCD:0012::0/64" designates the left-most 64 bits for the
+ * prefix, and the remaining 64 bits must be zero.
+ *
+ * If the field value is not a valid IPv6 prefix, an error message will be
+ * generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid IPv6 prefix
+ * string value = 1 [(buf.validate.field).string.ipv6_prefix = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ipv6_prefix = 31;
+ */
+ value: boolean;
+ case: "ipv6Prefix";
+ } | {
+ /**
+ * `host_and_port` specifies that the field value must be valid host/port
+ * pair—for example, "example.com:8080".
+ *
+ * The host can be one of:
+ * - An IPv4 address in dotted decimal format—for example, "192.168.5.21".
+ * - An IPv6 address enclosed in square brackets—for example, "[2001:0DB8:ABCD:0012::F1]".
+ * - A hostname—for example, "example.com".
+ *
+ * The port is separated by a colon. It must be non-empty, with a decimal number
+ * in the range of 0-65535, inclusive.
+ *
+ * @generated from field: bool host_and_port = 32;
+ */
+ value: boolean;
+ case: "hostAndPort";
+ } | {
+ /**
+ * `well_known_regex` specifies a common well-known pattern
+ * defined as a regex. If the field value doesn't match the well-known
+ * regex, an error message will be generated.
+ *
+ * ```proto
+ * message MyString {
+ * // value must be a valid HTTP header value
+ * string value = 1 [(buf.validate.field).string.well_known_regex = KNOWN_REGEX_HTTP_HEADER_VALUE];
+ * }
+ * ```
+ *
+ * #### KnownRegex
+ *
+ * `well_known_regex` contains some well-known patterns.
+ *
+ * | Name | Number | Description |
+ * |-------------------------------|--------|-------------------------------------------|
+ * | KNOWN_REGEX_UNSPECIFIED | 0 | |
+ * | KNOWN_REGEX_HTTP_HEADER_NAME | 1 | HTTP header name as defined by [RFC 7230](https://datatracker.ietf.org/doc/html/rfc7230#section-3.2) |
+ * | KNOWN_REGEX_HTTP_HEADER_VALUE | 2 | HTTP header value as defined by [RFC 7230](https://datatracker.ietf.org/doc/html/rfc7230#section-3.2.4) |
+ *
+ * @generated from field: buf.validate.KnownRegex well_known_regex = 24;
+ */
+ value: KnownRegex;
+ case: "wellKnownRegex";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * This applies to regexes `HTTP_HEADER_NAME` and `HTTP_HEADER_VALUE` to
+ * enable strict header validation. By default, this is true, and HTTP header
+ * validations are [RFC-compliant](https://datatracker.ietf.org/doc/html/rfc7230#section-3). Setting to false will enable looser
+ * validations that only disallow `\r\n\0` characters, which can be used to
+ * bypass header matching rules.
+ *
+ * ```proto
+ * message MyString {
+ * // The field `value` must have be a valid HTTP headers, but not enforced with strict rules.
+ * string value = 1 [(buf.validate.field).string.strict = false];
+ * }
+ * ```
+ *
+ * @generated from field: optional bool strict = 25;
+ */
+ strict: boolean;
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyString {
+ * string value = 1 [
+ * (buf.validate.field).string.example = "hello",
+ * (buf.validate.field).string.example = "world"
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated string example = 34;
+ */
+ example: string[];
+};
+
+/**
+ * Describes the message buf.validate.StringRules.
+ * Use `create(StringRulesSchema)` to create a new message.
+ */
+export const StringRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 18);
+
+/**
+ * BytesRules describe the rules applied to `bytes` values. These rules
+ * may also be applied to the `google.protobuf.BytesValue` Well-Known-Type.
+ *
+ * @generated from message buf.validate.BytesRules
+ */
+export type BytesRules = Message<"buf.validate.BytesRules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified bytes
+ * value. If the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value must be "\x01\x02\x03\x04"
+ * bytes value = 1 [(buf.validate.field).bytes.const = "\x01\x02\x03\x04"];
+ * }
+ * ```
+ *
+ * @generated from field: optional bytes const = 1;
+ */
+ const: Uint8Array;
+
+ /**
+ * `len` requires the field value to have the specified length in bytes.
+ * If the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value length must be 4 bytes.
+ * optional bytes value = 1 [(buf.validate.field).bytes.len = 4];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 len = 13;
+ */
+ len: bigint;
+
+ /**
+ * `min_len` requires the field value to have at least the specified minimum
+ * length in bytes.
+ * If the field value doesn't meet the requirement, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value length must be at least 2 bytes.
+ * optional bytes value = 1 [(buf.validate.field).bytes.min_len = 2];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 min_len = 2;
+ */
+ minLen: bigint;
+
+ /**
+ * `max_len` requires the field value to have at most the specified maximum
+ * length in bytes.
+ * If the field value exceeds the requirement, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value must be at most 6 bytes.
+ * optional bytes value = 1 [(buf.validate.field).bytes.max_len = 6];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 max_len = 3;
+ */
+ maxLen: bigint;
+
+ /**
+ * `pattern` requires the field value to match the specified regular
+ * expression ([RE2 syntax](https://github.com/google/re2/wiki/Syntax)).
+ * The value of the field must be valid UTF-8 or validation will fail with a
+ * runtime error.
+ * If the field value doesn't match the pattern, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value must match regex pattern "^[a-zA-Z0-9]+$".
+ * optional bytes value = 1 [(buf.validate.field).bytes.pattern = "^[a-zA-Z0-9]+$"];
+ * }
+ * ```
+ *
+ * @generated from field: optional string pattern = 4;
+ */
+ pattern: string;
+
+ /**
+ * `prefix` requires the field value to have the specified bytes at the
+ * beginning of the string.
+ * If the field value doesn't meet the requirement, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value does not have prefix \x01\x02
+ * optional bytes value = 1 [(buf.validate.field).bytes.prefix = "\x01\x02"];
+ * }
+ * ```
+ *
+ * @generated from field: optional bytes prefix = 5;
+ */
+ prefix: Uint8Array;
+
+ /**
+ * `suffix` requires the field value to have the specified bytes at the end
+ * of the string.
+ * If the field value doesn't meet the requirement, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value does not have suffix \x03\x04
+ * optional bytes value = 1 [(buf.validate.field).bytes.suffix = "\x03\x04"];
+ * }
+ * ```
+ *
+ * @generated from field: optional bytes suffix = 6;
+ */
+ suffix: Uint8Array;
+
+ /**
+ * `contains` requires the field value to have the specified bytes anywhere in
+ * the string.
+ * If the field value doesn't meet the requirement, an error message is generated.
+ *
+ * ```protobuf
+ * message MyBytes {
+ * // value does not contain \x02\x03
+ * optional bytes value = 1 [(buf.validate.field).bytes.contains = "\x02\x03"];
+ * }
+ * ```
+ *
+ * @generated from field: optional bytes contains = 7;
+ */
+ contains: Uint8Array;
+
+ /**
+ * `in` requires the field value to be equal to one of the specified
+ * values. If the field value doesn't match any of the specified values, an
+ * error message is generated.
+ *
+ * ```protobuf
+ * message MyBytes {
+ * // value must in ["\x01\x02", "\x02\x03", "\x03\x04"]
+ * optional bytes value = 1 [(buf.validate.field).bytes.in = {"\x01\x02", "\x02\x03", "\x03\x04"}];
+ * }
+ * ```
+ *
+ * @generated from field: repeated bytes in = 8;
+ */
+ in: Uint8Array[];
+
+ /**
+ * `not_in` requires the field value to be not equal to any of the specified
+ * values.
+ * If the field value matches any of the specified values, an error message is
+ * generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value must not in ["\x01\x02", "\x02\x03", "\x03\x04"]
+ * optional bytes value = 1 [(buf.validate.field).bytes.not_in = {"\x01\x02", "\x02\x03", "\x03\x04"}];
+ * }
+ * ```
+ *
+ * @generated from field: repeated bytes not_in = 9;
+ */
+ notIn: Uint8Array[];
+
+ /**
+ * WellKnown rules provide advanced rules against common byte
+ * patterns
+ *
+ * @generated from oneof buf.validate.BytesRules.well_known
+ */
+ wellKnown: {
+ /**
+ * `ip` ensures that the field `value` is a valid IP address (v4 or v6) in byte format.
+ * If the field value doesn't meet this rule, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value must be a valid IP address
+ * optional bytes value = 1 [(buf.validate.field).bytes.ip = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ip = 10;
+ */
+ value: boolean;
+ case: "ip";
+ } | {
+ /**
+ * `ipv4` ensures that the field `value` is a valid IPv4 address in byte format.
+ * If the field value doesn't meet this rule, an error message is generated.
+ *
+ * ```proto
+ * message MyBytes {
+ * // value must be a valid IPv4 address
+ * optional bytes value = 1 [(buf.validate.field).bytes.ipv4 = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ipv4 = 11;
+ */
+ value: boolean;
+ case: "ipv4";
+ } | {
+ /**
+ * `ipv6` ensures that the field `value` is a valid IPv6 address in byte format.
+ * If the field value doesn't meet this rule, an error message is generated.
+ * ```proto
+ * message MyBytes {
+ * // value must be a valid IPv6 address
+ * optional bytes value = 1 [(buf.validate.field).bytes.ipv6 = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool ipv6 = 12;
+ */
+ value: boolean;
+ case: "ipv6";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyBytes {
+ * bytes value = 1 [
+ * (buf.validate.field).bytes.example = "\x01\x02",
+ * (buf.validate.field).bytes.example = "\x02\x03"
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated bytes example = 14;
+ */
+ example: Uint8Array[];
+};
+
+/**
+ * Describes the message buf.validate.BytesRules.
+ * Use `create(BytesRulesSchema)` to create a new message.
+ */
+export const BytesRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 19);
+
+/**
+ * EnumRules describe the rules applied to `enum` values.
+ *
+ * @generated from message buf.validate.EnumRules
+ */
+export type EnumRules = Message<"buf.validate.EnumRules"> & {
+ /**
+ * `const` requires the field value to exactly match the specified enum value.
+ * If the field value doesn't match, an error message is generated.
+ *
+ * ```proto
+ * enum MyEnum {
+ * MY_ENUM_UNSPECIFIED = 0;
+ * MY_ENUM_VALUE1 = 1;
+ * MY_ENUM_VALUE2 = 2;
+ * }
+ *
+ * message MyMessage {
+ * // The field `value` must be exactly MY_ENUM_VALUE1.
+ * MyEnum value = 1 [(buf.validate.field).enum.const = 1];
+ * }
+ * ```
+ *
+ * @generated from field: optional int32 const = 1;
+ */
+ const: number;
+
+ /**
+ * `defined_only` requires the field value to be one of the defined values for
+ * this enum, failing on any undefined value.
+ *
+ * ```proto
+ * enum MyEnum {
+ * MY_ENUM_UNSPECIFIED = 0;
+ * MY_ENUM_VALUE1 = 1;
+ * MY_ENUM_VALUE2 = 2;
+ * }
+ *
+ * message MyMessage {
+ * // The field `value` must be a defined value of MyEnum.
+ * MyEnum value = 1 [(buf.validate.field).enum.defined_only = true];
+ * }
+ * ```
+ *
+ * @generated from field: optional bool defined_only = 2;
+ */
+ definedOnly: boolean;
+
+ /**
+ * `in` requires the field value to be equal to one of the
+ * specified enum values. If the field value doesn't match any of the
+ * specified values, an error message is generated.
+ *
+ * ```proto
+ * enum MyEnum {
+ * MY_ENUM_UNSPECIFIED = 0;
+ * MY_ENUM_VALUE1 = 1;
+ * MY_ENUM_VALUE2 = 2;
+ * }
+ *
+ * message MyMessage {
+ * // The field `value` must be equal to one of the specified values.
+ * MyEnum value = 1 [(buf.validate.field).enum = { in: [1, 2]}];
+ * }
+ * ```
+ *
+ * @generated from field: repeated int32 in = 3;
+ */
+ in: number[];
+
+ /**
+ * `not_in` requires the field value to be not equal to any of the
+ * specified enum values. If the field value matches one of the specified
+ * values, an error message is generated.
+ *
+ * ```proto
+ * enum MyEnum {
+ * MY_ENUM_UNSPECIFIED = 0;
+ * MY_ENUM_VALUE1 = 1;
+ * MY_ENUM_VALUE2 = 2;
+ * }
+ *
+ * message MyMessage {
+ * // The field `value` must not be equal to any of the specified values.
+ * MyEnum value = 1 [(buf.validate.field).enum = { not_in: [1, 2]}];
+ * }
+ * ```
+ *
+ * @generated from field: repeated int32 not_in = 4;
+ */
+ notIn: number[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * enum MyEnum {
+ * MY_ENUM_UNSPECIFIED = 0;
+ * MY_ENUM_VALUE1 = 1;
+ * MY_ENUM_VALUE2 = 2;
+ * }
+ *
+ * message MyMessage {
+ * (buf.validate.field).enum.example = 1,
+ * (buf.validate.field).enum.example = 2
+ * }
+ * ```
+ *
+ * @generated from field: repeated int32 example = 5;
+ */
+ example: number[];
+};
+
+/**
+ * Describes the message buf.validate.EnumRules.
+ * Use `create(EnumRulesSchema)` to create a new message.
+ */
+export const EnumRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 20);
+
+/**
+ * RepeatedRules describe the rules applied to `repeated` values.
+ *
+ * @generated from message buf.validate.RepeatedRules
+ */
+export type RepeatedRules = Message<"buf.validate.RepeatedRules"> & {
+ /**
+ * `min_items` requires that this field must contain at least the specified
+ * minimum number of items.
+ *
+ * Note that `min_items = 1` is equivalent to setting a field as `required`.
+ *
+ * ```proto
+ * message MyRepeated {
+ * // value must contain at least 2 items
+ * repeated string value = 1 [(buf.validate.field).repeated.min_items = 2];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 min_items = 1;
+ */
+ minItems: bigint;
+
+ /**
+ * `max_items` denotes that this field must not exceed a
+ * certain number of items as the upper limit. If the field contains more
+ * items than specified, an error message will be generated, requiring the
+ * field to maintain no more than the specified number of items.
+ *
+ * ```proto
+ * message MyRepeated {
+ * // value must contain no more than 3 item(s)
+ * repeated string value = 1 [(buf.validate.field).repeated.max_items = 3];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 max_items = 2;
+ */
+ maxItems: bigint;
+
+ /**
+ * `unique` indicates that all elements in this field must
+ * be unique. This rule is strictly applicable to scalar and enum
+ * types, with message types not being supported.
+ *
+ * ```proto
+ * message MyRepeated {
+ * // repeated value must contain unique items
+ * repeated string value = 1 [(buf.validate.field).repeated.unique = true];
+ * }
+ * ```
+ *
+ * @generated from field: optional bool unique = 3;
+ */
+ unique: boolean;
+
+ /**
+ * `items` details the rules to be applied to each item
+ * in the field. Even for repeated message fields, validation is executed
+ * against each item unless skip is explicitly specified.
+ *
+ * ```proto
+ * message MyRepeated {
+ * // The items in the field `value` must follow the specified rules.
+ * repeated string value = 1 [(buf.validate.field).repeated.items = {
+ * string: {
+ * min_len: 3
+ * max_len: 10
+ * }
+ * }];
+ * }
+ * ```
+ *
+ * @generated from field: optional buf.validate.FieldRules items = 4;
+ */
+ items?: FieldRules;
+};
+
+/**
+ * Describes the message buf.validate.RepeatedRules.
+ * Use `create(RepeatedRulesSchema)` to create a new message.
+ */
+export const RepeatedRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 21);
+
+/**
+ * MapRules describe the rules applied to `map` values.
+ *
+ * @generated from message buf.validate.MapRules
+ */
+export type MapRules = Message<"buf.validate.MapRules"> & {
+ /**
+ * Specifies the minimum number of key-value pairs allowed. If the field has
+ * fewer key-value pairs than specified, an error message is generated.
+ *
+ * ```proto
+ * message MyMap {
+ * // The field `value` must have at least 2 key-value pairs.
+ * map value = 1 [(buf.validate.field).map.min_pairs = 2];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 min_pairs = 1;
+ */
+ minPairs: bigint;
+
+ /**
+ * Specifies the maximum number of key-value pairs allowed. If the field has
+ * more key-value pairs than specified, an error message is generated.
+ *
+ * ```proto
+ * message MyMap {
+ * // The field `value` must have at most 3 key-value pairs.
+ * map value = 1 [(buf.validate.field).map.max_pairs = 3];
+ * }
+ * ```
+ *
+ * @generated from field: optional uint64 max_pairs = 2;
+ */
+ maxPairs: bigint;
+
+ /**
+ * Specifies the rules to be applied to each key in the field.
+ *
+ * ```proto
+ * message MyMap {
+ * // The keys in the field `value` must follow the specified rules.
+ * map value = 1 [(buf.validate.field).map.keys = {
+ * string: {
+ * min_len: 3
+ * max_len: 10
+ * }
+ * }];
+ * }
+ * ```
+ *
+ * @generated from field: optional buf.validate.FieldRules keys = 4;
+ */
+ keys?: FieldRules;
+
+ /**
+ * Specifies the rules to be applied to the value of each key in the
+ * field. Message values will still have their validations evaluated unless
+ * skip is specified here.
+ *
+ * ```proto
+ * message MyMap {
+ * // The values in the field `value` must follow the specified rules.
+ * map value = 1 [(buf.validate.field).map.values = {
+ * string: {
+ * min_len: 5
+ * max_len: 20
+ * }
+ * }];
+ * }
+ * ```
+ *
+ * @generated from field: optional buf.validate.FieldRules values = 5;
+ */
+ values?: FieldRules;
+};
+
+/**
+ * Describes the message buf.validate.MapRules.
+ * Use `create(MapRulesSchema)` to create a new message.
+ */
+export const MapRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 22);
+
+/**
+ * AnyRules describe rules applied exclusively to the `google.protobuf.Any` well-known type.
+ *
+ * @generated from message buf.validate.AnyRules
+ */
+export type AnyRules = Message<"buf.validate.AnyRules"> & {
+ /**
+ * `in` requires the field's `type_url` to be equal to one of the
+ * specified values. If it doesn't match any of the specified values, an error
+ * message is generated.
+ *
+ * ```proto
+ * message MyAny {
+ * // The `value` field must have a `type_url` equal to one of the specified values.
+ * google.protobuf.Any value = 1 [(buf.validate.field).any.in = ["type.googleapis.com/MyType1", "type.googleapis.com/MyType2"]];
+ * }
+ * ```
+ *
+ * @generated from field: repeated string in = 2;
+ */
+ in: string[];
+
+ /**
+ * requires the field's type_url to be not equal to any of the specified values. If it matches any of the specified values, an error message is generated.
+ *
+ * ```proto
+ * message MyAny {
+ * // The field `value` must not have a `type_url` equal to any of the specified values.
+ * google.protobuf.Any value = 1 [(buf.validate.field).any.not_in = ["type.googleapis.com/ForbiddenType1", "type.googleapis.com/ForbiddenType2"]];
+ * }
+ * ```
+ *
+ * @generated from field: repeated string not_in = 3;
+ */
+ notIn: string[];
+};
+
+/**
+ * Describes the message buf.validate.AnyRules.
+ * Use `create(AnyRulesSchema)` to create a new message.
+ */
+export const AnyRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 23);
+
+/**
+ * DurationRules describe the rules applied exclusively to the `google.protobuf.Duration` well-known type.
+ *
+ * @generated from message buf.validate.DurationRules
+ */
+export type DurationRules = Message<"buf.validate.DurationRules"> & {
+ /**
+ * `const` dictates that the field must match the specified value of the `google.protobuf.Duration` type exactly.
+ * If the field's value deviates from the specified value, an error message
+ * will be generated.
+ *
+ * ```proto
+ * message MyDuration {
+ * // value must equal 5s
+ * google.protobuf.Duration value = 1 [(buf.validate.field).duration.const = "5s"];
+ * }
+ * ```
+ *
+ * @generated from field: optional google.protobuf.Duration const = 2;
+ */
+ const?: Duration;
+
+ /**
+ * @generated from oneof buf.validate.DurationRules.less_than
+ */
+ lessThan: {
+ /**
+ * `lt` stipulates that the field must be less than the specified value of the `google.protobuf.Duration` type,
+ * exclusive. If the field's value is greater than or equal to the specified
+ * value, an error message will be generated.
+ *
+ * ```proto
+ * message MyDuration {
+ * // value must be less than 5s
+ * google.protobuf.Duration value = 1 [(buf.validate.field).duration.lt = "5s"];
+ * }
+ * ```
+ *
+ * @generated from field: google.protobuf.Duration lt = 3;
+ */
+ value: Duration;
+ case: "lt";
+ } | {
+ /**
+ * `lte` indicates that the field must be less than or equal to the specified
+ * value of the `google.protobuf.Duration` type, inclusive. If the field's value is greater than the specified value,
+ * an error message will be generated.
+ *
+ * ```proto
+ * message MyDuration {
+ * // value must be less than or equal to 10s
+ * google.protobuf.Duration value = 1 [(buf.validate.field).duration.lte = "10s"];
+ * }
+ * ```
+ *
+ * @generated from field: google.protobuf.Duration lte = 4;
+ */
+ value: Duration;
+ case: "lte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.DurationRules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the duration field value to be greater than the specified
+ * value (exclusive). If the value of `gt` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyDuration {
+ * // duration must be greater than 5s [duration.gt]
+ * google.protobuf.Duration value = 1 [(buf.validate.field).duration.gt = { seconds: 5 }];
+ *
+ * // duration must be greater than 5s and less than 10s [duration.gt_lt]
+ * google.protobuf.Duration another_value = 2 [(buf.validate.field).duration = { gt: { seconds: 5 }, lt: { seconds: 10 } }];
+ *
+ * // duration must be greater than 10s or less than 5s [duration.gt_lt_exclusive]
+ * google.protobuf.Duration other_value = 3 [(buf.validate.field).duration = { gt: { seconds: 10 }, lt: { seconds: 5 } }];
+ * }
+ * ```
+ *
+ * @generated from field: google.protobuf.Duration gt = 5;
+ */
+ value: Duration;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the duration field value to be greater than or equal to the
+ * specified value (exclusive). If the value of `gte` is larger than a
+ * specified `lt` or `lte`, the range is reversed, and the field value must
+ * be outside the specified range. If the field value doesn't meet the
+ * required conditions, an error message is generated.
+ *
+ * ```proto
+ * message MyDuration {
+ * // duration must be greater than or equal to 5s [duration.gte]
+ * google.protobuf.Duration value = 1 [(buf.validate.field).duration.gte = { seconds: 5 }];
+ *
+ * // duration must be greater than or equal to 5s and less than 10s [duration.gte_lt]
+ * google.protobuf.Duration another_value = 2 [(buf.validate.field).duration = { gte: { seconds: 5 }, lt: { seconds: 10 } }];
+ *
+ * // duration must be greater than or equal to 10s or less than 5s [duration.gte_lt_exclusive]
+ * google.protobuf.Duration other_value = 3 [(buf.validate.field).duration = { gte: { seconds: 10 }, lt: { seconds: 5 } }];
+ * }
+ * ```
+ *
+ * @generated from field: google.protobuf.Duration gte = 6;
+ */
+ value: Duration;
+ case: "gte";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `in` asserts that the field must be equal to one of the specified values of the `google.protobuf.Duration` type.
+ * If the field's value doesn't correspond to any of the specified values,
+ * an error message will be generated.
+ *
+ * ```proto
+ * message MyDuration {
+ * // value must be in list [1s, 2s, 3s]
+ * google.protobuf.Duration value = 1 [(buf.validate.field).duration.in = ["1s", "2s", "3s"]];
+ * }
+ * ```
+ *
+ * @generated from field: repeated google.protobuf.Duration in = 7;
+ */
+ in: Duration[];
+
+ /**
+ * `not_in` denotes that the field must not be equal to
+ * any of the specified values of the `google.protobuf.Duration` type.
+ * If the field's value matches any of these values, an error message will be
+ * generated.
+ *
+ * ```proto
+ * message MyDuration {
+ * // value must not be in list [1s, 2s, 3s]
+ * google.protobuf.Duration value = 1 [(buf.validate.field).duration.not_in = ["1s", "2s", "3s"]];
+ * }
+ * ```
+ *
+ * @generated from field: repeated google.protobuf.Duration not_in = 8;
+ */
+ notIn: Duration[];
+
+ /**
+ * `example` specifies values that the field may have. These values SHOULD
+ * conform to other rules. `example` values will not impact validation
+ * but may be used as helpful guidance on how to populate the given field.
+ *
+ * ```proto
+ * message MyDuration {
+ * google.protobuf.Duration value = 1 [
+ * (buf.validate.field).duration.example = { seconds: 1 },
+ * (buf.validate.field).duration.example = { seconds: 2 },
+ * ];
+ * }
+ * ```
+ *
+ * @generated from field: repeated google.protobuf.Duration example = 9;
+ */
+ example: Duration[];
+};
+
+/**
+ * Describes the message buf.validate.DurationRules.
+ * Use `create(DurationRulesSchema)` to create a new message.
+ */
+export const DurationRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 24);
+
+/**
+ * TimestampRules describe the rules applied exclusively to the `google.protobuf.Timestamp` well-known type.
+ *
+ * @generated from message buf.validate.TimestampRules
+ */
+export type TimestampRules = Message<"buf.validate.TimestampRules"> & {
+ /**
+ * `const` dictates that this field, of the `google.protobuf.Timestamp` type, must exactly match the specified value. If the field value doesn't correspond to the specified timestamp, an error message will be generated.
+ *
+ * ```proto
+ * message MyTimestamp {
+ * // value must equal 2023-05-03T10:00:00Z
+ * google.protobuf.Timestamp created_at = 1 [(buf.validate.field).timestamp.const = {seconds: 1727998800}];
+ * }
+ * ```
+ *
+ * @generated from field: optional google.protobuf.Timestamp const = 2;
+ */
+ const?: Timestamp;
+
+ /**
+ * @generated from oneof buf.validate.TimestampRules.less_than
+ */
+ lessThan: {
+ /**
+ * requires the duration field value to be less than the specified value (field < value). If the field value doesn't meet the required conditions, an error message is generated.
+ *
+ * ```proto
+ * message MyDuration {
+ * // duration must be less than 'P3D' [duration.lt]
+ * google.protobuf.Duration value = 1 [(buf.validate.field).duration.lt = { seconds: 259200 }];
+ * }
+ * ```
+ *
+ * @generated from field: google.protobuf.Timestamp lt = 3;
+ */
+ value: Timestamp;
+ case: "lt";
+ } | {
+ /**
+ * requires the timestamp field value to be less than or equal to the specified value (field <= value). If the field value doesn't meet the required conditions, an error message is generated.
+ *
+ * ```proto
+ * message MyTimestamp {
+ * // timestamp must be less than or equal to '2023-05-14T00:00:00Z' [timestamp.lte]
+ * google.protobuf.Timestamp value = 1 [(buf.validate.field).timestamp.lte = { seconds: 1678867200 }];
+ * }
+ * ```
+ *
+ * @generated from field: google.protobuf.Timestamp lte = 4;
+ */
+ value: Timestamp;
+ case: "lte";
+ } | {
+ /**
+ * `lt_now` specifies that this field, of the `google.protobuf.Timestamp` type, must be less than the current time. `lt_now` can only be used with the `within` rule.
+ *
+ * ```proto
+ * message MyTimestamp {
+ * // value must be less than now
+ * google.protobuf.Timestamp created_at = 1 [(buf.validate.field).timestamp.lt_now = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool lt_now = 7;
+ */
+ value: boolean;
+ case: "ltNow";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * @generated from oneof buf.validate.TimestampRules.greater_than
+ */
+ greaterThan: {
+ /**
+ * `gt` requires the timestamp field value to be greater than the specified
+ * value (exclusive). If the value of `gt` is larger than a specified `lt`
+ * or `lte`, the range is reversed, and the field value must be outside the
+ * specified range. If the field value doesn't meet the required conditions,
+ * an error message is generated.
+ *
+ * ```proto
+ * message MyTimestamp {
+ * // timestamp must be greater than '2023-01-01T00:00:00Z' [timestamp.gt]
+ * google.protobuf.Timestamp value = 1 [(buf.validate.field).timestamp.gt = { seconds: 1672444800 }];
+ *
+ * // timestamp must be greater than '2023-01-01T00:00:00Z' and less than '2023-01-02T00:00:00Z' [timestamp.gt_lt]
+ * google.protobuf.Timestamp another_value = 2 [(buf.validate.field).timestamp = { gt: { seconds: 1672444800 }, lt: { seconds: 1672531200 } }];
+ *
+ * // timestamp must be greater than '2023-01-02T00:00:00Z' or less than '2023-01-01T00:00:00Z' [timestamp.gt_lt_exclusive]
+ * google.protobuf.Timestamp other_value = 3 [(buf.validate.field).timestamp = { gt: { seconds: 1672531200 }, lt: { seconds: 1672444800 } }];
+ * }
+ * ```
+ *
+ * @generated from field: google.protobuf.Timestamp gt = 5;
+ */
+ value: Timestamp;
+ case: "gt";
+ } | {
+ /**
+ * `gte` requires the timestamp field value to be greater than or equal to the
+ * specified value (exclusive). If the value of `gte` is larger than a
+ * specified `lt` or `lte`, the range is reversed, and the field value
+ * must be outside the specified range. If the field value doesn't meet
+ * the required conditions, an error message is generated.
+ *
+ * ```proto
+ * message MyTimestamp {
+ * // timestamp must be greater than or equal to '2023-01-01T00:00:00Z' [timestamp.gte]
+ * google.protobuf.Timestamp value = 1 [(buf.validate.field).timestamp.gte = { seconds: 1672444800 }];
+ *
+ * // timestamp must be greater than or equal to '2023-01-01T00:00:00Z' and less than '2023-01-02T00:00:00Z' [timestamp.gte_lt]
+ * google.protobuf.Timestamp another_value = 2 [(buf.validate.field).timestamp = { gte: { seconds: 1672444800 }, lt: { seconds: 1672531200 } }];
+ *
+ * // timestamp must be greater than or equal to '2023-01-02T00:00:00Z' or less than '2023-01-01T00:00:00Z' [timestamp.gte_lt_exclusive]
+ * google.protobuf.Timestamp other_value = 3 [(buf.validate.field).timestamp = { gte: { seconds: 1672531200 }, lt: { seconds: 1672444800 } }];
+ * }
+ * ```
+ *
+ * @generated from field: google.protobuf.Timestamp gte = 6;
+ */
+ value: Timestamp;
+ case: "gte";
+ } | {
+ /**
+ * `gt_now` specifies that this field, of the `google.protobuf.Timestamp` type, must be greater than the current time. `gt_now` can only be used with the `within` rule.
+ *
+ * ```proto
+ * message MyTimestamp {
+ * // value must be greater than now
+ * google.protobuf.Timestamp created_at = 1 [(buf.validate.field).timestamp.gt_now = true];
+ * }
+ * ```
+ *
+ * @generated from field: bool gt_now = 8;
+ */
+ value: boolean;
+ case: "gtNow";
+ } | { case: undefined; value?: undefined };
+
+ /**
+ * `within` specifies that this field, of the `google.protobuf.Timestamp` type, must be within the specified duration of the current time. If the field value isn't within the duration, an error message is generated.
+ *
+ * ```proto
+ * message MyTimestamp {
+ * // value must be within 1 hour of now
+ * google.protobuf.Timestamp created_at = 1 [(buf.validate.field).timestamp.within = {seconds: 3600}];
+ * }
+ * ```
+ *
+ * @generated from field: optional google.protobuf.Duration within = 9;
+ */
+ within?: Duration;
+
+ /**
+ * @generated from field: repeated google.protobuf.Timestamp example = 10;
+ */
+ example: Timestamp[];
+};
+
+/**
+ * Describes the message buf.validate.TimestampRules.
+ * Use `create(TimestampRulesSchema)` to create a new message.
+ */
+export const TimestampRulesSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 25);
+
+/**
+ * `Violations` is a collection of `Violation` messages. This message type is returned by
+ * protovalidate when a proto message fails to meet the requirements set by the `Rule` validation rules.
+ * Each individual violation is represented by a `Violation` message.
+ *
+ * @generated from message buf.validate.Violations
+ */
+export type Violations = Message<"buf.validate.Violations"> & {
+ /**
+ * `violations` is a repeated field that contains all the `Violation` messages corresponding to the violations detected.
+ *
+ * @generated from field: repeated buf.validate.Violation violations = 1;
+ */
+ violations: Violation[];
+};
+
+/**
+ * Describes the message buf.validate.Violations.
+ * Use `create(ViolationsSchema)` to create a new message.
+ */
+export const ViolationsSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 26);
+
+/**
+ * `Violation` represents a single instance where a validation rule, expressed
+ * as a `Rule`, was not met. It provides information about the field that
+ * caused the violation, the specific rule that wasn't fulfilled, and a
+ * human-readable error message.
+ *
+ * ```json
+ * {
+ * "fieldPath": "bar",
+ * "ruleId": "foo.bar",
+ * "message": "bar must be greater than 0"
+ * }
+ * ```
+ *
+ * @generated from message buf.validate.Violation
+ */
+export type Violation = Message<"buf.validate.Violation"> & {
+ /**
+ * `field` is a machine-readable path to the field that failed validation.
+ * This could be a nested field, in which case the path will include all the parent fields leading to the actual field that caused the violation.
+ *
+ * For example, consider the following message:
+ *
+ * ```proto
+ * message Message {
+ * bool a = 1 [(buf.validate.field).required = true];
+ * }
+ * ```
+ *
+ * It could produce the following violation:
+ *
+ * ```textproto
+ * violation {
+ * field { element { field_number: 1, field_name: "a", field_type: 8 } }
+ * ...
+ * }
+ * ```
+ *
+ * @generated from field: optional buf.validate.FieldPath field = 5;
+ */
+ field?: FieldPath;
+
+ /**
+ * `rule` is a machine-readable path that points to the specific rule rule that failed validation.
+ * This will be a nested field starting from the FieldRules of the field that failed validation.
+ * For custom rules, this will provide the path of the rule, e.g. `cel[0]`.
+ *
+ * For example, consider the following message:
+ *
+ * ```proto
+ * message Message {
+ * bool a = 1 [(buf.validate.field).required = true];
+ * bool b = 2 [(buf.validate.field).cel = {
+ * id: "custom_rule",
+ * expression: "!this ? 'b must be true': ''"
+ * }]
+ * }
+ * ```
+ *
+ * It could produce the following violations:
+ *
+ * ```textproto
+ * violation {
+ * rule { element { field_number: 25, field_name: "required", field_type: 8 } }
+ * ...
+ * }
+ * violation {
+ * rule { element { field_number: 23, field_name: "cel", field_type: 11, index: 0 } }
+ * ...
+ * }
+ * ```
+ *
+ * @generated from field: optional buf.validate.FieldPath rule = 6;
+ */
+ rule?: FieldPath;
+
+ /**
+ * `rule_id` is the unique identifier of the `Rule` that was not fulfilled.
+ * This is the same `id` that was specified in the `Rule` message, allowing easy tracing of which rule was violated.
+ *
+ * @generated from field: optional string rule_id = 2;
+ */
+ ruleId: string;
+
+ /**
+ * `message` is a human-readable error message that describes the nature of the violation.
+ * This can be the default error message from the violated `Rule`, or it can be a custom message that gives more context about the violation.
+ *
+ * @generated from field: optional string message = 3;
+ */
+ message: string;
+
+ /**
+ * `for_key` indicates whether the violation was caused by a map key, rather than a value.
+ *
+ * @generated from field: optional bool for_key = 4;
+ */
+ forKey: boolean;
+};
+
+/**
+ * Describes the message buf.validate.Violation.
+ * Use `create(ViolationSchema)` to create a new message.
+ */
+export const ViolationSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 27);
+
+/**
+ * `FieldPath` provides a path to a nested protobuf field.
+ *
+ * This message provides enough information to render a dotted field path even without protobuf descriptors.
+ * It also provides enough information to resolve a nested field through unknown wire data.
+ *
+ * @generated from message buf.validate.FieldPath
+ */
+export type FieldPath = Message<"buf.validate.FieldPath"> & {
+ /**
+ * `elements` contains each element of the path, starting from the root and recursing downward.
+ *
+ * @generated from field: repeated buf.validate.FieldPathElement elements = 1;
+ */
+ elements: FieldPathElement[];
+};
+
+/**
+ * Describes the message buf.validate.FieldPath.
+ * Use `create(FieldPathSchema)` to create a new message.
+ */
+export const FieldPathSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 28);
+
+/**
+ * `FieldPathElement` provides enough information to nest through a single protobuf field.
+ *
+ * If the selected field is a map or repeated field, the `subscript` value selects a specific element from it.
+ * A path that refers to a value nested under a map key or repeated field index will have a `subscript` value.
+ * The `field_type` field allows unambiguous resolution of a field even if descriptors are not available.
+ *
+ * @generated from message buf.validate.FieldPathElement
+ */
+export type FieldPathElement = Message<"buf.validate.FieldPathElement"> & {
+ /**
+ * `field_number` is the field number this path element refers to.
+ *
+ * @generated from field: optional int32 field_number = 1;
+ */
+ fieldNumber: number;
+
+ /**
+ * `field_name` contains the field name this path element refers to.
+ * This can be used to display a human-readable path even if the field number is unknown.
+ *
+ * @generated from field: optional string field_name = 2;
+ */
+ fieldName: string;
+
+ /**
+ * `field_type` specifies the type of this field. When using reflection, this value is not needed.
+ *
+ * This value is provided to make it possible to traverse unknown fields through wire data.
+ * When traversing wire data, be mindful of both packed[1] and delimited[2] encoding schemes.
+ *
+ * [1]: https://protobuf.dev/programming-guides/encoding/#packed
+ * [2]: https://protobuf.dev/programming-guides/encoding/#groups
+ *
+ * N.B.: Although groups are deprecated, the corresponding delimited encoding scheme is not, and
+ * can be explicitly used in Protocol Buffers 2023 Edition.
+ *
+ * @generated from field: optional google.protobuf.FieldDescriptorProto.Type field_type = 3;
+ */
+ fieldType: FieldDescriptorProto_Type;
+
+ /**
+ * `key_type` specifies the map key type of this field. This value is useful when traversing
+ * unknown fields through wire data: specifically, it allows handling the differences between
+ * different integer encodings.
+ *
+ * @generated from field: optional google.protobuf.FieldDescriptorProto.Type key_type = 4;
+ */
+ keyType: FieldDescriptorProto_Type;
+
+ /**
+ * `value_type` specifies map value type of this field. This is useful if you want to display a
+ * value inside unknown fields through wire data.
+ *
+ * @generated from field: optional google.protobuf.FieldDescriptorProto.Type value_type = 5;
+ */
+ valueType: FieldDescriptorProto_Type;
+
+ /**
+ * `subscript` contains a repeated index or map key, if this path element nests into a repeated or map field.
+ *
+ * @generated from oneof buf.validate.FieldPathElement.subscript
+ */
+ subscript: {
+ /**
+ * `index` specifies a 0-based index into a repeated field.
+ *
+ * @generated from field: uint64 index = 6;
+ */
+ value: bigint;
+ case: "index";
+ } | {
+ /**
+ * `bool_key` specifies a map key of type bool.
+ *
+ * @generated from field: bool bool_key = 7;
+ */
+ value: boolean;
+ case: "boolKey";
+ } | {
+ /**
+ * `int_key` specifies a map key of type int32, int64, sint32, sint64, sfixed32 or sfixed64.
+ *
+ * @generated from field: int64 int_key = 8;
+ */
+ value: bigint;
+ case: "intKey";
+ } | {
+ /**
+ * `uint_key` specifies a map key of type uint32, uint64, fixed32 or fixed64.
+ *
+ * @generated from field: uint64 uint_key = 9;
+ */
+ value: bigint;
+ case: "uintKey";
+ } | {
+ /**
+ * `string_key` specifies a map key of type string.
+ *
+ * @generated from field: string string_key = 10;
+ */
+ value: string;
+ case: "stringKey";
+ } | { case: undefined; value?: undefined };
+};
+
+/**
+ * Describes the message buf.validate.FieldPathElement.
+ * Use `create(FieldPathElementSchema)` to create a new message.
+ */
+export const FieldPathElementSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_buf_validate_validate, 29);
+
+/**
+ * Specifies how FieldRules.ignore behaves. See the documentation for
+ * FieldRules.required for definitions of "populated" and "nullable".
+ *
+ * @generated from enum buf.validate.Ignore
+ */
+export enum Ignore {
+ /**
+ * Validation is only skipped if it's an unpopulated nullable fields.
+ *
+ * ```proto
+ * syntax="proto3";
+ *
+ * message Request {
+ * // The uri rule applies to any value, including the empty string.
+ * string foo = 1 [
+ * (buf.validate.field).string.uri = true
+ * ];
+ *
+ * // The uri rule only applies if the field is set, including if it's
+ * // set to the empty string.
+ * optional string bar = 2 [
+ * (buf.validate.field).string.uri = true
+ * ];
+ *
+ * // The min_items rule always applies, even if the list is empty.
+ * repeated string baz = 3 [
+ * (buf.validate.field).repeated.min_items = 3
+ * ];
+ *
+ * // The custom CEL rule applies only if the field is set, including if
+ * // it's the "zero" value of that message.
+ * SomeMessage quux = 4 [
+ * (buf.validate.field).cel = {/* ... *\/}
+ * ];
+ * }
+ * ```
+ *
+ * @generated from enum value: IGNORE_UNSPECIFIED = 0;
+ */
+ UNSPECIFIED = 0,
+
+ /**
+ * Validation is skipped if the field is unpopulated. This rule is redundant
+ * if the field is already nullable.
+ *
+ * ```proto
+ * syntax="proto3
+ *
+ * message Request {
+ * // The uri rule applies only if the value is not the empty string.
+ * string foo = 1 [
+ * (buf.validate.field).string.uri = true,
+ * (buf.validate.field).ignore = IGNORE_IF_UNPOPULATED
+ * ];
+ *
+ * // IGNORE_IF_UNPOPULATED is equivalent to IGNORE_UNSPECIFIED in this
+ * // case: the uri rule only applies if the field is set, including if
+ * // it's set to the empty string.
+ * optional string bar = 2 [
+ * (buf.validate.field).string.uri = true,
+ * (buf.validate.field).ignore = IGNORE_IF_UNPOPULATED
+ * ];
+ *
+ * // The min_items rule only applies if the list has at least one item.
+ * repeated string baz = 3 [
+ * (buf.validate.field).repeated.min_items = 3,
+ * (buf.validate.field).ignore = IGNORE_IF_UNPOPULATED
+ * ];
+ *
+ * // IGNORE_IF_UNPOPULATED is equivalent to IGNORE_UNSPECIFIED in this
+ * // case: the custom CEL rule applies only if the field is set, including
+ * // if it's the "zero" value of that message.
+ * SomeMessage quux = 4 [
+ * (buf.validate.field).cel = {/* ... *\/},
+ * (buf.validate.field).ignore = IGNORE_IF_UNPOPULATED
+ * ];
+ * }
+ * ```
+ *
+ * @generated from enum value: IGNORE_IF_UNPOPULATED = 1;
+ */
+ IF_UNPOPULATED = 1,
+
+ /**
+ * Validation is skipped if the field is unpopulated or if it is a nullable
+ * field populated with its default value. This is typically the zero or
+ * empty value, but proto2 scalars support custom defaults. For messages, the
+ * default is a non-null message with all its fields unpopulated.
+ *
+ * ```proto
+ * syntax="proto3
+ *
+ * message Request {
+ * // IGNORE_IF_DEFAULT_VALUE is equivalent to IGNORE_IF_UNPOPULATED in
+ * // this case; the uri rule applies only if the value is not the empty
+ * // string.
+ * string foo = 1 [
+ * (buf.validate.field).string.uri = true,
+ * (buf.validate.field).ignore = IGNORE_IF_DEFAULT_VALUE
+ * ];
+ *
+ * // The uri rule only applies if the field is set to a value other than
+ * // the empty string.
+ * optional string bar = 2 [
+ * (buf.validate.field).string.uri = true,
+ * (buf.validate.field).ignore = IGNORE_IF_DEFAULT_VALUE
+ * ];
+ *
+ * // IGNORE_IF_DEFAULT_VALUE is equivalent to IGNORE_IF_UNPOPULATED in
+ * // this case; the min_items rule only applies if the list has at least
+ * // one item.
+ * repeated string baz = 3 [
+ * (buf.validate.field).repeated.min_items = 3,
+ * (buf.validate.field).ignore = IGNORE_IF_DEFAULT_VALUE
+ * ];
+ *
+ * // The custom CEL rule only applies if the field is set to a value other
+ * // than an empty message (i.e., fields are unpopulated).
+ * SomeMessage quux = 4 [
+ * (buf.validate.field).cel = {/* ... *\/},
+ * (buf.validate.field).ignore = IGNORE_IF_DEFAULT_VALUE
+ * ];
+ * }
+ * ```
+ *
+ * This rule is affected by proto2 custom default values:
+ *
+ * ```proto
+ * syntax="proto2";
+ *
+ * message Request {
+ * // The gt rule only applies if the field is set and it's value is not
+ * the default (i.e., not -42). The rule even applies if the field is set
+ * to zero since the default value differs.
+ * optional int32 value = 1 [
+ * default = -42,
+ * (buf.validate.field).int32.gt = 0,
+ * (buf.validate.field).ignore = IGNORE_IF_DEFAULT_VALUE
+ * ];
+ * }
+ *
+ * @generated from enum value: IGNORE_IF_DEFAULT_VALUE = 2;
+ */
+ IF_DEFAULT_VALUE = 2,
+
+ /**
+ * The validation rules of this field will be skipped and not evaluated. This
+ * is useful for situations that necessitate turning off the rules of a field
+ * containing a message that may not make sense in the current context, or to
+ * temporarily disable rules during development.
+ *
+ * ```proto
+ * message MyMessage {
+ * // The field's rules will always be ignored, including any validation's
+ * // on value's fields.
+ * MyOtherMessage value = 1 [
+ * (buf.validate.field).ignore = IGNORE_ALWAYS];
+ * }
+ * ```
+ *
+ * @generated from enum value: IGNORE_ALWAYS = 3;
+ */
+ ALWAYS = 3,
+}
+
+/**
+ * Describes the enum buf.validate.Ignore.
+ */
+export const IgnoreSchema: GenEnum = /*@__PURE__*/
+ enumDesc(file_buf_validate_validate, 0);
+
+/**
+ * WellKnownRegex contain some well-known patterns.
+ *
+ * @generated from enum buf.validate.KnownRegex
+ */
+export enum KnownRegex {
+ /**
+ * @generated from enum value: KNOWN_REGEX_UNSPECIFIED = 0;
+ */
+ UNSPECIFIED = 0,
+
+ /**
+ * HTTP header name as defined by [RFC 7230](https://datatracker.ietf.org/doc/html/rfc7230#section-3.2).
+ *
+ * @generated from enum value: KNOWN_REGEX_HTTP_HEADER_NAME = 1;
+ */
+ HTTP_HEADER_NAME = 1,
+
+ /**
+ * HTTP header value as defined by [RFC 7230](https://datatracker.ietf.org/doc/html/rfc7230#section-3.2.4).
+ *
+ * @generated from enum value: KNOWN_REGEX_HTTP_HEADER_VALUE = 2;
+ */
+ HTTP_HEADER_VALUE = 2,
+}
+
+/**
+ * Describes the enum buf.validate.KnownRegex.
+ */
+export const KnownRegexSchema: GenEnum = /*@__PURE__*/
+ enumDesc(file_buf_validate_validate, 1);
+
+/**
+ * Rules specify the validations to be performed on this message. By default,
+ * no validation is performed against a message.
+ *
+ * @generated from extension: optional buf.validate.MessageRules message = 1159;
+ */
+export const message: GenExtension = /*@__PURE__*/
+ extDesc(file_buf_validate_validate, 0);
+
+/**
+ * Rules specify the validations to be performed on this oneof. By default,
+ * no validation is performed against a oneof.
+ *
+ * @generated from extension: optional buf.validate.OneofRules oneof = 1159;
+ */
+export const oneof: GenExtension = /*@__PURE__*/
+ extDesc(file_buf_validate_validate, 1);
+
+/**
+ * Rules specify the validations to be performed on this field. By default,
+ * no validation is performed against a field.
+ *
+ * @generated from extension: optional buf.validate.FieldRules field = 1159;
+ */
+export const field: GenExtension = /*@__PURE__*/
+ extDesc(file_buf_validate_validate, 2);
+
+/**
+ * Specifies predefined rules. When extending a standard rule message,
+ * this adds additional CEL expressions that apply when the extension is used.
+ *
+ * ```proto
+ * extend buf.validate.Int32Rules {
+ * bool is_zero [(buf.validate.predefined).cel = {
+ * id: "int32.is_zero",
+ * message: "value must be zero",
+ * expression: "!rule || this == 0",
+ * }];
+ * }
+ *
+ * message Foo {
+ * int32 reserved = 1 [(buf.validate.field).int32.(is_zero) = true];
+ * }
+ * ```
+ *
+ * @generated from extension: optional buf.validate.PredefinedRules predefined = 1160;
+ */
+export const predefined: GenExtension = /*@__PURE__*/
+ extDesc(file_buf_validate_validate, 3);
+
diff --git a/client/src/lib/connect/item/v1/item_pb.ts b/client/src/lib/connect/item/v1/item_pb.ts
index adea77a..c427e31 100644
--- a/client/src/lib/connect/item/v1/item_pb.ts
+++ b/client/src/lib/connect/item/v1/item_pb.ts
@@ -1,9 +1,10 @@
-// @generated by protoc-gen-es v2.2.3 with parameter "target=ts"
+// @generated by protoc-gen-es v2.2.5 with parameter "target=ts"
// @generated from file item/v1/item.proto (package item.v1, syntax proto3)
/* eslint-disable */
import type { GenFile, GenMessage, GenService } from "@bufbuild/protobuf/codegenv1";
import { fileDesc, messageDesc, serviceDesc } from "@bufbuild/protobuf/codegenv1";
+import { file_buf_validate_validate } from "../../buf/validate/validate_pb";
import type { Timestamp } from "@bufbuild/protobuf/wkt";
import { file_google_protobuf_timestamp } from "@bufbuild/protobuf/wkt";
import type { Message } from "@bufbuild/protobuf";
@@ -12,7 +13,7 @@ import type { Message } from "@bufbuild/protobuf";
* Describes the file item/v1/item.proto.
*/
export const file_item_v1_item: GenFile = /*@__PURE__*/
- fileDesc("ChJpdGVtL3YxL2l0ZW0ucHJvdG8SB2l0ZW0udjEigQEKBEl0ZW0SCgoCaWQYASABKAMSDAoEbmFtZRgCIAEoCRIpCgVhZGRlZBgDIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXASEwoLZGVzY3JpcHRpb24YBCABKAkSDQoFcHJpY2UYBSABKAISEAoIcXVhbnRpdHkYBiABKAUiHAoOR2V0SXRlbVJlcXVlc3QSCgoCaWQYASABKAMiLgoPR2V0SXRlbVJlc3BvbnNlEhsKBGl0ZW0YASABKAsyDS5pdGVtLnYxLkl0ZW0i3wEKD0dldEl0ZW1zUmVxdWVzdBIuCgVzdGFydBgBIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBIAIgBARIsCgNlbmQYAiABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wSAGIAQESEwoGZmlsdGVyGAMgASgJSAKIAQESEgoFbGltaXQYBCABKAVIA4gBARITCgZvZmZzZXQYBSABKAVIBIgBAUIICgZfc3RhcnRCBgoEX2VuZEIJCgdfZmlsdGVyQggKBl9saW1pdEIJCgdfb2Zmc2V0Ij8KEEdldEl0ZW1zUmVzcG9uc2USHAoFaXRlbXMYASADKAsyDS5pdGVtLnYxLkl0ZW0SDQoFY291bnQYAiABKAMiVwoRQ3JlYXRlSXRlbVJlcXVlc3QSDAoEbmFtZRgBIAEoCRITCgtkZXNjcmlwdGlvbhgCIAEoCRINCgVwcmljZRgDIAEoAhIQCghxdWFudGl0eRgEIAEoBSJLChJDcmVhdGVJdGVtUmVzcG9uc2USCgoCaWQYASABKAMSKQoFYWRkZWQYAiABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wIqcBChFVcGRhdGVJdGVtUmVxdWVzdBIKCgJpZBgBIAEoAxIRCgRuYW1lGAIgASgJSACIAQESGAoLZGVzY3JpcHRpb24YAyABKAlIAYgBARISCgVwcmljZRgEIAEoAkgCiAEBEhUKCHF1YW50aXR5GAUgASgFSAOIAQFCBwoFX25hbWVCDgoMX2Rlc2NyaXB0aW9uQggKBl9wcmljZUILCglfcXVhbnRpdHkiFAoSVXBkYXRlSXRlbVJlc3BvbnNlIh8KEURlbGV0ZUl0ZW1SZXF1ZXN0EgoKAmlkGAEgASgDIhQKEkRlbGV0ZUl0ZW1SZXNwb25zZTLrAgoLSXRlbVNlcnZpY2USPgoHR2V0SXRlbRIXLml0ZW0udjEuR2V0SXRlbVJlcXVlc3QaGC5pdGVtLnYxLkdldEl0ZW1SZXNwb25zZSIAEkEKCEdldEl0ZW1zEhguaXRlbS52MS5HZXRJdGVtc1JlcXVlc3QaGS5pdGVtLnYxLkdldEl0ZW1zUmVzcG9uc2UiABJHCgpDcmVhdGVJdGVtEhouaXRlbS52MS5DcmVhdGVJdGVtUmVxdWVzdBobLml0ZW0udjEuQ3JlYXRlSXRlbVJlc3BvbnNlIgASRwoKVXBkYXRlSXRlbRIaLml0ZW0udjEuVXBkYXRlSXRlbVJlcXVlc3QaGy5pdGVtLnYxLlVwZGF0ZUl0ZW1SZXNwb25zZSIAEkcKCkRlbGV0ZUl0ZW0SGi5pdGVtLnYxLkRlbGV0ZUl0ZW1SZXF1ZXN0GhsuaXRlbS52MS5EZWxldGVJdGVtUmVzcG9uc2UiAEKcAQoLY29tLml0ZW0udjFCCUl0ZW1Qcm90b1ABWkVnaXRodWIuY29tL3Nwb3RkZW1vNC90cmV2c3RhY2svc2VydmVyL2ludGVybmFsL2Nvbm5lY3QvaXRlbS92MTtpdGVtdjGiAgNJWFiqAgdJdGVtLlYxygIHSXRlbVxWMeICE0l0ZW1cVjFcR1BCTWV0YWRhdGHqAghJdGVtOjpWMWIGcHJvdG8z", [file_google_protobuf_timestamp]);
+ fileDesc("ChJpdGVtL3YxL2l0ZW0ucHJvdG8SB2l0ZW0udjEiigEKBEl0ZW0SCgoCaWQYASABKAMSFQoEbmFtZRgCIAEoCUIHukgEcgIQAxIpCgVhZGRlZBgDIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXASEwoLZGVzY3JpcHRpb24YBCABKAkSDQoFcHJpY2UYBSABKAISEAoIcXVhbnRpdHkYBiABKAUiHAoOR2V0SXRlbVJlcXVlc3QSCgoCaWQYASABKAMiLgoPR2V0SXRlbVJlc3BvbnNlEhsKBGl0ZW0YASABKAsyDS5pdGVtLnYxLkl0ZW0i3wEKD0dldEl0ZW1zUmVxdWVzdBIuCgVzdGFydBgBIAEoCzIaLmdvb2dsZS5wcm90b2J1Zi5UaW1lc3RhbXBIAIgBARIsCgNlbmQYAiABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wSAGIAQESEwoGZmlsdGVyGAMgASgJSAKIAQESEgoFbGltaXQYBCABKAVIA4gBARITCgZvZmZzZXQYBSABKAVIBIgBAUIICgZfc3RhcnRCBgoEX2VuZEIJCgdfZmlsdGVyQggKBl9saW1pdEIJCgdfb2Zmc2V0Ij8KEEdldEl0ZW1zUmVzcG9uc2USHAoFaXRlbXMYASADKAsyDS5pdGVtLnYxLkl0ZW0SDQoFY291bnQYAiABKAMiVwoRQ3JlYXRlSXRlbVJlcXVlc3QSDAoEbmFtZRgBIAEoCRITCgtkZXNjcmlwdGlvbhgCIAEoCRINCgVwcmljZRgDIAEoAhIQCghxdWFudGl0eRgEIAEoBSJLChJDcmVhdGVJdGVtUmVzcG9uc2USCgoCaWQYASABKAMSKQoFYWRkZWQYAiABKAsyGi5nb29nbGUucHJvdG9idWYuVGltZXN0YW1wIqcBChFVcGRhdGVJdGVtUmVxdWVzdBIKCgJpZBgBIAEoAxIRCgRuYW1lGAIgASgJSACIAQESGAoLZGVzY3JpcHRpb24YAyABKAlIAYgBARISCgVwcmljZRgEIAEoAkgCiAEBEhUKCHF1YW50aXR5GAUgASgFSAOIAQFCBwoFX25hbWVCDgoMX2Rlc2NyaXB0aW9uQggKBl9wcmljZUILCglfcXVhbnRpdHkiFAoSVXBkYXRlSXRlbVJlc3BvbnNlIh8KEURlbGV0ZUl0ZW1SZXF1ZXN0EgoKAmlkGAEgASgDIhQKEkRlbGV0ZUl0ZW1SZXNwb25zZTLrAgoLSXRlbVNlcnZpY2USPgoHR2V0SXRlbRIXLml0ZW0udjEuR2V0SXRlbVJlcXVlc3QaGC5pdGVtLnYxLkdldEl0ZW1SZXNwb25zZSIAEkEKCEdldEl0ZW1zEhguaXRlbS52MS5HZXRJdGVtc1JlcXVlc3QaGS5pdGVtLnYxLkdldEl0ZW1zUmVzcG9uc2UiABJHCgpDcmVhdGVJdGVtEhouaXRlbS52MS5DcmVhdGVJdGVtUmVxdWVzdBobLml0ZW0udjEuQ3JlYXRlSXRlbVJlc3BvbnNlIgASRwoKVXBkYXRlSXRlbRIaLml0ZW0udjEuVXBkYXRlSXRlbVJlcXVlc3QaGy5pdGVtLnYxLlVwZGF0ZUl0ZW1SZXNwb25zZSIAEkcKCkRlbGV0ZUl0ZW0SGi5pdGVtLnYxLkRlbGV0ZUl0ZW1SZXF1ZXN0GhsuaXRlbS52MS5EZWxldGVJdGVtUmVzcG9uc2UiAEKcAQoLY29tLml0ZW0udjFCCUl0ZW1Qcm90b1ABWkVnaXRodWIuY29tL3Nwb3RkZW1vNC90cmV2c3RhY2svc2VydmVyL2ludGVybmFsL2Nvbm5lY3QvaXRlbS92MTtpdGVtdjGiAgNJWFiqAgdJdGVtLlYxygIHSXRlbVxWMeICE0l0ZW1cVjFcR1BCTWV0YWRhdGHqAghJdGVtOjpWMWIGcHJvdG8z", [file_buf_validate_validate, file_google_protobuf_timestamp]);
/**
* @generated from message item.v1.Item
diff --git a/client/src/lib/connect/user/v1/auth_pb.ts b/client/src/lib/connect/user/v1/auth_pb.ts
index 028d827..a97c4b9 100644
--- a/client/src/lib/connect/user/v1/auth_pb.ts
+++ b/client/src/lib/connect/user/v1/auth_pb.ts
@@ -1,16 +1,17 @@
-// @generated by protoc-gen-es v2.2.3 with parameter "target=ts"
+// @generated by protoc-gen-es v2.2.5 with parameter "target=ts"
// @generated from file user/v1/auth.proto (package user.v1, syntax proto3)
/* eslint-disable */
import type { GenFile, GenMessage, GenService } from "@bufbuild/protobuf/codegenv1";
import { fileDesc, messageDesc, serviceDesc } from "@bufbuild/protobuf/codegenv1";
+import { file_buf_validate_validate } from "../../buf/validate/validate_pb";
import type { Message } from "@bufbuild/protobuf";
/**
* Describes the file user/v1/auth.proto.
*/
export const file_user_v1_auth: GenFile = /*@__PURE__*/
- fileDesc("ChJ1c2VyL3YxL2F1dGgucHJvdG8SB3VzZXIudjEiMgoMTG9naW5SZXF1ZXN0EhAKCHVzZXJuYW1lGAEgASgJEhAKCHBhc3N3b3JkGAIgASgJIh4KDUxvZ2luUmVzcG9uc2USDQoFdG9rZW4YASABKAkiTQoNU2lnblVwUmVxdWVzdBIQCgh1c2VybmFtZRgBIAEoCRIQCghwYXNzd29yZBgCIAEoCRIYChBjb25maXJtX3Bhc3N3b3JkGAMgASgJIhAKDlNpZ25VcFJlc3BvbnNlIg8KDUxvZ291dFJlcXVlc3QiEAoOTG9nb3V0UmVzcG9uc2UywQEKC0F1dGhTZXJ2aWNlEjgKBUxvZ2luEhUudXNlci52MS5Mb2dpblJlcXVlc3QaFi51c2VyLnYxLkxvZ2luUmVzcG9uc2UiABI7CgZTaWduVXASFi51c2VyLnYxLlNpZ25VcFJlcXVlc3QaFy51c2VyLnYxLlNpZ25VcFJlc3BvbnNlIgASOwoGTG9nb3V0EhYudXNlci52MS5Mb2dvdXRSZXF1ZXN0GhcudXNlci52MS5Mb2dvdXRSZXNwb25zZSIAQpwBCgtjb20udXNlci52MUIJQXV0aFByb3RvUAFaRWdpdGh1Yi5jb20vc3BvdGRlbW80L3RyZXZzdGFjay9zZXJ2ZXIvaW50ZXJuYWwvY29ubmVjdC91c2VyL3YxO3VzZXJ2MaICA1VYWKoCB1VzZXIuVjHKAgdVc2VyXFYx4gITVXNlclxWMVxHUEJNZXRhZGF0YeoCCFVzZXI6OlYxYgZwcm90bzM");
+ fileDesc("ChJ1c2VyL3YxL2F1dGgucHJvdG8SB3VzZXIudjEiOwoMTG9naW5SZXF1ZXN0EhkKCHVzZXJuYW1lGAEgASgJQge6SARyAhADEhAKCHBhc3N3b3JkGAIgASgJIh4KDUxvZ2luUmVzcG9uc2USDQoFdG9rZW4YASABKAkiVgoNU2lnblVwUmVxdWVzdBIZCgh1c2VybmFtZRgBIAEoCUIHukgEcgIQAxIQCghwYXNzd29yZBgCIAEoCRIYChBjb25maXJtX3Bhc3N3b3JkGAMgASgJIhAKDlNpZ25VcFJlc3BvbnNlIg8KDUxvZ291dFJlcXVlc3QiEAoOTG9nb3V0UmVzcG9uc2UiLAoYQmVnaW5QYXNza2V5TG9naW5SZXF1ZXN0EhAKCHVzZXJuYW1lGAEgASgJIjEKGUJlZ2luUGFzc2tleUxvZ2luUmVzcG9uc2USFAoMb3B0aW9uc19qc29uGAEgASgJIkIKGUZpbmlzaFBhc3NrZXlMb2dpblJlcXVlc3QSEAoIdXNlcm5hbWUYASABKAkSEwoLYXR0ZXN0YXRpb24YAiABKAkiKwoaRmluaXNoUGFzc2tleUxvZ2luUmVzcG9uc2USDQoFdG9rZW4YASABKAkygAMKC0F1dGhTZXJ2aWNlEjgKBUxvZ2luEhUudXNlci52MS5Mb2dpblJlcXVlc3QaFi51c2VyLnYxLkxvZ2luUmVzcG9uc2UiABI7CgZTaWduVXASFi51c2VyLnYxLlNpZ25VcFJlcXVlc3QaFy51c2VyLnYxLlNpZ25VcFJlc3BvbnNlIgASOwoGTG9nb3V0EhYudXNlci52MS5Mb2dvdXRSZXF1ZXN0GhcudXNlci52MS5Mb2dvdXRSZXNwb25zZSIAElwKEUJlZ2luUGFzc2tleUxvZ2luEiEudXNlci52MS5CZWdpblBhc3NrZXlMb2dpblJlcXVlc3QaIi51c2VyLnYxLkJlZ2luUGFzc2tleUxvZ2luUmVzcG9uc2UiABJfChJGaW5pc2hQYXNza2V5TG9naW4SIi51c2VyLnYxLkZpbmlzaFBhc3NrZXlMb2dpblJlcXVlc3QaIy51c2VyLnYxLkZpbmlzaFBhc3NrZXlMb2dpblJlc3BvbnNlIgBCnAEKC2NvbS51c2VyLnYxQglBdXRoUHJvdG9QAVpFZ2l0aHViLmNvbS9zcG90ZGVtbzQvdHJldnN0YWNrL3NlcnZlci9pbnRlcm5hbC9jb25uZWN0L3VzZXIvdjE7dXNlcnYxogIDVVhYqgIHVXNlci5WMcoCB1VzZXJcVjHiAhNVc2VyXFYxXEdQQk1ldGFkYXRh6gIIVXNlcjo6VjFiBnByb3RvMw", [file_buf_validate_validate]);
/**
* @generated from message user.v1.LoginRequest
@@ -117,6 +118,79 @@ export type LogoutResponse = Message<"user.v1.LogoutResponse"> & {
export const LogoutResponseSchema: GenMessage = /*@__PURE__*/
messageDesc(file_user_v1_auth, 5);
+/**
+ * @generated from message user.v1.BeginPasskeyLoginRequest
+ */
+export type BeginPasskeyLoginRequest = Message<"user.v1.BeginPasskeyLoginRequest"> & {
+ /**
+ * @generated from field: string username = 1;
+ */
+ username: string;
+};
+
+/**
+ * Describes the message user.v1.BeginPasskeyLoginRequest.
+ * Use `create(BeginPasskeyLoginRequestSchema)` to create a new message.
+ */
+export const BeginPasskeyLoginRequestSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_user_v1_auth, 6);
+
+/**
+ * @generated from message user.v1.BeginPasskeyLoginResponse
+ */
+export type BeginPasskeyLoginResponse = Message<"user.v1.BeginPasskeyLoginResponse"> & {
+ /**
+ * @generated from field: string options_json = 1;
+ */
+ optionsJson: string;
+};
+
+/**
+ * Describes the message user.v1.BeginPasskeyLoginResponse.
+ * Use `create(BeginPasskeyLoginResponseSchema)` to create a new message.
+ */
+export const BeginPasskeyLoginResponseSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_user_v1_auth, 7);
+
+/**
+ * @generated from message user.v1.FinishPasskeyLoginRequest
+ */
+export type FinishPasskeyLoginRequest = Message<"user.v1.FinishPasskeyLoginRequest"> & {
+ /**
+ * @generated from field: string username = 1;
+ */
+ username: string;
+
+ /**
+ * @generated from field: string attestation = 2;
+ */
+ attestation: string;
+};
+
+/**
+ * Describes the message user.v1.FinishPasskeyLoginRequest.
+ * Use `create(FinishPasskeyLoginRequestSchema)` to create a new message.
+ */
+export const FinishPasskeyLoginRequestSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_user_v1_auth, 8);
+
+/**
+ * @generated from message user.v1.FinishPasskeyLoginResponse
+ */
+export type FinishPasskeyLoginResponse = Message<"user.v1.FinishPasskeyLoginResponse"> & {
+ /**
+ * @generated from field: string token = 1;
+ */
+ token: string;
+};
+
+/**
+ * Describes the message user.v1.FinishPasskeyLoginResponse.
+ * Use `create(FinishPasskeyLoginResponseSchema)` to create a new message.
+ */
+export const FinishPasskeyLoginResponseSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_user_v1_auth, 9);
+
/**
* @generated from service user.v1.AuthService
*/
@@ -145,6 +219,22 @@ export const AuthService: GenService<{
input: typeof LogoutRequestSchema;
output: typeof LogoutResponseSchema;
},
+ /**
+ * @generated from rpc user.v1.AuthService.BeginPasskeyLogin
+ */
+ beginPasskeyLogin: {
+ methodKind: "unary";
+ input: typeof BeginPasskeyLoginRequestSchema;
+ output: typeof BeginPasskeyLoginResponseSchema;
+ },
+ /**
+ * @generated from rpc user.v1.AuthService.FinishPasskeyLogin
+ */
+ finishPasskeyLogin: {
+ methodKind: "unary";
+ input: typeof FinishPasskeyLoginRequestSchema;
+ output: typeof FinishPasskeyLoginResponseSchema;
+ },
}> = /*@__PURE__*/
serviceDesc(file_user_v1_auth, 0);
diff --git a/client/src/lib/connect/user/v1/user_pb.ts b/client/src/lib/connect/user/v1/user_pb.ts
index 83bda51..281bbcd 100644
--- a/client/src/lib/connect/user/v1/user_pb.ts
+++ b/client/src/lib/connect/user/v1/user_pb.ts
@@ -1,4 +1,4 @@
-// @generated by protoc-gen-es v2.2.3 with parameter "target=ts"
+// @generated by protoc-gen-es v2.2.5 with parameter "target=ts"
// @generated from file user/v1/user.proto (package user.v1, syntax proto3)
/* eslint-disable */
@@ -10,7 +10,7 @@ import type { Message } from "@bufbuild/protobuf";
* Describes the file user/v1/user.proto.
*/
export const file_user_v1_user: GenFile = /*@__PURE__*/
- fileDesc("ChJ1c2VyL3YxL3VzZXIucHJvdG8SB3VzZXIudjEiXAoEVXNlchIKCgJpZBgBIAEoAxIQCgh1c2VybmFtZRgCIAEoCRIfChJwcm9maWxlX3BpY3R1cmVfaWQYAyABKANIAIgBAUIVChNfcHJvZmlsZV9waWN0dXJlX2lkIhAKDkdldFVzZXJSZXF1ZXN0Ii4KD0dldFVzZXJSZXNwb25zZRIbCgR1c2VyGAEgASgLMg0udXNlci52MS5Vc2VyIl0KFVVwZGF0ZVBhc3N3b3JkUmVxdWVzdBIUCgxvbGRfcGFzc3dvcmQYASABKAkSFAoMbmV3X3Bhc3N3b3JkGAIgASgJEhgKEGNvbmZpcm1fcGFzc3dvcmQYAyABKAkiNQoWVXBkYXRlUGFzc3dvcmRSZXNwb25zZRIbCgR1c2VyGAEgASgLMg0udXNlci52MS5Vc2VyIj4KEEdldEFQSUtleVJlcXVlc3QSEAoIcGFzc3dvcmQYASABKAkSGAoQY29uZmlybV9wYXNzd29yZBgCIAEoCSIgChFHZXRBUElLZXlSZXNwb25zZRILCgNrZXkYASABKAkiPgobVXBkYXRlUHJvZmlsZVBpY3R1cmVSZXF1ZXN0EhEKCWZpbGVfbmFtZRgBIAEoCRIMCgRkYXRhGAIgASgMIjsKHFVwZGF0ZVByb2ZpbGVQaWN0dXJlUmVzcG9uc2USGwoEdXNlchgBIAEoCzINLnVzZXIudjEuVXNlcjLPAgoLVXNlclNlcnZpY2USPgoHR2V0VXNlchIXLnVzZXIudjEuR2V0VXNlclJlcXVlc3QaGC51c2VyLnYxLkdldFVzZXJSZXNwb25zZSIAElMKDlVwZGF0ZVBhc3N3b3JkEh4udXNlci52MS5VcGRhdGVQYXNzd29yZFJlcXVlc3QaHy51c2VyLnYxLlVwZGF0ZVBhc3N3b3JkUmVzcG9uc2UiABJECglHZXRBUElLZXkSGS51c2VyLnYxLkdldEFQSUtleVJlcXVlc3QaGi51c2VyLnYxLkdldEFQSUtleVJlc3BvbnNlIgASZQoUVXBkYXRlUHJvZmlsZVBpY3R1cmUSJC51c2VyLnYxLlVwZGF0ZVByb2ZpbGVQaWN0dXJlUmVxdWVzdBolLnVzZXIudjEuVXBkYXRlUHJvZmlsZVBpY3R1cmVSZXNwb25zZSIAQpwBCgtjb20udXNlci52MUIJVXNlclByb3RvUAFaRWdpdGh1Yi5jb20vc3BvdGRlbW80L3RyZXZzdGFjay9zZXJ2ZXIvaW50ZXJuYWwvY29ubmVjdC91c2VyL3YxO3VzZXJ2MaICA1VYWKoCB1VzZXIuVjHKAgdVc2VyXFYx4gITVXNlclxWMVxHUEJNZXRhZGF0YeoCCFVzZXI6OlYxYgZwcm90bzM");
+ fileDesc("ChJ1c2VyL3YxL3VzZXIucHJvdG8SB3VzZXIudjEiXAoEVXNlchIKCgJpZBgBIAEoAxIQCgh1c2VybmFtZRgCIAEoCRIfChJwcm9maWxlX3BpY3R1cmVfaWQYAyABKANIAIgBAUIVChNfcHJvZmlsZV9waWN0dXJlX2lkIhAKDkdldFVzZXJSZXF1ZXN0Ii4KD0dldFVzZXJSZXNwb25zZRIbCgR1c2VyGAEgASgLMg0udXNlci52MS5Vc2VyIl0KFVVwZGF0ZVBhc3N3b3JkUmVxdWVzdBIUCgxvbGRfcGFzc3dvcmQYASABKAkSFAoMbmV3X3Bhc3N3b3JkGAIgASgJEhgKEGNvbmZpcm1fcGFzc3dvcmQYAyABKAkiNQoWVXBkYXRlUGFzc3dvcmRSZXNwb25zZRIbCgR1c2VyGAEgASgLMg0udXNlci52MS5Vc2VyIj4KEEdldEFQSUtleVJlcXVlc3QSEAoIcGFzc3dvcmQYASABKAkSGAoQY29uZmlybV9wYXNzd29yZBgCIAEoCSIgChFHZXRBUElLZXlSZXNwb25zZRILCgNrZXkYASABKAkiPgobVXBkYXRlUHJvZmlsZVBpY3R1cmVSZXF1ZXN0EhEKCWZpbGVfbmFtZRgBIAEoCRIMCgRkYXRhGAIgASgMIjsKHFVwZGF0ZVByb2ZpbGVQaWN0dXJlUmVzcG9uc2USGwoEdXNlchgBIAEoCzINLnVzZXIudjEuVXNlciIhCh9CZWdpblBhc3NrZXlSZWdpc3RyYXRpb25SZXF1ZXN0IjgKIEJlZ2luUGFzc2tleVJlZ2lzdHJhdGlvblJlc3BvbnNlEhQKDG9wdGlvbnNfanNvbhgBIAEoCSI3CiBGaW5pc2hQYXNza2V5UmVnaXN0cmF0aW9uUmVxdWVzdBITCgthdHRlc3RhdGlvbhgBIAEoCSIjCiFGaW5pc2hQYXNza2V5UmVnaXN0cmF0aW9uUmVzcG9uc2UyuAQKC1VzZXJTZXJ2aWNlEj4KB0dldFVzZXISFy51c2VyLnYxLkdldFVzZXJSZXF1ZXN0GhgudXNlci52MS5HZXRVc2VyUmVzcG9uc2UiABJTCg5VcGRhdGVQYXNzd29yZBIeLnVzZXIudjEuVXBkYXRlUGFzc3dvcmRSZXF1ZXN0Gh8udXNlci52MS5VcGRhdGVQYXNzd29yZFJlc3BvbnNlIgASRAoJR2V0QVBJS2V5EhkudXNlci52MS5HZXRBUElLZXlSZXF1ZXN0GhoudXNlci52MS5HZXRBUElLZXlSZXNwb25zZSIAEmUKFFVwZGF0ZVByb2ZpbGVQaWN0dXJlEiQudXNlci52MS5VcGRhdGVQcm9maWxlUGljdHVyZVJlcXVlc3QaJS51c2VyLnYxLlVwZGF0ZVByb2ZpbGVQaWN0dXJlUmVzcG9uc2UiABJxChhCZWdpblBhc3NrZXlSZWdpc3RyYXRpb24SKC51c2VyLnYxLkJlZ2luUGFzc2tleVJlZ2lzdHJhdGlvblJlcXVlc3QaKS51c2VyLnYxLkJlZ2luUGFzc2tleVJlZ2lzdHJhdGlvblJlc3BvbnNlIgASdAoZRmluaXNoUGFzc2tleVJlZ2lzdHJhdGlvbhIpLnVzZXIudjEuRmluaXNoUGFzc2tleVJlZ2lzdHJhdGlvblJlcXVlc3QaKi51c2VyLnYxLkZpbmlzaFBhc3NrZXlSZWdpc3RyYXRpb25SZXNwb25zZSIAQpwBCgtjb20udXNlci52MUIJVXNlclByb3RvUAFaRWdpdGh1Yi5jb20vc3BvdGRlbW80L3RyZXZzdGFjay9zZXJ2ZXIvaW50ZXJuYWwvY29ubmVjdC91c2VyL3YxO3VzZXJ2MaICA1VYWKoCB1VzZXIuVjHKAgdVc2VyXFYx4gITVXNlclxWMVxHUEJNZXRhZGF0YeoCCFVzZXI6OlYxYgZwcm90bzM");
/**
* @generated from message user.v1.User
@@ -191,6 +191,66 @@ export type UpdateProfilePictureResponse = Message<"user.v1.UpdateProfilePicture
export const UpdateProfilePictureResponseSchema: GenMessage = /*@__PURE__*/
messageDesc(file_user_v1_user, 8);
+/**
+ * @generated from message user.v1.BeginPasskeyRegistrationRequest
+ */
+export type BeginPasskeyRegistrationRequest = Message<"user.v1.BeginPasskeyRegistrationRequest"> & {
+};
+
+/**
+ * Describes the message user.v1.BeginPasskeyRegistrationRequest.
+ * Use `create(BeginPasskeyRegistrationRequestSchema)` to create a new message.
+ */
+export const BeginPasskeyRegistrationRequestSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_user_v1_user, 9);
+
+/**
+ * @generated from message user.v1.BeginPasskeyRegistrationResponse
+ */
+export type BeginPasskeyRegistrationResponse = Message<"user.v1.BeginPasskeyRegistrationResponse"> & {
+ /**
+ * @generated from field: string options_json = 1;
+ */
+ optionsJson: string;
+};
+
+/**
+ * Describes the message user.v1.BeginPasskeyRegistrationResponse.
+ * Use `create(BeginPasskeyRegistrationResponseSchema)` to create a new message.
+ */
+export const BeginPasskeyRegistrationResponseSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_user_v1_user, 10);
+
+/**
+ * @generated from message user.v1.FinishPasskeyRegistrationRequest
+ */
+export type FinishPasskeyRegistrationRequest = Message<"user.v1.FinishPasskeyRegistrationRequest"> & {
+ /**
+ * @generated from field: string attestation = 1;
+ */
+ attestation: string;
+};
+
+/**
+ * Describes the message user.v1.FinishPasskeyRegistrationRequest.
+ * Use `create(FinishPasskeyRegistrationRequestSchema)` to create a new message.
+ */
+export const FinishPasskeyRegistrationRequestSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_user_v1_user, 11);
+
+/**
+ * @generated from message user.v1.FinishPasskeyRegistrationResponse
+ */
+export type FinishPasskeyRegistrationResponse = Message<"user.v1.FinishPasskeyRegistrationResponse"> & {
+};
+
+/**
+ * Describes the message user.v1.FinishPasskeyRegistrationResponse.
+ * Use `create(FinishPasskeyRegistrationResponseSchema)` to create a new message.
+ */
+export const FinishPasskeyRegistrationResponseSchema: GenMessage = /*@__PURE__*/
+ messageDesc(file_user_v1_user, 12);
+
/**
* @generated from service user.v1.UserService
*/
@@ -227,6 +287,22 @@ export const UserService: GenService<{
input: typeof UpdateProfilePictureRequestSchema;
output: typeof UpdateProfilePictureResponseSchema;
},
+ /**
+ * @generated from rpc user.v1.UserService.BeginPasskeyRegistration
+ */
+ beginPasskeyRegistration: {
+ methodKind: "unary";
+ input: typeof BeginPasskeyRegistrationRequestSchema;
+ output: typeof BeginPasskeyRegistrationResponseSchema;
+ },
+ /**
+ * @generated from rpc user.v1.UserService.FinishPasskeyRegistration
+ */
+ finishPasskeyRegistration: {
+ methodKind: "unary";
+ input: typeof FinishPasskeyRegistrationRequestSchema;
+ output: typeof FinishPasskeyRegistrationResponseSchema;
+ },
}> = /*@__PURE__*/
serviceDesc(file_user_v1_user, 0);
diff --git a/client/src/lib/coolforms/conststate.svelte.ts b/client/src/lib/coolforms/conststate.svelte.ts
new file mode 100644
index 0000000..3925550
--- /dev/null
+++ b/client/src/lib/coolforms/conststate.svelte.ts
@@ -0,0 +1,7 @@
+
+
+export function newState(s: T) {
+ const state = $state(s);
+
+ return state;
+}
\ No newline at end of file
diff --git a/client/src/lib/coolforms/coolforms.svelte.ts b/client/src/lib/coolforms/coolforms.svelte.ts
new file mode 100644
index 0000000..779fa3e
--- /dev/null
+++ b/client/src/lib/coolforms/coolforms.svelte.ts
@@ -0,0 +1,175 @@
+import { create, type DescMessage, type DescService, type MessageShape, type MessageInitShape } from "@bufbuild/protobuf";
+import { ValidationError, type Violation } from "@bufbuild/protovalidate";
+import { Validator } from "../transport";
+import { ConnectError, type Client } from "@connectrpc/connect";
+import type { Action } from "svelte/action";
+
+type Options = {
+ init?: MessageInitShape,
+ start?: boolean,
+ reset?: boolean,
+ onSubmit?: (formData: FormData, input: MessageShape) => Promise>,
+ onResult?: (result: MessageShape