From 1d9813eb7e5bee27fd51ea7278a1737301b9c8cb Mon Sep 17 00:00:00 2001 From: Andrew Werner Date: Wed, 23 Dec 2020 01:04:33 -0500 Subject: [PATCH] jobs,migration: introduce long running migration job This commit introduces a job to run long-running migration. This empowers long-running migrations with leases, pausability, and cancelability. Fixes #58183 Release note: None --- pkg/jobs/adopt.go | 6 +- pkg/jobs/jobspb/BUILD.bazel | 2 + pkg/jobs/jobspb/jobs.pb.go | 1334 +++++++++++------ pkg/jobs/jobspb/jobs.proto | 13 + pkg/jobs/jobspb/wrap.go | 16 +- pkg/jobs/registry.go | 2 +- pkg/migration/BUILD.bazel | 1 + pkg/migration/migration.go | 3 +- pkg/migration/migrationjob/BUILD.bazel | 15 + pkg/migration/migrationjob/migration_job.go | 52 + pkg/migration/migrationmanager/BUILD.bazel | 11 +- pkg/migration/migrationmanager/manager.go | 132 +- .../migrationmanager/manager_external_test.go | 120 ++ pkg/migration/migrations/BUILD.bazel | 5 +- pkg/migration/migrations/migrations.go | 5 +- pkg/server/BUILD.bazel | 2 + pkg/server/server_sql.go | 18 +- pkg/sql/BUILD.bazel | 1 + pkg/sql/exec_util.go | 12 +- pkg/sql/job_exec_context.go | 11 +- pkg/sql/planhook.go | 2 + pkg/sql/planner.go | 6 + pkg/sql/set_cluster_setting.go | 4 +- 23 files changed, 1296 insertions(+), 477 deletions(-) create mode 100644 pkg/migration/migrationjob/BUILD.bazel create mode 100644 pkg/migration/migrationjob/migration_job.go diff --git a/pkg/jobs/adopt.go b/pkg/jobs/adopt.go index c2fde4654f0f..c9ab35edaf9b 100644 --- a/pkg/jobs/adopt.go +++ b/pkg/jobs/adopt.go @@ -25,7 +25,9 @@ import ( "github.com/cockroachdb/errors" ) -const claimableStatusTupleString = `(` + +// NonTerminalStatusTupleString is a sql tuple corresponding to statuses of +// non-terminal jobs. +const NonTerminalStatusTupleString = `(` + `'` + string(StatusRunning) + `', ` + `'` + string(StatusPending) + `', ` + `'` + string(StatusCancelRequested) + `', ` + @@ -42,7 +44,7 @@ func (r *Registry) claimJobs(ctx context.Context, s sqlliveness.Session) error { UPDATE system.jobs SET claim_session_id = $1, claim_instance_id = $2 WHERE claim_session_id IS NULL - AND status IN `+claimableStatusTupleString+` + AND status IN `+NonTerminalStatusTupleString+` ORDER BY created DESC LIMIT $3 RETURNING id;`, diff --git a/pkg/jobs/jobspb/BUILD.bazel b/pkg/jobs/jobspb/BUILD.bazel index 99e4d9544f56..be82a240d4e7 100644 --- a/pkg/jobs/jobspb/BUILD.bazel +++ b/pkg/jobs/jobspb/BUILD.bazel @@ -24,6 +24,7 @@ proto_library( strip_import_prefix = "/pkg", visibility = ["//visibility:public"], deps = [ + "//pkg/clusterversion:clusterversion_proto", "//pkg/roachpb:roachpb_proto", "//pkg/sql/catalog/descpb:descpb_proto", "//pkg/sql/schemachanger/scpb:scpb_proto", @@ -42,6 +43,7 @@ go_proto_library( visibility = ["//visibility:public"], deps = [ "//pkg/ccl/streamingccl", # keep + "//pkg/clusterversion", "//pkg/roachpb", "//pkg/security", # keep "//pkg/sql/catalog/descpb", diff --git a/pkg/jobs/jobspb/jobs.pb.go b/pkg/jobs/jobspb/jobs.pb.go index 9c33c7f27662..2bd9ef60abbe 100644 --- a/pkg/jobs/jobspb/jobs.pb.go +++ b/pkg/jobs/jobspb/jobs.pb.go @@ -6,6 +6,7 @@ package jobspb import proto "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" +import clusterversion "github.com/cockroachdb/cockroach/pkg/clusterversion" import errorspb "github.com/cockroachdb/errors/errorspb" import roachpb "github.com/cockroachdb/cockroach/pkg/roachpb" import descpb "github.com/cockroachdb/cockroach/pkg/sql/catalog/descpb" @@ -57,7 +58,7 @@ func (x EncryptionMode) String() string { return proto.EnumName(EncryptionMode_name, int32(x)) } func (EncryptionMode) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{0} + return fileDescriptor_jobs_71126cd89273342d, []int{0} } type Status int32 @@ -86,7 +87,7 @@ func (x Status) String() string { return proto.EnumName(Status_name, int32(x)) } func (Status) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{1} + return fileDescriptor_jobs_71126cd89273342d, []int{1} } type Type int32 @@ -103,9 +104,10 @@ const ( TypeSchemaChangeGC Type = 8 // We can't name this TYPE_SCHEMA_CHANGE due to how proto generates actual // names for this enum, which cause a conflict with the SCHEMA_CHANGE entry. - TypeTypeSchemaChange Type = 9 - TypeStreamIngestion Type = 10 - TypeNewSchemaChange Type = 11 + TypeTypeSchemaChange Type = 9 + TypeStreamIngestion Type = 10 + TypeNewSchemaChange Type = 11 + TypeLongRunningMigration Type = 12 ) var Type_name = map[int32]string{ @@ -121,6 +123,7 @@ var Type_name = map[int32]string{ 9: "TYPEDESC_SCHEMA_CHANGE", 10: "STREAM_INGESTION", 11: "NEW_SCHEMA_CHANGE", + 12: "LONG_RUNNING_MIGRATION", } var Type_value = map[string]int32{ "UNSPECIFIED": 0, @@ -135,10 +138,11 @@ var Type_value = map[string]int32{ "TYPEDESC_SCHEMA_CHANGE": 9, "STREAM_INGESTION": 10, "NEW_SCHEMA_CHANGE": 11, + "LONG_RUNNING_MIGRATION": 12, } func (Type) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{2} + return fileDescriptor_jobs_71126cd89273342d, []int{2} } type EncryptionInfo_Scheme int32 @@ -158,7 +162,7 @@ func (x EncryptionInfo_Scheme) String() string { return proto.EnumName(EncryptionInfo_Scheme_name, int32(x)) } func (EncryptionInfo_Scheme) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{2, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{2, 0} } type SchemaChangeGCProgress_Status int32 @@ -188,7 +192,7 @@ func (x SchemaChangeGCProgress_Status) String() string { return proto.EnumName(SchemaChangeGCProgress_Status_name, int32(x)) } func (SchemaChangeGCProgress_Status) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{22, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{22, 0} } type Lease struct { @@ -202,7 +206,7 @@ func (m *Lease) Reset() { *m = Lease{} } func (m *Lease) String() string { return proto.CompactTextString(m) } func (*Lease) ProtoMessage() {} func (*Lease) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{0} + return fileDescriptor_jobs_71126cd89273342d, []int{0} } func (m *Lease) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -243,7 +247,7 @@ func (m *BackupEncryptionOptions) Reset() { *m = BackupEncryptionOptions func (m *BackupEncryptionOptions) String() string { return proto.CompactTextString(m) } func (*BackupEncryptionOptions) ProtoMessage() {} func (*BackupEncryptionOptions) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{1} + return fileDescriptor_jobs_71126cd89273342d, []int{1} } func (m *BackupEncryptionOptions) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -277,7 +281,7 @@ func (m *BackupEncryptionOptions_KMSInfo) Reset() { *m = BackupEncryptio func (m *BackupEncryptionOptions_KMSInfo) String() string { return proto.CompactTextString(m) } func (*BackupEncryptionOptions_KMSInfo) ProtoMessage() {} func (*BackupEncryptionOptions_KMSInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{1, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{1, 0} } func (m *BackupEncryptionOptions_KMSInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -317,7 +321,7 @@ func (m *EncryptionInfo) Reset() { *m = EncryptionInfo{} } func (m *EncryptionInfo) String() string { return proto.CompactTextString(m) } func (*EncryptionInfo) ProtoMessage() {} func (*EncryptionInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{2} + return fileDescriptor_jobs_71126cd89273342d, []int{2} } func (m *EncryptionInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -360,7 +364,7 @@ func (m *StreamIngestionDetails) Reset() { *m = StreamIngestionDetails{} func (m *StreamIngestionDetails) String() string { return proto.CompactTextString(m) } func (*StreamIngestionDetails) ProtoMessage() {} func (*StreamIngestionDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{3} + return fileDescriptor_jobs_71126cd89273342d, []int{3} } func (m *StreamIngestionDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -392,7 +396,7 @@ func (m *StreamIngestionProgress) Reset() { *m = StreamIngestionProgress func (m *StreamIngestionProgress) String() string { return proto.CompactTextString(m) } func (*StreamIngestionProgress) ProtoMessage() {} func (*StreamIngestionProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{4} + return fileDescriptor_jobs_71126cd89273342d, []int{4} } func (m *StreamIngestionProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -447,7 +451,7 @@ func (m *BackupDetails) Reset() { *m = BackupDetails{} } func (m *BackupDetails) String() string { return proto.CompactTextString(m) } func (*BackupDetails) ProtoMessage() {} func (*BackupDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{5} + return fileDescriptor_jobs_71126cd89273342d, []int{5} } func (m *BackupDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -479,7 +483,7 @@ func (m *BackupProgress) Reset() { *m = BackupProgress{} } func (m *BackupProgress) String() string { return proto.CompactTextString(m) } func (*BackupProgress) ProtoMessage() {} func (*BackupProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{6} + return fileDescriptor_jobs_71126cd89273342d, []int{6} } func (m *BackupProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -541,7 +545,7 @@ func (m *RestoreDetails) Reset() { *m = RestoreDetails{} } func (m *RestoreDetails) String() string { return proto.CompactTextString(m) } func (*RestoreDetails) ProtoMessage() {} func (*RestoreDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{7} + return fileDescriptor_jobs_71126cd89273342d, []int{7} } func (m *RestoreDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -578,7 +582,7 @@ func (m *RestoreDetails_DescriptorRewrite) Reset() { *m = RestoreDetails func (m *RestoreDetails_DescriptorRewrite) String() string { return proto.CompactTextString(m) } func (*RestoreDetails_DescriptorRewrite) ProtoMessage() {} func (*RestoreDetails_DescriptorRewrite) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{7, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{7, 0} } func (m *RestoreDetails_DescriptorRewrite) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -611,7 +615,7 @@ func (m *RestoreDetails_BackupLocalityInfo) Reset() { *m = RestoreDetail func (m *RestoreDetails_BackupLocalityInfo) String() string { return proto.CompactTextString(m) } func (*RestoreDetails_BackupLocalityInfo) ProtoMessage() {} func (*RestoreDetails_BackupLocalityInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{7, 1} + return fileDescriptor_jobs_71126cd89273342d, []int{7, 1} } func (m *RestoreDetails_BackupLocalityInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -644,7 +648,7 @@ func (m *RestoreProgress) Reset() { *m = RestoreProgress{} } func (m *RestoreProgress) String() string { return proto.CompactTextString(m) } func (*RestoreProgress) ProtoMessage() {} func (*RestoreProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{8} + return fileDescriptor_jobs_71126cd89273342d, []int{8} } func (m *RestoreProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -705,7 +709,7 @@ func (m *ImportDetails) Reset() { *m = ImportDetails{} } func (m *ImportDetails) String() string { return proto.CompactTextString(m) } func (*ImportDetails) ProtoMessage() {} func (*ImportDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{9} + return fileDescriptor_jobs_71126cd89273342d, []int{9} } func (m *ImportDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -743,7 +747,7 @@ func (m *ImportDetails_Table) Reset() { *m = ImportDetails_Table{} } func (m *ImportDetails_Table) String() string { return proto.CompactTextString(m) } func (*ImportDetails_Table) ProtoMessage() {} func (*ImportDetails_Table) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{9, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{9, 0} } func (m *ImportDetails_Table) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -785,7 +789,7 @@ func (m *SequenceValChunk) Reset() { *m = SequenceValChunk{} } func (m *SequenceValChunk) String() string { return proto.CompactTextString(m) } func (*SequenceValChunk) ProtoMessage() {} func (*SequenceValChunk) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{10} + return fileDescriptor_jobs_71126cd89273342d, []int{10} } func (m *SequenceValChunk) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -821,7 +825,7 @@ func (m *SequenceDetails) Reset() { *m = SequenceDetails{} } func (m *SequenceDetails) String() string { return proto.CompactTextString(m) } func (*SequenceDetails) ProtoMessage() {} func (*SequenceDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{11} + return fileDescriptor_jobs_71126cd89273342d, []int{11} } func (m *SequenceDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -856,7 +860,7 @@ func (m *SequenceDetails_SequenceChunks) Reset() { *m = SequenceDetails_ func (m *SequenceDetails_SequenceChunks) String() string { return proto.CompactTextString(m) } func (*SequenceDetails_SequenceChunks) ProtoMessage() {} func (*SequenceDetails_SequenceChunks) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{11, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{11, 0} } func (m *SequenceDetails_SequenceChunks) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -902,7 +906,7 @@ func (m *ImportProgress) Reset() { *m = ImportProgress{} } func (m *ImportProgress) String() string { return proto.CompactTextString(m) } func (*ImportProgress) ProtoMessage() {} func (*ImportProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{12} + return fileDescriptor_jobs_71126cd89273342d, []int{12} } func (m *ImportProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -936,7 +940,7 @@ func (m *TypeSchemaChangeDetails) Reset() { *m = TypeSchemaChangeDetails func (m *TypeSchemaChangeDetails) String() string { return proto.CompactTextString(m) } func (*TypeSchemaChangeDetails) ProtoMessage() {} func (*TypeSchemaChangeDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{13} + return fileDescriptor_jobs_71126cd89273342d, []int{13} } func (m *TypeSchemaChangeDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -969,7 +973,7 @@ func (m *TypeSchemaChangeProgress) Reset() { *m = TypeSchemaChangeProgre func (m *TypeSchemaChangeProgress) String() string { return proto.CompactTextString(m) } func (*TypeSchemaChangeProgress) ProtoMessage() {} func (*TypeSchemaChangeProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{14} + return fileDescriptor_jobs_71126cd89273342d, []int{14} } func (m *TypeSchemaChangeProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1003,7 +1007,7 @@ func (m *NewSchemaChangeDetails) Reset() { *m = NewSchemaChangeDetails{} func (m *NewSchemaChangeDetails) String() string { return proto.CompactTextString(m) } func (*NewSchemaChangeDetails) ProtoMessage() {} func (*NewSchemaChangeDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{15} + return fileDescriptor_jobs_71126cd89273342d, []int{15} } func (m *NewSchemaChangeDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1037,7 +1041,7 @@ func (m *NewSchemaChangeProgress) Reset() { *m = NewSchemaChangeProgress func (m *NewSchemaChangeProgress) String() string { return proto.CompactTextString(m) } func (*NewSchemaChangeProgress) ProtoMessage() {} func (*NewSchemaChangeProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{16} + return fileDescriptor_jobs_71126cd89273342d, []int{16} } func (m *NewSchemaChangeProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1070,7 +1074,7 @@ func (m *ResumeSpanList) Reset() { *m = ResumeSpanList{} } func (m *ResumeSpanList) String() string { return proto.CompactTextString(m) } func (*ResumeSpanList) ProtoMessage() {} func (*ResumeSpanList) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{17} + return fileDescriptor_jobs_71126cd89273342d, []int{17} } func (m *ResumeSpanList) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1105,7 +1109,7 @@ func (m *DroppedTableDetails) Reset() { *m = DroppedTableDetails{} } func (m *DroppedTableDetails) String() string { return proto.CompactTextString(m) } func (*DroppedTableDetails) ProtoMessage() {} func (*DroppedTableDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{18} + return fileDescriptor_jobs_71126cd89273342d, []int{18} } func (m *DroppedTableDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1168,7 +1172,7 @@ func (m *SchemaChangeGCDetails) Reset() { *m = SchemaChangeGCDetails{} } func (m *SchemaChangeGCDetails) String() string { return proto.CompactTextString(m) } func (*SchemaChangeGCDetails) ProtoMessage() {} func (*SchemaChangeGCDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{19} + return fileDescriptor_jobs_71126cd89273342d, []int{19} } func (m *SchemaChangeGCDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1202,7 +1206,7 @@ func (m *SchemaChangeGCDetails_DroppedIndex) Reset() { *m = SchemaChange func (m *SchemaChangeGCDetails_DroppedIndex) String() string { return proto.CompactTextString(m) } func (*SchemaChangeGCDetails_DroppedIndex) ProtoMessage() {} func (*SchemaChangeGCDetails_DroppedIndex) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{19, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{19, 0} } func (m *SchemaChangeGCDetails_DroppedIndex) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1236,7 +1240,7 @@ func (m *SchemaChangeGCDetails_DroppedID) Reset() { *m = SchemaChangeGCD func (m *SchemaChangeGCDetails_DroppedID) String() string { return proto.CompactTextString(m) } func (*SchemaChangeGCDetails_DroppedID) ProtoMessage() {} func (*SchemaChangeGCDetails_DroppedID) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{19, 1} + return fileDescriptor_jobs_71126cd89273342d, []int{19, 1} } func (m *SchemaChangeGCDetails_DroppedID) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1270,7 +1274,7 @@ func (m *SchemaChangeGCDetails_DroppedTenant) Reset() { *m = SchemaChang func (m *SchemaChangeGCDetails_DroppedTenant) String() string { return proto.CompactTextString(m) } func (*SchemaChangeGCDetails_DroppedTenant) ProtoMessage() {} func (*SchemaChangeGCDetails_DroppedTenant) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{19, 2} + return fileDescriptor_jobs_71126cd89273342d, []int{19, 2} } func (m *SchemaChangeGCDetails_DroppedTenant) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1334,7 +1338,7 @@ func (m *SchemaChangeDetails) Reset() { *m = SchemaChangeDetails{} } func (m *SchemaChangeDetails) String() string { return proto.CompactTextString(m) } func (*SchemaChangeDetails) ProtoMessage() {} func (*SchemaChangeDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{20} + return fileDescriptor_jobs_71126cd89273342d, []int{20} } func (m *SchemaChangeDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1366,7 +1370,7 @@ func (m *SchemaChangeProgress) Reset() { *m = SchemaChangeProgress{} } func (m *SchemaChangeProgress) String() string { return proto.CompactTextString(m) } func (*SchemaChangeProgress) ProtoMessage() {} func (*SchemaChangeProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{21} + return fileDescriptor_jobs_71126cd89273342d, []int{21} } func (m *SchemaChangeProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1404,7 +1408,7 @@ func (m *SchemaChangeGCProgress) Reset() { *m = SchemaChangeGCProgress{} func (m *SchemaChangeGCProgress) String() string { return proto.CompactTextString(m) } func (*SchemaChangeGCProgress) ProtoMessage() {} func (*SchemaChangeGCProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{22} + return fileDescriptor_jobs_71126cd89273342d, []int{22} } func (m *SchemaChangeGCProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1438,7 +1442,7 @@ func (m *SchemaChangeGCProgress_IndexProgress) Reset() { *m = SchemaChan func (m *SchemaChangeGCProgress_IndexProgress) String() string { return proto.CompactTextString(m) } func (*SchemaChangeGCProgress_IndexProgress) ProtoMessage() {} func (*SchemaChangeGCProgress_IndexProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{22, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{22, 0} } func (m *SchemaChangeGCProgress_IndexProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1472,7 +1476,7 @@ func (m *SchemaChangeGCProgress_TableProgress) Reset() { *m = SchemaChan func (m *SchemaChangeGCProgress_TableProgress) String() string { return proto.CompactTextString(m) } func (*SchemaChangeGCProgress_TableProgress) ProtoMessage() {} func (*SchemaChangeGCProgress_TableProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{22, 1} + return fileDescriptor_jobs_71126cd89273342d, []int{22, 1} } func (m *SchemaChangeGCProgress_TableProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1505,7 +1509,7 @@ func (m *SchemaChangeGCProgress_TenantProgress) Reset() { *m = SchemaCha func (m *SchemaChangeGCProgress_TenantProgress) String() string { return proto.CompactTextString(m) } func (*SchemaChangeGCProgress_TenantProgress) ProtoMessage() {} func (*SchemaChangeGCProgress_TenantProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{22, 2} + return fileDescriptor_jobs_71126cd89273342d, []int{22, 2} } func (m *SchemaChangeGCProgress_TenantProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1538,7 +1542,7 @@ func (m *ChangefeedTarget) Reset() { *m = ChangefeedTarget{} } func (m *ChangefeedTarget) String() string { return proto.CompactTextString(m) } func (*ChangefeedTarget) ProtoMessage() {} func (*ChangefeedTarget) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{23} + return fileDescriptor_jobs_71126cd89273342d, []int{23} } func (m *ChangefeedTarget) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1591,7 +1595,7 @@ func (m *ChangefeedDetails) Reset() { *m = ChangefeedDetails{} } func (m *ChangefeedDetails) String() string { return proto.CompactTextString(m) } func (*ChangefeedDetails) ProtoMessage() {} func (*ChangefeedDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{24} + return fileDescriptor_jobs_71126cd89273342d, []int{24} } func (m *ChangefeedDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1626,7 +1630,7 @@ func (m *ResolvedSpan) Reset() { *m = ResolvedSpan{} } func (m *ResolvedSpan) String() string { return proto.CompactTextString(m) } func (*ResolvedSpan) ProtoMessage() {} func (*ResolvedSpan) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{25} + return fileDescriptor_jobs_71126cd89273342d, []int{25} } func (m *ResolvedSpan) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1669,7 +1673,7 @@ func (m *ChangefeedProgress) Reset() { *m = ChangefeedProgress{} } func (m *ChangefeedProgress) String() string { return proto.CompactTextString(m) } func (*ChangefeedProgress) ProtoMessage() {} func (*ChangefeedProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{26} + return fileDescriptor_jobs_71126cd89273342d, []int{26} } func (m *ChangefeedProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1713,7 +1717,7 @@ func (m *CreateStatsDetails) Reset() { *m = CreateStatsDetails{} } func (m *CreateStatsDetails) String() string { return proto.CompactTextString(m) } func (*CreateStatsDetails) ProtoMessage() {} func (*CreateStatsDetails) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{27} + return fileDescriptor_jobs_71126cd89273342d, []int{27} } func (m *CreateStatsDetails) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1754,7 +1758,7 @@ func (m *CreateStatsDetails_ColStat) Reset() { *m = CreateStatsDetails_C func (m *CreateStatsDetails_ColStat) String() string { return proto.CompactTextString(m) } func (*CreateStatsDetails_ColStat) ProtoMessage() {} func (*CreateStatsDetails_ColStat) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{27, 0} + return fileDescriptor_jobs_71126cd89273342d, []int{27, 0} } func (m *CreateStatsDetails_ColStat) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1786,7 +1790,7 @@ func (m *CreateStatsProgress) Reset() { *m = CreateStatsProgress{} } func (m *CreateStatsProgress) String() string { return proto.CompactTextString(m) } func (*CreateStatsProgress) ProtoMessage() {} func (*CreateStatsProgress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{28} + return fileDescriptor_jobs_71126cd89273342d, []int{28} } func (m *CreateStatsProgress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1811,6 +1815,71 @@ func (m *CreateStatsProgress) XXX_DiscardUnknown() { var xxx_messageInfo_CreateStatsProgress proto.InternalMessageInfo +type LongRunningMigrationDetails struct { + ClusterVersion *clusterversion.ClusterVersion `protobuf:"bytes,1,opt,name=cluster_version,json=clusterVersion,proto3" json:"cluster_version,omitempty"` +} + +func (m *LongRunningMigrationDetails) Reset() { *m = LongRunningMigrationDetails{} } +func (m *LongRunningMigrationDetails) String() string { return proto.CompactTextString(m) } +func (*LongRunningMigrationDetails) ProtoMessage() {} +func (*LongRunningMigrationDetails) Descriptor() ([]byte, []int) { + return fileDescriptor_jobs_71126cd89273342d, []int{29} +} +func (m *LongRunningMigrationDetails) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *LongRunningMigrationDetails) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalTo(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (dst *LongRunningMigrationDetails) XXX_Merge(src proto.Message) { + xxx_messageInfo_LongRunningMigrationDetails.Merge(dst, src) +} +func (m *LongRunningMigrationDetails) XXX_Size() int { + return m.Size() +} +func (m *LongRunningMigrationDetails) XXX_DiscardUnknown() { + xxx_messageInfo_LongRunningMigrationDetails.DiscardUnknown(m) +} + +var xxx_messageInfo_LongRunningMigrationDetails proto.InternalMessageInfo + +type LongRunningMigrationProgress struct { +} + +func (m *LongRunningMigrationProgress) Reset() { *m = LongRunningMigrationProgress{} } +func (m *LongRunningMigrationProgress) String() string { return proto.CompactTextString(m) } +func (*LongRunningMigrationProgress) ProtoMessage() {} +func (*LongRunningMigrationProgress) Descriptor() ([]byte, []int) { + return fileDescriptor_jobs_71126cd89273342d, []int{30} +} +func (m *LongRunningMigrationProgress) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *LongRunningMigrationProgress) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalTo(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (dst *LongRunningMigrationProgress) XXX_Merge(src proto.Message) { + xxx_messageInfo_LongRunningMigrationProgress.Merge(dst, src) +} +func (m *LongRunningMigrationProgress) XXX_Size() int { + return m.Size() +} +func (m *LongRunningMigrationProgress) XXX_DiscardUnknown() { + xxx_messageInfo_LongRunningMigrationProgress.DiscardUnknown(m) +} + +var xxx_messageInfo_LongRunningMigrationProgress proto.InternalMessageInfo + type Payload struct { Description string `protobuf:"bytes,1,opt,name=description,proto3" json:"description,omitempty"` // If empty, the description is assumed to be the statement. @@ -1848,6 +1917,7 @@ type Payload struct { // *Payload_TypeSchemaChange // *Payload_StreamIngestion // *Payload_NewSchemaChange + // *Payload_LongRunningMigration Details isPayload_Details `protobuf_oneof:"details"` } @@ -1855,7 +1925,7 @@ func (m *Payload) Reset() { *m = Payload{} } func (m *Payload) String() string { return proto.CompactTextString(m) } func (*Payload) ProtoMessage() {} func (*Payload) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{29} + return fileDescriptor_jobs_71126cd89273342d, []int{31} } func (m *Payload) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1916,17 +1986,21 @@ type Payload_StreamIngestion struct { type Payload_NewSchemaChange struct { NewSchemaChange *NewSchemaChangeDetails `protobuf:"bytes,24,opt,name=newSchemaChange,proto3,oneof"` } +type Payload_LongRunningMigration struct { + LongRunningMigration *LongRunningMigrationDetails `protobuf:"bytes,25,opt,name=longRunningMigration,proto3,oneof"` +} -func (*Payload_Backup) isPayload_Details() {} -func (*Payload_Restore) isPayload_Details() {} -func (*Payload_SchemaChange) isPayload_Details() {} -func (*Payload_Import) isPayload_Details() {} -func (*Payload_Changefeed) isPayload_Details() {} -func (*Payload_CreateStats) isPayload_Details() {} -func (*Payload_SchemaChangeGC) isPayload_Details() {} -func (*Payload_TypeSchemaChange) isPayload_Details() {} -func (*Payload_StreamIngestion) isPayload_Details() {} -func (*Payload_NewSchemaChange) isPayload_Details() {} +func (*Payload_Backup) isPayload_Details() {} +func (*Payload_Restore) isPayload_Details() {} +func (*Payload_SchemaChange) isPayload_Details() {} +func (*Payload_Import) isPayload_Details() {} +func (*Payload_Changefeed) isPayload_Details() {} +func (*Payload_CreateStats) isPayload_Details() {} +func (*Payload_SchemaChangeGC) isPayload_Details() {} +func (*Payload_TypeSchemaChange) isPayload_Details() {} +func (*Payload_StreamIngestion) isPayload_Details() {} +func (*Payload_NewSchemaChange) isPayload_Details() {} +func (*Payload_LongRunningMigration) isPayload_Details() {} func (m *Payload) GetDetails() isPayload_Details { if m != nil { @@ -2005,6 +2079,13 @@ func (m *Payload) GetNewSchemaChange() *NewSchemaChangeDetails { return nil } +func (m *Payload) GetLongRunningMigration() *LongRunningMigrationDetails { + if x, ok := m.GetDetails().(*Payload_LongRunningMigration); ok { + return x.LongRunningMigration + } + return nil +} + // XXX_OneofFuncs is for the internal use of the proto package. func (*Payload) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { return _Payload_OneofMarshaler, _Payload_OneofUnmarshaler, _Payload_OneofSizer, []interface{}{ @@ -2018,6 +2099,7 @@ func (*Payload) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error (*Payload_TypeSchemaChange)(nil), (*Payload_StreamIngestion)(nil), (*Payload_NewSchemaChange)(nil), + (*Payload_LongRunningMigration)(nil), } } @@ -2075,6 +2157,11 @@ func _Payload_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { if err := b.EncodeMessage(x.NewSchemaChange); err != nil { return err } + case *Payload_LongRunningMigration: + _ = b.EncodeVarint(25<<3 | proto.WireBytes) + if err := b.EncodeMessage(x.LongRunningMigration); err != nil { + return err + } case nil: default: return fmt.Errorf("Payload.Details has unexpected type %T", x) @@ -2165,6 +2252,14 @@ func _Payload_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffer err := b.DecodeMessage(msg) m.Details = &Payload_NewSchemaChange{msg} return true, err + case 25: // details.longRunningMigration + if wire != proto.WireBytes { + return true, proto.ErrInternalBadWireType + } + msg := new(LongRunningMigrationDetails) + err := b.DecodeMessage(msg) + m.Details = &Payload_LongRunningMigration{msg} + return true, err default: return false, nil } @@ -2224,6 +2319,11 @@ func _Payload_OneofSizer(msg proto.Message) (n int) { n += 2 // tag and wire n += proto.SizeVarint(uint64(s)) n += s + case *Payload_LongRunningMigration: + s := proto.Size(x.LongRunningMigration) + n += 2 // tag and wire + n += proto.SizeVarint(uint64(s)) + n += s case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) @@ -2249,6 +2349,7 @@ type Progress struct { // *Progress_TypeSchemaChange // *Progress_StreamIngest // *Progress_NewSchemaChange + // *Progress_LongRunningMigration Details isProgress_Details `protobuf_oneof:"details"` } @@ -2256,7 +2357,7 @@ func (m *Progress) Reset() { *m = Progress{} } func (m *Progress) String() string { return proto.CompactTextString(m) } func (*Progress) ProtoMessage() {} func (*Progress) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{30} + return fileDescriptor_jobs_71126cd89273342d, []int{32} } func (m *Progress) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2328,19 +2429,23 @@ type Progress_StreamIngest struct { type Progress_NewSchemaChange struct { NewSchemaChange *NewSchemaChangeProgress `protobuf:"bytes,19,opt,name=newSchemaChange,proto3,oneof"` } +type Progress_LongRunningMigration struct { + LongRunningMigration *LongRunningMigrationProgress `protobuf:"bytes,20,opt,name=longRunningMigration,proto3,oneof"` +} -func (*Progress_FractionCompleted) isProgress_Progress() {} -func (*Progress_HighWater) isProgress_Progress() {} -func (*Progress_Backup) isProgress_Details() {} -func (*Progress_Restore) isProgress_Details() {} -func (*Progress_SchemaChange) isProgress_Details() {} -func (*Progress_Import) isProgress_Details() {} -func (*Progress_Changefeed) isProgress_Details() {} -func (*Progress_CreateStats) isProgress_Details() {} -func (*Progress_SchemaChangeGC) isProgress_Details() {} -func (*Progress_TypeSchemaChange) isProgress_Details() {} -func (*Progress_StreamIngest) isProgress_Details() {} -func (*Progress_NewSchemaChange) isProgress_Details() {} +func (*Progress_FractionCompleted) isProgress_Progress() {} +func (*Progress_HighWater) isProgress_Progress() {} +func (*Progress_Backup) isProgress_Details() {} +func (*Progress_Restore) isProgress_Details() {} +func (*Progress_SchemaChange) isProgress_Details() {} +func (*Progress_Import) isProgress_Details() {} +func (*Progress_Changefeed) isProgress_Details() {} +func (*Progress_CreateStats) isProgress_Details() {} +func (*Progress_SchemaChangeGC) isProgress_Details() {} +func (*Progress_TypeSchemaChange) isProgress_Details() {} +func (*Progress_StreamIngest) isProgress_Details() {} +func (*Progress_NewSchemaChange) isProgress_Details() {} +func (*Progress_LongRunningMigration) isProgress_Details() {} func (m *Progress) GetProgress() isProgress_Progress { if m != nil { @@ -2439,6 +2544,13 @@ func (m *Progress) GetNewSchemaChange() *NewSchemaChangeProgress { return nil } +func (m *Progress) GetLongRunningMigration() *LongRunningMigrationProgress { + if x, ok := m.GetDetails().(*Progress_LongRunningMigration); ok { + return x.LongRunningMigration + } + return nil +} + // XXX_OneofFuncs is for the internal use of the proto package. func (*Progress) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{}) { return _Progress_OneofMarshaler, _Progress_OneofUnmarshaler, _Progress_OneofSizer, []interface{}{ @@ -2454,6 +2566,7 @@ func (*Progress) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) erro (*Progress_TypeSchemaChange)(nil), (*Progress_StreamIngest)(nil), (*Progress_NewSchemaChange)(nil), + (*Progress_LongRunningMigration)(nil), } } @@ -2525,6 +2638,11 @@ func _Progress_OneofMarshaler(msg proto.Message, b *proto.Buffer) error { if err := b.EncodeMessage(x.NewSchemaChange); err != nil { return err } + case *Progress_LongRunningMigration: + _ = b.EncodeVarint(20<<3 | proto.WireBytes) + if err := b.EncodeMessage(x.LongRunningMigration); err != nil { + return err + } case nil: default: return fmt.Errorf("Progress.Details has unexpected type %T", x) @@ -2630,6 +2748,14 @@ func _Progress_OneofUnmarshaler(msg proto.Message, tag, wire int, b *proto.Buffe err := b.DecodeMessage(msg) m.Details = &Progress_NewSchemaChange{msg} return true, err + case 20: // details.longRunningMigration + if wire != proto.WireBytes { + return true, proto.ErrInternalBadWireType + } + msg := new(LongRunningMigrationProgress) + err := b.DecodeMessage(msg) + m.Details = &Progress_LongRunningMigration{msg} + return true, err default: return false, nil } @@ -2703,6 +2829,11 @@ func _Progress_OneofSizer(msg proto.Message) (n int) { n += 2 // tag and wire n += proto.SizeVarint(uint64(s)) n += s + case *Progress_LongRunningMigration: + s := proto.Size(x.LongRunningMigration) + n += 2 // tag and wire + n += proto.SizeVarint(uint64(s)) + n += s case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) @@ -2722,7 +2853,7 @@ func (m *Job) Reset() { *m = Job{} } func (m *Job) String() string { return proto.CompactTextString(m) } func (*Job) ProtoMessage() {} func (*Job) Descriptor() ([]byte, []int) { - return fileDescriptor_jobs_8f6d1b2aa13f3feb, []int{31} + return fileDescriptor_jobs_71126cd89273342d, []int{33} } func (m *Job) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2796,6 +2927,8 @@ func init() { proto.RegisterType((*CreateStatsDetails)(nil), "cockroach.sql.jobs.jobspb.CreateStatsDetails") proto.RegisterType((*CreateStatsDetails_ColStat)(nil), "cockroach.sql.jobs.jobspb.CreateStatsDetails.ColStat") proto.RegisterType((*CreateStatsProgress)(nil), "cockroach.sql.jobs.jobspb.CreateStatsProgress") + proto.RegisterType((*LongRunningMigrationDetails)(nil), "cockroach.sql.jobs.jobspb.LongRunningMigrationDetails") + proto.RegisterType((*LongRunningMigrationProgress)(nil), "cockroach.sql.jobs.jobspb.LongRunningMigrationProgress") proto.RegisterType((*Payload)(nil), "cockroach.sql.jobs.jobspb.Payload") proto.RegisterType((*Progress)(nil), "cockroach.sql.jobs.jobspb.Progress") proto.RegisterType((*Job)(nil), "cockroach.sql.jobs.jobspb.Job") @@ -4917,6 +5050,52 @@ func (m *CreateStatsProgress) MarshalTo(dAtA []byte) (int, error) { return i, nil } +func (m *LongRunningMigrationDetails) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalTo(dAtA) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *LongRunningMigrationDetails) MarshalTo(dAtA []byte) (int, error) { + var i int + _ = i + var l int + _ = l + if m.ClusterVersion != nil { + dAtA[i] = 0xa + i++ + i = encodeVarintJobs(dAtA, i, uint64(m.ClusterVersion.Size())) + n39, err := m.ClusterVersion.MarshalTo(dAtA[i:]) + if err != nil { + return 0, err + } + i += n39 + } + return i, nil +} + +func (m *LongRunningMigrationProgress) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalTo(dAtA) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *LongRunningMigrationProgress) MarshalTo(dAtA []byte) (int, error) { + var i int + _ = i + var l int + _ = l + return i, nil +} + func (m *Payload) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -4955,21 +5134,21 @@ func (m *Payload) MarshalTo(dAtA []byte) (int, error) { i = encodeVarintJobs(dAtA, i, uint64(m.FinishedMicros)) } if len(m.DescriptorIDs) > 0 { - dAtA40 := make([]byte, len(m.DescriptorIDs)*10) - var j39 int + dAtA41 := make([]byte, len(m.DescriptorIDs)*10) + var j40 int for _, num := range m.DescriptorIDs { for num >= 1<<7 { - dAtA40[j39] = uint8(uint64(num)&0x7f | 0x80) + dAtA41[j40] = uint8(uint64(num)&0x7f | 0x80) num >>= 7 - j39++ + j40++ } - dAtA40[j39] = uint8(num) - j39++ + dAtA41[j40] = uint8(num) + j40++ } dAtA[i] = 0x32 i++ - i = encodeVarintJobs(dAtA, i, uint64(j39)) - i += copy(dAtA[i:], dAtA40[:j39]) + i = encodeVarintJobs(dAtA, i, uint64(j40)) + i += copy(dAtA[i:], dAtA41[:j40]) } if len(m.Error) > 0 { dAtA[i] = 0x42 @@ -4981,18 +5160,18 @@ func (m *Payload) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x4a i++ i = encodeVarintJobs(dAtA, i, uint64(m.Lease.Size())) - n41, err := m.Lease.MarshalTo(dAtA[i:]) + n42, err := m.Lease.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n41 + i += n42 } if m.Details != nil { - nn42, err := m.Details.MarshalTo(dAtA[i:]) + nn43, err := m.Details.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += nn42 + i += nn43 } if len(m.Statement) > 0 { dAtA[i] = 0x82 @@ -5036,11 +5215,11 @@ func (m *Payload) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.FinalResumeError.Size())) - n43, err := m.FinalResumeError.MarshalTo(dAtA[i:]) + n44, err := m.FinalResumeError.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n43 + i += n44 } if m.Noncancelable { dAtA[i] = 0xa0 @@ -5063,11 +5242,11 @@ func (m *Payload_Backup) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x52 i++ i = encodeVarintJobs(dAtA, i, uint64(m.Backup.Size())) - n44, err := m.Backup.MarshalTo(dAtA[i:]) + n45, err := m.Backup.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n44 + i += n45 } return i, nil } @@ -5077,11 +5256,11 @@ func (m *Payload_Restore) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x5a i++ i = encodeVarintJobs(dAtA, i, uint64(m.Restore.Size())) - n45, err := m.Restore.MarshalTo(dAtA[i:]) + n46, err := m.Restore.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n45 + i += n46 } return i, nil } @@ -5091,11 +5270,11 @@ func (m *Payload_SchemaChange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x62 i++ i = encodeVarintJobs(dAtA, i, uint64(m.SchemaChange.Size())) - n46, err := m.SchemaChange.MarshalTo(dAtA[i:]) + n47, err := m.SchemaChange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n46 + i += n47 } return i, nil } @@ -5105,11 +5284,11 @@ func (m *Payload_Import) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x6a i++ i = encodeVarintJobs(dAtA, i, uint64(m.Import.Size())) - n47, err := m.Import.MarshalTo(dAtA[i:]) + n48, err := m.Import.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n47 + i += n48 } return i, nil } @@ -5119,11 +5298,11 @@ func (m *Payload_Changefeed) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x72 i++ i = encodeVarintJobs(dAtA, i, uint64(m.Changefeed.Size())) - n48, err := m.Changefeed.MarshalTo(dAtA[i:]) + n49, err := m.Changefeed.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n48 + i += n49 } return i, nil } @@ -5133,11 +5312,11 @@ func (m *Payload_CreateStats) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x7a i++ i = encodeVarintJobs(dAtA, i, uint64(m.CreateStats.Size())) - n49, err := m.CreateStats.MarshalTo(dAtA[i:]) + n50, err := m.CreateStats.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n49 + i += n50 } return i, nil } @@ -5149,11 +5328,11 @@ func (m *Payload_SchemaChangeGC) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.SchemaChangeGC.Size())) - n50, err := m.SchemaChangeGC.MarshalTo(dAtA[i:]) + n51, err := m.SchemaChangeGC.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n50 + i += n51 } return i, nil } @@ -5165,11 +5344,11 @@ func (m *Payload_TypeSchemaChange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.TypeSchemaChange.Size())) - n51, err := m.TypeSchemaChange.MarshalTo(dAtA[i:]) + n52, err := m.TypeSchemaChange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n51 + i += n52 } return i, nil } @@ -5181,11 +5360,11 @@ func (m *Payload_StreamIngestion) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.StreamIngestion.Size())) - n52, err := m.StreamIngestion.MarshalTo(dAtA[i:]) + n53, err := m.StreamIngestion.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n52 + i += n53 } return i, nil } @@ -5197,11 +5376,27 @@ func (m *Payload_NewSchemaChange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.NewSchemaChange.Size())) - n53, err := m.NewSchemaChange.MarshalTo(dAtA[i:]) + n54, err := m.NewSchemaChange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n53 + i += n54 + } + return i, nil +} +func (m *Payload_LongRunningMigration) MarshalTo(dAtA []byte) (int, error) { + i := 0 + if m.LongRunningMigration != nil { + dAtA[i] = 0xca + i++ + dAtA[i] = 0x1 + i++ + i = encodeVarintJobs(dAtA, i, uint64(m.LongRunningMigration.Size())) + n55, err := m.LongRunningMigration.MarshalTo(dAtA[i:]) + if err != nil { + return 0, err + } + i += n55 } return i, nil } @@ -5221,11 +5416,11 @@ func (m *Progress) MarshalTo(dAtA []byte) (int, error) { var l int _ = l if m.Progress != nil { - nn54, err := m.Progress.MarshalTo(dAtA[i:]) + nn56, err := m.Progress.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += nn54 + i += nn56 } if m.ModifiedMicros != 0 { dAtA[i] = 0x10 @@ -5239,11 +5434,11 @@ func (m *Progress) MarshalTo(dAtA []byte) (int, error) { i += copy(dAtA[i:], m.RunningStatus) } if m.Details != nil { - nn55, err := m.Details.MarshalTo(dAtA[i:]) + nn57, err := m.Details.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += nn55 + i += nn57 } return i, nil } @@ -5262,11 +5457,11 @@ func (m *Progress_HighWater) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1a i++ i = encodeVarintJobs(dAtA, i, uint64(m.HighWater.Size())) - n56, err := m.HighWater.MarshalTo(dAtA[i:]) + n58, err := m.HighWater.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n56 + i += n58 } return i, nil } @@ -5276,11 +5471,11 @@ func (m *Progress_Backup) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x52 i++ i = encodeVarintJobs(dAtA, i, uint64(m.Backup.Size())) - n57, err := m.Backup.MarshalTo(dAtA[i:]) + n59, err := m.Backup.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n57 + i += n59 } return i, nil } @@ -5290,11 +5485,11 @@ func (m *Progress_Restore) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x5a i++ i = encodeVarintJobs(dAtA, i, uint64(m.Restore.Size())) - n58, err := m.Restore.MarshalTo(dAtA[i:]) + n60, err := m.Restore.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n58 + i += n60 } return i, nil } @@ -5304,11 +5499,11 @@ func (m *Progress_SchemaChange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x62 i++ i = encodeVarintJobs(dAtA, i, uint64(m.SchemaChange.Size())) - n59, err := m.SchemaChange.MarshalTo(dAtA[i:]) + n61, err := m.SchemaChange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n59 + i += n61 } return i, nil } @@ -5318,11 +5513,11 @@ func (m *Progress_Import) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x6a i++ i = encodeVarintJobs(dAtA, i, uint64(m.Import.Size())) - n60, err := m.Import.MarshalTo(dAtA[i:]) + n62, err := m.Import.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n60 + i += n62 } return i, nil } @@ -5332,11 +5527,11 @@ func (m *Progress_Changefeed) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x72 i++ i = encodeVarintJobs(dAtA, i, uint64(m.Changefeed.Size())) - n61, err := m.Changefeed.MarshalTo(dAtA[i:]) + n63, err := m.Changefeed.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n61 + i += n63 } return i, nil } @@ -5346,11 +5541,11 @@ func (m *Progress_CreateStats) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x7a i++ i = encodeVarintJobs(dAtA, i, uint64(m.CreateStats.Size())) - n62, err := m.CreateStats.MarshalTo(dAtA[i:]) + n64, err := m.CreateStats.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n62 + i += n64 } return i, nil } @@ -5362,11 +5557,11 @@ func (m *Progress_SchemaChangeGC) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.SchemaChangeGC.Size())) - n63, err := m.SchemaChangeGC.MarshalTo(dAtA[i:]) + n65, err := m.SchemaChangeGC.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n63 + i += n65 } return i, nil } @@ -5378,11 +5573,11 @@ func (m *Progress_TypeSchemaChange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.TypeSchemaChange.Size())) - n64, err := m.TypeSchemaChange.MarshalTo(dAtA[i:]) + n66, err := m.TypeSchemaChange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n64 + i += n66 } return i, nil } @@ -5394,11 +5589,11 @@ func (m *Progress_StreamIngest) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.StreamIngest.Size())) - n65, err := m.StreamIngest.MarshalTo(dAtA[i:]) + n67, err := m.StreamIngest.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n65 + i += n67 } return i, nil } @@ -5410,11 +5605,27 @@ func (m *Progress_NewSchemaChange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintJobs(dAtA, i, uint64(m.NewSchemaChange.Size())) - n66, err := m.NewSchemaChange.MarshalTo(dAtA[i:]) + n68, err := m.NewSchemaChange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n66 + i += n68 + } + return i, nil +} +func (m *Progress_LongRunningMigration) MarshalTo(dAtA []byte) (int, error) { + i := 0 + if m.LongRunningMigration != nil { + dAtA[i] = 0xa2 + i++ + dAtA[i] = 0x1 + i++ + i = encodeVarintJobs(dAtA, i, uint64(m.LongRunningMigration.Size())) + n69, err := m.LongRunningMigration.MarshalTo(dAtA[i:]) + if err != nil { + return 0, err + } + i += n69 } return i, nil } @@ -5442,21 +5653,21 @@ func (m *Job) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x12 i++ i = encodeVarintJobs(dAtA, i, uint64(m.Progress.Size())) - n67, err := m.Progress.MarshalTo(dAtA[i:]) + n70, err := m.Progress.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n67 + i += n70 } if m.Payload != nil { dAtA[i] = 0x1a i++ i = encodeVarintJobs(dAtA, i, uint64(m.Payload.Size())) - n68, err := m.Payload.MarshalTo(dAtA[i:]) + n71, err := m.Payload.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n68 + i += n71 } return i, nil } @@ -6395,6 +6606,28 @@ func (m *CreateStatsProgress) Size() (n int) { return n } +func (m *LongRunningMigrationDetails) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ClusterVersion != nil { + l = m.ClusterVersion.Size() + n += 1 + l + sovJobs(uint64(l)) + } + return n +} + +func (m *LongRunningMigrationProgress) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + func (m *Payload) Size() (n int) { if m == nil { return 0 @@ -6579,6 +6812,18 @@ func (m *Payload_NewSchemaChange) Size() (n int) { } return n } +func (m *Payload_LongRunningMigration) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.LongRunningMigration != nil { + l = m.LongRunningMigration.Size() + n += 2 + l + sovJobs(uint64(l)) + } + return n +} func (m *Progress) Size() (n int) { if m == nil { return 0 @@ -6742,6 +6987,18 @@ func (m *Progress_NewSchemaChange) Size() (n int) { } return n } +func (m *Progress_LongRunningMigration) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.LongRunningMigration != nil { + l = m.LongRunningMigration.Size() + n += 2 + l + sovJobs(uint64(l)) + } + return n +} func (m *Job) Size() (n int) { if m == nil { return 0 @@ -13110,6 +13367,139 @@ func (m *CreateStatsProgress) Unmarshal(dAtA []byte) error { } return nil } +func (m *LongRunningMigrationDetails) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowJobs + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: LongRunningMigrationDetails: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: LongRunningMigrationDetails: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ClusterVersion", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowJobs + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthJobs + } + postIndex := iNdEx + msglen + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ClusterVersion == nil { + m.ClusterVersion = &clusterversion.ClusterVersion{} + } + if err := m.ClusterVersion.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipJobs(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthJobs + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *LongRunningMigrationProgress) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowJobs + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= (uint64(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: LongRunningMigrationProgress: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: LongRunningMigrationProgress: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + default: + iNdEx = preIndex + skippy, err := skipJobs(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthJobs + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *Payload) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 @@ -13834,6 +14224,38 @@ func (m *Payload) Unmarshal(dAtA []byte) error { } m.Details = &Payload_NewSchemaChange{v} iNdEx = postIndex + case 25: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LongRunningMigration", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowJobs + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthJobs + } + postIndex := iNdEx + msglen + if postIndex > l { + return io.ErrUnexpectedEOF + } + v := &LongRunningMigrationDetails{} + if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + m.Details = &Payload_LongRunningMigration{v} + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipJobs(dAtA[iNdEx:]) @@ -14295,6 +14717,38 @@ func (m *Progress) Unmarshal(dAtA []byte) error { } m.Details = &Progress_NewSchemaChange{v} iNdEx = postIndex + case 20: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LongRunningMigration", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowJobs + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthJobs + } + postIndex := iNdEx + msglen + if postIndex > l { + return io.ErrUnexpectedEOF + } + v := &LongRunningMigrationProgress{} + if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + m.Details = &Progress_LongRunningMigration{v} + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipJobs(dAtA[iNdEx:]) @@ -14556,302 +15010,310 @@ var ( ErrIntOverflowJobs = fmt.Errorf("proto: integer overflow") ) -func init() { proto.RegisterFile("jobs/jobspb/jobs.proto", fileDescriptor_jobs_8f6d1b2aa13f3feb) } - -var fileDescriptor_jobs_8f6d1b2aa13f3feb = []byte{ - // 4692 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xc4, 0x7b, 0x4b, 0x6c, 0x23, 0x47, - 0x7a, 0xbf, 0x9a, 0xa4, 0xc8, 0xe6, 0x47, 0x91, 0x6a, 0x95, 0x34, 0x33, 0x5c, 0xfe, 0x6d, 0x51, - 0x4b, 0xbf, 0x66, 0xc6, 0x36, 0xe5, 0x95, 0xff, 0xeb, 0xb5, 0x27, 0xf6, 0xd8, 0x7c, 0x8d, 0x44, - 0x6a, 0xf4, 0x70, 0x53, 0x1a, 0x3f, 0x36, 0xde, 0x4e, 0xb3, 0xbb, 0x24, 0x75, 0x44, 0x76, 0x73, - 0xba, 0x9a, 0x33, 0xa3, 0x4d, 0x90, 0x04, 0x1b, 0x04, 0x58, 0xcc, 0x29, 0x01, 0x92, 0x5c, 0x92, - 0x01, 0x02, 0x64, 0x17, 0x08, 0x92, 0x00, 0x01, 0x8c, 0x20, 0xc9, 0x21, 0xb7, 0x5c, 0x7c, 0x48, - 0x80, 0xbd, 0x04, 0x30, 0x72, 0xe0, 0x26, 0xf2, 0x25, 0xc7, 0x20, 0x7b, 0x9b, 0x4b, 0x82, 0x7a, - 0x74, 0xb3, 0x49, 0xea, 0x41, 0x8d, 0xec, 0xcd, 0x45, 0xc3, 0xfe, 0xea, 0xab, 0x5f, 0xbd, 0xbe, - 0xfa, 0x7d, 0x5f, 0x7d, 0x55, 0x03, 0x57, 0x7f, 0xdd, 0x69, 0x91, 0x65, 0xfa, 0xa7, 0xdb, 0x62, - 0xff, 0x14, 0xbb, 0xae, 0xe3, 0x39, 0xe8, 0x5b, 0x86, 0x63, 0x1c, 0xba, 0x8e, 0x6e, 0x1c, 0x14, - 0xc9, 0xfd, 0x76, 0x91, 0x95, 0x70, 0xad, 0xdc, 0x15, 0xec, 0xba, 0x8e, 0x4b, 0xf5, 0xf9, 0x0f, - 0x5e, 0x23, 0xb7, 0xb0, 0xef, 0xec, 0x3b, 0xec, 0xe7, 0x32, 0xfd, 0x25, 0xa4, 0x88, 0x61, 0x74, - 0x5b, 0xcb, 0xa6, 0xee, 0xe9, 0x42, 0x96, 0xf5, 0x65, 0x96, 0xf3, 0xfa, 0x9e, 0xe3, 0x76, 0x74, - 0xcf, 0xc7, 0x78, 0x81, 0xdc, 0x6f, 0x2f, 0x1b, 0xba, 0xa7, 0xb7, 0x9d, 0xfd, 0x65, 0x13, 0x13, - 0xa3, 0xdb, 0x5a, 0x26, 0x9e, 0xdb, 0x33, 0xbc, 0x9e, 0x8b, 0x4d, 0xa1, 0x94, 0x3f, 0x41, 0xc9, - 0xc3, 0xb6, 0x6e, 0x7b, 0x3e, 0x7e, 0xcf, 0xb3, 0xda, 0xcb, 0x07, 0x6d, 0x63, 0xd9, 0xb3, 0x3a, - 0x98, 0x78, 0x7a, 0xa7, 0x2b, 0x4a, 0xbe, 0x4d, 0xab, 0x12, 0xe3, 0x00, 0x77, 0x74, 0xe3, 0x40, - 0xb7, 0xf7, 0xb1, 0xbb, 0xcc, 0xdb, 0x30, 0xba, 0x2d, 0xae, 0x52, 0xf8, 0x6d, 0x98, 0xbe, 0x8b, - 0x75, 0x82, 0xd1, 0xa7, 0x90, 0xb0, 0x1d, 0x13, 0x6b, 0x96, 0x99, 0x95, 0x96, 0xa4, 0xeb, 0xe9, - 0x72, 0xe9, 0xb8, 0x9f, 0x8f, 0x6f, 0x3a, 0x26, 0xae, 0x57, 0x9f, 0xf6, 0xf3, 0x6f, 0xee, 0x5b, - 0xde, 0x41, 0xaf, 0x55, 0x34, 0x9c, 0xce, 0x72, 0x30, 0x57, 0x66, 0x6b, 0xf0, 0x7b, 0xb9, 0x7b, - 0xb8, 0xbf, 0x2c, 0x46, 0x5a, 0xe4, 0xd5, 0xd4, 0x38, 0x45, 0xac, 0x9b, 0x68, 0x01, 0xa6, 0x71, - 0xd7, 0x31, 0x0e, 0xb2, 0x91, 0x25, 0xe9, 0x7a, 0x54, 0xe5, 0x1f, 0xb7, 0x62, 0xff, 0xf9, 0x67, - 0x79, 0xa9, 0xf0, 0xd3, 0x08, 0x5c, 0x2b, 0xeb, 0xc6, 0x61, 0xaf, 0x5b, 0xb3, 0x0d, 0xf7, 0xa8, - 0xeb, 0x59, 0x8e, 0xbd, 0xc5, 0xfe, 0x12, 0xa4, 0x40, 0xf4, 0x10, 0x1f, 0xb1, 0xfe, 0xcc, 0xa8, - 0xf4, 0x27, 0x7a, 0x0f, 0x62, 0x1d, 0xc7, 0xc4, 0x0c, 0x28, 0xb3, 0x72, 0xa3, 0x78, 0xea, 0xb2, - 0x15, 0x07, 0x68, 0x1b, 0x8e, 0x89, 0x55, 0x56, 0x0d, 0xb5, 0x40, 0x3e, 0xec, 0x10, 0xcd, 0xb2, - 0xf7, 0x9c, 0x6c, 0x74, 0x49, 0xba, 0x9e, 0x5a, 0xb9, 0x75, 0x06, 0xc4, 0x29, 0xdd, 0x2a, 0xae, - 0x6f, 0x34, 0xeb, 0xf6, 0x9e, 0x53, 0x4e, 0x1d, 0xf7, 0xf3, 0x09, 0xf1, 0xa1, 0x26, 0x0e, 0x3b, - 0x84, 0xfe, 0xc8, 0x6d, 0x81, 0x2f, 0xa3, 0xfd, 0xef, 0xb9, 0x16, 0xeb, 0x7f, 0x52, 0xa5, 0x3f, - 0xd1, 0x6b, 0x80, 0x30, 0xc7, 0xc3, 0xa6, 0x46, 0x6d, 0x44, 0xa3, 0x03, 0x8c, 0xb0, 0x01, 0x2a, - 0x41, 0x49, 0x55, 0xf7, 0xf4, 0x75, 0x7c, 0xc4, 0x67, 0x48, 0xcc, 0xd3, 0xef, 0x44, 0x21, 0x33, - 0xe8, 0x0a, 0x83, 0x5f, 0x83, 0x38, 0x5b, 0x5c, 0xcc, 0x5a, 0xc8, 0xac, 0xbc, 0x31, 0xd1, 0x74, - 0xd0, 0xaa, 0xc5, 0x26, 0xab, 0xa7, 0x8a, 0xfa, 0x08, 0x41, 0x8c, 0xe8, 0x6d, 0x4f, 0x74, 0x84, - 0xfd, 0x46, 0x7f, 0x22, 0xc1, 0xd2, 0x68, 0x8f, 0xca, 0x47, 0xeb, 0x1b, 0xcd, 0x0d, 0x9d, 0x78, - 0xd8, 0x5d, 0xc7, 0x47, 0xf5, 0x6a, 0x36, 0xba, 0x14, 0xbd, 0x9e, 0x5a, 0xd9, 0x9a, 0xbc, 0xe1, - 0xda, 0x39, 0x88, 0x35, 0xdb, 0x73, 0x8f, 0xd4, 0x73, 0x1b, 0xce, 0x35, 0xe1, 0xa5, 0x89, 0xa0, - 0xc2, 0x36, 0x94, 0xe4, 0x36, 0xb4, 0x00, 0xd3, 0x0f, 0xf4, 0x76, 0x0f, 0x8b, 0xd1, 0xf2, 0x8f, - 0x5b, 0x91, 0xb7, 0xa5, 0xc2, 0x35, 0x88, 0xf3, 0x89, 0x41, 0x69, 0x48, 0x96, 0x6a, 0xcd, 0x95, - 0xef, 0xbe, 0xb5, 0x5a, 0xd9, 0x50, 0xa6, 0xc4, 0x12, 0xfc, 0x8f, 0x04, 0x57, 0x9b, 0x9e, 0x8b, - 0xf5, 0x4e, 0xdd, 0xde, 0xc7, 0x84, 0x8e, 0xa9, 0x8a, 0x3d, 0xdd, 0x6a, 0x13, 0x64, 0x43, 0x86, - 0xb0, 0x12, 0x4d, 0x37, 0x4d, 0x17, 0x13, 0xc2, 0x1b, 0x2c, 0xaf, 0x3e, 0xed, 0xe7, 0x2b, 0x13, - 0x6d, 0x1d, 0xc3, 0x68, 0x2f, 0x73, 0x08, 0xcb, 0xde, 0x37, 0x8c, 0x76, 0x91, 0xb7, 0x54, 0xe2, - 0x70, 0x6a, 0x9a, 0x84, 0x3f, 0xd1, 0x77, 0x20, 0x46, 0xba, 0xba, 0xcd, 0x86, 0x90, 0x5a, 0xb9, - 0x16, 0x9a, 0x7f, 0x7f, 0x0b, 0x36, 0xbb, 0xba, 0x5d, 0x8e, 0x7d, 0xd1, 0xcf, 0x4f, 0xa9, 0x4c, - 0x15, 0x95, 0x01, 0x88, 0xa7, 0xbb, 0x9e, 0x46, 0x59, 0x42, 0x58, 0xff, 0xf3, 0xa1, 0x8a, 0x94, - 0x45, 0x8a, 0x07, 0x6d, 0xa3, 0xb8, 0xe3, 0xb3, 0x88, 0xa8, 0x9e, 0x64, 0xd5, 0xa8, 0xb4, 0xf0, - 0x2d, 0xb8, 0x36, 0x32, 0x01, 0xdb, 0xae, 0xb3, 0x4f, 0x7b, 0x54, 0xf8, 0xc7, 0x38, 0xa4, 0xf9, - 0x86, 0xf1, 0xe7, 0x64, 0xb8, 0x41, 0xe9, 0x59, 0x1a, 0x44, 0xb7, 0x41, 0xc6, 0xb6, 0xc9, 0x11, - 0x22, 0x93, 0x23, 0x24, 0xb0, 0x6d, 0xb2, 0xfa, 0xdf, 0xe2, 0x3b, 0x30, 0xca, 0x16, 0x23, 0x71, - 0xdc, 0xcf, 0x47, 0x77, 0xd5, 0x3a, 0xdf, 0x8a, 0xef, 0x42, 0xce, 0xc4, 0x5d, 0x17, 0x1b, 0x3a, - 0xdd, 0x8b, 0x2d, 0xd6, 0x75, 0xad, 0xa3, 0xdb, 0xd6, 0x1e, 0x26, 0x5e, 0x36, 0xc6, 0x6c, 0x23, - 0x3b, 0xd0, 0xe0, 0x63, 0xdb, 0x10, 0xe5, 0xe8, 0x77, 0x25, 0x98, 0xef, 0xb9, 0x16, 0xd1, 0x5a, - 0x47, 0x5a, 0xdb, 0x31, 0xf4, 0xb6, 0xe5, 0x1d, 0x69, 0x87, 0x0f, 0xb2, 0xd3, 0x6c, 0x43, 0xdc, - 0x3e, 0x97, 0x55, 0xc4, 0x24, 0x15, 0x77, 0x5d, 0x8b, 0x94, 0x8f, 0xee, 0x0a, 0x84, 0xf5, 0x07, - 0xcc, 0x68, 0xcb, 0x0b, 0xc7, 0xfd, 0xbc, 0xb2, 0xab, 0xd6, 0xc3, 0x45, 0xf7, 0x54, 0xa5, 0x37, - 0xa2, 0x8c, 0xf4, 0x80, 0x4e, 0x2c, 0xc7, 0xd6, 0x1c, 0xce, 0x4f, 0xd9, 0x38, 0x9b, 0xa8, 0x95, - 0x8b, 0x33, 0x9b, 0x3a, 0x87, 0xc7, 0x38, 0xf8, 0x0f, 0x24, 0xc8, 0x51, 0x57, 0x81, 0x0d, 0x3a, - 0x4d, 0x81, 0x87, 0xd1, 0x5c, 0x6c, 0x38, 0xae, 0x99, 0x4d, 0xd0, 0x79, 0x2a, 0x37, 0xff, 0x6d, - 0x52, 0x0f, 0xc1, 0x7c, 0x55, 0xaf, 0x67, 0x99, 0xc5, 0xdd, 0xdd, 0x7a, 0xf5, 0xb8, 0x9f, 0xcf, - 0x6e, 0xfb, 0xe0, 0xc1, 0x22, 0xaa, 0x0c, 0x5a, 0xcd, 0x76, 0x4f, 0x29, 0x41, 0x6f, 0x43, 0xc6, - 0x70, 0xda, 0x6d, 0x6c, 0xb0, 0x61, 0xef, 0xaa, 0xf5, 0xac, 0xcc, 0x16, 0x78, 0xee, 0xb8, 0x9f, - 0x4f, 0x57, 0x82, 0x12, 0xba, 0xd4, 0x69, 0x23, 0xfc, 0x89, 0x54, 0x98, 0x0d, 0x4d, 0x18, 0xf3, - 0x03, 0x49, 0x36, 0x5b, 0x37, 0x26, 0xa6, 0x30, 0x35, 0x83, 0x87, 0xbe, 0x73, 0x15, 0xb8, 0x72, - 0xe2, 0x2a, 0x9e, 0x47, 0x3d, 0xc9, 0x30, 0xf5, 0x28, 0x90, 0xe1, 0x8b, 0x12, 0x6c, 0xa8, 0xcf, - 0x33, 0x90, 0x51, 0x31, 0xf1, 0x1c, 0x17, 0xfb, 0x3b, 0xea, 0x73, 0x09, 0xe6, 0x69, 0x04, 0xe0, - 0x5a, 0x5d, 0xcf, 0x71, 0x35, 0x17, 0x3f, 0x74, 0x2d, 0x0f, 0x93, 0x6c, 0x84, 0x19, 0x5d, 0xe9, - 0x8c, 0x21, 0x0c, 0x03, 0x15, 0xab, 0x01, 0x88, 0x2a, 0x30, 0xb8, 0xdd, 0xdd, 0xfe, 0xd1, 0xcf, - 0xf3, 0xb7, 0x26, 0x5a, 0xc7, 0xf1, 0xa0, 0xa4, 0x58, 0xaf, 0xaa, 0xc8, 0x1c, 0x03, 0x46, 0xcf, - 0x41, 0x8c, 0xda, 0x2d, 0x73, 0x15, 0xc9, 0xb2, 0x7c, 0xdc, 0xcf, 0xc7, 0xa8, 0x65, 0xab, 0x4c, - 0x3a, 0xb4, 0xc1, 0x63, 0xcf, 0xb0, 0xc1, 0x57, 0x21, 0xe5, 0xe9, 0xad, 0x36, 0xd6, 0x68, 0xcb, - 0x44, 0x6c, 0xbf, 0x97, 0x47, 0x66, 0x82, 0xdc, 0x6f, 0xb7, 0x74, 0x82, 0x8b, 0x3b, 0x54, 0x33, - 0x34, 0x76, 0xf0, 0x7c, 0x01, 0x41, 0xcb, 0x90, 0x72, 0x1e, 0x60, 0xd7, 0xb5, 0x4c, 0xac, 0x99, - 0x2d, 0xb6, 0x87, 0x92, 0xe5, 0xcc, 0x71, 0x3f, 0x0f, 0x5b, 0x42, 0x5c, 0x2d, 0xab, 0xe0, 0xab, - 0x54, 0x5b, 0xc8, 0x83, 0x05, 0x41, 0x1a, 0xc1, 0xfe, 0x67, 0xf6, 0x94, 0x60, 0x5d, 0x78, 0x77, - 0xf2, 0xc5, 0xe0, 0xeb, 0xee, 0x1b, 0x0f, 0x8b, 0x2c, 0xf8, 0x20, 0x51, 0x6b, 0xac, 0x04, 0xbd, - 0x0a, 0x73, 0x5d, 0x17, 0x77, 0x75, 0x17, 0x6b, 0x86, 0xd3, 0xe9, 0xb6, 0xb1, 0x87, 0x4d, 0x66, - 0xfd, 0xb2, 0xaa, 0x88, 0x82, 0x8a, 0x2f, 0x47, 0x2f, 0x51, 0xaf, 0xa4, 0x7b, 0x34, 0xe0, 0x21, - 0xd8, 0xa5, 0x9a, 0x49, 0xa6, 0x99, 0x66, 0xd2, 0xba, 0x10, 0xa2, 0x37, 0xe1, 0xca, 0x60, 0xdd, - 0x88, 0xd6, 0xed, 0xb5, 0xda, 0x16, 0x39, 0xc0, 0x66, 0x16, 0x98, 0xf6, 0x42, 0xa8, 0x70, 0xdb, - 0x2f, 0x43, 0x47, 0x43, 0xa6, 0x68, 0xd0, 0x89, 0xd1, 0xf7, 0x71, 0x36, 0xb5, 0x24, 0x5d, 0x9f, - 0x2e, 0xaf, 0x3d, 0xed, 0xe7, 0xab, 0x13, 0xdb, 0x11, 0xc1, 0x9d, 0x65, 0xcf, 0xc5, 0x38, 0x64, - 0x96, 0x15, 0x81, 0x17, 0xb6, 0x28, 0x5f, 0x86, 0x54, 0x80, 0xc1, 0x16, 0xcc, 0xce, 0x3c, 0x33, - 0xdb, 0x85, 0x50, 0x50, 0x09, 0x12, 0x3c, 0xa8, 0x26, 0xd9, 0x34, 0x5b, 0xc0, 0x6f, 0x9f, 0x66, - 0x43, 0x4c, 0x2b, 0xb4, 0x4a, 0x7e, 0x3d, 0x54, 0x05, 0xf0, 0x8e, 0xba, 0xbe, 0x25, 0x66, 0x18, - 0xca, 0x4b, 0xa7, 0xa1, 0x1c, 0x75, 0xc3, 0x86, 0x98, 0xf4, 0xc4, 0x37, 0x41, 0x0d, 0x98, 0xe1, - 0x11, 0xbb, 0xc0, 0x99, 0x65, 0x38, 0xaf, 0x9c, 0x82, 0xc3, 0xc2, 0x15, 0x3d, 0x84, 0x94, 0x22, - 0x81, 0x84, 0xa0, 0x6d, 0xc8, 0xd0, 0x18, 0x93, 0x6a, 0x0a, 0x34, 0x85, 0xa1, 0xdd, 0x38, 0x05, - 0xad, 0x2a, 0x94, 0x43, 0x78, 0x69, 0x33, 0x24, 0x23, 0xb9, 0x5f, 0x48, 0x30, 0x37, 0x46, 0x1e, - 0x68, 0x07, 0x22, 0xc1, 0xb1, 0x81, 0x72, 0x7a, 0x84, 0x1d, 0x19, 0x2e, 0x43, 0x24, 0x11, 0xcb, - 0x44, 0xfb, 0x90, 0xa4, 0xe6, 0x6c, 0x7b, 0xf4, 0x4c, 0x12, 0x61, 0xe0, 0x8d, 0xe3, 0x7e, 0x5e, - 0xde, 0x66, 0xc2, 0x4b, 0x37, 0x21, 0x73, 0xf0, 0xba, 0x89, 0xf2, 0x90, 0xf2, 0x1c, 0x0d, 0x3f, - 0xb2, 0x88, 0x67, 0xd9, 0xfb, 0x2c, 0x58, 0x90, 0x55, 0xf0, 0x9c, 0x9a, 0x90, 0xe4, 0xfe, 0x34, - 0x02, 0x68, 0x7c, 0x97, 0xa2, 0x7f, 0x90, 0xe0, 0x39, 0x3f, 0x06, 0x70, 0x5c, 0x6b, 0xdf, 0xb2, - 0xf5, 0xf6, 0x50, 0x30, 0x20, 0xb1, 0xd9, 0xfe, 0xf4, 0x32, 0x54, 0x20, 0x02, 0x84, 0x2d, 0x01, - 0x3f, 0x1a, 0x28, 0x3c, 0x47, 0x3d, 0x28, 0x0f, 0x14, 0xc6, 0x54, 0xee, 0xa9, 0xd9, 0xde, 0x29, - 0x95, 0x73, 0xeb, 0xf0, 0xfc, 0x99, 0xc0, 0x17, 0xf1, 0x5d, 0xb9, 0x1f, 0x49, 0x70, 0xed, 0x14, - 0x8f, 0x12, 0xc6, 0x49, 0x73, 0x9c, 0x0f, 0xc3, 0x38, 0xa9, 0x95, 0x5f, 0xb9, 0x84, 0xd7, 0x0a, - 0x75, 0xa2, 0x11, 0x93, 0x25, 0x25, 0x52, 0x78, 0x03, 0x66, 0x45, 0x25, 0xdf, 0x8f, 0xa2, 0xe7, - 0x01, 0x0e, 0xac, 0xfd, 0x03, 0xed, 0xa1, 0xee, 0x61, 0x57, 0x9c, 0x25, 0x93, 0x54, 0xf2, 0x11, - 0x15, 0x14, 0xfe, 0x55, 0x86, 0x74, 0xbd, 0xd3, 0x75, 0x5c, 0xcf, 0xf7, 0xb2, 0x77, 0x21, 0xce, - 0xfc, 0x02, 0x11, 0xeb, 0x57, 0x3c, 0xa3, 0x87, 0x43, 0x35, 0xb9, 0x7f, 0x11, 0xb4, 0x20, 0x30, - 0x02, 0xf7, 0x17, 0x39, 0xd1, 0xfd, 0xbd, 0x07, 0x71, 0x9e, 0x12, 0x10, 0x01, 0x79, 0xfe, 0x84, - 0x48, 0xbe, 0xbe, 0x75, 0xc7, 0x6a, 0xe3, 0x3b, 0x4c, 0xcd, 0x07, 0xe7, 0x95, 0xd0, 0xcb, 0x20, - 0x13, 0xe2, 0x69, 0xc4, 0xfa, 0x21, 0xf7, 0x9e, 0x51, 0x7e, 0x26, 0x6d, 0x36, 0x77, 0x9a, 0xd6, - 0x0f, 0xb1, 0x9a, 0x20, 0xc4, 0xa3, 0x3f, 0x50, 0x0e, 0xe4, 0x87, 0x7a, 0xbb, 0xcd, 0xbc, 0xec, - 0x34, 0x3b, 0x83, 0x07, 0xdf, 0xc3, 0xdb, 0x2c, 0xfe, 0xcd, 0x6e, 0x33, 0xe1, 0x30, 0xbb, 0xba, - 0x77, 0xc0, 0x22, 0xc7, 0xa4, 0x0a, 0x5c, 0xb4, 0xad, 0x7b, 0x07, 0x28, 0x0b, 0x09, 0xa2, 0x53, - 0xdf, 0x45, 0xb2, 0xf2, 0x52, 0xf4, 0xfa, 0x8c, 0xea, 0x7f, 0xa2, 0x45, 0x60, 0x9e, 0x97, 0x7f, - 0x32, 0x27, 0x16, 0x55, 0x43, 0x12, 0x36, 0x0f, 0x87, 0x56, 0x57, 0xdb, 0x3b, 0x24, 0xdc, 0x69, - 0x89, 0x79, 0x38, 0xb4, 0xba, 0x77, 0xd6, 0x89, 0x9a, 0xa0, 0x85, 0x77, 0x0e, 0x09, 0x7a, 0x05, - 0x66, 0x2d, 0x76, 0x72, 0xd1, 0x4c, 0xcb, 0xc5, 0x86, 0xd7, 0x3e, 0x62, 0x0e, 0x4b, 0x56, 0x33, - 0x5c, 0x5c, 0x15, 0x52, 0x74, 0x03, 0x94, 0x51, 0x37, 0xcb, 0x1c, 0x8d, 0xac, 0xce, 0x8e, 0x78, - 0x59, 0xaa, 0xca, 0x97, 0x3a, 0xe4, 0x38, 0xd3, 0x5c, 0x95, 0xcb, 0x07, 0x3e, 0xb3, 0x08, 0xf3, - 0x5d, 0xdd, 0x25, 0x58, 0x6b, 0xf5, 0x6c, 0xb3, 0x8d, 0x35, 0xce, 0xd5, 0xd9, 0x0c, 0xd3, 0x9e, - 0x63, 0x45, 0x65, 0x56, 0xc2, 0x69, 0xfd, 0xbc, 0xd8, 0xfb, 0xea, 0xff, 0x41, 0xec, 0x9d, 0xfb, - 0x69, 0x04, 0xa6, 0x99, 0x9d, 0xa3, 0x5b, 0x10, 0xa3, 0xcb, 0x2c, 0x4e, 0x76, 0x93, 0xc6, 0x5c, - 0xac, 0x0e, 0x42, 0x10, 0xb3, 0xf5, 0x0e, 0xce, 0x22, 0x66, 0x04, 0xec, 0x37, 0xba, 0x06, 0x09, - 0x82, 0xef, 0x6b, 0x0f, 0xf4, 0x76, 0x76, 0x9e, 0xad, 0x70, 0x9c, 0xe0, 0xfb, 0xf7, 0xf4, 0x36, - 0xba, 0x02, 0x71, 0x8b, 0x68, 0x36, 0x7e, 0x98, 0x5d, 0x60, 0x33, 0x35, 0x6d, 0x91, 0x4d, 0xfc, - 0x90, 0xd1, 0xb6, 0xee, 0xee, 0x63, 0x4f, 0x33, 0x9c, 0x36, 0xc9, 0x5e, 0xa1, 0x1b, 0x8c, 0x86, - 0x74, 0x54, 0x54, 0x71, 0xda, 0x04, 0xfd, 0x3f, 0x48, 0x3e, 0xd4, 0x89, 0x86, 0x3b, 0x5d, 0xef, - 0x88, 0x4d, 0x96, 0x4c, 0xcd, 0x9e, 0xd4, 0xe8, 0x77, 0x23, 0x26, 0x47, 0x94, 0x68, 0x23, 0x26, - 0x47, 0x95, 0x58, 0x23, 0x26, 0xc7, 0x94, 0xe9, 0x46, 0x4c, 0x9e, 0x56, 0xe2, 0x8d, 0x98, 0x1c, - 0x57, 0x12, 0x8d, 0x98, 0x9c, 0x50, 0xe4, 0x46, 0x4c, 0x96, 0x95, 0x64, 0x23, 0x26, 0x27, 0x15, - 0x68, 0xc4, 0x64, 0x50, 0x52, 0x8d, 0x98, 0x9c, 0x52, 0x66, 0x1a, 0x31, 0x79, 0x46, 0x49, 0x37, - 0x62, 0x72, 0x5a, 0xc9, 0x34, 0x62, 0x72, 0x46, 0x99, 0x6d, 0xc4, 0xe4, 0x59, 0x45, 0x69, 0xc4, - 0x64, 0x45, 0x99, 0x6b, 0xc4, 0xe4, 0x39, 0x05, 0x15, 0x3e, 0x97, 0x40, 0x69, 0xe2, 0xfb, 0x3d, - 0x6c, 0x1b, 0xf8, 0x9e, 0xde, 0xae, 0x1c, 0xf4, 0xec, 0x43, 0xf4, 0x32, 0xcc, 0x1a, 0xf4, 0x87, - 0xc6, 0x0f, 0xc6, 0x74, 0xa8, 0x12, 0x1b, 0x6a, 0x9a, 0x89, 0x9b, 0x54, 0x4a, 0x47, 0xfc, 0x3c, - 0x80, 0xd0, 0xa3, 0x3b, 0x9b, 0x67, 0xcd, 0x92, 0x5c, 0x85, 0x6e, 0xe7, 0x11, 0x18, 0xd7, 0x79, - 0xc8, 0xe8, 0x63, 0x08, 0x46, 0x75, 0x1e, 0xa2, 0x65, 0x58, 0xb0, 0xf1, 0x23, 0x4f, 0x1b, 0x55, - 0x66, 0x54, 0xa1, 0xce, 0xd1, 0xb2, 0x4a, 0xb8, 0x42, 0xe1, 0x5f, 0x22, 0x30, 0xeb, 0x77, 0xda, - 0xa7, 0xc3, 0x3d, 0x50, 0xe8, 0xb2, 0x58, 0xa6, 0xe6, 0x39, 0x1c, 0xc9, 0x27, 0xc6, 0xf7, 0xce, - 0x20, 0xc6, 0x11, 0x14, 0xfa, 0x5d, 0x37, 0x77, 0x1c, 0xd6, 0x1c, 0x77, 0x0d, 0x6a, 0x9a, 0x84, - 0x65, 0xb9, 0x5d, 0xc8, 0xf8, 0x95, 0xb8, 0x04, 0x55, 0x20, 0x3e, 0xd4, 0xde, 0xab, 0x13, 0xb4, - 0xe7, 0x4f, 0xb5, 0x2a, 0xaa, 0xe6, 0x7e, 0x03, 0xd0, 0x78, 0xdb, 0x61, 0xb7, 0x34, 0xcd, 0xdd, - 0xd2, 0xd6, 0xb0, 0x5b, 0x7a, 0xe7, 0x62, 0x63, 0x0b, 0x75, 0x3b, 0x7c, 0xaa, 0xfb, 0xa7, 0x08, - 0x64, 0xb8, 0x8b, 0x08, 0xdc, 0xd1, 0xab, 0x30, 0xc7, 0x48, 0xcb, 0xb2, 0xf7, 0xb5, 0xae, 0x10, - 0xb2, 0xf1, 0x45, 0x54, 0xc5, 0x2f, 0x08, 0x94, 0x5f, 0x80, 0xb4, 0x8b, 0x75, 0x73, 0xa0, 0x18, - 0x61, 0x8a, 0x33, 0x54, 0x18, 0x28, 0xbd, 0x04, 0x19, 0xe6, 0x0d, 0x07, 0x5a, 0x51, 0xa6, 0x95, - 0x66, 0xd2, 0x40, 0xad, 0x0c, 0x69, 0xd2, 0xd5, 0xed, 0x81, 0x56, 0x8c, 0x4d, 0xea, 0x39, 0xb9, - 0xa3, 0x19, 0x5a, 0x27, 0xec, 0x4b, 0x5d, 0x4c, 0x7a, 0x1d, 0xac, 0x75, 0x1d, 0x7e, 0xd8, 0x8a, - 0xaa, 0x49, 0x2e, 0xd9, 0x76, 0x08, 0xda, 0x65, 0xa6, 0xc2, 0xe6, 0x42, 0x33, 0xf9, 0xe4, 0x64, - 0xe3, 0xac, 0x95, 0x9b, 0x93, 0x4f, 0xa7, 0x3a, 0x4b, 0x86, 0x05, 0x85, 0xdf, 0x84, 0x6b, 0x34, - 0x5e, 0xe6, 0xa4, 0x58, 0x61, 0x89, 0x6c, 0xdf, 0x38, 0x75, 0x48, 0xb0, 0x98, 0x3b, 0x08, 0x3f, - 0xd7, 0x8e, 0xfb, 0xf9, 0x38, 0xd5, 0xbe, 0xb4, 0xe3, 0x8a, 0x53, 0xe0, 0xba, 0x59, 0xc8, 0x41, - 0x76, 0xb4, 0xf5, 0xe0, 0x8c, 0xfe, 0xab, 0x70, 0x75, 0x13, 0x3f, 0x3c, 0xa9, 0x63, 0x65, 0x48, - 0x70, 0x26, 0xf2, 0x8d, 0xf7, 0xfa, 0x28, 0x3f, 0x86, 0xd3, 0xf2, 0x45, 0xd6, 0xe8, 0x0e, 0xab, - 0xa0, 0xfa, 0x15, 0x0b, 0x9f, 0xc2, 0xb5, 0x11, 0xf4, 0x60, 0x21, 0xde, 0x87, 0x38, 0x3d, 0xc3, - 0x89, 0x18, 0x25, 0x33, 0x7e, 0x3e, 0x18, 0x47, 0x6f, 0x52, 0x7d, 0x55, 0x54, 0x2b, 0xa8, 0x2c, - 0xb9, 0xd0, 0xeb, 0x60, 0xba, 0xd6, 0x77, 0x2d, 0xe2, 0xa1, 0x0f, 0x60, 0x46, 0xac, 0x2d, 0x5d, - 0x72, 0xbf, 0xdb, 0xe7, 0x98, 0x47, 0xca, 0x0d, 0x40, 0x48, 0xe1, 0x6f, 0x25, 0x98, 0xaf, 0xba, - 0x4e, 0xb7, 0x8b, 0x4d, 0xc1, 0xfa, 0x7c, 0x2e, 0x7c, 0xb2, 0x97, 0x42, 0x64, 0xbf, 0x09, 0x91, - 0x7a, 0x55, 0x44, 0xf5, 0xb7, 0x2f, 0x7b, 0x58, 0xa8, 0x57, 0xd1, 0x3b, 0x7c, 0x42, 0x7a, 0x84, - 0x31, 0x61, 0x66, 0xec, 0xf8, 0x36, 0x64, 0x70, 0x4c, 0x51, 0x15, 0x15, 0x0a, 0x3f, 0x49, 0xc0, - 0x95, 0xf0, 0x24, 0xaf, 0x56, 0xfc, 0x8e, 0x7f, 0x06, 0x09, 0xcb, 0x36, 0xf1, 0x23, 0x3c, 0x11, - 0xe3, 0x9d, 0x04, 0x51, 0x14, 0xf3, 0x51, 0xa7, 0x30, 0xfe, 0x81, 0x51, 0x60, 0xa2, 0x8f, 0x83, - 0x40, 0x93, 0x27, 0x70, 0x6e, 0x3d, 0x33, 0x7a, 0x75, 0x24, 0xe8, 0x1c, 0x8a, 0xe9, 0x98, 0x6b, - 0xf8, 0x86, 0x62, 0xba, 0x26, 0xcc, 0x59, 0xb6, 0x87, 0xdd, 0x36, 0xd6, 0x1f, 0xd0, 0x10, 0x85, - 0x36, 0x2f, 0xf2, 0x38, 0x93, 0x06, 0x04, 0x4a, 0x08, 0x80, 0x07, 0x16, 0x9f, 0xc1, 0x7c, 0x18, - 0xd4, 0x5f, 0x82, 0xb3, 0x73, 0x3b, 0x6c, 0x86, 0x07, 0xb0, 0x7e, 0x0a, 0x25, 0x04, 0x54, 0x17, - 0xd3, 0x7e, 0x0f, 0xe2, 0xfc, 0xc8, 0x2e, 0x12, 0xa5, 0xb7, 0x9f, 0x75, 0xda, 0x79, 0x2a, 0x40, - 0x15, 0x68, 0xb9, 0x3f, 0x96, 0x60, 0x26, 0xbc, 0xdc, 0xc8, 0x02, 0x99, 0xf5, 0xdd, 0x67, 0xa7, - 0x68, 0x79, 0x93, 0x46, 0xa5, 0xac, 0x90, 0xad, 0xc1, 0xfb, 0xcf, 0xbc, 0x06, 0x1c, 0x42, 0x98, - 0x52, 0xdd, 0xa4, 0xa1, 0x8e, 0xe9, 0x3a, 0xdd, 0x41, 0xa2, 0x3c, 0xaa, 0xca, 0x54, 0x40, 0xa3, - 0xb7, 0xdc, 0x6f, 0x41, 0x32, 0x30, 0x94, 0xd0, 0x59, 0x3d, 0xfa, 0x35, 0x9e, 0xd5, 0xcf, 0x6c, - 0xbf, 0x0a, 0xe9, 0xa1, 0x19, 0x43, 0x57, 0x83, 0x3e, 0xc4, 0xca, 0x71, 0xde, 0x87, 0x73, 0x51, - 0x0a, 0x3f, 0x8f, 0xc3, 0xfc, 0x49, 0x4c, 0xfb, 0x09, 0x28, 0x21, 0xde, 0xd2, 0xda, 0x16, 0xf1, - 0xc4, 0x7e, 0xba, 0x71, 0xf6, 0xd1, 0x32, 0x44, 0x7e, 0xc2, 0x5a, 0x32, 0xee, 0x30, 0x25, 0x7e, - 0x1f, 0x32, 0x26, 0xef, 0xb8, 0x26, 0x36, 0x6a, 0xf4, 0xdc, 0x13, 0xe1, 0x09, 0x04, 0x28, 0xd0, - 0xd3, 0x66, 0xa8, 0x88, 0xb0, 0x1b, 0x04, 0x1f, 0x3d, 0xc8, 0xd2, 0x58, 0x26, 0xdb, 0x3d, 0xe9, - 0x72, 0xf3, 0xb8, 0x9f, 0x9f, 0x13, 0x58, 0x7e, 0x5a, 0xe6, 0xd2, 0x2b, 0x35, 0x67, 0x8e, 0x00, - 0x9a, 0xd4, 0x81, 0xd2, 0x72, 0xda, 0xf0, 0xf4, 0xc0, 0x81, 0xd2, 0x7d, 0x74, 0x79, 0x07, 0x4a, - 0x7f, 0xd6, 0x4d, 0xf4, 0x7b, 0x12, 0xcc, 0xf1, 0x1c, 0x6d, 0xa7, 0xe7, 0xe9, 0x3c, 0xf1, 0xee, - 0x9f, 0x34, 0x3f, 0x39, 0xee, 0xe7, 0x67, 0xd9, 0x84, 0x6c, 0x88, 0x32, 0xd6, 0x6c, 0xf9, 0x59, - 0x9b, 0x1d, 0xa0, 0x88, 0xd3, 0x57, 0x20, 0x30, 0xd1, 0x3a, 0x64, 0xf8, 0xb1, 0x59, 0xa3, 0x07, - 0x47, 0xcb, 0xb1, 0xd9, 0x11, 0x34, 0x5d, 0x7e, 0xf1, 0x69, 0x3f, 0xbf, 0x74, 0x82, 0x65, 0xf1, - 0x13, 0xf7, 0x3d, 0xae, 0xab, 0xa6, 0xf7, 0xc2, 0x9f, 0xc8, 0x80, 0x74, 0x60, 0x1a, 0x47, 0x5d, - 0x71, 0x62, 0xbd, 0xbc, 0x2b, 0x9b, 0xf1, 0x6d, 0x84, 0x62, 0xa2, 0x7d, 0x98, 0xf5, 0x1b, 0xe1, - 0x0e, 0x9d, 0x64, 0x93, 0x5f, 0x4b, 0x33, 0xbe, 0x59, 0xf3, 0x51, 0x13, 0x91, 0x3c, 0xb9, 0x0a, - 0x0b, 0x27, 0x46, 0x39, 0x5f, 0xc6, 0xe1, 0xea, 0x30, 0x11, 0x06, 0x71, 0x88, 0x36, 0xea, 0x21, - 0xdf, 0x9f, 0x98, 0x4c, 0x7d, 0x0c, 0x4e, 0x66, 0xfe, 0xd7, 0xa8, 0x8f, 0xfc, 0x6c, 0xc4, 0x47, - 0x3e, 0x03, 0x3e, 0x33, 0xaf, 0x11, 0x7c, 0xdf, 0x51, 0x7e, 0x1c, 0xf8, 0x02, 0x9e, 0x7f, 0xf9, - 0xe0, 0x19, 0xe0, 0x59, 0x7d, 0xff, 0x33, 0xf0, 0x06, 0xff, 0x2c, 0x41, 0x7a, 0x68, 0x64, 0xbf, - 0x4c, 0x77, 0xb0, 0x1d, 0x44, 0x43, 0xfc, 0xa1, 0xc4, 0xdb, 0x17, 0x1f, 0xd6, 0x70, 0x90, 0x94, - 0xfb, 0x7b, 0x09, 0xd2, 0x43, 0x13, 0xf9, 0x0d, 0x39, 0x92, 0xaf, 0xbf, 0xe7, 0x2d, 0xc8, 0x0c, - 0x2f, 0x51, 0xa8, 0x0d, 0xe9, 0xeb, 0x69, 0xa3, 0xf0, 0x3d, 0x88, 0x73, 0x09, 0x42, 0x90, 0xf9, - 0xa8, 0x54, 0xdf, 0xa9, 0x6f, 0xae, 0x6a, 0x77, 0xb6, 0x54, 0x6d, 0xb5, 0xa2, 0x4c, 0xa1, 0x19, - 0x90, 0xab, 0xb5, 0xbb, 0x35, 0x2a, 0x54, 0x24, 0x94, 0x82, 0x04, 0xfb, 0xaa, 0x55, 0x95, 0x48, - 0xa1, 0x0c, 0x0a, 0xc7, 0xde, 0xc3, 0xd4, 0x31, 0xd0, 0xb8, 0x1f, 0x15, 0x61, 0x9e, 0x05, 0xe9, - 0x1d, 0x1a, 0xbf, 0x51, 0x57, 0xa8, 0x85, 0xa2, 0xe7, 0xb9, 0xa0, 0x88, 0x3a, 0xc5, 0x4d, 0xbd, - 0x83, 0x0b, 0x7f, 0x17, 0x83, 0xb9, 0x01, 0x88, 0xef, 0x16, 0x5f, 0x06, 0x99, 0x58, 0xf6, 0xa1, - 0x36, 0xb8, 0xfe, 0xe6, 0x29, 0x31, 0xcb, 0x3e, 0xdc, 0x55, 0xeb, 0x6a, 0x82, 0x16, 0xee, 0xba, - 0x16, 0x6a, 0x40, 0xcc, 0xe9, 0x7a, 0xfe, 0x69, 0xf0, 0xad, 0x33, 0xa6, 0x62, 0xac, 0x8d, 0xe2, - 0x56, 0xd7, 0x13, 0x67, 0x79, 0x86, 0x81, 0xfe, 0x5a, 0x1a, 0x9c, 0x7a, 0xf8, 0xb9, 0xef, 0x9d, - 0x0b, 0xe1, 0xf1, 0x09, 0x10, 0x77, 0x91, 0x1f, 0xd1, 0x8d, 0xfa, 0xb4, 0x9f, 0x9f, 0x1b, 0x9d, - 0x20, 0x72, 0xc9, 0x4b, 0x4a, 0xbf, 0x8b, 0xa8, 0xc1, 0xaf, 0xc7, 0x06, 0x13, 0xcd, 0x1c, 0xc2, - 0x84, 0x37, 0x90, 0xe9, 0xa1, 0x85, 0xc8, 0xed, 0xc3, 0x4c, 0xb8, 0xf7, 0x27, 0xe4, 0xbd, 0x4b, - 0xc3, 0x09, 0x86, 0x57, 0x27, 0x9a, 0x19, 0x71, 0x24, 0x0c, 0x25, 0xdb, 0xbf, 0x07, 0xc9, 0x60, - 0xda, 0x2f, 0x92, 0xa5, 0xe7, 0x1c, 0x1f, 0xa4, 0xbd, 0xa6, 0x95, 0x78, 0xe1, 0x6f, 0x24, 0x98, - 0x51, 0x31, 0x71, 0xda, 0x0f, 0xb0, 0x49, 0x63, 0x9e, 0xe0, 0x55, 0x89, 0x34, 0xf9, 0xab, 0x92, - 0x12, 0x24, 0x83, 0xbc, 0xe4, 0x45, 0x5e, 0x68, 0x0c, 0x6a, 0xa1, 0x1b, 0xa0, 0xb4, 0x9c, 0x9e, - 0x6d, 0xea, 0xee, 0x91, 0xe6, 0x62, 0xdd, 0x38, 0xc0, 0xa6, 0xb8, 0x83, 0x99, 0xf5, 0xe5, 0x2a, - 0x17, 0x17, 0x7e, 0x1c, 0x01, 0x34, 0x98, 0x9c, 0x10, 0x15, 0xd1, 0xc8, 0x8d, 0x8d, 0x43, 0x1c, - 0x5e, 0x23, 0x27, 0xde, 0x9a, 0x8d, 0x04, 0x80, 0xc1, 0xc0, 0xfd, 0x25, 0x75, 0x43, 0x32, 0x82, - 0xfe, 0xe8, 0xec, 0xec, 0x6b, 0x94, 0x65, 0x5f, 0x99, 0x95, 0xfe, 0x52, 0x33, 0xb0, 0xc2, 0x59, - 0xff, 0x77, 0x0c, 0x50, 0xc5, 0xc5, 0xba, 0x87, 0x29, 0xf3, 0x90, 0xb3, 0xce, 0xda, 0x65, 0x98, - 0xe6, 0x07, 0xb3, 0xc8, 0x45, 0x0e, 0x66, 0x62, 0x52, 0x78, 0x55, 0xf4, 0x03, 0x98, 0x31, 0x9c, - 0x76, 0xaf, 0x63, 0x6b, 0xec, 0xee, 0x58, 0x04, 0xc2, 0xdf, 0x3d, 0xcb, 0x88, 0xc7, 0x3a, 0x57, - 0xac, 0x38, 0x6d, 0xfa, 0xed, 0xe7, 0x0e, 0x38, 0x20, 0xd3, 0x40, 0xcf, 0x41, 0x32, 0xd8, 0x50, - 0x2c, 0x04, 0x4e, 0xaa, 0x03, 0x01, 0x5a, 0x81, 0x69, 0x9d, 0x68, 0xce, 0x1e, 0x8b, 0x51, 0xcf, - 0xb3, 0x30, 0x35, 0xa6, 0x93, 0xad, 0x3d, 0xf4, 0x26, 0xa4, 0xf7, 0xee, 0xf3, 0xb8, 0x9d, 0x13, - 0x28, 0xbf, 0xd2, 0x9f, 0x3d, 0xee, 0xe7, 0x53, 0x77, 0x3e, 0x64, 0x83, 0xa5, 0xf4, 0xa9, 0xa6, - 0xf6, 0xee, 0x07, 0x1f, 0xe8, 0x26, 0xcc, 0x75, 0xf4, 0x47, 0xda, 0x9e, 0xab, 0x1b, 0x22, 0x50, - 0x6d, 0x73, 0x56, 0x90, 0xd4, 0xd9, 0x8e, 0xfe, 0xe8, 0x8e, 0x90, 0xd7, 0xcd, 0x36, 0xce, 0xfd, - 0x97, 0x04, 0x09, 0x31, 0x22, 0xd4, 0x05, 0x10, 0xd3, 0x63, 0x99, 0x3c, 0x14, 0x4a, 0x97, 0x3f, - 0x3c, 0xee, 0xe7, 0x93, 0x15, 0x26, 0xad, 0x57, 0xc9, 0xd3, 0x7e, 0xfe, 0x83, 0x67, 0x25, 0x2d, - 0x1f, 0x44, 0x4d, 0xf2, 0x46, 0xea, 0x26, 0x4b, 0x0d, 0x1e, 0xe8, 0x44, 0x3b, 0xb0, 0x88, 0xe7, - 0xec, 0xbb, 0x7a, 0x87, 0x2d, 0xae, 0xac, 0xce, 0x1c, 0xe8, 0x64, 0xcd, 0x97, 0xa1, 0x1c, 0x0d, - 0x39, 0x1e, 0xf0, 0xab, 0x7f, 0xbe, 0xa5, 0x82, 0x6f, 0xb4, 0x02, 0x57, 0x82, 0xca, 0x1a, 0x1d, - 0x74, 0xab, 0x67, 0x1c, 0x62, 0xe6, 0x09, 0x28, 0x67, 0xcd, 0x07, 0x85, 0x1b, 0xfa, 0xa3, 0x32, - 0x2f, 0x2a, 0x5c, 0x81, 0xf9, 0xd0, 0xb2, 0x06, 0x01, 0xe2, 0x5f, 0xcd, 0x40, 0x62, 0x5b, 0x3f, - 0x6a, 0x3b, 0xba, 0x89, 0x96, 0x20, 0xe5, 0x5f, 0xd9, 0xd3, 0x10, 0x9b, 0xdb, 0x61, 0x58, 0x84, - 0x2c, 0xc8, 0xf4, 0x08, 0x76, 0xe9, 0x9a, 0x68, 0xec, 0x11, 0x2a, 0xe7, 0xaa, 0x72, 0xf9, 0x69, - 0x3f, 0x7f, 0x7b, 0xb2, 0x29, 0xc2, 0x46, 0xcf, 0xb5, 0xbc, 0xa3, 0x62, 0xf3, 0xc3, 0xbb, 0xbb, - 0x02, 0x8a, 0x6e, 0x24, 0x47, 0x4d, 0xf7, 0xc2, 0x9f, 0xe2, 0x01, 0x04, 0x1d, 0xae, 0xd6, 0xb1, - 0x0c, 0xd7, 0x21, 0x7e, 0x9e, 0x5c, 0x48, 0x37, 0x98, 0x10, 0xbd, 0x02, 0xb3, 0x7b, 0x96, 0xcd, - 0xee, 0x68, 0x7c, 0x3d, 0x9e, 0x22, 0xcf, 0xf8, 0x62, 0xa1, 0xf8, 0x00, 0x32, 0xa1, 0x47, 0x0f, - 0x74, 0xa9, 0xe3, 0x6c, 0xa9, 0xb7, 0x8e, 0xfb, 0xf9, 0xf4, 0x60, 0xeb, 0xf0, 0xe5, 0xbe, 0x8c, - 0x8f, 0x4a, 0x0f, 0x9a, 0xa1, 0x8b, 0xbd, 0x00, 0xd3, 0xec, 0xf1, 0x31, 0x7f, 0xe7, 0xa4, 0xf2, - 0x0f, 0xf4, 0x16, 0x4c, 0xb7, 0xb1, 0x4e, 0xb0, 0x78, 0xc2, 0xb4, 0x74, 0xc6, 0x66, 0x64, 0x6f, - 0x7c, 0x55, 0xae, 0x8e, 0xca, 0x10, 0xe7, 0xb7, 0x6e, 0xec, 0xae, 0x6c, 0x3c, 0x35, 0x79, 0xea, - 0x6b, 0xb5, 0xb5, 0x29, 0x55, 0xd4, 0x44, 0x35, 0x48, 0xb8, 0xfc, 0xa2, 0x95, 0xdd, 0xa0, 0x9d, - 0x7b, 0xd8, 0x0e, 0xdd, 0xe3, 0xae, 0x4d, 0xa9, 0x7e, 0x5d, 0xb4, 0xe3, 0xbf, 0x76, 0xe0, 0xac, - 0x2e, 0x1e, 0x73, 0x14, 0x27, 0x0c, 0xc8, 0x06, 0x80, 0x43, 0x28, 0x74, 0x80, 0x16, 0xcb, 0xba, - 0xb3, 0x8b, 0xb8, 0xb3, 0x07, 0x38, 0x74, 0x83, 0x4b, 0x07, 0xc8, 0x6b, 0xa2, 0x4d, 0x00, 0x23, - 0xf0, 0x34, 0xec, 0x8a, 0x2e, 0xb5, 0xf2, 0xda, 0x45, 0xa2, 0x99, 0xb5, 0x29, 0x35, 0x84, 0x80, - 0x3e, 0x84, 0x94, 0x31, 0xd8, 0x3a, 0xd9, 0x59, 0x06, 0xf8, 0xfa, 0x85, 0xf8, 0x73, 0x8d, 0x72, - 0xe6, 0x40, 0x3a, 0xcc, 0x99, 0xca, 0x28, 0x67, 0xd6, 0x20, 0x2d, 0xf2, 0x22, 0xfc, 0xdd, 0x7a, - 0x76, 0x8e, 0x51, 0x76, 0xd8, 0x4a, 0xfc, 0x97, 0xed, 0xc5, 0x9a, 0x6d, 0x38, 0x26, 0x36, 0x6b, - 0xf4, 0x5b, 0x15, 0x69, 0x60, 0xf6, 0x41, 0xd0, 0x2a, 0x64, 0x8c, 0x36, 0xd6, 0xed, 0x5e, 0xd7, - 0xc7, 0x41, 0x13, 0xe2, 0xa4, 0x45, 0x3d, 0x01, 0xb4, 0x09, 0x68, 0x8f, 0xbd, 0x90, 0x08, 0xf7, - 0x8a, 0xdd, 0xf4, 0x4d, 0x02, 0xa6, 0xb0, 0xba, 0xea, 0xa0, 0x67, 0xe8, 0x45, 0x48, 0xdb, 0x8e, - 0x6d, 0xe8, 0xb6, 0x81, 0xdb, 0xcc, 0xbb, 0xf1, 0xcb, 0xc1, 0x61, 0x21, 0xfa, 0x14, 0x32, 0x64, - 0x28, 0x84, 0xcf, 0x5e, 0x61, 0x2d, 0xbe, 0x71, 0xd1, 0xa4, 0xdf, 0xda, 0x94, 0x3a, 0x82, 0x84, - 0x7e, 0x0d, 0x14, 0x6f, 0xe4, 0x66, 0x80, 0x5d, 0x33, 0x9e, 0xfd, 0x1a, 0xe9, 0x94, 0xab, 0x8c, - 0xb5, 0x29, 0x75, 0x0c, 0x0d, 0x7d, 0x06, 0xb3, 0x64, 0xf8, 0xbd, 0x6d, 0xf6, 0x1a, 0x6b, 0xe0, - 0x3b, 0x67, 0xa6, 0xb7, 0x4f, 0x7a, 0xa2, 0xbc, 0x36, 0xa5, 0x8e, 0x62, 0x51, 0x78, 0x7b, 0xf8, - 0x82, 0x21, 0x9b, 0x3d, 0x17, 0xfe, 0xe4, 0x0b, 0x0f, 0x0a, 0x3f, 0x82, 0x55, 0x4e, 0x42, 0x42, - 0xdc, 0x02, 0x05, 0x77, 0xab, 0x09, 0x45, 0x2e, 0xfc, 0xa5, 0x0c, 0x72, 0x10, 0xba, 0x2d, 0x03, - 0x0a, 0x9c, 0xed, 0xe0, 0x41, 0x1b, 0xf5, 0x1a, 0x91, 0xb5, 0x29, 0x75, 0xce, 0x2f, 0x1b, 0xbc, - 0x69, 0x7b, 0x05, 0x66, 0x3b, 0x8e, 0x69, 0xed, 0x59, 0x03, 0xae, 0xe6, 0x99, 0xc2, 0x8c, 0x2f, - 0x16, 0x5c, 0x7d, 0x7b, 0xe8, 0xdd, 0xc7, 0x24, 0xef, 0x9d, 0xd7, 0xa6, 0x42, 0x0f, 0x43, 0xa8, - 0xef, 0x70, 0x7b, 0xb6, 0x6d, 0xd9, 0xfb, 0x9a, 0x38, 0x2d, 0xf2, 0xb0, 0x24, 0x2d, 0xa4, 0xe2, - 0xc0, 0x57, 0x19, 0x21, 0xd3, 0x1b, 0xe7, 0x92, 0xa9, 0x3f, 0xf6, 0x35, 0x29, 0x60, 0xd3, 0x3b, - 0xa3, 0x6c, 0x7a, 0xf3, 0x7c, 0x36, 0x0d, 0xc1, 0x04, 0x74, 0xba, 0x7b, 0x22, 0x9d, 0x2e, 0x4f, - 0x68, 0xeb, 0x21, 0xc4, 0x61, 0x3e, 0xad, 0x8c, 0xf0, 0xe9, 0x8d, 0x73, 0xf9, 0x34, 0x3c, 0x46, - 0x41, 0xa8, 0x5b, 0x27, 0x10, 0xea, 0xeb, 0x13, 0x11, 0x6a, 0x08, 0x2c, 0xcc, 0xa8, 0xea, 0x49, - 0x8c, 0x5a, 0x9c, 0x8c, 0x51, 0x43, 0x90, 0x43, 0x94, 0xfa, 0xfd, 0x31, 0xba, 0x50, 0xce, 0xdf, - 0x6f, 0x27, 0xa6, 0x08, 0xd6, 0xa4, 0x31, 0xbe, 0xd0, 0x4f, 0xe0, 0x8b, 0x39, 0x06, 0xff, 0xe6, - 0x05, 0xf8, 0x22, 0xd4, 0xc0, 0x38, 0x61, 0x7c, 0x0c, 0x33, 0xe1, 0x4d, 0xce, 0xde, 0x57, 0x9c, - 0x4d, 0x47, 0xa7, 0xbc, 0xe7, 0x67, 0x36, 0x10, 0x2a, 0x42, 0x3f, 0x18, 0xe7, 0x8a, 0xf9, 0x73, - 0xc1, 0x4f, 0xb9, 0xbe, 0x5c, 0x93, 0xc6, 0xc9, 0x02, 0x40, 0xf6, 0x6f, 0xa6, 0x43, 0xc4, 0x51, - 0xf8, 0x43, 0x09, 0xa2, 0x0d, 0xa7, 0x85, 0x32, 0x83, 0x6c, 0x13, 0xcb, 0x13, 0xbd, 0x3f, 0x50, - 0x17, 0xc7, 0x9a, 0x17, 0xce, 0xe8, 0x47, 0x90, 0x9d, 0x0b, 0x2a, 0xa1, 0x77, 0x21, 0xd1, 0xe5, - 0x21, 0xab, 0xe0, 0x86, 0xc2, 0x59, 0xf5, 0xb9, 0xa6, 0xea, 0x57, 0xb9, 0x79, 0x23, 0xfc, 0x9f, - 0x71, 0x36, 0x1c, 0x13, 0xa3, 0x0c, 0xc0, 0xb6, 0x4e, 0x48, 0xf7, 0xc0, 0xd5, 0x09, 0x56, 0xa6, - 0x50, 0x02, 0xa2, 0xeb, 0x1b, 0x4d, 0x45, 0xba, 0xf9, 0x71, 0x38, 0x37, 0x54, 0x55, 0x4b, 0xf5, - 0xcd, 0xfa, 0xe6, 0xaa, 0xb6, 0x59, 0xda, 0xa8, 0x35, 0x95, 0x29, 0x94, 0x85, 0x85, 0x8f, 0x4a, - 0xf5, 0x1d, 0x91, 0x2c, 0xd2, 0xea, 0x9b, 0x3b, 0x35, 0xf5, 0x5e, 0xe9, 0xae, 0x22, 0xa1, 0xab, - 0x80, 0xd4, 0xad, 0xca, 0x7a, 0xb3, 0x5a, 0xd6, 0x2a, 0x5b, 0x1b, 0xdb, 0xa5, 0xca, 0x4e, 0x7d, - 0x6b, 0x53, 0x89, 0x20, 0x19, 0x62, 0xd5, 0xad, 0xcd, 0x9a, 0x02, 0x37, 0x7f, 0x11, 0x85, 0x18, - 0xb5, 0x0e, 0xf4, 0x22, 0xa4, 0x76, 0x37, 0x9b, 0xdb, 0xb5, 0x4a, 0xfd, 0x4e, 0xbd, 0x56, 0x55, - 0xa6, 0x72, 0xf3, 0x8f, 0x9f, 0x2c, 0xcd, 0xd2, 0xa2, 0x5d, 0x9b, 0x74, 0xb1, 0xc1, 0x68, 0x11, - 0xe5, 0x20, 0x5e, 0x2e, 0x55, 0xd6, 0x77, 0xb7, 0x15, 0x29, 0x97, 0x79, 0xfc, 0x64, 0x09, 0xa8, - 0x02, 0xa7, 0x24, 0xf4, 0x1c, 0x24, 0xd4, 0x5a, 0x73, 0x67, 0x4b, 0xad, 0x29, 0x91, 0xdc, 0xec, - 0xe3, 0x27, 0x4b, 0x29, 0x5a, 0x28, 0x98, 0x06, 0xbd, 0x02, 0xe9, 0x66, 0x65, 0xad, 0xb6, 0x51, - 0xd2, 0x2a, 0x6b, 0xa5, 0xcd, 0xd5, 0x9a, 0x12, 0xcd, 0x2d, 0x3c, 0x7e, 0xb2, 0xa4, 0x8c, 0x9a, - 0x26, 0x6d, 0xa2, 0xbe, 0xb1, 0xbd, 0xa5, 0xee, 0x28, 0xb1, 0x41, 0x13, 0x9c, 0x11, 0x50, 0x01, - 0x80, 0xd7, 0xbe, 0x53, 0xab, 0x55, 0x95, 0xe9, 0x1c, 0x7a, 0xfc, 0x64, 0x29, 0x43, 0xcb, 0x07, - 0x1b, 0x1d, 0xbd, 0x04, 0x33, 0x15, 0xb5, 0x56, 0xda, 0xa9, 0x69, 0xcd, 0x9d, 0xd2, 0x4e, 0x53, - 0x89, 0x0f, 0x46, 0x12, 0xda, 0xbc, 0xa8, 0x08, 0x73, 0xa5, 0xdd, 0x9d, 0x2d, 0x6d, 0x48, 0x37, - 0x91, 0xbb, 0xf6, 0xf8, 0xc9, 0xd2, 0x3c, 0xd5, 0x2d, 0xf5, 0x3c, 0x27, 0xac, 0xff, 0x1a, 0x28, - 0x43, 0xfd, 0xd7, 0x56, 0x2b, 0x8a, 0x9c, 0xbb, 0xfa, 0xf8, 0xc9, 0x12, 0x1a, 0x1d, 0xc2, 0x6a, - 0x05, 0xfd, 0x7f, 0xb8, 0xba, 0xf3, 0xc9, 0x76, 0xad, 0x5a, 0x6b, 0x56, 0xb4, 0xe1, 0x61, 0x27, - 0x73, 0xd9, 0xc7, 0x4f, 0x96, 0x16, 0x68, 0x9d, 0xb1, 0xa1, 0xbf, 0x0e, 0x4a, 0x73, 0x47, 0xad, - 0x95, 0x36, 0xb4, 0xfa, 0xe6, 0x6a, 0xad, 0xc9, 0x16, 0x0b, 0x06, 0x5d, 0x1a, 0xd9, 0x66, 0x74, - 0x08, 0x9b, 0xb5, 0x8f, 0x46, 0xf0, 0x53, 0x03, 0xfd, 0x91, 0x9d, 0x93, 0x93, 0x7f, 0xfc, 0xe7, - 0x8b, 0x53, 0x7f, 0xf1, 0x93, 0xc5, 0xa9, 0xf2, 0xf5, 0x2f, 0xfe, 0x63, 0x71, 0xea, 0x8b, 0xe3, - 0x45, 0xe9, 0x67, 0xc7, 0x8b, 0xd2, 0x97, 0xc7, 0x8b, 0xd2, 0xbf, 0x1f, 0x2f, 0x4a, 0xbf, 0xff, - 0xd5, 0xe2, 0xd4, 0xcf, 0xbe, 0x5a, 0x9c, 0xfa, 0xf2, 0xab, 0xc5, 0xa9, 0x4f, 0xe3, 0xdc, 0x6a, - 0x5b, 0x71, 0x76, 0xba, 0x7a, 0xf3, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0x3f, 0x14, 0x3b, 0x78, - 0xf5, 0x38, 0x00, 0x00, +func init() { proto.RegisterFile("jobs/jobspb/jobs.proto", fileDescriptor_jobs_71126cd89273342d) } + +var fileDescriptor_jobs_71126cd89273342d = []byte{ + // 4824 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xc4, 0x5b, 0x4b, 0x6c, 0x1b, 0x49, + 0x7a, 0x56, 0x93, 0x14, 0xd9, 0xfc, 0x25, 0x52, 0xad, 0x92, 0x6c, 0x73, 0xb8, 0x1e, 0x51, 0xcb, + 0x9d, 0x87, 0xed, 0xd9, 0xa1, 0x76, 0x3d, 0xd9, 0x79, 0x38, 0x33, 0x9e, 0x11, 0x1f, 0x96, 0x48, + 0x5b, 0x0f, 0x37, 0x25, 0xcf, 0x63, 0x33, 0xdb, 0x69, 0x76, 0x97, 0xa8, 0x8e, 0x9a, 0xdd, 0x74, + 0x57, 0xd3, 0xb6, 0x36, 0x41, 0x12, 0x6c, 0x10, 0x60, 0xe1, 0x53, 0x02, 0x24, 0x01, 0x16, 0x89, + 0x81, 0x00, 0xd9, 0x05, 0x72, 0x48, 0x10, 0x60, 0x10, 0x24, 0x39, 0xe4, 0x96, 0xcb, 0x1c, 0x12, + 0x60, 0x2f, 0x01, 0x06, 0x39, 0x70, 0x13, 0xcd, 0x25, 0xc7, 0x20, 0xb9, 0xf9, 0x92, 0xa0, 0x1e, + 0xdd, 0x6c, 0x52, 0x94, 0x44, 0xd9, 0x33, 0x9b, 0x8b, 0xcd, 0xfe, 0xeb, 0xaf, 0xaf, 0x5e, 0x7f, + 0x7d, 0xff, 0x5f, 0x7f, 0x95, 0xe0, 0xe2, 0x6f, 0xb8, 0x2d, 0xb2, 0x42, 0xff, 0xe9, 0xb6, 0xd8, + 0x7f, 0xa5, 0xae, 0xe7, 0xfa, 0x2e, 0x7a, 0xc1, 0x70, 0x8d, 0x03, 0xcf, 0xd5, 0x8d, 0xfd, 0x12, + 0xb9, 0x6f, 0x97, 0x58, 0x09, 0xd7, 0xca, 0x5f, 0xc0, 0x9e, 0xe7, 0x7a, 0x54, 0x9f, 0xff, 0xe0, + 0x35, 0xf2, 0x8b, 0x6d, 0xb7, 0xed, 0xb2, 0x9f, 0x2b, 0xf4, 0x97, 0x90, 0x22, 0x86, 0xd1, 0x6d, + 0xad, 0x98, 0xba, 0xaf, 0x0b, 0x59, 0x2e, 0x90, 0x59, 0xee, 0xeb, 0x7b, 0xae, 0xd7, 0xd1, 0xfd, + 0x00, 0xe3, 0x5b, 0xe4, 0xbe, 0xbd, 0x62, 0xe8, 0xbe, 0x6e, 0xbb, 0xed, 0x15, 0x13, 0x13, 0xa3, + 0xdb, 0x5a, 0x21, 0xbe, 0xd7, 0x33, 0xfc, 0x9e, 0x87, 0x4d, 0xa1, 0x54, 0x18, 0xa3, 0xe4, 0x63, + 0x47, 0x77, 0xfc, 0x00, 0xbf, 0xe7, 0x5b, 0xf6, 0xca, 0xbe, 0x6d, 0xac, 0xf8, 0x56, 0x07, 0x13, + 0x5f, 0xef, 0x74, 0x45, 0xc9, 0x37, 0x69, 0x55, 0x62, 0xec, 0xe3, 0x8e, 0x6e, 0xec, 0xeb, 0x4e, + 0x1b, 0x7b, 0x2b, 0xbc, 0x0d, 0xa3, 0xdb, 0x12, 0x2a, 0x2f, 0x19, 0x76, 0x8f, 0xf8, 0xd8, 0x7b, + 0x80, 0x3d, 0x62, 0xb9, 0xce, 0x8a, 0xf8, 0xd4, 0xc4, 0x37, 0xd7, 0x2a, 0xfe, 0x0e, 0x4c, 0xdf, + 0xc1, 0x3a, 0xc1, 0xe8, 0x13, 0x48, 0x39, 0xae, 0x89, 0x35, 0xcb, 0xcc, 0x49, 0xcb, 0xd2, 0x95, + 0x4c, 0x79, 0xf5, 0xa8, 0x5f, 0x48, 0x6e, 0xba, 0x26, 0xae, 0x57, 0x9f, 0xf6, 0x0b, 0x6f, 0xb4, + 0x2d, 0x7f, 0xbf, 0xd7, 0x2a, 0x19, 0x6e, 0x67, 0x25, 0x9c, 0x51, 0xb3, 0x35, 0xf8, 0xbd, 0xd2, + 0x3d, 0x68, 0xaf, 0x88, 0xf9, 0x28, 0xf1, 0x6a, 0x6a, 0x92, 0x22, 0xd6, 0x4d, 0xb4, 0x08, 0xd3, + 0xb8, 0xeb, 0x1a, 0xfb, 0xb9, 0xd8, 0xb2, 0x74, 0x25, 0xae, 0xf2, 0x8f, 0x1b, 0x89, 0xff, 0xfc, + 0xf3, 0x82, 0x54, 0xfc, 0x59, 0x0c, 0x2e, 0x95, 0x75, 0xe3, 0xa0, 0xd7, 0xad, 0x39, 0x86, 0x77, + 0xd8, 0xf5, 0x2d, 0xd7, 0xd9, 0x62, 0xff, 0x12, 0xa4, 0x40, 0xfc, 0x00, 0x1f, 0xb2, 0xfe, 0xcc, + 0xaa, 0xf4, 0x27, 0x7a, 0x0f, 0x12, 0x1d, 0xd7, 0xc4, 0x0c, 0x28, 0x7b, 0xfd, 0x6a, 0xe9, 0xc4, + 0xc5, 0x2d, 0x0d, 0xd0, 0x36, 0x5c, 0x13, 0xab, 0xac, 0x1a, 0x6a, 0x81, 0x7c, 0xd0, 0x21, 0x9a, + 0xe5, 0xec, 0xb9, 0xb9, 0xf8, 0xb2, 0x74, 0x65, 0xe6, 0xfa, 0x8d, 0x53, 0x20, 0x4e, 0xe8, 0x56, + 0xe9, 0xf6, 0x46, 0xb3, 0xee, 0xec, 0xb9, 0xe5, 0x99, 0xa3, 0x7e, 0x21, 0x25, 0x3e, 0xd4, 0xd4, + 0x41, 0x87, 0xd0, 0x1f, 0xf9, 0x2d, 0x08, 0x64, 0xb4, 0xff, 0x3d, 0xcf, 0x62, 0xfd, 0x4f, 0xab, + 0xf4, 0x27, 0xfa, 0x36, 0x20, 0xcc, 0xf1, 0xb0, 0xa9, 0x51, 0x4b, 0xd2, 0xe8, 0x00, 0x63, 0x6c, + 0x80, 0x4a, 0x58, 0x52, 0xd5, 0x7d, 0xfd, 0x36, 0x3e, 0xe4, 0x33, 0x24, 0xe6, 0xe9, 0x77, 0xe3, + 0x90, 0x1d, 0x74, 0x85, 0xc1, 0xaf, 0x43, 0x92, 0x99, 0x00, 0x66, 0x2d, 0x64, 0xaf, 0x7f, 0x67, + 0xa2, 0xe9, 0xa0, 0x55, 0x4b, 0x4d, 0x56, 0x4f, 0x15, 0xf5, 0x11, 0x82, 0x04, 0xd1, 0x6d, 0x5f, + 0x74, 0x84, 0xfd, 0x46, 0x7f, 0x2a, 0xc1, 0xf2, 0x68, 0x8f, 0xca, 0x87, 0xb7, 0x37, 0x9a, 0x1b, + 0x3a, 0xb5, 0xa3, 0xdb, 0xf8, 0xb0, 0x5e, 0xcd, 0xc5, 0x97, 0xe3, 0x57, 0x66, 0xae, 0x6f, 0x4d, + 0xde, 0x70, 0xed, 0x0c, 0xc4, 0x9a, 0xe3, 0x7b, 0x87, 0xea, 0x99, 0x0d, 0xe7, 0x9b, 0xf0, 0xf2, + 0x44, 0x50, 0x51, 0x1b, 0x4a, 0x73, 0x1b, 0x5a, 0x84, 0xe9, 0x07, 0xba, 0xdd, 0xc3, 0x62, 0xb4, + 0xfc, 0xe3, 0x46, 0xec, 0x6d, 0xa9, 0x78, 0x09, 0x92, 0x7c, 0x62, 0x50, 0x06, 0xd2, 0xab, 0xb5, + 0xe6, 0xf5, 0xef, 0xbd, 0xb9, 0x56, 0xd9, 0x50, 0xa6, 0xc4, 0x12, 0xfc, 0xaf, 0x04, 0x17, 0x9b, + 0xbe, 0x87, 0xf5, 0x4e, 0xdd, 0x69, 0x63, 0x42, 0xc7, 0x54, 0xc5, 0xbe, 0x6e, 0xd9, 0x04, 0x39, + 0x90, 0x25, 0xac, 0x44, 0xd3, 0x4d, 0xd3, 0xc3, 0x84, 0xf0, 0x06, 0xcb, 0x6b, 0x4f, 0xfb, 0x85, + 0xca, 0x44, 0x5b, 0xc7, 0x30, 0xec, 0x15, 0x0e, 0x61, 0x39, 0x6d, 0xc3, 0xb0, 0x4b, 0xbc, 0xa5, + 0x55, 0x0e, 0xa7, 0x66, 0x48, 0xf4, 0x13, 0x7d, 0x17, 0x12, 0xa4, 0xab, 0x3b, 0x6c, 0x08, 0x33, + 0xd7, 0x2f, 0x45, 0xe6, 0x3f, 0xd8, 0x82, 0xcd, 0xae, 0xee, 0x94, 0x13, 0x9f, 0xf7, 0x0b, 0x53, + 0x2a, 0x53, 0x45, 0x65, 0x00, 0xe2, 0xeb, 0x9e, 0xaf, 0x51, 0x2e, 0x11, 0xd6, 0xff, 0x62, 0xa4, + 0x22, 0xe5, 0x9a, 0xd2, 0xbe, 0x6d, 0x94, 0x76, 0x02, 0xae, 0x11, 0xd5, 0xd3, 0xac, 0x1a, 0x95, + 0x16, 0x5f, 0x80, 0x4b, 0x23, 0x13, 0xb0, 0xed, 0xb9, 0x6d, 0xda, 0xa3, 0xe2, 0x3f, 0x26, 0x21, + 0xc3, 0x37, 0x4c, 0x30, 0x27, 0xc3, 0x0d, 0x4a, 0xcf, 0xd2, 0x20, 0xba, 0x09, 0x32, 0x76, 0x4c, + 0x8e, 0x10, 0x9b, 0x1c, 0x21, 0x85, 0x1d, 0x93, 0xd5, 0x7f, 0x81, 0xef, 0xc0, 0x38, 0x5b, 0x8c, + 0xd4, 0x51, 0xbf, 0x10, 0xdf, 0x55, 0xeb, 0x7c, 0x2b, 0xbe, 0x0b, 0x79, 0x13, 0x77, 0x3d, 0x6c, + 0xe8, 0x74, 0x2f, 0xb6, 0x58, 0xd7, 0xb5, 0x8e, 0xee, 0x58, 0x7b, 0x98, 0xf8, 0xb9, 0x04, 0xb3, + 0x8d, 0xdc, 0x40, 0x83, 0x8f, 0x6d, 0x43, 0x94, 0xa3, 0xdf, 0x93, 0x60, 0xa1, 0xe7, 0x59, 0x44, + 0x6b, 0x1d, 0x6a, 0xb6, 0x6b, 0xe8, 0xb6, 0xe5, 0x1f, 0x6a, 0x07, 0x0f, 0x72, 0xd3, 0x6c, 0x43, + 0xdc, 0x3c, 0x93, 0x55, 0xc4, 0x24, 0x95, 0x76, 0x3d, 0x8b, 0x94, 0x0f, 0xef, 0x08, 0x84, 0xdb, + 0x0f, 0x98, 0xd1, 0x96, 0x17, 0x8f, 0xfa, 0x05, 0x65, 0x57, 0xad, 0x47, 0x8b, 0xee, 0xa9, 0x4a, + 0x6f, 0x44, 0x19, 0xe9, 0x21, 0x9d, 0x58, 0xae, 0xa3, 0xb9, 0x9c, 0x9f, 0x72, 0x49, 0x36, 0x51, + 0xd7, 0xcf, 0xcf, 0x6c, 0xea, 0x3c, 0x3e, 0xc6, 0xc1, 0x7f, 0x28, 0x41, 0x9e, 0xba, 0x0a, 0x6c, + 0xd0, 0x69, 0x0a, 0xfd, 0x90, 0xe6, 0x61, 0xc3, 0xf5, 0xcc, 0x5c, 0x8a, 0xce, 0x53, 0xb9, 0xf9, + 0x6f, 0x93, 0x7a, 0x08, 0xe6, 0xd1, 0x7a, 0x3d, 0xcb, 0x2c, 0xed, 0xee, 0xd6, 0xab, 0x47, 0xfd, + 0x42, 0x6e, 0x3b, 0x00, 0x0f, 0x17, 0x51, 0x65, 0xd0, 0x6a, 0xae, 0x7b, 0x42, 0x09, 0x7a, 0x1b, + 0xb2, 0x86, 0x6b, 0xdb, 0xd8, 0x60, 0xc3, 0xde, 0x55, 0xeb, 0x39, 0x99, 0x2d, 0xf0, 0xfc, 0x51, + 0xbf, 0x90, 0xa9, 0x84, 0x25, 0x74, 0xa9, 0x33, 0x46, 0xf4, 0x13, 0xa9, 0x30, 0x17, 0x99, 0x30, + 0xe6, 0x07, 0xd2, 0x6c, 0xb6, 0xae, 0x4e, 0x4c, 0x61, 0x6a, 0x16, 0x0f, 0x7d, 0xe7, 0x2b, 0x70, + 0x61, 0xec, 0x2a, 0x9e, 0x45, 0x3d, 0xe9, 0x28, 0xf5, 0x28, 0x90, 0xe5, 0x8b, 0x12, 0x6e, 0xa8, + 0xcf, 0xb2, 0x90, 0x55, 0x31, 0xf1, 0x5d, 0x0f, 0x07, 0x3b, 0xea, 0x33, 0x09, 0x16, 0x68, 0x9c, + 0xe0, 0x59, 0x5d, 0xdf, 0xf5, 0x34, 0x0f, 0x3f, 0xf4, 0x2c, 0x1f, 0x93, 0x5c, 0x8c, 0x19, 0xdd, + 0xea, 0x29, 0x43, 0x18, 0x06, 0x2a, 0x55, 0x43, 0x10, 0x55, 0x60, 0x70, 0xbb, 0xbb, 0xf9, 0xa3, + 0x5f, 0x14, 0x6e, 0x4c, 0xb4, 0x8e, 0xc7, 0x43, 0x97, 0x52, 0xbd, 0xaa, 0x22, 0xf3, 0x18, 0x30, + 0xba, 0x0c, 0x09, 0x6a, 0xb7, 0xcc, 0x55, 0xa4, 0xcb, 0xf2, 0x51, 0xbf, 0x90, 0xa0, 0x96, 0xad, + 0x32, 0xe9, 0xd0, 0x06, 0x4f, 0x3c, 0xc3, 0x06, 0x5f, 0x83, 0x19, 0x5f, 0x6f, 0xd9, 0x58, 0xa3, + 0x2d, 0x13, 0xb1, 0xfd, 0x5e, 0x19, 0x99, 0x09, 0x72, 0xdf, 0x6e, 0xe9, 0x04, 0x97, 0x76, 0xa8, + 0x66, 0x64, 0xec, 0xe0, 0x07, 0x02, 0x82, 0x56, 0x60, 0xc6, 0x7d, 0x80, 0x3d, 0xcf, 0x32, 0xb1, + 0x66, 0xb6, 0xd8, 0x1e, 0x4a, 0x97, 0xb3, 0x47, 0xfd, 0x02, 0x6c, 0x09, 0x71, 0xb5, 0xac, 0x42, + 0xa0, 0x52, 0x6d, 0x21, 0x1f, 0x16, 0x05, 0x69, 0x84, 0xfb, 0x9f, 0xd9, 0x53, 0x8a, 0x75, 0xe1, + 0xdd, 0xc9, 0x17, 0x83, 0xaf, 0x7b, 0x60, 0x3c, 0x2c, 0xb2, 0xe0, 0x83, 0x44, 0xad, 0x63, 0x25, + 0xe8, 0x35, 0x98, 0xef, 0x7a, 0xb8, 0xab, 0x7b, 0x58, 0x33, 0xdc, 0x4e, 0xd7, 0xc6, 0x3e, 0x36, + 0x99, 0xf5, 0xcb, 0xaa, 0x22, 0x0a, 0x2a, 0x81, 0x1c, 0xbd, 0x4c, 0xbd, 0x92, 0xee, 0xd3, 0x80, + 0x87, 0x60, 0x8f, 0x6a, 0xa6, 0x99, 0x66, 0x86, 0x49, 0xeb, 0x42, 0x88, 0xde, 0x80, 0x0b, 0x83, + 0x75, 0x23, 0x5a, 0xb7, 0xd7, 0xb2, 0x2d, 0xb2, 0x8f, 0xcd, 0x1c, 0x30, 0xed, 0xc5, 0x48, 0xe1, + 0x76, 0x50, 0x86, 0x0e, 0x87, 0x4c, 0xd1, 0xa0, 0x13, 0xa3, 0xb7, 0x71, 0x6e, 0x66, 0x59, 0xba, + 0x32, 0x5d, 0x5e, 0x7f, 0xda, 0x2f, 0x54, 0x27, 0xb6, 0x23, 0x82, 0x3b, 0x2b, 0xbe, 0x87, 0x71, + 0xc4, 0x2c, 0x2b, 0x02, 0x2f, 0x6a, 0x51, 0x81, 0x0c, 0xa9, 0x00, 0x83, 0x2d, 0x98, 0x9b, 0x7d, + 0x66, 0xb6, 0x8b, 0xa0, 0xa0, 0x55, 0x48, 0xf1, 0xd0, 0x9b, 0xe4, 0x32, 0x6c, 0x01, 0xbf, 0x79, + 0x92, 0x0d, 0x31, 0xad, 0xc8, 0x2a, 0x05, 0xf5, 0x50, 0x15, 0xc0, 0x3f, 0xec, 0x06, 0x96, 0x98, + 0x65, 0x28, 0x2f, 0x9f, 0x84, 0x72, 0xd8, 0x8d, 0x1a, 0x62, 0xda, 0x17, 0xdf, 0x04, 0x35, 0x60, + 0x96, 0xc7, 0xf5, 0x02, 0x67, 0x8e, 0xe1, 0xbc, 0x7a, 0x02, 0x0e, 0x0b, 0x57, 0xf4, 0x08, 0xd2, + 0x0c, 0x09, 0x25, 0x04, 0x6d, 0x43, 0x96, 0xc6, 0x98, 0x54, 0x53, 0xa0, 0x29, 0x0c, 0xed, 0xea, + 0x09, 0x68, 0x55, 0xa1, 0x1c, 0xc1, 0xcb, 0x98, 0x11, 0x19, 0xc9, 0xff, 0x8f, 0x04, 0xf3, 0xc7, + 0xc8, 0x03, 0xed, 0x40, 0x2c, 0x3c, 0x36, 0x50, 0x4e, 0x8f, 0xb1, 0x23, 0xc3, 0xf3, 0x10, 0x49, + 0xcc, 0x32, 0x51, 0x1b, 0xd2, 0xd4, 0x9c, 0x1d, 0x9f, 0x9e, 0x49, 0x62, 0x0c, 0xbc, 0x71, 0xd4, + 0x2f, 0xc8, 0xdb, 0x4c, 0xf8, 0xdc, 0x4d, 0xc8, 0x1c, 0xbc, 0x6e, 0xa2, 0x02, 0xcc, 0xf8, 0xae, + 0x86, 0x1f, 0x59, 0xc4, 0xb7, 0x9c, 0x36, 0x0b, 0x16, 0x64, 0x15, 0x7c, 0xb7, 0x26, 0x24, 0xf9, + 0x3f, 0x8b, 0x01, 0x3a, 0xbe, 0x4b, 0xd1, 0x3f, 0x48, 0x70, 0x39, 0x88, 0x01, 0x5c, 0xcf, 0x6a, + 0x5b, 0x8e, 0x6e, 0x0f, 0x05, 0x03, 0x12, 0x9b, 0xed, 0x4f, 0x9e, 0x87, 0x0a, 0x44, 0x80, 0xb0, + 0x25, 0xe0, 0x47, 0x03, 0x85, 0xcb, 0xd4, 0x83, 0xf2, 0x40, 0xe1, 0x98, 0xca, 0x3d, 0x35, 0xd7, + 0x3b, 0xa1, 0x72, 0xfe, 0x36, 0xbc, 0x78, 0x2a, 0xf0, 0x79, 0x7c, 0x57, 0xfe, 0x47, 0x12, 0x5c, + 0x3a, 0xc1, 0xa3, 0x44, 0x71, 0x32, 0x1c, 0xe7, 0x6e, 0x14, 0x67, 0xe6, 0xfa, 0xaf, 0x3e, 0x87, + 0xd7, 0x8a, 0x74, 0xa2, 0x91, 0x90, 0x25, 0x25, 0x56, 0xfc, 0x0e, 0xcc, 0x89, 0x4a, 0x81, 0x1f, + 0x45, 0x2f, 0x02, 0xec, 0x5b, 0xed, 0x7d, 0xed, 0xa1, 0xee, 0x63, 0x4f, 0x9c, 0x25, 0xd3, 0x54, + 0xf2, 0x21, 0x15, 0x14, 0xff, 0x55, 0x86, 0x4c, 0xbd, 0xd3, 0x75, 0x3d, 0x3f, 0xf0, 0xb2, 0x77, + 0x20, 0xc9, 0xfc, 0x02, 0x11, 0xeb, 0x57, 0x3a, 0xa5, 0x87, 0x43, 0x35, 0xb9, 0x7f, 0x11, 0xb4, + 0x20, 0x30, 0x42, 0xf7, 0x17, 0x1b, 0xeb, 0xfe, 0xde, 0x83, 0x24, 0x4f, 0x1c, 0x88, 0x80, 0xbc, + 0x30, 0x26, 0x92, 0xaf, 0x6f, 0xdd, 0xb2, 0x6c, 0x7c, 0x8b, 0xa9, 0x05, 0xe0, 0xbc, 0x12, 0x7a, + 0x05, 0x64, 0x42, 0x7c, 0x8d, 0x58, 0x3f, 0xe4, 0xde, 0x33, 0xce, 0xcf, 0xa4, 0xcd, 0xe6, 0x4e, + 0xd3, 0xfa, 0x21, 0x56, 0x53, 0x84, 0xf8, 0xf4, 0x07, 0xca, 0x83, 0xfc, 0x50, 0xb7, 0x6d, 0xe6, + 0x65, 0xa7, 0xd9, 0x19, 0x3c, 0xfc, 0x1e, 0xde, 0x66, 0xc9, 0xaf, 0x77, 0x9b, 0x09, 0x87, 0xd9, + 0xd5, 0xfd, 0x7d, 0x16, 0x39, 0xa6, 0x55, 0xe0, 0xa2, 0x6d, 0xdd, 0xdf, 0x47, 0x39, 0x48, 0x11, + 0x9d, 0xfa, 0x2e, 0x92, 0x93, 0x97, 0xe3, 0x57, 0x66, 0xd5, 0xe0, 0x13, 0x2d, 0x01, 0xf3, 0xbc, + 0xfc, 0x93, 0x39, 0xb1, 0xb8, 0x1a, 0x91, 0xb0, 0x79, 0x38, 0xb0, 0xba, 0xda, 0xde, 0x01, 0xe1, + 0x4e, 0x4b, 0xcc, 0xc3, 0x81, 0xd5, 0xbd, 0x75, 0x9b, 0xa8, 0x29, 0x5a, 0x78, 0xeb, 0x80, 0xa0, + 0x57, 0x61, 0xce, 0x62, 0x27, 0x17, 0xcd, 0xb4, 0x3c, 0x6c, 0xf8, 0xf6, 0x21, 0x73, 0x58, 0xb2, + 0x9a, 0xe5, 0xe2, 0xaa, 0x90, 0xa2, 0xab, 0xa0, 0x8c, 0xba, 0x59, 0xe6, 0x68, 0x64, 0x75, 0x6e, + 0xc4, 0xcb, 0x52, 0x55, 0xbe, 0xd4, 0x11, 0xc7, 0x99, 0xe1, 0xaa, 0x5c, 0x3e, 0xf0, 0x99, 0x25, + 0x58, 0xe8, 0xea, 0x1e, 0xc1, 0x5a, 0xab, 0xe7, 0x98, 0x36, 0xd6, 0x38, 0x57, 0xe7, 0xb2, 0x4c, + 0x7b, 0x9e, 0x15, 0x95, 0x59, 0x09, 0xa7, 0xf5, 0xb3, 0x62, 0xef, 0x8b, 0xff, 0x0f, 0xb1, 0x77, + 0xfe, 0x67, 0x31, 0x98, 0x66, 0x76, 0x8e, 0x6e, 0x40, 0x82, 0x2e, 0xb3, 0x38, 0xd9, 0x4d, 0x1a, + 0x73, 0xb1, 0x3a, 0x08, 0x41, 0xc2, 0xd1, 0x3b, 0x38, 0x87, 0x98, 0x11, 0xb0, 0xdf, 0xe8, 0x12, + 0xa4, 0x08, 0xbe, 0xaf, 0x3d, 0xd0, 0xed, 0xdc, 0x02, 0x5b, 0xe1, 0x24, 0xc1, 0xf7, 0xef, 0xe9, + 0x36, 0xba, 0x00, 0x49, 0x8b, 0x68, 0x0e, 0x7e, 0x98, 0x5b, 0x64, 0x33, 0x35, 0x6d, 0x91, 0x4d, + 0xfc, 0x90, 0xd1, 0xb6, 0xee, 0xb5, 0xb1, 0xaf, 0x19, 0xae, 0x4d, 0x72, 0x17, 0xe8, 0x06, 0xa3, + 0x21, 0x1d, 0x15, 0x55, 0x5c, 0x9b, 0xa0, 0x6f, 0x40, 0xfa, 0xa1, 0x4e, 0x34, 0xdc, 0xe9, 0xfa, + 0x87, 0x6c, 0xb2, 0x64, 0x6a, 0xf6, 0xa4, 0x46, 0xbf, 0x1b, 0x09, 0x39, 0xa6, 0xc4, 0x1b, 0x09, + 0x39, 0xae, 0x24, 0x1a, 0x09, 0x39, 0xa1, 0x4c, 0x37, 0x12, 0xf2, 0xb4, 0x92, 0x6c, 0x24, 0xe4, + 0xa4, 0x92, 0x6a, 0x24, 0xe4, 0x94, 0x22, 0x37, 0x12, 0xb2, 0xac, 0xa4, 0x1b, 0x09, 0x39, 0xad, + 0x40, 0x23, 0x21, 0x83, 0x32, 0xd3, 0x48, 0xc8, 0x33, 0xca, 0x6c, 0x23, 0x21, 0xcf, 0x2a, 0x99, + 0x46, 0x42, 0xce, 0x28, 0xd9, 0x46, 0x42, 0xce, 0x2a, 0x73, 0x8d, 0x84, 0x3c, 0xa7, 0x28, 0x8d, + 0x84, 0xac, 0x28, 0xf3, 0x8d, 0x84, 0x3c, 0xaf, 0xa0, 0xe2, 0x67, 0x12, 0x28, 0x4d, 0x7c, 0xbf, + 0x87, 0x1d, 0x03, 0xdf, 0xd3, 0xed, 0xca, 0x7e, 0xcf, 0x39, 0x40, 0xaf, 0xc0, 0x9c, 0x41, 0x7f, + 0x68, 0xfc, 0x60, 0x4c, 0x87, 0x2a, 0xb1, 0xa1, 0x66, 0x98, 0xb8, 0x49, 0xa5, 0x74, 0xc4, 0x2f, + 0x02, 0x08, 0x3d, 0xba, 0xb3, 0x79, 0xd6, 0x2c, 0xcd, 0x55, 0xe8, 0x76, 0x1e, 0x81, 0xf1, 0xdc, + 0x87, 0x8c, 0x3e, 0x86, 0x60, 0x54, 0xf7, 0x21, 0x5a, 0x81, 0x45, 0x07, 0x3f, 0xf2, 0xb5, 0x51, + 0x65, 0x46, 0x15, 0xea, 0x3c, 0x2d, 0xab, 0x44, 0x2b, 0x14, 0xff, 0x25, 0x06, 0x73, 0x41, 0xa7, + 0x03, 0x3a, 0xdc, 0x03, 0x85, 0x2e, 0x8b, 0x65, 0x6a, 0xbe, 0xcb, 0x91, 0x02, 0x62, 0x7c, 0xef, + 0x14, 0x62, 0x1c, 0x41, 0xa1, 0xdf, 0x75, 0x73, 0xc7, 0x65, 0xcd, 0x71, 0xd7, 0xa0, 0x66, 0x48, + 0x54, 0x96, 0xdf, 0x85, 0x6c, 0x50, 0x89, 0x4b, 0x50, 0x05, 0x92, 0x43, 0xed, 0xbd, 0x36, 0x41, + 0x7b, 0xc1, 0x54, 0xab, 0xa2, 0x6a, 0xfe, 0x37, 0x01, 0x1d, 0x6f, 0x3b, 0xea, 0x96, 0xa6, 0xb9, + 0x5b, 0xda, 0x1a, 0x76, 0x4b, 0xef, 0x9c, 0x6f, 0x6c, 0x91, 0x6e, 0x47, 0x4f, 0x75, 0xff, 0x14, + 0x83, 0x2c, 0x77, 0x11, 0xa1, 0x3b, 0x7a, 0x0d, 0xe6, 0x19, 0x69, 0x59, 0x4e, 0x5b, 0xeb, 0x0a, + 0x21, 0x1b, 0x5f, 0x4c, 0x55, 0x82, 0x82, 0x50, 0xf9, 0x5b, 0x90, 0xf1, 0xb0, 0x6e, 0x0e, 0x14, + 0x63, 0x4c, 0x71, 0x96, 0x0a, 0x43, 0xa5, 0x97, 0x21, 0xcb, 0xbc, 0xe1, 0x40, 0x2b, 0xce, 0xb4, + 0x32, 0x4c, 0x1a, 0xaa, 0x95, 0x21, 0x43, 0xba, 0xba, 0x33, 0xd0, 0x4a, 0xb0, 0x49, 0x3d, 0x23, + 0x77, 0x34, 0x4b, 0xeb, 0x44, 0x7d, 0xa9, 0x87, 0x49, 0xaf, 0x83, 0xb5, 0xae, 0xcb, 0x0f, 0x5b, + 0x71, 0x35, 0xcd, 0x25, 0xdb, 0x2e, 0x41, 0xbb, 0xcc, 0x54, 0xd8, 0x5c, 0x68, 0x26, 0x9f, 0x9c, + 0x5c, 0x92, 0xb5, 0x72, 0x6d, 0xf2, 0xe9, 0x54, 0xe7, 0xc8, 0xb0, 0xa0, 0xf8, 0x5b, 0x70, 0x89, + 0xc6, 0xcb, 0x9c, 0x14, 0x2b, 0x2c, 0xdd, 0x1d, 0x18, 0xa7, 0x0e, 0x29, 0x16, 0x73, 0x87, 0xe1, + 0xe7, 0xfa, 0x51, 0xbf, 0x90, 0xa4, 0xda, 0xcf, 0xed, 0xb8, 0x92, 0x14, 0xb8, 0x6e, 0x16, 0xf3, + 0x90, 0x1b, 0x6d, 0x3d, 0x3c, 0xa3, 0xff, 0x1a, 0x5c, 0xdc, 0xc4, 0x0f, 0xc7, 0x75, 0xac, 0x0c, + 0x29, 0xce, 0x44, 0x81, 0xf1, 0x5e, 0x19, 0xe5, 0xc7, 0x68, 0xf2, 0xbe, 0xc4, 0x1a, 0xdd, 0x61, + 0x15, 0xd4, 0xa0, 0x62, 0xf1, 0x13, 0xb8, 0x34, 0x82, 0x1e, 0x2e, 0xc4, 0xfb, 0x90, 0xa4, 0x67, + 0x38, 0x11, 0xa3, 0x64, 0x8f, 0x9f, 0x0f, 0x8e, 0xa3, 0x37, 0xa9, 0xbe, 0x2a, 0xaa, 0x15, 0x55, + 0x96, 0x5c, 0xe8, 0x75, 0x30, 0x5d, 0xeb, 0x3b, 0x16, 0xf1, 0xd1, 0x07, 0x30, 0x2b, 0xd6, 0x96, + 0x2e, 0x79, 0xd0, 0xed, 0x33, 0xcc, 0x63, 0xc6, 0x0b, 0x41, 0x48, 0xf1, 0x6f, 0x25, 0x58, 0xa8, + 0x7a, 0x6e, 0xb7, 0x8b, 0x4d, 0xc1, 0xfa, 0x7c, 0x2e, 0x02, 0xb2, 0x97, 0x22, 0x64, 0xbf, 0x09, + 0xb1, 0x7a, 0x55, 0x44, 0xf5, 0x37, 0x9f, 0xf7, 0xb0, 0x50, 0xaf, 0xa2, 0x77, 0xf8, 0x84, 0xf4, + 0x08, 0x63, 0xc2, 0xec, 0xb1, 0xe3, 0xdb, 0x90, 0xc1, 0x31, 0x45, 0x55, 0x54, 0x28, 0xfe, 0x34, + 0x05, 0x17, 0xa2, 0x93, 0xbc, 0x56, 0x09, 0x3a, 0xfe, 0x29, 0xa4, 0x2c, 0xc7, 0xc4, 0x8f, 0xf0, + 0x44, 0x8c, 0x37, 0x0e, 0xa2, 0x24, 0xe6, 0xa3, 0x4e, 0x61, 0x82, 0x03, 0xa3, 0xc0, 0x44, 0x1f, + 0x85, 0x81, 0x26, 0x4f, 0xe0, 0xdc, 0x78, 0x66, 0xf4, 0xea, 0x48, 0xd0, 0x39, 0x14, 0xd3, 0x31, + 0xd7, 0xf0, 0x35, 0xc5, 0x74, 0x4d, 0x98, 0xb7, 0x1c, 0x1f, 0x7b, 0x36, 0xd6, 0x1f, 0xd0, 0x10, + 0x85, 0x36, 0x2f, 0xf2, 0x38, 0x93, 0x06, 0x04, 0x4a, 0x04, 0x80, 0x07, 0x16, 0x9f, 0xc2, 0x42, + 0x14, 0x34, 0x58, 0x82, 0xd3, 0x73, 0x3b, 0x6c, 0x86, 0x07, 0xb0, 0x41, 0x0a, 0x25, 0x02, 0x54, + 0x17, 0xd3, 0x7e, 0x0f, 0x92, 0xfc, 0xc8, 0x2e, 0x12, 0xa5, 0x37, 0x9f, 0x75, 0xda, 0x79, 0x2a, + 0x40, 0x15, 0x68, 0xf9, 0x3f, 0x91, 0x60, 0x36, 0xba, 0xdc, 0xc8, 0x02, 0x99, 0xf5, 0x3d, 0x60, + 0xa7, 0x78, 0x79, 0x93, 0x46, 0xa5, 0xac, 0x90, 0xad, 0xc1, 0xfb, 0xcf, 0xbc, 0x06, 0x1c, 0x42, + 0x98, 0x52, 0xdd, 0xa4, 0xa1, 0x8e, 0xe9, 0xb9, 0xdd, 0x41, 0xa2, 0x3c, 0xae, 0xca, 0x54, 0x40, + 0xa3, 0xb7, 0xfc, 0x6f, 0x43, 0x3a, 0x34, 0x94, 0xc8, 0x59, 0x3d, 0xfe, 0x15, 0x9e, 0xd5, 0x4f, + 0x6d, 0xbf, 0x0a, 0x99, 0xa1, 0x19, 0x43, 0x17, 0xc3, 0x3e, 0x24, 0xca, 0x49, 0xde, 0x87, 0x33, + 0x51, 0x8a, 0xbf, 0x48, 0xc2, 0xc2, 0x38, 0xa6, 0xfd, 0x18, 0x94, 0x08, 0x6f, 0x69, 0xb6, 0x45, + 0x7c, 0xb1, 0x9f, 0xae, 0x9e, 0x7e, 0xb4, 0x8c, 0x90, 0x9f, 0xb0, 0x96, 0xac, 0x37, 0x4c, 0x89, + 0xdf, 0x87, 0xac, 0xc9, 0x3b, 0xae, 0x89, 0x8d, 0x1a, 0x3f, 0xf3, 0x44, 0x38, 0x86, 0x00, 0x05, + 0x7a, 0xc6, 0x8c, 0x14, 0x11, 0x76, 0x83, 0x10, 0xa0, 0x87, 0x59, 0x1a, 0xcb, 0x64, 0xbb, 0x27, + 0x53, 0x6e, 0x1e, 0xf5, 0x0b, 0xf3, 0x02, 0x2b, 0x48, 0xcb, 0x3c, 0xf7, 0x4a, 0xcd, 0x9b, 0x23, + 0x80, 0x26, 0x75, 0xa0, 0xb4, 0x9c, 0x36, 0x3c, 0x3d, 0x70, 0xa0, 0x74, 0x1f, 0x3d, 0xbf, 0x03, + 0xa5, 0x3f, 0xeb, 0x26, 0xfa, 0x7d, 0x09, 0xe6, 0x79, 0x8e, 0xb6, 0xd3, 0xf3, 0x75, 0x9e, 0x78, + 0x0f, 0x4e, 0x9a, 0x1f, 0x1f, 0xf5, 0x0b, 0x73, 0x6c, 0x42, 0x36, 0x44, 0x19, 0x6b, 0xb6, 0xfc, + 0xac, 0xcd, 0x0e, 0x50, 0xc4, 0xe9, 0x2b, 0x14, 0x98, 0xe8, 0x36, 0x64, 0xf9, 0xb1, 0x39, 0xb8, + 0x02, 0x67, 0x47, 0xd0, 0x4c, 0xf9, 0xa5, 0xa7, 0xfd, 0xc2, 0xf2, 0x18, 0xcb, 0xe2, 0x27, 0xee, + 0x7b, 0x5c, 0x57, 0xcd, 0xec, 0x45, 0x3f, 0x91, 0x01, 0x99, 0xd0, 0x34, 0x0e, 0xbb, 0xe2, 0xc4, + 0xfa, 0xfc, 0xae, 0x6c, 0x36, 0xb0, 0x11, 0x8a, 0x89, 0xda, 0x30, 0x17, 0x34, 0xc2, 0x1d, 0x3a, + 0xc9, 0xa5, 0xbf, 0x92, 0x66, 0x02, 0xb3, 0xe6, 0xa3, 0x26, 0x22, 0x79, 0x72, 0x11, 0x16, 0xc7, + 0x46, 0x39, 0x5f, 0x24, 0xe1, 0xe2, 0x30, 0x11, 0x86, 0x71, 0x88, 0x36, 0xea, 0x21, 0xdf, 0x9f, + 0x98, 0x4c, 0x03, 0x0c, 0x4e, 0x66, 0xc1, 0xd7, 0xa8, 0x8f, 0xfc, 0x74, 0xc4, 0x47, 0x3e, 0x03, + 0x3e, 0x33, 0xaf, 0x11, 0xfc, 0xc0, 0x51, 0x7e, 0x14, 0xfa, 0x02, 0x9e, 0x7f, 0xf9, 0xe0, 0x19, + 0xe0, 0x59, 0xfd, 0xe0, 0x33, 0xf4, 0x06, 0xff, 0x2c, 0x41, 0x66, 0x68, 0x64, 0xbf, 0x4c, 0x77, + 0xb0, 0x1d, 0x46, 0x43, 0xfc, 0xa1, 0xc4, 0xdb, 0xe7, 0x1f, 0xd6, 0x70, 0x90, 0x94, 0xff, 0x7b, + 0x09, 0x32, 0x43, 0x13, 0xf9, 0x35, 0x39, 0x92, 0xaf, 0xbe, 0xe7, 0x2d, 0xc8, 0x0e, 0x2f, 0x51, + 0xa4, 0x0d, 0xe9, 0xab, 0x69, 0xa3, 0xf8, 0x16, 0x24, 0xb9, 0x04, 0x21, 0xc8, 0x7e, 0xb8, 0x5a, + 0xdf, 0xa9, 0x6f, 0xae, 0x69, 0xb7, 0xb6, 0x54, 0x6d, 0xad, 0xa2, 0x4c, 0xa1, 0x59, 0x90, 0xab, + 0xb5, 0x3b, 0x35, 0x2a, 0x54, 0x24, 0x34, 0x03, 0x29, 0xf6, 0x55, 0xab, 0x2a, 0xb1, 0x62, 0x19, + 0x14, 0x8e, 0xbd, 0x87, 0xa9, 0x63, 0xa0, 0x71, 0x3f, 0x2a, 0xc1, 0x02, 0x0b, 0xd2, 0x3b, 0x34, + 0x7e, 0xa3, 0xae, 0x50, 0x8b, 0x44, 0xcf, 0xf3, 0x61, 0x11, 0x75, 0x8a, 0x9b, 0x7a, 0x07, 0x17, + 0xff, 0x2e, 0x01, 0xf3, 0x03, 0x90, 0xc0, 0x2d, 0xbe, 0x02, 0x32, 0xb1, 0x9c, 0x03, 0x6d, 0x70, + 0xfd, 0xcd, 0x53, 0x62, 0x96, 0x73, 0xb0, 0xab, 0xd6, 0xd5, 0x14, 0x2d, 0xdc, 0xf5, 0x2c, 0xd4, + 0x80, 0x84, 0xdb, 0xf5, 0x83, 0xd3, 0xe0, 0x9b, 0xa7, 0x4c, 0xc5, 0xb1, 0x36, 0x4a, 0x5b, 0x5d, + 0x5f, 0x9c, 0xe5, 0x19, 0x06, 0xfa, 0x2b, 0x69, 0x70, 0xea, 0xe1, 0xe7, 0xbe, 0x77, 0xce, 0x85, + 0xc7, 0x27, 0x40, 0xdc, 0x45, 0x7e, 0x48, 0x37, 0xea, 0xd3, 0x7e, 0x61, 0x7e, 0x74, 0x82, 0xc8, + 0x73, 0x5e, 0x52, 0x06, 0x5d, 0x44, 0x0d, 0x7e, 0x3d, 0x36, 0x98, 0x68, 0xe6, 0x10, 0x26, 0xbc, + 0x81, 0xcc, 0x0c, 0x2d, 0x44, 0xbe, 0x0d, 0xb3, 0xd1, 0xde, 0x8f, 0xc9, 0x7b, 0xaf, 0x0e, 0x27, + 0x18, 0x5e, 0x9b, 0x68, 0x66, 0xc4, 0x91, 0x30, 0x92, 0x6c, 0x7f, 0x0b, 0xd2, 0xe1, 0xb4, 0x9f, + 0x27, 0x4b, 0xcf, 0x39, 0x3e, 0x4c, 0x7b, 0x4d, 0x2b, 0xc9, 0xe2, 0xdf, 0x48, 0x30, 0xab, 0x62, + 0xe2, 0xda, 0x0f, 0xb0, 0x49, 0x63, 0x9e, 0xf0, 0x55, 0x89, 0x34, 0xf9, 0xab, 0x92, 0x55, 0x48, + 0x87, 0x79, 0xc9, 0xf3, 0xbc, 0xd0, 0x18, 0xd4, 0x42, 0x57, 0x41, 0x69, 0xb9, 0x3d, 0xc7, 0xd4, + 0xbd, 0x43, 0xcd, 0xc3, 0xba, 0xb1, 0x8f, 0x4d, 0x71, 0x07, 0x33, 0x17, 0xc8, 0x55, 0x2e, 0x2e, + 0xfe, 0x38, 0x06, 0x68, 0x30, 0x39, 0x11, 0x2a, 0xa2, 0x91, 0x1b, 0x1b, 0x87, 0x38, 0xbc, 0xc6, + 0xc6, 0xde, 0x9a, 0x8d, 0x04, 0x80, 0xe1, 0xc0, 0x83, 0x25, 0xf5, 0x22, 0x32, 0x82, 0xfe, 0xf8, + 0xf4, 0xec, 0x6b, 0x9c, 0x65, 0x5f, 0x99, 0x95, 0xfe, 0x52, 0x33, 0xb0, 0xc2, 0x59, 0xff, 0x77, + 0x02, 0x50, 0xc5, 0xc3, 0xba, 0x8f, 0x29, 0xf3, 0x90, 0xd3, 0xce, 0xda, 0x65, 0x98, 0xe6, 0x07, + 0xb3, 0xd8, 0x79, 0x0e, 0x66, 0x62, 0x52, 0x78, 0x55, 0xf4, 0x03, 0x98, 0x35, 0x5c, 0xbb, 0xd7, + 0x71, 0x34, 0x76, 0x77, 0x2c, 0x02, 0xe1, 0xef, 0x9d, 0x66, 0xc4, 0xc7, 0x3a, 0x57, 0xaa, 0xb8, + 0x36, 0xfd, 0x0e, 0x72, 0x07, 0x1c, 0x90, 0x69, 0xa0, 0xcb, 0x90, 0x0e, 0x37, 0x14, 0x0b, 0x81, + 0xd3, 0xea, 0x40, 0x80, 0xae, 0xc3, 0xb4, 0x4e, 0x34, 0x77, 0x8f, 0xc5, 0xa8, 0x67, 0x59, 0x98, + 0x9a, 0xd0, 0xc9, 0xd6, 0x1e, 0x7a, 0x03, 0x32, 0x7b, 0xf7, 0x79, 0xdc, 0xce, 0x09, 0x94, 0x5f, + 0xe9, 0xcf, 0x1d, 0xf5, 0x0b, 0x33, 0xb7, 0xee, 0xb2, 0xc1, 0x52, 0xfa, 0x54, 0x67, 0xf6, 0xee, + 0x87, 0x1f, 0xe8, 0x1a, 0xcc, 0x77, 0xf4, 0x47, 0xda, 0x9e, 0xa7, 0x1b, 0x22, 0x50, 0xb5, 0x39, + 0x2b, 0x48, 0xea, 0x5c, 0x47, 0x7f, 0x74, 0x4b, 0xc8, 0xeb, 0xa6, 0x8d, 0xf3, 0xff, 0x25, 0x41, + 0x4a, 0x8c, 0x08, 0x75, 0x01, 0xc4, 0xf4, 0x58, 0x26, 0x0f, 0x85, 0x32, 0xe5, 0xbb, 0x47, 0xfd, + 0x42, 0xba, 0xc2, 0xa4, 0xf5, 0x2a, 0x79, 0xda, 0x2f, 0x7c, 0xf0, 0xac, 0xa4, 0x15, 0x80, 0xa8, + 0x69, 0xde, 0x48, 0xdd, 0x64, 0xa9, 0xc1, 0x7d, 0x9d, 0x68, 0xfb, 0x16, 0xf1, 0xdd, 0xb6, 0xa7, + 0x77, 0xd8, 0xe2, 0xca, 0xea, 0xec, 0xbe, 0x4e, 0xd6, 0x03, 0x19, 0xca, 0xd3, 0x90, 0xe3, 0x01, + 0xbf, 0xfa, 0xe7, 0x5b, 0x2a, 0xfc, 0x46, 0xd7, 0xe1, 0x42, 0x58, 0x59, 0xa3, 0x83, 0x6e, 0xf5, + 0x8c, 0x03, 0xcc, 0x3c, 0x01, 0xe5, 0xac, 0x85, 0xb0, 0x70, 0x43, 0x7f, 0x54, 0xe6, 0x45, 0xc5, + 0x0b, 0xb0, 0x10, 0x59, 0xd6, 0x30, 0x40, 0xec, 0xc2, 0x37, 0xee, 0xb8, 0x4e, 0x5b, 0xed, 0x39, + 0x8e, 0xe5, 0xb4, 0x37, 0xac, 0xb6, 0xa7, 0x47, 0x1f, 0xc7, 0xdd, 0x85, 0xb9, 0x91, 0xc7, 0xa7, + 0x82, 0x61, 0xa2, 0x39, 0xb1, 0xe1, 0xd7, 0xaa, 0xa5, 0x0a, 0xff, 0x0c, 0xa2, 0xef, 0xac, 0x31, + 0xf4, 0x5d, 0x5c, 0x82, 0xcb, 0xe3, 0x5a, 0x0c, 0x7b, 0xf4, 0x93, 0x0c, 0xa4, 0xb6, 0xf5, 0x43, + 0xdb, 0xd5, 0x4d, 0xb4, 0x0c, 0x33, 0xc1, 0x23, 0x82, 0xa0, 0xe9, 0xb4, 0x1a, 0x15, 0x21, 0x0b, + 0xb2, 0x3d, 0x82, 0x3d, 0x6a, 0x25, 0x1a, 0x7b, 0x16, 0xcb, 0xd9, 0xb3, 0x5c, 0x7e, 0xda, 0x2f, + 0xdc, 0x9c, 0x6c, 0xd1, 0xb0, 0xd1, 0xf3, 0x2c, 0xff, 0xb0, 0xd4, 0xbc, 0x7b, 0x67, 0x57, 0x40, + 0xd1, 0xad, 0xed, 0xaa, 0x99, 0x5e, 0xf4, 0x53, 0x3c, 0xc9, 0xa0, 0x0b, 0xa0, 0x75, 0x2c, 0xc3, + 0x73, 0x49, 0x90, 0xb9, 0x17, 0xd2, 0x0d, 0x26, 0x44, 0xaf, 0xc2, 0xdc, 0x9e, 0xe5, 0xb0, 0x5b, + 0xa3, 0x40, 0x8f, 0x27, 0xed, 0xb3, 0x81, 0x58, 0x28, 0x3e, 0x80, 0x6c, 0xe4, 0x19, 0x06, 0x35, + 0xbe, 0x24, 0x33, 0xbe, 0xad, 0xa3, 0x7e, 0x21, 0x33, 0xd8, 0xcc, 0xdc, 0x00, 0x9f, 0xc7, 0x6b, + 0x66, 0x06, 0xcd, 0x50, 0xf3, 0x5b, 0x84, 0x69, 0xf6, 0x68, 0x9a, 0xbf, 0xbc, 0x52, 0xf9, 0x07, + 0x7a, 0x13, 0xa6, 0x6d, 0xac, 0x13, 0x2c, 0x1e, 0x55, 0x2d, 0x9f, 0x42, 0x0f, 0xec, 0xd5, 0xb1, + 0xca, 0xd5, 0x51, 0x19, 0x92, 0xfc, 0x1e, 0x90, 0xdd, 0xde, 0x1d, 0x4f, 0x96, 0x9e, 0xf8, 0x7e, + 0x6e, 0x7d, 0x4a, 0x15, 0x35, 0x51, 0x0d, 0x52, 0x1e, 0xbf, 0xfa, 0x65, 0x77, 0x7a, 0x67, 0x1e, + 0xff, 0x23, 0x37, 0xcb, 0xeb, 0x53, 0x6a, 0x50, 0x17, 0xed, 0x04, 0xef, 0x2f, 0xb8, 0x9f, 0x11, + 0xcf, 0x4b, 0x4a, 0x13, 0x86, 0x88, 0x03, 0xc0, 0x21, 0x14, 0x3a, 0x40, 0x8b, 0xdd, 0x03, 0xb0, + 0xab, 0xc1, 0xd3, 0x07, 0x38, 0x74, 0xa7, 0x4c, 0x07, 0xc8, 0x6b, 0xa2, 0x4d, 0x00, 0x23, 0xf4, + 0x7d, 0xec, 0xd2, 0x70, 0xe6, 0xfa, 0xb7, 0xcf, 0x13, 0x5f, 0xad, 0x4f, 0xa9, 0x11, 0x04, 0x74, + 0x17, 0x66, 0x8c, 0xc1, 0x66, 0xce, 0xcd, 0x31, 0xc0, 0xd7, 0xcf, 0xc5, 0xe8, 0xeb, 0x94, 0xc5, + 0x07, 0xd2, 0x61, 0x16, 0x57, 0x46, 0x59, 0xbc, 0x06, 0x19, 0x91, 0xa9, 0xe1, 0xef, 0xed, 0x73, + 0xf3, 0xcc, 0x89, 0x44, 0xad, 0x24, 0x78, 0x91, 0x5f, 0xaa, 0x39, 0x86, 0x6b, 0x62, 0xb3, 0x46, + 0xbf, 0x55, 0x91, 0x98, 0x66, 0x1f, 0x04, 0xad, 0x41, 0xd6, 0xb0, 0xb1, 0xee, 0xf4, 0xba, 0x01, + 0x0e, 0x9a, 0x10, 0x27, 0x23, 0xea, 0x09, 0xa0, 0x4d, 0x40, 0x7b, 0xec, 0xcd, 0x46, 0xb4, 0x57, + 0xec, 0xee, 0x71, 0x12, 0x30, 0x85, 0xd5, 0x55, 0x07, 0x3d, 0x43, 0x2f, 0x41, 0xc6, 0x71, 0x1d, + 0x43, 0x77, 0x0c, 0x6c, 0x33, 0x7f, 0xcb, 0xaf, 0x2b, 0x87, 0x85, 0xe8, 0x13, 0xc8, 0x92, 0xa1, + 0x43, 0x45, 0xee, 0x02, 0x6b, 0xf1, 0x3b, 0xe7, 0x4d, 0x43, 0xae, 0x4f, 0xa9, 0x23, 0x48, 0xe8, + 0xd7, 0x41, 0xf1, 0x47, 0xee, 0x2a, 0xd8, 0xc5, 0xe7, 0xe9, 0xef, 0xa3, 0x4e, 0xb8, 0x5c, 0x59, + 0x9f, 0x52, 0x8f, 0xa1, 0xa1, 0x4f, 0x61, 0x8e, 0x0c, 0xbf, 0x00, 0xce, 0x5d, 0x62, 0x0d, 0x7c, + 0xf7, 0xd4, 0x84, 0xfb, 0xb8, 0x47, 0xd3, 0xeb, 0x53, 0xea, 0x28, 0x16, 0x85, 0x77, 0x86, 0xaf, + 0x3c, 0x72, 0xb9, 0x33, 0xe1, 0xc7, 0x5f, 0xc1, 0x50, 0xf8, 0x11, 0x2c, 0x64, 0xc3, 0xa2, 0x3d, + 0xc6, 0x6d, 0xe4, 0x5e, 0x60, 0x6d, 0x9c, 0x76, 0xf8, 0x39, 0xc5, 0xbf, 0xad, 0x4f, 0xa9, 0x63, + 0x51, 0xcb, 0x69, 0x48, 0x89, 0x5b, 0xb0, 0xf0, 0x6e, 0x39, 0xa5, 0xc8, 0xc5, 0x9f, 0xa4, 0x41, + 0x0e, 0x43, 0xd7, 0x15, 0x40, 0x61, 0xb0, 0x31, 0x78, 0xd0, 0x47, 0x7d, 0x54, 0x6c, 0x7d, 0x4a, + 0x9d, 0x0f, 0xca, 0x06, 0x6f, 0xfa, 0x5e, 0x85, 0xb9, 0x8e, 0x6b, 0x5a, 0x7b, 0xd6, 0xc0, 0x33, + 0xf0, 0x4c, 0x69, 0x36, 0x10, 0x0b, 0xcf, 0x70, 0x73, 0xe8, 0xdd, 0xcb, 0x24, 0xef, 0xbd, 0xd7, + 0xa7, 0x22, 0x0f, 0x63, 0xa8, 0xa7, 0xf2, 0xf8, 0x88, 0x34, 0x71, 0x5a, 0xe6, 0x61, 0x59, 0x46, + 0x48, 0xc5, 0x81, 0xb7, 0x32, 0x42, 0xdd, 0x57, 0xcf, 0xa4, 0xee, 0x60, 0xec, 0xeb, 0x52, 0xc8, + 0xdd, 0xb7, 0x46, 0xb9, 0xfb, 0xda, 0xd9, 0xdc, 0x1d, 0x81, 0x09, 0xc9, 0x7b, 0x77, 0x2c, 0x79, + 0xaf, 0x4c, 0xb8, 0xb3, 0x22, 0x88, 0xc3, 0xec, 0x5d, 0x19, 0x61, 0xef, 0xab, 0x67, 0xb2, 0x77, + 0x74, 0x8c, 0x82, 0xbe, 0xb7, 0xc6, 0xd0, 0xf7, 0xeb, 0x13, 0xd1, 0x77, 0x04, 0x2c, 0xca, 0xdf, + 0xea, 0x38, 0xfe, 0x2e, 0x4d, 0xc6, 0xdf, 0x11, 0xc8, 0x21, 0x02, 0xff, 0xfe, 0x31, 0x72, 0x52, + 0xce, 0xde, 0xdd, 0x63, 0x53, 0x24, 0xeb, 0xd2, 0x31, 0x76, 0xd2, 0xc7, 0xb0, 0xd3, 0x3c, 0x83, + 0x7f, 0xe3, 0x1c, 0xec, 0x14, 0x69, 0xe0, 0x38, 0x3d, 0x7d, 0x04, 0xb3, 0x51, 0x4a, 0x61, 0xef, + 0x4b, 0x4e, 0x27, 0xbf, 0x13, 0xfe, 0x9e, 0x81, 0xd9, 0x40, 0xa4, 0x08, 0xfd, 0xe0, 0x38, 0x33, + 0x2d, 0x9c, 0x09, 0x7e, 0xc2, 0xf5, 0xed, 0xba, 0x74, 0x9c, 0x9a, 0x3a, 0x27, 0x50, 0xd3, 0x22, + 0x6b, 0xe4, 0xad, 0x73, 0x52, 0x53, 0xa4, 0xa5, 0xf1, 0xdc, 0x04, 0x20, 0x07, 0x0f, 0x01, 0x22, + 0x3c, 0x55, 0xfc, 0x23, 0x09, 0xe2, 0x0d, 0xb7, 0x85, 0xb2, 0x83, 0xe4, 0x1e, 0x4b, 0xcb, 0xbd, + 0x3f, 0x50, 0x17, 0xa7, 0xc8, 0x6f, 0x9d, 0xd2, 0xa3, 0x30, 0x19, 0x1a, 0x56, 0x42, 0xef, 0x42, + 0xaa, 0xcb, 0xe3, 0x71, 0x41, 0x45, 0xc5, 0xd3, 0xea, 0x73, 0x4d, 0x35, 0xa8, 0x72, 0xed, 0x6a, + 0xf4, 0x6f, 0x9f, 0x36, 0x5c, 0x13, 0xa3, 0x2c, 0xc0, 0xb6, 0x4e, 0x48, 0x77, 0xdf, 0xd3, 0x09, + 0x56, 0xa6, 0x50, 0x0a, 0xe2, 0xb7, 0x37, 0x9a, 0x8a, 0x74, 0xed, 0xa3, 0x68, 0x2a, 0xae, 0xaa, + 0xae, 0xd6, 0x37, 0xeb, 0x9b, 0x6b, 0xda, 0xe6, 0xea, 0x46, 0xad, 0xa9, 0x4c, 0xa1, 0x1c, 0x2c, + 0x7e, 0xb8, 0x5a, 0xdf, 0x11, 0xb9, 0x39, 0xad, 0xbe, 0xb9, 0x53, 0x53, 0xef, 0xad, 0xde, 0x51, + 0x24, 0x74, 0x11, 0x90, 0xba, 0x55, 0xb9, 0xdd, 0xac, 0x96, 0xb5, 0xca, 0xd6, 0xc6, 0xf6, 0x6a, + 0x65, 0xa7, 0xbe, 0xb5, 0xa9, 0xc4, 0x90, 0x0c, 0x89, 0xea, 0xd6, 0x66, 0x4d, 0x81, 0x6b, 0x7f, + 0x9d, 0x80, 0x04, 0x35, 0x46, 0xf4, 0x12, 0xcc, 0xec, 0x6e, 0x36, 0xb7, 0x6b, 0x95, 0xfa, 0xad, + 0x7a, 0xad, 0xaa, 0x4c, 0xe5, 0x17, 0x1e, 0x3f, 0x59, 0x9e, 0xa3, 0x45, 0xbb, 0x0e, 0xe9, 0x62, + 0x83, 0xb1, 0x30, 0xca, 0x43, 0xb2, 0xbc, 0x5a, 0xb9, 0xbd, 0xbb, 0xad, 0x48, 0xf9, 0xec, 0xe3, + 0x27, 0xcb, 0x40, 0x15, 0x38, 0x03, 0xa2, 0xcb, 0x90, 0x52, 0x6b, 0xcd, 0x9d, 0x2d, 0xb5, 0xa6, + 0xc4, 0xf2, 0x73, 0x8f, 0x9f, 0x2c, 0xcf, 0xd0, 0x42, 0x41, 0x6c, 0xe8, 0x55, 0xc8, 0x34, 0x2b, + 0xeb, 0xb5, 0x8d, 0x55, 0xad, 0xb2, 0xbe, 0xba, 0xb9, 0x56, 0x53, 0xe2, 0xf9, 0xc5, 0xc7, 0x4f, + 0x96, 0x95, 0xd1, 0x9d, 0x40, 0x9b, 0xa8, 0x6f, 0x6c, 0x6f, 0xa9, 0x3b, 0x4a, 0x62, 0xd0, 0x04, + 0x27, 0x20, 0x54, 0x04, 0xe0, 0xb5, 0x6f, 0xd5, 0x6a, 0x55, 0x65, 0x3a, 0x8f, 0x1e, 0x3f, 0x59, + 0xce, 0xd2, 0xf2, 0x01, 0xaf, 0xa0, 0x97, 0x61, 0xb6, 0xa2, 0xd6, 0x56, 0x77, 0x6a, 0x5a, 0x73, + 0x67, 0x75, 0xa7, 0xa9, 0x24, 0x07, 0x23, 0x89, 0x70, 0x05, 0x2a, 0xc1, 0xfc, 0xea, 0xee, 0xce, + 0x96, 0x36, 0xa4, 0x9b, 0xca, 0x5f, 0x7a, 0xfc, 0x64, 0x79, 0x81, 0xea, 0xae, 0xf6, 0x7c, 0x37, + 0xaa, 0xff, 0x6d, 0x50, 0x86, 0xfa, 0xaf, 0xad, 0x55, 0x14, 0x39, 0x7f, 0xf1, 0xf1, 0x93, 0x65, + 0x34, 0x3a, 0x84, 0xb5, 0x0a, 0xfa, 0x15, 0xb8, 0xb8, 0xf3, 0xf1, 0x76, 0xad, 0x5a, 0x6b, 0x56, + 0xb4, 0xe1, 0x61, 0xa7, 0xf3, 0xb9, 0xc7, 0x4f, 0x96, 0x17, 0x69, 0x9d, 0x63, 0x43, 0x7f, 0x1d, + 0x94, 0xe6, 0x8e, 0x5a, 0x5b, 0xdd, 0xd0, 0xea, 0x9b, 0x6b, 0xb5, 0x26, 0x5b, 0x2c, 0x18, 0x74, + 0x69, 0x64, 0x57, 0xd3, 0x21, 0x6c, 0xd6, 0x3e, 0x1c, 0xc1, 0x9f, 0x19, 0xe8, 0x8f, 0x6c, 0x54, + 0xf4, 0x36, 0x5c, 0xbc, 0xb3, 0xb5, 0xb9, 0xa6, 0xa9, 0xbb, 0x9b, 0xcc, 0x7e, 0x36, 0xea, 0x6b, + 0xea, 0x2a, 0x6b, 0x64, 0x36, 0x7f, 0xf9, 0xf1, 0x93, 0x65, 0xf6, 0x24, 0x64, 0xdc, 0xc6, 0xcb, + 0xcb, 0x3f, 0xfe, 0x8b, 0xa5, 0xa9, 0xbf, 0xfc, 0xe9, 0xd2, 0x54, 0xf9, 0xca, 0xe7, 0xff, 0xb1, + 0x34, 0xf5, 0xf9, 0xd1, 0x92, 0xf4, 0xf3, 0xa3, 0x25, 0xe9, 0x8b, 0xa3, 0x25, 0xe9, 0xdf, 0x8f, + 0x96, 0xa4, 0x3f, 0xf8, 0x72, 0x69, 0xea, 0xe7, 0x5f, 0x2e, 0x4d, 0x7d, 0xf1, 0xe5, 0xd2, 0xd4, + 0x27, 0x49, 0x6e, 0xef, 0xad, 0x24, 0x3b, 0x74, 0xbe, 0xf1, 0x7f, 0x01, 0x00, 0x00, 0xff, 0xff, + 0x86, 0x63, 0xbc, 0x8b, 0xc4, 0x3a, 0x00, 0x00, } diff --git a/pkg/jobs/jobspb/jobs.proto b/pkg/jobs/jobspb/jobs.proto index c556ccaf9a0f..d3c532c3f3d7 100644 --- a/pkg/jobs/jobspb/jobs.proto +++ b/pkg/jobs/jobspb/jobs.proto @@ -20,6 +20,7 @@ import "sql/catalog/descpb/structured.proto"; import "sql/catalog/descpb/tenant.proto"; import "util/hlc/timestamp.proto"; import "sql/schemachanger/scpb/scpb.proto"; +import "clusterversion/cluster_version.proto"; message Lease { option (gogoproto.equal) = true; @@ -313,6 +314,7 @@ message NewSchemaChangeProgress { repeated cockroach.sql.schemachanger.scpb.State states = 1; } + message ResumeSpanList { repeated roachpb.Span resume_spans = 1 [(gogoproto.nullable) = false]; } @@ -568,6 +570,14 @@ message CreateStatsProgress { } +message LongRunningMigrationDetails { + clusterversion.ClusterVersion cluster_version = 1; +} + +message LongRunningMigrationProgress { + +} + message Payload { string description = 1; // If empty, the description is assumed to be the statement. @@ -610,6 +620,7 @@ message Payload { TypeSchemaChangeDetails typeSchemaChange = 22; StreamIngestionDetails streamIngestion = 23; NewSchemaChangeDetails newSchemaChange = 24; + LongRunningMigrationDetails longRunningMigration = 25; } } @@ -632,6 +643,7 @@ message Progress { TypeSchemaChangeProgress typeSchemaChange = 17; StreamIngestionProgress streamIngest = 18; NewSchemaChangeProgress newSchemaChange = 19; + LongRunningMigrationProgress longRunningMigration = 20; } } @@ -653,6 +665,7 @@ enum Type { TYPEDESC_SCHEMA_CHANGE = 9 [(gogoproto.enumvalue_customname) = "TypeTypeSchemaChange"]; STREAM_INGESTION = 10 [(gogoproto.enumvalue_customname) = "TypeStreamIngestion"]; NEW_SCHEMA_CHANGE = 11 [(gogoproto.enumvalue_customname) = "TypeNewSchemaChange"]; + LONG_RUNNING_MIGRATION = 12 [(gogoproto.enumvalue_customname) = "TypeLongRunningMigration"]; } message Job { diff --git a/pkg/jobs/jobspb/wrap.go b/pkg/jobs/jobspb/wrap.go index 44809875b621..ae0b7be7ef13 100644 --- a/pkg/jobs/jobspb/wrap.go +++ b/pkg/jobs/jobspb/wrap.go @@ -30,6 +30,7 @@ var _ Details = CreateStatsDetails{} var _ Details = SchemaChangeGCDetails{} var _ Details = StreamIngestionDetails{} var _ Details = NewSchemaChangeDetails{} +var _ Details = LongRunningMigrationDetails{} // ProgressDetails is a marker interface for job progress details proto structs. type ProgressDetails interface{} @@ -42,6 +43,7 @@ var _ ProgressDetails = CreateStatsProgress{} var _ ProgressDetails = SchemaChangeGCProgress{} var _ ProgressDetails = StreamIngestionProgress{} var _ ProgressDetails = NewSchemaChangeProgress{} +var _ ProgressDetails = LongRunningMigrationProgress{} // Type returns the payload's job type. func (p *Payload) Type() Type { @@ -75,6 +77,8 @@ func DetailsType(d isPayload_Details) Type { return TypeStreamIngestion case *Payload_NewSchemaChange: return TypeNewSchemaChange + case *Payload_LongRunningMigration: + return TypeLongRunningMigration default: panic(errors.AssertionFailedf("Payload.Type called on a payload with an unknown details type: %T", d)) } @@ -109,6 +113,8 @@ func WrapProgressDetails(details ProgressDetails) interface { return &Progress_StreamIngest{StreamIngest: &d} case NewSchemaChangeProgress: return &Progress_NewSchemaChange{NewSchemaChange: &d} + case LongRunningMigrationProgress: + return &Progress_LongRunningMigration{LongRunningMigration: &d} default: panic(errors.AssertionFailedf("WrapProgressDetails: unknown details type %T", d)) } @@ -138,6 +144,8 @@ func (p *Payload) UnwrapDetails() Details { return *d.StreamIngestion case *Payload_NewSchemaChange: return *d.NewSchemaChange + case *Payload_LongRunningMigration: + return *d.LongRunningMigration default: return nil } @@ -167,6 +175,8 @@ func (p *Progress) UnwrapDetails() ProgressDetails { return *d.StreamIngest case *Progress_NewSchemaChange: return *d.NewSchemaChange + case *Progress_LongRunningMigration: + return *d.LongRunningMigration default: return nil } @@ -207,8 +217,8 @@ func WrapPayloadDetails(details Details) interface { return &Payload_TypeSchemaChange{TypeSchemaChange: &d} case StreamIngestionDetails: return &Payload_StreamIngestion{StreamIngestion: &d} - case NewSchemaChangeDetails: - return &Payload_NewSchemaChange{NewSchemaChange: &d} + case LongRunningMigrationDetails: + return &Payload_LongRunningMigration{LongRunningMigration: &d} default: panic(errors.AssertionFailedf("jobs.WrapPayloadDetails: unknown details type %T", d)) } @@ -244,7 +254,7 @@ const ( func (Type) SafeValue() {} // NumJobTypes is the number of jobs types. -const NumJobTypes = 12 +const NumJobTypes = 13 func init() { if len(Type_name) != NumJobTypes { diff --git a/pkg/jobs/registry.go b/pkg/jobs/registry.go index fbf34efa3b78..d3c7d95cc8c5 100644 --- a/pkg/jobs/registry.go +++ b/pkg/jobs/registry.go @@ -648,7 +648,7 @@ func (r *Registry) Start( UPDATE system.jobs SET claim_session_id = NULL WHERE claim_session_id <> $1 - AND status IN `+claimableStatusTupleString+` + AND status IN `+NonTerminalStatusTupleString+` AND NOT crdb_internal.sql_liveness_is_alive(claim_session_id)`, s.ID().UnsafeBytes(), ); err != nil { diff --git a/pkg/migration/BUILD.bazel b/pkg/migration/BUILD.bazel index 968c7fd4b4b9..9ad83fe4cf7d 100644 --- a/pkg/migration/BUILD.bazel +++ b/pkg/migration/BUILD.bazel @@ -13,6 +13,7 @@ go_library( "//pkg/clusterversion", "//pkg/kv", "//pkg/roachpb", + "//pkg/security", "//pkg/server/serverpb", "//pkg/util/log", "@com_github_cockroachdb_logtags//:logtags", diff --git a/pkg/migration/migration.go b/pkg/migration/migration.go index c5c2f45347e0..94bfff02f356 100644 --- a/pkg/migration/migration.go +++ b/pkg/migration/migration.go @@ -28,13 +28,14 @@ import ( "github.com/cockroachdb/cockroach/pkg/clusterversion" "github.com/cockroachdb/cockroach/pkg/kv" "github.com/cockroachdb/cockroach/pkg/roachpb" + "github.com/cockroachdb/cockroach/pkg/security" "github.com/cockroachdb/cockroach/pkg/server/serverpb" "github.com/cockroachdb/logtags" ) // Manager coordinates long-running migrations. type Manager interface { - Migrate(ctx context.Context, from, to clusterversion.ClusterVersion) error + Migrate(ctx context.Context, user security.SQLUsername, from, to clusterversion.ClusterVersion) error } // Cluster abstracts a physical KV cluster and can be utilized by a long-runnng diff --git a/pkg/migration/migrationjob/BUILD.bazel b/pkg/migration/migrationjob/BUILD.bazel new file mode 100644 index 000000000000..47544b726855 --- /dev/null +++ b/pkg/migration/migrationjob/BUILD.bazel @@ -0,0 +1,15 @@ +load("@io_bazel_rules_go//go:def.bzl", "go_library") + +go_library( + name = "migrationjob", + srcs = ["migration_job.go"], + importpath = "github.com/cockroachdb/cockroach/pkg/migration/migrationjob", + visibility = ["//visibility:public"], + deps = [ + "//pkg/jobs", + "//pkg/jobs/jobspb", + "//pkg/migration", + "//pkg/settings/cluster", + "//pkg/sql", + ], +) diff --git a/pkg/migration/migrationjob/migration_job.go b/pkg/migration/migrationjob/migration_job.go new file mode 100644 index 000000000000..34b4899e23ef --- /dev/null +++ b/pkg/migration/migrationjob/migration_job.go @@ -0,0 +1,52 @@ +// Copyright 2018 The Cockroach Authors. +// +// Use of this software is governed by the Business Source License +// included in the file licenses/BSL.txt. +// +// As of the Change Date specified in that file, in accordance with +// the Business Source License, use of this software will be governed +// by the Apache License, Version 2.0, included in the file +// licenses/APL.txt. + +// Package migrationjob contains the jobs.Resumer implementation +// used for long-running migrations. +package migrationjob + +import ( + "context" + + "github.com/cockroachdb/cockroach/pkg/jobs" + "github.com/cockroachdb/cockroach/pkg/jobs/jobspb" + "github.com/cockroachdb/cockroach/pkg/migration" + "github.com/cockroachdb/cockroach/pkg/settings/cluster" + "github.com/cockroachdb/cockroach/pkg/sql" +) + +func init() { + jobs.RegisterConstructor(jobspb.TypeLongRunningMigration, func(job *jobs.Job, settings *cluster.Settings) jobs.Resumer { + return &resumer{j: job} + }) +} + +type resumer struct { + j *jobs.Job +} + +var _ jobs.Resumer = (*resumer)(nil) + +func (r resumer) Resume(ctx context.Context, execCtxI interface{}) error { + // TODO(ajwerner): add some check to see if we're done. + execCtx := execCtxI.(sql.JobExecContext) + pl := r.j.Payload() + cv := *pl.GetLongRunningMigration().ClusterVersion + m, ok := migration.GetMigration(cv) + if !ok { + return nil + } + return m.Run(ctx, cv, execCtx.MigrationCluster()) +} + +// The long-running migration resumer has no reverting logic. +func (r resumer) OnFailOrCancel(ctx context.Context, execCtx interface{}) error { + return nil +} diff --git a/pkg/migration/migrationmanager/BUILD.bazel b/pkg/migration/migrationmanager/BUILD.bazel index 87aaae5a8c3a..3c2e7dad3aac 100644 --- a/pkg/migration/migrationmanager/BUILD.bazel +++ b/pkg/migration/migrationmanager/BUILD.bazel @@ -7,11 +7,17 @@ go_library( visibility = ["//visibility:public"], deps = [ "//pkg/clusterversion", + "//pkg/jobs", + "//pkg/jobs/jobspb", "//pkg/kv", "//pkg/migration", - "//pkg/migration/migrationcluster", + "//pkg/security", "//pkg/server/serverpb", + "//pkg/sql/protoreflect", + "//pkg/sql/sem/tree", + "//pkg/sql/sqlutil", "//pkg/util/log", + "@com_github_cockroachdb_errors//:errors", "@com_github_cockroachdb_logtags//:logtags", ], ) @@ -25,6 +31,7 @@ go_test( deps = [ "//pkg/base", "//pkg/clusterversion", + "//pkg/jobs", "//pkg/kv/kvserver/batcheval", "//pkg/kv/kvserver/liveness", "//pkg/migration", @@ -33,11 +40,13 @@ go_test( "//pkg/security/securitytest", "//pkg/server", "//pkg/settings/cluster", + "//pkg/sql/sqlutil", "//pkg/testutils", "//pkg/testutils/serverutils", "//pkg/testutils/testcluster", "//pkg/util/leaktest", "//pkg/util/log", + "//pkg/util/tracing", "@com_github_cockroachdb_errors//:errors", "@com_github_stretchr_testify//require", ], diff --git a/pkg/migration/migrationmanager/manager.go b/pkg/migration/migrationmanager/manager.go index 1adf78a23bfa..c416be89ab23 100644 --- a/pkg/migration/migrationmanager/manager.go +++ b/pkg/migration/migrationmanager/manager.go @@ -15,40 +15,47 @@ package migrationmanager import ( "context" "fmt" + "strings" "github.com/cockroachdb/cockroach/pkg/clusterversion" + "github.com/cockroachdb/cockroach/pkg/jobs" + "github.com/cockroachdb/cockroach/pkg/jobs/jobspb" "github.com/cockroachdb/cockroach/pkg/kv" "github.com/cockroachdb/cockroach/pkg/migration" - "github.com/cockroachdb/cockroach/pkg/migration/migrationcluster" + "github.com/cockroachdb/cockroach/pkg/security" "github.com/cockroachdb/cockroach/pkg/server/serverpb" + "github.com/cockroachdb/cockroach/pkg/sql/protoreflect" + "github.com/cockroachdb/cockroach/pkg/sql/sem/tree" + "github.com/cockroachdb/cockroach/pkg/sql/sqlutil" "github.com/cockroachdb/cockroach/pkg/util/log" + "github.com/cockroachdb/errors" "github.com/cockroachdb/logtags" ) // Manager is the instance responsible for executing migrations across the // cluster. type Manager struct { - c migration.Cluster + c migration.Cluster + ie sqlutil.InternalExecutor + jr *jobs.Registry } // NewManager constructs a new Manager. // // TODO(irfansharif): We'll need to eventually plumb in on a lease manager here. -func NewManager( - dialer migrationcluster.NodeDialer, nl migrationcluster.NodeLiveness, db *kv.DB, -) *Manager { +func NewManager(c migration.Cluster, ie sqlutil.InternalExecutor, jr *jobs.Registry) *Manager { return &Manager{ - c: migrationcluster.New(migrationcluster.ClusterConfig{ - NodeLiveness: nl, - Dialer: dialer, - DB: db, - }), + c: c, + ie: ie, + jr: jr, } } // Migrate runs the set of migrations required to upgrade the cluster version // from the current version to the target one. -func (m *Manager) Migrate(ctx context.Context, from, to clusterversion.ClusterVersion) error { +func (m *Manager) Migrate( + ctx context.Context, user security.SQLUsername, from, to clusterversion.ClusterVersion, +) error { // TODO(irfansharif): Should we inject every ctx here with specific labels // for each migration, so they log distinctly? ctx = logtags.AddTag(ctx, "migration-mgr", nil) @@ -79,11 +86,10 @@ func (m *Manager) Migrate(ctx context.Context, from, to clusterversion.ClusterVe log.Infof(ctx, "migrating cluster from %s to %s (stepping through %s)", from, to, clusterVersions) for _, clusterVersion := range clusterVersions { + log.Infof(ctx, "stepping through %s", from, to, clusterVersions) // First, run the actual migration if any. - if mig, ok := migration.GetMigration(clusterVersion); ok { - if err := mig.Run(ctx, clusterVersion, m.c); err != nil { - return err - } + if err := m.runMigration(ctx, user, clusterVersion); err != nil { + return err } // Next we'll push out the version gate to every node in the cluster. @@ -208,3 +214,99 @@ func (m *Manager) Migrate(ctx context.Context, from, to clusterversion.ClusterVe return nil } + +func (m *Manager) runMigration( + ctx context.Context, user security.SQLUsername, version clusterversion.ClusterVersion, +) error { + if _, exists := migration.GetMigration(version); !exists { + return nil + } + id, err := m.getOrCreateMigrationJob(ctx, user, version) + if err != nil { + return err + } + return m.jr.Run(ctx, m.ie, []int64{id}) +} + +func (m *Manager) getOrCreateMigrationJob( + ctx context.Context, user security.SQLUsername, version clusterversion.ClusterVersion, +) (jobID int64, _ error) { + + if err := m.c.DB().Txn(ctx, func(ctx context.Context, txn *kv.Txn) (err error) { + var found bool + found, jobID, err = m.getRunningMigrationJob(ctx, txn, version) + if err != nil { + return err + } + if found { + return nil + } + var j *jobs.Job + j, err = m.jr.CreateJobWithTxn(ctx, jobs.Record{ + Description: "Long running migration", + Details: jobspb.LongRunningMigrationDetails{ + ClusterVersion: &version, + }, + Username: user, + Progress: jobspb.LongRunningMigrationProgress{}, + NonCancelable: true, + }, txn) + if err != nil { + return err + } + jobID = *j.ID() + return nil + }); err != nil { + return 0, err + } + return jobID, nil +} + +func (m *Manager) getRunningMigrationJob( + ctx context.Context, txn *kv.Txn, version clusterversion.ClusterVersion, +) (found bool, jobID int64, _ error) { + const query = ` +SELECT id, status + FROM ( + SELECT id, + status, + crdb_internal.pb_to_json( + 'cockroach.sql.jobs.jobspb.Payload', + payload + ) AS pl + FROM system.jobs + WHERE status IN ` + jobs.NonTerminalStatusTupleString + ` + ) + WHERE pl->'longRunningMigration'->'clusterVersion' = $1::JSON;` + // TODO(ajwerner): Flip the emitDefaults flag once this is rebased on master. + jsonMsg, err := protoreflect.MessageToJSON(&version, true /* emitDefaults */) + if err != nil { + return false, 0, errors.Wrap(err, "failed to marshal version to JSON") + } + rows, err := m.ie.Query(ctx, "migration-manager-find-jobs", txn, query, jsonMsg.String()) + if err != nil { + return false, 0, err + } + parseRow := func(row tree.Datums) (id int64, status jobs.Status) { + return int64(*row[0].(*tree.DInt)), jobs.Status(*row[1].(*tree.DString)) + } + switch len(rows) { + case 0: + return false, 0, nil + case 1: + id, status := parseRow(rows[0]) + log.Infof(ctx, "found existing migration job %d for version %v in status %s, waiting", + id, &version, status) + return true, id, nil + default: + format := "found multiple non-terminal jobs for version %v: [" + + strings.Repeat("(%d, %s), ", len(rows)-1) + "(%d, %s)]" + args := make([]interface{}, 1+len(rows)*2) + args[0] = &version + for i := range rows { + args[2*i+1], args[2*i+2] = parseRow(rows[i]) + } + log.Errorf(ctx, format, args...) + return false, 0, errors.AssertionFailedf(format, args...) + } +} diff --git a/pkg/migration/migrationmanager/manager_external_test.go b/pkg/migration/migrationmanager/manager_external_test.go index 48382c1d08ac..dd0a637fa638 100644 --- a/pkg/migration/migrationmanager/manager_external_test.go +++ b/pkg/migration/migrationmanager/manager_external_test.go @@ -16,20 +16,140 @@ import ( "github.com/cockroachdb/cockroach/pkg/base" "github.com/cockroachdb/cockroach/pkg/clusterversion" + "github.com/cockroachdb/cockroach/pkg/jobs" "github.com/cockroachdb/cockroach/pkg/kv/kvserver/batcheval" "github.com/cockroachdb/cockroach/pkg/kv/kvserver/liveness" "github.com/cockroachdb/cockroach/pkg/migration" "github.com/cockroachdb/cockroach/pkg/roachpb" "github.com/cockroachdb/cockroach/pkg/server" "github.com/cockroachdb/cockroach/pkg/settings/cluster" + "github.com/cockroachdb/cockroach/pkg/sql/sqlutil" "github.com/cockroachdb/cockroach/pkg/testutils" "github.com/cockroachdb/cockroach/pkg/testutils/testcluster" "github.com/cockroachdb/cockroach/pkg/util/leaktest" "github.com/cockroachdb/cockroach/pkg/util/log" + "github.com/cockroachdb/cockroach/pkg/util/tracing" "github.com/cockroachdb/errors" "github.com/stretchr/testify/require" ) +// TestAlreadyRunningJobsAreHandledProperly is a relatively low-level test to +// ensure that the behavior to detect running jobs is sane. The test intercepts +// and blocks a migration that it first runs. It then duplicates the job to +// break the single-running job invariant. It then ensures that that invariant +// violation is detected. After that errant job is finished, it ensures that +// concurrent attempts to bump the cluster version detect the already running +// migration and wait. +func TestAlreadyRunningJobsAreHandledProperly(t *testing.T) { + defer leaktest.AfterTest(t)() + defer log.Scope(t).Close(t) + + // We're going to be migrating from startCV to endCV. + startCV := clusterversion.ClusterVersion{Version: roachpb.Version{Major: 41}} + endCV := clusterversion.ClusterVersion{Version: roachpb.Version{Major: 42}} + + ctx := context.Background() + tc := testcluster.StartTestCluster(t, 2, base.TestClusterArgs{ + ReplicationMode: base.ReplicationManual, + ServerArgs: base.TestServerArgs{ + Settings: cluster.MakeTestingClusterSettingsWithVersions(endCV.Version, startCV.Version, false), + Knobs: base.TestingKnobs{ + Server: &server.TestingKnobs{ + BinaryVersionOverride: startCV.Version, + DisableAutomaticVersionUpgrade: 1, + }, + }, + }, + }) + defer tc.Stopper().Stop(ctx) + + ch := make(chan chan struct{}) + defer migration.TestingRegisterMigrationInterceptor(endCV, func( + ctx context.Context, cv clusterversion.ClusterVersion, h migration.Cluster, + ) error { + canResume := make(chan struct{}) + ch <- canResume + <-canResume + return nil + })() + upgrade1Err := make(chan error, 1) + go func() { + _, err := tc.ServerConn(0).ExecContext(ctx, `SET CLUSTER SETTING version = $1`, endCV.String()) + upgrade1Err <- err + }() + unblock := <-ch + + // Inject a second job for the same migration and ensure that that causes + // an error. This is pretty gnarly. + var secondID int64 + require.NoError(t, tc.ServerConn(0).QueryRow(` + INSERT + INTO system.jobs + ( + SELECT + unique_rowid(), + status, + created, + payload, + progress, + created_by_type, + created_by_id, + claim_session_id, + claim_instance_id + FROM system.jobs + WHERE ( + crdb_internal.pb_to_json( + 'cockroach.sql.jobs.jobspb.Payload', + payload + )->'longRunningMigration' + ) IS NOT NULL + ) +RETURNING id;`).Scan(&secondID)) + + // Make sure that the second job gets run in a timely manner. + runErr := make(chan error) + go func() { + runErr <- tc.Server(0).JobRegistry().(*jobs.Registry). + Run( + ctx, + tc.Server(0).InternalExecutor().(sqlutil.InternalExecutor), + []int64{secondID}, + ) + }() + fakeJobBlockChan := <-ch + + // Ensure that we see the assertion error. + _, err := tc.Conns[0].ExecContext(ctx, `SET CLUSTER SETTING version = $1`, endCV.String()) + require.Regexp(t, "found multiple non-terminal jobs for version", err) + + // Let the fake, erroneous job finish. + close(fakeJobBlockChan) + require.NoError(t, <-runErr) + + // Launch a second migration which later we'll ensure does not kick off + // another job. We'll make sure this happens by polling the trace to see + // the log line indicating what we want. + recCtx, getRecording, cancel := tracing.ContextWithRecordingSpan(ctx, "test") + defer cancel() + upgrade2Err := make(chan error, 1) + go func() { + // Use an internal executor to get access to the trace as it happens. + _, err := tc.Server(0).InternalExecutor().(sqlutil.InternalExecutor).Exec( + recCtx, "test", nil /* txn */, `SET CLUSTER SETTING version = $1`, endCV.String()) + upgrade2Err <- err + }() + + testutils.SucceedsSoon(t, func() error { + if tracing.FindMsgInRecording(getRecording(), "found existing migration job") > 0 { + return nil + } + return errors.Errorf("waiting for job to be discovered: %v", getRecording()) + }) + close(unblock) + require.NoError(t, <-upgrade1Err) + require.NoError(t, <-upgrade2Err) +} + func TestMigrateUpdatesReplicaVersion(t *testing.T) { defer leaktest.AfterTest(t)() defer log.Scope(t).Close(t) diff --git a/pkg/migration/migrations/BUILD.bazel b/pkg/migration/migrations/BUILD.bazel index 3652c33e25c4..3fba9346bebe 100644 --- a/pkg/migration/migrations/BUILD.bazel +++ b/pkg/migration/migrations/BUILD.bazel @@ -5,5 +5,8 @@ go_library( srcs = ["migrations.go"], importpath = "github.com/cockroachdb/cockroach/pkg/migration/migrations", visibility = ["//visibility:public"], - deps = ["//pkg/migration/migrations/truncatedstate"], + deps = [ + "//pkg/migration/migrationjob", + "//pkg/migration/migrations/truncatedstate", + ], ) diff --git a/pkg/migration/migrations/migrations.go b/pkg/migration/migrations/migrations.go index b75b7b6fdb7b..d837971b93c8 100644 --- a/pkg/migration/migrations/migrations.go +++ b/pkg/migration/migrations/migrations.go @@ -12,4 +12,7 @@ // It is imported by the server. package migrations -import _ "github.com/cockroachdb/cockroach/pkg/migration/migrations/truncatedstate" +import ( + _ "github.com/cockroachdb/cockroach/pkg/migration/migrationjob" + _ "github.com/cockroachdb/cockroach/pkg/migration/migrations/truncatedstate" +) diff --git a/pkg/server/BUILD.bazel b/pkg/server/BUILD.bazel index c5a763ed4108..8d12f2f4d8a1 100644 --- a/pkg/server/BUILD.bazel +++ b/pkg/server/BUILD.bazel @@ -74,7 +74,9 @@ go_library( "//pkg/kv/kvserver/protectedts/ptprovider", "//pkg/kv/kvserver/protectedts/ptreconcile", "//pkg/kv/kvserver/reports", + "//pkg/migration/migrationcluster", "//pkg/migration/migrationmanager", + "//pkg/migration/migrations", "//pkg/roachpb", "//pkg/rpc", "//pkg/rpc/nodedialer", diff --git a/pkg/server/server_sql.go b/pkg/server/server_sql.go index e79ea1c027da..00f247e2c429 100644 --- a/pkg/server/server_sql.go +++ b/pkg/server/server_sql.go @@ -32,7 +32,9 @@ import ( "github.com/cockroachdb/cockroach/pkg/kv/kvclient/kvtenant" "github.com/cockroachdb/cockroach/pkg/kv/kvserver/kvserverbase" "github.com/cockroachdb/cockroach/pkg/kv/kvserver/protectedts" + "github.com/cockroachdb/cockroach/pkg/migration/migrationcluster" "github.com/cockroachdb/cockroach/pkg/migration/migrationmanager" + _ "github.com/cockroachdb/cockroach/pkg/migration/migrations" "github.com/cockroachdb/cockroach/pkg/roachpb" "github.com/cockroachdb/cockroach/pkg/rpc" "github.com/cockroachdb/cockroach/pkg/rpc/nodedialer" @@ -623,14 +625,14 @@ func newSQLServer(ctx context.Context, cfg sqlServerArgs) (*SQLServer, error) { // We only need to attach a version upgrade hook if we're the system // tenant. Regular tenants are disallowed from changing cluster // versions. - migrationMgr := migrationmanager.NewManager( - cfg.nodeDialer, - nodeLiveness, - cfg.db, - ) - execCfg.VersionUpgradeHook = func(ctx context.Context, from, to clusterversion.ClusterVersion) error { - return migrationMgr.Migrate(ctx, from, to) - } + c := migrationcluster.New(migrationcluster.ClusterConfig{ + NodeLiveness: nodeLiveness, + Dialer: cfg.nodeDialer, + DB: cfg.db, + }) + migrationMgr := migrationmanager.NewManager(c, cfg.circularInternalExecutor, jobRegistry) + execCfg.MigrationCluster = c + execCfg.VersionUpgradeHook = migrationMgr.Migrate } temporaryObjectCleaner := sql.NewTemporaryObjectCleaner( diff --git a/pkg/sql/BUILD.bazel b/pkg/sql/BUILD.bazel index 19a7df843cf9..1b2e5f826dc3 100644 --- a/pkg/sql/BUILD.bazel +++ b/pkg/sql/BUILD.bazel @@ -248,6 +248,7 @@ go_library( "//pkg/kv/kvserver", "//pkg/kv/kvserver/liveness/livenesspb", "//pkg/kv/kvserver/protectedts", + "//pkg/migration", "//pkg/roachpb", "//pkg/rpc", "//pkg/rpc/nodedialer", diff --git a/pkg/sql/exec_util.go b/pkg/sql/exec_util.go index b42049597661..8bfc116bd667 100644 --- a/pkg/sql/exec_util.go +++ b/pkg/sql/exec_util.go @@ -35,6 +35,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/kv/kvclient/kvcoord" "github.com/cockroachdb/cockroach/pkg/kv/kvclient/rangecache" "github.com/cockroachdb/cockroach/pkg/kv/kvserver/protectedts" + "github.com/cockroachdb/cockroach/pkg/migration" "github.com/cockroachdb/cockroach/pkg/roachpb" "github.com/cockroachdb/cockroach/pkg/rpc" "github.com/cockroachdb/cockroach/pkg/security" @@ -793,8 +794,15 @@ type ExecutorConfig struct { // VersionUpgradeHook is called after validating a `SET CLUSTER SETTING // version` but before executing it. It can carry out arbitrary migrations - // that allow us to eventually remove legacy code. - VersionUpgradeHook func(ctx context.Context, from, to clusterversion.ClusterVersion) error + // that allow us to eventually remove legacy code. It will only be populated + // on the system tenant. + // + // TODO(tbg,irfansharif,ajwerner): Hook up for secondary tenants. + VersionUpgradeHook func(ctx context.Context, user security.SQLUsername, from, to clusterversion.ClusterVersion) error + + // MigrationCluster is used to drive KV-level, long-running migrations. + // It will only be populated on the system tenant. + MigrationCluster migration.Cluster // IndexBackfiller is used to backfill indexes. It is another rather circular // object which mostly just holds on to an ExecConfig. diff --git a/pkg/sql/job_exec_context.go b/pkg/sql/job_exec_context.go index 31f87c07ca61..024a9af47e95 100644 --- a/pkg/sql/job_exec_context.go +++ b/pkg/sql/job_exec_context.go @@ -11,6 +11,7 @@ package sql import ( + "github.com/cockroachdb/cockroach/pkg/migration" "github.com/cockroachdb/cockroach/pkg/security" "github.com/cockroachdb/cockroach/pkg/sql/catalog/lease" "github.com/cockroachdb/cockroach/pkg/sql/sem/tree" @@ -41,10 +42,11 @@ func (e *plannerJobExecContext) ExtendedEvalContext() *extendedEvalContext { func (e *plannerJobExecContext) SessionData() *sessiondata.SessionData { return e.p.SessionData() } -func (e *plannerJobExecContext) ExecCfg() *ExecutorConfig { return e.p.ExecCfg() } -func (e *plannerJobExecContext) DistSQLPlanner() *DistSQLPlanner { return e.p.DistSQLPlanner() } -func (e *plannerJobExecContext) LeaseMgr() *lease.Manager { return e.p.LeaseMgr() } -func (e *plannerJobExecContext) User() security.SQLUsername { return e.p.User() } +func (e *plannerJobExecContext) ExecCfg() *ExecutorConfig { return e.p.ExecCfg() } +func (e *plannerJobExecContext) DistSQLPlanner() *DistSQLPlanner { return e.p.DistSQLPlanner() } +func (e *plannerJobExecContext) LeaseMgr() *lease.Manager { return e.p.LeaseMgr() } +func (e *plannerJobExecContext) User() security.SQLUsername { return e.p.User() } +func (e *plannerJobExecContext) MigrationCluster() migration.Cluster { return e.p.MigrationCluster() } // JobExecContext provides the execution environment for a job. It is what is // passed to the Resume/OnFailOrCancel/OnPauseRequested methods of a jobs's @@ -63,4 +65,5 @@ type JobExecContext interface { DistSQLPlanner() *DistSQLPlanner LeaseMgr() *lease.Manager User() security.SQLUsername + MigrationCluster() migration.Cluster } diff --git a/pkg/sql/planhook.go b/pkg/sql/planhook.go index f61af5e7bba6..cf1747471105 100644 --- a/pkg/sql/planhook.go +++ b/pkg/sql/planhook.go @@ -13,6 +13,7 @@ package sql import ( "context" + "github.com/cockroachdb/cockroach/pkg/migration" "github.com/cockroachdb/cockroach/pkg/roachpb" "github.com/cockroachdb/cockroach/pkg/security" "github.com/cockroachdb/cockroach/pkg/sql/catalog" @@ -97,6 +98,7 @@ type PlanHookState interface { ) (string, error) CreateSchemaNamespaceEntry(ctx context.Context, schemaNameKey roachpb.Key, schemaID descpb.ID) error + MigrationCluster() migration.Cluster } // AddPlanHook adds a hook used to short-circuit creating a planNode from a diff --git a/pkg/sql/planner.go b/pkg/sql/planner.go index ab3c9a840f67..beb0ba52d128 100644 --- a/pkg/sql/planner.go +++ b/pkg/sql/planner.go @@ -18,6 +18,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/jobs" "github.com/cockroachdb/cockroach/pkg/kv" "github.com/cockroachdb/cockroach/pkg/kv/kvserver" + "github.com/cockroachdb/cockroach/pkg/migration" "github.com/cockroachdb/cockroach/pkg/roachpb" "github.com/cockroachdb/cockroach/pkg/rpc" "github.com/cockroachdb/cockroach/pkg/security" @@ -473,6 +474,11 @@ func (p *planner) DistSQLPlanner() *DistSQLPlanner { return p.extendedEvalCtx.DistSQLPlanner } +// MigrationCluster returns the migration.Cluster if there is one. +func (p *planner) MigrationCluster() migration.Cluster { + return p.execCfg.MigrationCluster +} + // GetTypeFromValidSQLSyntax implements the tree.EvalPlanner interface. // We define this here to break the dependency from eval.go to the parser. func (p *planner) GetTypeFromValidSQLSyntax(sql string) (*types.T, error) { diff --git a/pkg/sql/set_cluster_setting.go b/pkg/sql/set_cluster_setting.go index 249ad5d68cfc..9022229cbfd4 100644 --- a/pkg/sql/set_cluster_setting.go +++ b/pkg/sql/set_cluster_setting.go @@ -53,7 +53,7 @@ type setClusterSettingNode struct { // versionUpgradeHook is called after validating a `SET CLUSTER SETTING // version` but before executing it. It can carry out arbitrary migrations // that allow us to eventually remove legacy code. - versionUpgradeHook func(ctx context.Context, from, to clusterversion.ClusterVersion) error + versionUpgradeHook func(ctx context.Context, username security.SQLUsername, from, to clusterversion.ClusterVersion) error } func checkPrivilegesForSetting(ctx context.Context, p *planner, name string, action string) error { @@ -259,7 +259,7 @@ func (n *setClusterSettingNode) startExec(params runParams) error { // toSettingString already validated the input, and checked to // see that we are allowed to transition. Let's call into our // upgrade hook to run migrations, if any. - if err := n.versionUpgradeHook(ctx, from, to); err != nil { + if err := n.versionUpgradeHook(ctx, params.p.User(), from, to); err != nil { return err } }