diff --git a/docs/generated/eventlog.md b/docs/generated/eventlog.md index 4642062e6f84..5c3f5d346dee 100644 --- a/docs/generated/eventlog.md +++ b/docs/generated/eventlog.md @@ -1939,6 +1939,63 @@ set to a non-zero value, AND | `FullIndexScan` | Whether the query contains a full secondary index scan. | no | | `TxnCounter` | The sequence number of the SQL transaction inside its session. | no | +### `txn_rows_read_limit` + +An event of type `txn_rows_read_limit` is recorded when a transaction tries to read more rows than +cluster setting `sql.defaults.transaction_rows_read_log`. There will only be +a single record for a single transaction (unless it is retried) even if there +are more statement within the transaction that haven't been executed yet. + + + + +#### Common fields + +| Field | Description | Sensitive | +|--|--|--| +| `Timestamp` | The timestamp of the event. Expressed as nanoseconds since the Unix epoch. | no | +| `EventType` | The type of the event. | no | +| `Statement` | A normalized copy of the SQL statement that triggered the event. The statement string contains a mix of sensitive and non-sensitive details (it is redactable). | partially | +| `Tag` | The statement tag. This is separate from the statement string, since the statement string can contain sensitive information. The tag is guaranteed not to. | no | +| `User` | The user account that triggered the event. The special usernames `root` and `node` are not considered sensitive. | depends | +| `DescriptorID` | The primary object descriptor affected by the operation. Set to zero for operations that don't affect descriptors. | no | +| `ApplicationName` | The application name for the session where the event was emitted. This is included in the event to ease filtering of logging output by application. Application names starting with a dollar sign (`$`) are not considered sensitive. | depends | +| `PlaceholderValues` | The mapping of SQL placeholders to their values, for prepared statements. | yes | +| `TxnID` | TxnID is the ID of the transaction that hit the row count limit. | no | +| `SessionID` | SessionID is the ID of the session that initiated the transaction. | no | +| `Limit` | Limit indicates the value of the transaction row count limit that was reached. | no | +| `ViolatesTxnRowsLimitErr` | ViolatesTxnRowsLimitErr if true indicates that 'transaction_rows_{written|read}_err' limit is violated. | no | +| `IsRead` | IsRead if true indicates that the "rows read" limit is reached and the "rows written" limit otherwise. | no | + +### `txn_rows_written_limit` + +An event of type `txn_rows_written_limit` is recorded when a transaction tries to write more rows +than cluster setting `sql.defaults.transaction_rows_written_log`. There will +only be a single record for a single transaction (unless it is retried) even +if there are more mutation statements within the transaction that haven't +been executed yet. + + + + +#### Common fields + +| Field | Description | Sensitive | +|--|--|--| +| `Timestamp` | The timestamp of the event. Expressed as nanoseconds since the Unix epoch. | no | +| `EventType` | The type of the event. | no | +| `Statement` | A normalized copy of the SQL statement that triggered the event. The statement string contains a mix of sensitive and non-sensitive details (it is redactable). | partially | +| `Tag` | The statement tag. This is separate from the statement string, since the statement string can contain sensitive information. The tag is guaranteed not to. | no | +| `User` | The user account that triggered the event. The special usernames `root` and `node` are not considered sensitive. | depends | +| `DescriptorID` | The primary object descriptor affected by the operation. Set to zero for operations that don't affect descriptors. | no | +| `ApplicationName` | The application name for the session where the event was emitted. This is included in the event to ease filtering of logging output by application. Application names starting with a dollar sign (`$`) are not considered sensitive. | depends | +| `PlaceholderValues` | The mapping of SQL placeholders to their values, for prepared statements. | yes | +| `TxnID` | TxnID is the ID of the transaction that hit the row count limit. | no | +| `SessionID` | SessionID is the ID of the session that initiated the transaction. | no | +| `Limit` | Limit indicates the value of the transaction row count limit that was reached. | no | +| `ViolatesTxnRowsLimitErr` | ViolatesTxnRowsLimitErr if true indicates that 'transaction_rows_{written|read}_err' limit is violated. | no | +| `IsRead` | IsRead if true indicates that the "rows read" limit is reached and the "rows written" limit otherwise. | no | + ## SQL Slow Query Log (Internal) Events in this category report slow query execution by @@ -2006,6 +2063,65 @@ the "slow query" condition. | `FullIndexScan` | Whether the query contains a full secondary index scan. | no | | `TxnCounter` | The sequence number of the SQL transaction inside its session. | no | +### `txn_rows_read_limit_internal` + +An event of type `txn_rows_read_limit_internal` is recorded when an internal transaction tries to +read more rows than cluster setting `sql.defaults.transaction_rows_read_log` +or `sql.defaults.transaction_rows_read_err`. There will only be a single +record for a single transaction (unless it is retried) even if there are more +mutation statements within the transaction that haven't been executed yet. + + + + +#### Common fields + +| Field | Description | Sensitive | +|--|--|--| +| `Timestamp` | The timestamp of the event. Expressed as nanoseconds since the Unix epoch. | no | +| `EventType` | The type of the event. | no | +| `Statement` | A normalized copy of the SQL statement that triggered the event. The statement string contains a mix of sensitive and non-sensitive details (it is redactable). | partially | +| `Tag` | The statement tag. This is separate from the statement string, since the statement string can contain sensitive information. The tag is guaranteed not to. | no | +| `User` | The user account that triggered the event. The special usernames `root` and `node` are not considered sensitive. | depends | +| `DescriptorID` | The primary object descriptor affected by the operation. Set to zero for operations that don't affect descriptors. | no | +| `ApplicationName` | The application name for the session where the event was emitted. This is included in the event to ease filtering of logging output by application. Application names starting with a dollar sign (`$`) are not considered sensitive. | depends | +| `PlaceholderValues` | The mapping of SQL placeholders to their values, for prepared statements. | yes | +| `TxnID` | TxnID is the ID of the transaction that hit the row count limit. | no | +| `SessionID` | SessionID is the ID of the session that initiated the transaction. | no | +| `Limit` | Limit indicates the value of the transaction row count limit that was reached. | no | +| `ViolatesTxnRowsLimitErr` | ViolatesTxnRowsLimitErr if true indicates that 'transaction_rows_{written|read}_err' limit is violated. | no | +| `IsRead` | IsRead if true indicates that the "rows read" limit is reached and the "rows written" limit otherwise. | no | + +### `txn_rows_written_limit_internal` + +An event of type `txn_rows_written_limit_internal` is recorded when an internal transaction tries to +write more rows than cluster setting +`sql.defaults.transaction_rows_written_log` or +`sql.defaults.transaction_rows_written_err`. There will only be a single +record for a single transaction (unless it is retried) even if there are more +mutation statements within the transaction that haven't been executed yet. + + + + +#### Common fields + +| Field | Description | Sensitive | +|--|--|--| +| `Timestamp` | The timestamp of the event. Expressed as nanoseconds since the Unix epoch. | no | +| `EventType` | The type of the event. | no | +| `Statement` | A normalized copy of the SQL statement that triggered the event. The statement string contains a mix of sensitive and non-sensitive details (it is redactable). | partially | +| `Tag` | The statement tag. This is separate from the statement string, since the statement string can contain sensitive information. The tag is guaranteed not to. | no | +| `User` | The user account that triggered the event. The special usernames `root` and `node` are not considered sensitive. | depends | +| `DescriptorID` | The primary object descriptor affected by the operation. Set to zero for operations that don't affect descriptors. | no | +| `ApplicationName` | The application name for the session where the event was emitted. This is included in the event to ease filtering of logging output by application. Application names starting with a dollar sign (`$`) are not considered sensitive. | depends | +| `PlaceholderValues` | The mapping of SQL placeholders to their values, for prepared statements. | yes | +| `TxnID` | TxnID is the ID of the transaction that hit the row count limit. | no | +| `SessionID` | SessionID is the ID of the session that initiated the transaction. | no | +| `Limit` | Limit indicates the value of the transaction row count limit that was reached. | no | +| `ViolatesTxnRowsLimitErr` | ViolatesTxnRowsLimitErr if true indicates that 'transaction_rows_{written|read}_err' limit is violated. | no | +| `IsRead` | IsRead if true indicates that the "rows read" limit is reached and the "rows written" limit otherwise. | no | + ## SQL User and Role operations Events in this category pertain to SQL statements that modify the diff --git a/docs/generated/settings/settings-for-tenants.txt b/docs/generated/settings/settings-for-tenants.txt index e65be50c01ff..95bb0e17f9e3 100644 --- a/docs/generated/settings/settings-for-tenants.txt +++ b/docs/generated/settings/settings-for-tenants.txt @@ -110,6 +110,10 @@ sql.defaults.results_buffer.size byte size 16 KiB default size of the buffer tha sql.defaults.serial_normalization enumeration rowid default handling of SERIAL in table definitions [rowid = 0, virtual_sequence = 1, sql_sequence = 2, sql_sequence_cached = 3] sql.defaults.statement_timeout duration 0s default value for the statement_timeout; default value for the statement_timeout session setting; controls the duration a query is permitted to run before it is canceled; if set to 0, there is no timeout sql.defaults.stub_catalog_tables.enabled boolean true default value for stub_catalog_tables session setting +sql.defaults.transaction_rows_read_err integer 0 the limit for the number of rows read by a SQL transaction which - once reached - will fail the transaction (or will trigger a logging event to SQL_INTERNAL_PERF for internal transactions); use 0 to disable +sql.defaults.transaction_rows_read_log integer 0 the threshold for the number of rows read by a SQL transaction which - once reached - will trigger a logging event to SQL_PERF (or SQL_INTERNAL_PERF for internal transactions); use 0 to disable +sql.defaults.transaction_rows_written_err integer 0 the limit for the number of rows written by a SQL transaction which - once reached - will fail the transaction (or will trigger a logging event to SQL_INTERNAL_PERF for internal transactions); use 0 to disable +sql.defaults.transaction_rows_written_log integer 0 the threshold for the number of rows written by a SQL transaction which - once reached - will trigger a logging event to SQL_PERF (or SQL_INTERNAL_PERF for internal transactions); use 0 to disable sql.defaults.vectorize enumeration on default vectorize mode [on = 0, on = 2, experimental_always = 3, off = 4] sql.defaults.zigzag_join.enabled boolean true default value for enable_zigzag_join session setting; allows use of zig-zag join by default sql.distsql.max_running_flows integer 500 maximum number of concurrent flows that can be run on a node diff --git a/docs/generated/settings/settings.html b/docs/generated/settings/settings.html index 4d88552c02e9..7b7b779632a3 100644 --- a/docs/generated/settings/settings.html +++ b/docs/generated/settings/settings.html @@ -114,6 +114,10 @@ sql.defaults.serial_normalizationenumerationrowiddefault handling of SERIAL in table definitions [rowid = 0, virtual_sequence = 1, sql_sequence = 2, sql_sequence_cached = 3] sql.defaults.statement_timeoutduration0sdefault value for the statement_timeout; default value for the statement_timeout session setting; controls the duration a query is permitted to run before it is canceled; if set to 0, there is no timeout sql.defaults.stub_catalog_tables.enabledbooleantruedefault value for stub_catalog_tables session setting +sql.defaults.transaction_rows_read_errinteger0the limit for the number of rows read by a SQL transaction which - once reached - will fail the transaction (or will trigger a logging event to SQL_INTERNAL_PERF for internal transactions); use 0 to disable +sql.defaults.transaction_rows_read_loginteger0the threshold for the number of rows read by a SQL transaction which - once reached - will trigger a logging event to SQL_PERF (or SQL_INTERNAL_PERF for internal transactions); use 0 to disable +sql.defaults.transaction_rows_written_errinteger0the limit for the number of rows written by a SQL transaction which - once reached - will fail the transaction (or will trigger a logging event to SQL_INTERNAL_PERF for internal transactions); use 0 to disable +sql.defaults.transaction_rows_written_loginteger0the threshold for the number of rows written by a SQL transaction which - once reached - will trigger a logging event to SQL_PERF (or SQL_INTERNAL_PERF for internal transactions); use 0 to disable sql.defaults.vectorizeenumerationondefault vectorize mode [on = 0, on = 2, experimental_always = 3, off = 4] sql.defaults.zigzag_join.enabledbooleantruedefault value for enable_zigzag_join session setting; allows use of zig-zag join by default sql.distsql.max_running_flowsinteger500maximum number of concurrent flows that can be run on a node diff --git a/pkg/sql/conn_executor.go b/pkg/sql/conn_executor.go index 83fed57a11ca..dd66963fc481 100644 --- a/pkg/sql/conn_executor.go +++ b/pkg/sql/conn_executor.go @@ -305,6 +305,10 @@ type Metrics struct { // StatsMetrics contains metrics for SQL statistics collection. StatsMetrics StatsMetrics + + // GuardrailMetrics contains metrics related to different guardrails in the + // SQL layer. + GuardrailMetrics GuardrailMetrics } // NewServer creates a new Server. Start() needs to be called before the Server @@ -416,6 +420,12 @@ func makeMetrics(cfg *ExecutorConfig, internal bool) Metrics { ), SQLStatsRemovedRows: metric.NewCounter(getMetricMeta(MetaSQLStatsRemovedRows, internal)), }, + GuardrailMetrics: GuardrailMetrics{ + TxnRowsWrittenLogCount: metric.NewCounter(getMetricMeta(MetaTxnRowsWrittenLog, internal)), + TxnRowsWrittenErrCount: metric.NewCounter(getMetricMeta(MetaTxnRowsWrittenErr, internal)), + TxnRowsReadLogCount: metric.NewCounter(getMetricMeta(MetaTxnRowsReadLog, internal)), + TxnRowsReadErrCount: metric.NewCounter(getMetricMeta(MetaTxnRowsReadErr, internal)), + }, } } @@ -1218,6 +1228,16 @@ type connExecutor struct { rowsRead int64 bytesRead int64 + // rowsWritten tracks the number of rows written (modified) by all + // statements in this txn so far. + rowsWritten int64 + + // rowsWrittenLogged and rowsReadLogged indicates whether we have + // already logged an event about reaching written/read rows setting, + // respectively. + rowsWrittenLogged bool + rowsReadLogged bool + // hasAdminRole is used to cache if the user running the transaction // has admin privilege. hasAdminRoleCache is set for the first statement // in a transaction. diff --git a/pkg/sql/conn_executor_exec.go b/pkg/sql/conn_executor_exec.go index 97b33e7b72d4..41d665064c79 100644 --- a/pkg/sql/conn_executor_exec.go +++ b/pkg/sql/conn_executor_exec.go @@ -47,6 +47,8 @@ import ( "github.com/cockroachdb/cockroach/pkg/util/fsm" "github.com/cockroachdb/cockroach/pkg/util/hlc" "github.com/cockroachdb/cockroach/pkg/util/log" + "github.com/cockroachdb/cockroach/pkg/util/log/eventpb" + "github.com/cockroachdb/cockroach/pkg/util/metric" "github.com/cockroachdb/cockroach/pkg/util/timeutil" "github.com/cockroachdb/cockroach/pkg/util/tracing" "github.com/cockroachdb/errors" @@ -1020,6 +1022,7 @@ func (ex *connExecutor) dispatchToExecutionEngine( ex.extraTxnState.rowsRead += stats.rowsRead ex.extraTxnState.bytesRead += stats.bytesRead + ex.extraTxnState.rowsWritten += stats.rowsWritten // Record the statement summary. This also closes the plan if the // plan has not been closed earlier. @@ -1031,9 +1034,132 @@ func (ex *connExecutor) dispatchToExecutionEngine( ex.server.cfg.TestingKnobs.AfterExecute(ctx, stmt.String(), res.Err()) } + if limitsErr := ex.handleTxnRowsWrittenReadLimits(ctx); limitsErr != nil && res.Err() == nil { + res.SetError(limitsErr) + } + return err } +// handleTxnRowsGuardrails handles either "written" or "read" rows guardrails. +func (ex *connExecutor) handleTxnRowsGuardrails( + ctx context.Context, + numRows, logLimit, errLimit int64, + alreadyLogged *bool, + isRead bool, + logCounter, errCounter *metric.Counter, +) error { + var err error + shouldLog := logLimit != 0 && numRows >= logLimit + shouldErr := errLimit != 0 && numRows >= errLimit + if !shouldLog && !shouldErr { + return nil + } + commonTxnRowsLimitDetails := eventpb.CommonTxnRowsLimitDetails{ + TxnID: ex.state.mu.txn.ID().String(), + SessionID: ex.sessionID.String(), + // Limit will be set below. + ViolatesTxnRowsLimitErr: shouldErr, + IsRead: isRead, + } + if shouldErr && ex.executorType == executorTypeInternal { + // Internal work should never err and always log if violating either + // limit. + shouldErr = false + if !shouldLog { + shouldLog = true + logLimit = errLimit + } + } + if *alreadyLogged { + // We have already logged this kind of event about this transaction. + if shouldErr { + // But this time we also reached the error limit, so we want to log + // an event again (it will have ViolatesTxnRowsLimitErr set to + // true). Note that we couldn't have reached the error limit when we + // logged the event the previous time because that would have + // aborted the execution of the transaction. + shouldLog = true + logLimit = errLimit + } else { + shouldLog = false + } + } else { + *alreadyLogged = shouldLog + } + if shouldLog { + commonSQLEventDetails := ex.planner.getCommonSQLEventDetails() + commonTxnRowsLimitDetails.Limit = logLimit + var event eventpb.EventPayload + if ex.executorType == executorTypeInternal { + if isRead { + event = &eventpb.TxnRowsReadLimitInternal{ + CommonSQLEventDetails: commonSQLEventDetails, + CommonTxnRowsLimitDetails: commonTxnRowsLimitDetails, + } + } else { + event = &eventpb.TxnRowsWrittenLimitInternal{ + CommonSQLEventDetails: commonSQLEventDetails, + CommonTxnRowsLimitDetails: commonTxnRowsLimitDetails, + } + } + } else { + if isRead { + event = &eventpb.TxnRowsReadLimit{ + CommonSQLEventDetails: commonSQLEventDetails, + CommonTxnRowsLimitDetails: commonTxnRowsLimitDetails, + } + } else { + event = &eventpb.TxnRowsWrittenLimit{ + CommonSQLEventDetails: commonSQLEventDetails, + CommonTxnRowsLimitDetails: commonTxnRowsLimitDetails, + } + } + log.StructuredEvent(ctx, event) + logCounter.Inc(1) + } + } + if shouldErr { + commonTxnRowsLimitDetails.Limit = errLimit + err = pgerror.WithCandidateCode(&commonTxnRowsLimitDetails, pgcode.ProgramLimitExceeded) + errCounter.Inc(1) + } + return err +} + +// handleTxnRowsWrittenReadLimits checks whether the current transaction has +// reached the limits on the number of rows written/read and logs the +// corresponding event or returns an error. It should be called after executing +// a single statement. +func (ex *connExecutor) handleTxnRowsWrittenReadLimits(ctx context.Context) error { + // Note that in many cases, the internal executor doesn't have the + // sessionData properly set (i.e. the default values are used), so we'll + // never log anything then. This seems acceptable since the focus of these + // guardrails is on the externally initiated queries. + sd := ex.sessionData + writtenErr := ex.handleTxnRowsGuardrails( + ctx, + ex.extraTxnState.rowsWritten, + sd.TxnRowsWrittenLog, + sd.TxnRowsWrittenErr, + &ex.extraTxnState.rowsWrittenLogged, + false, /* isRead */ + ex.metrics.GuardrailMetrics.TxnRowsWrittenLogCount, + ex.metrics.GuardrailMetrics.TxnRowsWrittenErrCount, + ) + readErr := ex.handleTxnRowsGuardrails( + ctx, + ex.extraTxnState.rowsRead, + sd.TxnRowsReadLog, + sd.TxnRowsReadErr, + &ex.extraTxnState.rowsReadLogged, + true, /* isRead */ + ex.metrics.GuardrailMetrics.TxnRowsReadLogCount, + ex.metrics.GuardrailMetrics.TxnRowsReadErrCount, + ) + return errors.CombineErrors(writtenErr, readErr) +} + // makeExecPlan creates an execution plan and populates planner.curPlan using // the cost-based optimizer. func (ex *connExecutor) makeExecPlan(ctx context.Context, planner *planner) error { @@ -1074,6 +1200,8 @@ type topLevelQueryStats struct { bytesRead int64 // rowsRead is the number of rows read from disk. rowsRead int64 + // rowsWritten is the number of rows written. + rowsWritten int64 } // execWithDistSQLEngine converts a plan to a distributed SQL physical plan and @@ -1652,6 +1780,9 @@ func (ex *connExecutor) recordTransactionStart() ( ex.extraTxnState.accumulatedStats = execstats.QueryLevelStats{} ex.extraTxnState.rowsRead = 0 ex.extraTxnState.bytesRead = 0 + ex.extraTxnState.rowsWritten = 0 + ex.extraTxnState.rowsWrittenLogged = false + ex.extraTxnState.rowsReadLogged = false if txnExecStatsSampleRate := collectTxnStatsSampleRate.Get(&ex.server.GetExecutorConfig().Settings.SV); txnExecStatsSampleRate > 0 { ex.extraTxnState.shouldCollectTxnExecutionStats = txnExecStatsSampleRate > ex.rng.Float64() } @@ -1678,6 +1809,7 @@ func (ex *connExecutor) recordTransactionStart() ( ex.extraTxnState.accumulatedStats = execstats.QueryLevelStats{} ex.extraTxnState.rowsRead = 0 ex.extraTxnState.bytesRead = 0 + ex.extraTxnState.rowsWritten = 0 if ex.server.cfg.TestingKnobs.BeforeRestart != nil { ex.server.cfg.TestingKnobs.BeforeRestart(ex.Ctx(), ex.extraTxnState.autoRetryReason) diff --git a/pkg/sql/create_stats.go b/pkg/sql/create_stats.go index 5809c671b13d..de9f0c32eba4 100644 --- a/pkg/sql/create_stats.go +++ b/pkg/sql/create_stats.go @@ -610,12 +610,12 @@ func (r *createStatsResumer) Resume(ctx context.Context, execCtx interface{}) er evalCtx.ExecCfg, txn, 0, /* depth: use event_log=2 for vmodule filtering */ eventLogOptions{dst: LogEverywhere}, - sqlEventCommonExecPayload{ - user: evalCtx.SessionData.User(), - appName: evalCtx.SessionData.ApplicationName, - stmt: redact.Sprint(details.Statement), - stmtTag: "CREATE STATISTICS", - placeholders: nil, /* no placeholders known at this point */ + eventpb.CommonSQLEventDetails{ + Statement: redact.Sprint(details.Statement), + Tag: "CREATE STATISTICS", + User: evalCtx.SessionData.User().Normalized(), + ApplicationName: evalCtx.SessionData.ApplicationName, + PlaceholderValues: []string{}, /* no placeholders known at this point */ }, eventLogEntry{ targetID: int32(details.Table.ID), diff --git a/pkg/sql/delete.go b/pkg/sql/delete.go index d123cd231fea..75253850059f 100644 --- a/pkg/sql/delete.go +++ b/pkg/sql/delete.go @@ -39,8 +39,9 @@ type deleteNode struct { // deleteRun contains the run-time state of deleteNode during local execution. type deleteRun struct { - td tableDeleter - rowsNeeded bool + td tableDeleter + rowsNeeded bool + rowsDeleted int64 // done informs a new call to BatchedNext() that the previous call // to BatchedNext() has completed the work already. @@ -62,6 +63,8 @@ type deleteRun struct { rowIdxToRetIdx []int } +var _ mutationPlanNode = &deleteNode{} + func (d *deleteNode) startExec(params runParams) error { // cache traceKV during execution, to avoid re-evaluating it for every row. d.run.traceKV = params.p.ExtendedEvalContext().Tracing.KVTracingEnabled() @@ -193,6 +196,7 @@ func (d *deleteNode) processSourceRow(params runParams, sourceVals tree.Datums) } } + d.run.rowsDeleted++ return nil } @@ -209,6 +213,10 @@ func (d *deleteNode) Close(ctx context.Context) { deleteNodePool.Put(d) } +func (d *deleteNode) rowsWritten() int64 { + return d.run.rowsDeleted +} + func (d *deleteNode) enableAutoCommit() { d.run.td.enableAutoCommit() } diff --git a/pkg/sql/delete_range.go b/pkg/sql/delete_range.go index 17e48123df64..420a8c00003f 100644 --- a/pkg/sql/delete_range.go +++ b/pkg/sql/delete_range.go @@ -61,6 +61,7 @@ type deleteRangeNode struct { var _ planNode = &deleteRangeNode{} var _ planNodeFastPath = &deleteRangeNode{} var _ batchedPlanNode = &deleteRangeNode{} +var _ mutationPlanNode = &deleteRangeNode{} // BatchedNext implements the batchedPlanNode interface. func (d *deleteRangeNode) BatchedNext(params runParams) (bool, error) { @@ -82,6 +83,10 @@ func (d *deleteRangeNode) FastPathResults() (int, bool) { return d.rowCount, true } +func (d *deleteRangeNode) rowsWritten() int64 { + return int64(d.rowCount) +} + // startExec implements the planNode interface. func (d *deleteRangeNode) startExec(params runParams) error { if err := params.p.cancelChecker.Check(); err != nil { diff --git a/pkg/sql/distsql_running.go b/pkg/sql/distsql_running.go index 8f4c762c43ca..37651da69186 100644 --- a/pkg/sql/distsql_running.go +++ b/pkg/sql/distsql_running.go @@ -608,6 +608,10 @@ type DistSQLReceiver struct { // this node's clock. clockUpdater clockUpdater + // TODO(yuzefovich): I believe these stats currently only include the + // metrics from the main query, and not from any sub- or post-queries + // because we use DistSQLReceiver.clone() for those. Think through whether + // this is expected or not. stats topLevelQueryStats expectedRowsRead int64 @@ -874,6 +878,7 @@ func (r *DistSQLReceiver) pushMeta(meta *execinfrapb.ProducerMetadata) execinfra if meta.Metrics != nil { r.stats.bytesRead += meta.Metrics.BytesRead r.stats.rowsRead += meta.Metrics.RowsRead + r.stats.rowsWritten += meta.Metrics.RowsWritten if r.progressAtomic != nil && r.expectedRowsRead != 0 { progress := float64(r.stats.rowsRead) / float64(r.expectedRowsRead) atomic.StoreUint64(r.progressAtomic, math.Float64bits(progress)) diff --git a/pkg/sql/event_log.go b/pkg/sql/event_log.go index f760039db267..c90874160806 100644 --- a/pkg/sql/event_log.go +++ b/pkg/sql/event_log.go @@ -22,7 +22,6 @@ import ( "github.com/cockroachdb/cockroach/pkg/security" "github.com/cockroachdb/cockroach/pkg/settings" "github.com/cockroachdb/cockroach/pkg/sql/catalog/descpb" - "github.com/cockroachdb/cockroach/pkg/sql/sem/tree" "github.com/cockroachdb/cockroach/pkg/util/log" "github.com/cockroachdb/cockroach/pkg/util/log/eventpb" "github.com/cockroachdb/cockroach/pkg/util/timeutil" @@ -166,6 +165,23 @@ type eventLogOptions struct { verboseTraceLevel log.Level } +func (p *planner) getCommonSQLEventDetails() eventpb.CommonSQLEventDetails { + redactableStmt := formatStmtKeyAsRedactableString(p.extendedEvalCtx.VirtualSchemas, p.stmt.AST, p.extendedEvalCtx.EvalContext.Annotations) + commonSQLEventDetails := eventpb.CommonSQLEventDetails{ + Statement: redactableStmt, + Tag: p.stmt.AST.StatementTag(), + User: p.User().Normalized(), + ApplicationName: p.SessionData().ApplicationName, + } + if pls := p.extendedEvalCtx.EvalContext.Placeholders.Values; len(pls) > 0 { + commonSQLEventDetails.PlaceholderValues = make([]string, len(pls)) + for idx, val := range pls { + commonSQLEventDetails.PlaceholderValues[idx] = val.String() + } + } + return commonSQLEventDetails +} + // logEventsWithOptions is like logEvent() but it gives control to the // caller as to where the event is written to. // @@ -174,22 +190,11 @@ type eventLogOptions struct { func (p *planner) logEventsWithOptions( ctx context.Context, depth int, opts eventLogOptions, entries ...eventLogEntry, ) error { - - redactableStmt := formatStmtKeyAsRedactableString(p.extendedEvalCtx.VirtualSchemas, p.stmt.AST, p.extendedEvalCtx.EvalContext.Annotations) - - commonPayload := sqlEventCommonExecPayload{ - user: p.User(), - stmt: redactableStmt, - stmtTag: p.stmt.AST.StatementTag(), - placeholders: p.extendedEvalCtx.EvalContext.Placeholders.Values, - appName: p.SessionData().ApplicationName, - } - return logEventInternalForSQLStatements(ctx, p.extendedEvalCtx.ExecCfg, p.txn, 1+depth, opts, - commonPayload, + p.getCommonSQLEventDetails(), entries...) } @@ -232,16 +237,6 @@ func logEventInternalForSchemaChanges( ) } -// sqlEventExecPayload contains the statement and session details -// necessary to populate an eventpb.CommonSQLExecDetails. -type sqlEventCommonExecPayload struct { - user security.SQLUsername - stmt redact.RedactableString - stmtTag string - placeholders tree.QueryArguments - appName string -} - // logEventInternalForSQLStatements emits a cluster event on behalf of // a SQL statement, when the point where the event is emitted does not // have access to a (*planner) and the current statement metadata. @@ -256,7 +251,7 @@ func logEventInternalForSQLStatements( txn *kv.Txn, depth int, opts eventLogOptions, - commonPayload sqlEventCommonExecPayload, + commonSQLEventDetails eventpb.CommonSQLEventDetails, entries ...eventLogEntry, ) error { // Inject the common fields into the payload provided by the caller. @@ -268,17 +263,8 @@ func logEventInternalForSQLStatements( return errors.AssertionFailedf("unknown event type: %T", event) } m := sqlCommon.CommonSQLDetails() - m.Statement = commonPayload.stmt - m.Tag = commonPayload.stmtTag - m.ApplicationName = commonPayload.appName - m.User = commonPayload.user.Normalized() + *m = commonSQLEventDetails m.DescriptorID = uint32(entry.targetID) - if pls := commonPayload.placeholders; len(pls) > 0 { - m.PlaceholderValues = make([]string, len(pls)) - for idx, val := range pls { - m.PlaceholderValues[idx] = val.String() - } - } return nil } diff --git a/pkg/sql/event_log_test.go b/pkg/sql/event_log_test.go index 8253739712f2..d9217331d666 100644 --- a/pkg/sql/event_log_test.go +++ b/pkg/sql/event_log_test.go @@ -110,7 +110,8 @@ func TestPerfLogging(t *testing.T) { defer leaktest.AfterTest(t)() var testCases = []struct { - // Query to execute. + // Query to execute. query might be empty if setup is not empty, in + // which case only the setup is performed. query string // Regular expression the error message must match ("" for no error). errRe string @@ -120,6 +121,8 @@ func TestPerfLogging(t *testing.T) { logExpected bool // Logging channel all log messages matching logRe must be in. channel logpb.Channel + // Optional queries to execute before/after running query. + setup, cleanup string }{ { query: `SELECT pg_sleep(0.256)`, @@ -387,6 +390,274 @@ func TestPerfLogging(t *testing.T) { logExpected: false, channel: channel.SQL_INTERNAL_PERF, }, + + // Tests for the limits on the number of txn rows written/read. + { + // Enable the relevant cluster settings and reset the session + // variables to the values of the cluster settings just set. + setup: ` + SET CLUSTER SETTING sql.defaults.transaction_rows_written_log = 2; + SET CLUSTER SETTING sql.defaults.transaction_rows_written_err = 3; + SET CLUSTER SETTING sql.defaults.transaction_rows_read_log = 2; + SET CLUSTER SETTING sql.defaults.transaction_rows_read_err = 3; + RESET transaction_rows_written_log; + RESET transaction_rows_written_err; + RESET transaction_rows_read_log; + RESET transaction_rows_read_err; + `, + }, + { + query: `INSERT INTO t(i) VALUES (6)`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit"`, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + query: `INSERT INTO t(i) VALUES (7), (8)`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit","Statement":"INSERT INTO.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `INSERT INTO t(i) VALUES (-1), (-2)`, + query: `UPDATE t SET i = i - 10 WHERE i < 0`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit","Statement":"UPDATE.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `BEGIN`, + cleanup: `COMMIT`, + query: `INSERT INTO t(i) VALUES (9); INSERT INTO t(i) VALUES (10);`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit","Statement":"INSERT INTO.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `SET transaction_rows_written_log = 1`, + cleanup: `RESET transaction_rows_written_log`, + query: `INSERT INTO t(i) VALUES (11)`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit","Statement":"INSERT INTO.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + query: `INSERT INTO t(i) VALUES (12), (13), (14)`, + errRe: `pq: txn reached the number of rows written \(3\): TxnID .* SessionID .*`, + logRe: `"EventType":"txn_rows_written_limit","Statement":"INSERT INTO.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `INSERT INTO t(i) VALUES (-1)`, + // We now have 3 negative values in the table t. + query: `DELETE FROM t WHERE i < 0`, + errRe: `pq: txn reached the number of rows written \(3\): TxnID .* SessionID .*`, + logRe: `"EventType":"txn_rows_written_limit","Statement":"DELETE.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + query: `UPSERT INTO t(i) VALUES (-2), (-3), (-4)`, + errRe: `pq: txn reached the number of rows written \(3\): TxnID .* SessionID .*`, + logRe: `"EventType":"txn_rows_written_limit","Statement":"UPSERT INTO.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + // The next two cases check that we log two events if both _log and _err + // limits are reached when the former is smaller. + { + setup: `BEGIN`, + cleanup: `ROLLBACK`, + query: `INSERT INTO t(i) VALUES (15), (16); INSERT INTO t(i) VALUES (17);`, + errRe: `pq: txn reached the number of rows written \(3\): TxnID .* SessionID .*`, + logRe: `"EventType":"txn_rows_written_limit","Statement":"INSERT INTO.*","TxnID":".*","SessionID":".*","Limit":2`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `BEGIN`, + cleanup: `ROLLBACK`, + query: `INSERT INTO t(i) VALUES (15), (16); INSERT INTO t(i) VALUES (17);`, + errRe: `pq: txn reached the number of rows written \(3\): TxnID .* SessionID .*`, + logRe: `"EventType":"txn_rows_written_limit","Statement":"INSERT INTO.*","TxnID":".*","SessionID":".*","Limit":3,"ViolatesTxnRowsLimitErr":true`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `SET transaction_rows_written_err = 1`, + cleanup: `RESET transaction_rows_written_err`, + query: `INSERT INTO t(i) VALUES (18)`, + errRe: `pq: txn reached the number of rows written \(1\): TxnID .* SessionID .*`, + logRe: ``, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + query: `SELECT * FROM t WHERE i = 6`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit"`, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + query: `SELECT * FROM t WHERE i IN (6, 7)`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit","Statement":"SELECT.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `BEGIN`, + cleanup: `COMMIT`, + query: `SELECT * FROM t WHERE i = 6; SELECT * FROM t WHERE i = 7;`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit","Statement":"SELECT.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `SET transaction_rows_read_log = 1`, + cleanup: `RESET transaction_rows_read_log`, + query: `SELECT * FROM t WHERE i = 6`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit","Statement":"SELECT.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + query: `SELECT * FROM t WHERE i IN (6, 7, 8)`, + errRe: `pq: txn reached the number of rows read \(3\): TxnID .* SessionID .*`, + logRe: `"EventType":"txn_rows_read_limit","Statement":"SELECT.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `BEGIN`, + cleanup: `ROLLBACK`, + query: `SELECT * FROM t WHERE i IN (6, 7); SELECT * FROM t WHERE i = 8`, + errRe: `pq: txn reached the number of rows read \(3\): TxnID .* SessionID .*`, + logRe: `"EventType":"txn_rows_read_limit","Statement":"SELECT.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + setup: `SET transaction_rows_read_err = 1`, + cleanup: `RESET transaction_rows_read_err`, + query: `SELECT * FROM t WHERE i = 6`, + errRe: `pq: txn reached the number of rows read \(1\): TxnID .* SessionID .*`, + logRe: ``, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + // Temporarily disable the "written" limits so that we can check + // that a mutation can run into the "read" limits too. + setup: `SET transaction_rows_written_log = 0; SET transaction_rows_written_err = 0;`, + cleanup: `SET transaction_rows_written_log = 2; SET transaction_rows_written_err = 3;`, + query: `UPDATE t SET i = i - 10 WHERE i < 0`, + errRe: `pq: txn reached the number of rows read \(3\): TxnID .* SessionID .*`, + logRe: `"EventType":"txn_rows_read_limit","Statement":"UPDATE.*","TxnID":".*","SessionID":".*"`, + logExpected: true, + channel: channel.SQL_PERF, + }, + { + cleanup: `DROP TABLE t_copy`, + query: `CREATE TABLE t_copy (i PRIMARY KEY) AS SELECT i FROM t`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit"`, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + cleanup: `DROP TABLE t_copy`, + query: `CREATE TABLE t_copy (i PRIMARY KEY) AS SELECT i FROM t`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit"`, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + cleanup: `DROP TABLE t_copy`, + query: `CREATE TABLE t_copy (i PRIMARY KEY) AS SELECT i FROM t`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit"`, + logExpected: false, + channel: channel.SQL_INTERNAL_PERF, + }, + { + cleanup: `DROP TABLE t_copy`, + query: `CREATE TABLE t_copy (i PRIMARY KEY) AS SELECT i FROM t`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit"`, + logExpected: false, + channel: channel.SQL_INTERNAL_PERF, + }, + { + setup: `CREATE TABLE t_copy (i PRIMARY KEY) AS SELECT i FROM t`, + query: `DROP TABLE t_copy`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit"`, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + setup: `CREATE TABLE t_copy (i PRIMARY KEY) AS SELECT i FROM t`, + query: `DROP TABLE t_copy`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit"`, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + setup: `CREATE TABLE t_copy (i PRIMARY KEY) AS SELECT i FROM t`, + query: `DROP TABLE t_copy`, + errRe: ``, + logRe: `"EventType":"txn_rows_written_limit"`, + logExpected: false, + channel: channel.SQL_INTERNAL_PERF, + }, + { + setup: `CREATE TABLE t_copy (i PRIMARY KEY) AS SELECT i FROM t`, + query: `DROP TABLE t_copy`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit"`, + logExpected: false, + channel: channel.SQL_INTERNAL_PERF, + }, + { + query: `ANALYZE t`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit"`, + logExpected: false, + channel: channel.SQL_PERF, + }, + { + query: `ANALYZE t`, + errRe: ``, + logRe: `"EventType":"txn_rows_read_limit"`, + logExpected: false, + channel: channel.SQL_INTERNAL_PERF, + }, + { + // Disable the relevant cluster settings and reset the session + // variables to the values of the cluster settings just set. + setup: ` + SET CLUSTER SETTING sql.defaults.transaction_rows_written_log = DEFAULT; + SET CLUSTER SETTING sql.defaults.transaction_rows_written_err = DEFAULT; + SET CLUSTER SETTING sql.defaults.transaction_rows_read_log = DEFAULT; + SET CLUSTER SETTING sql.defaults.transaction_rows_read_err = DEFAULT; + RESET transaction_rows_written_log; + RESET transaction_rows_written_err; + RESET transaction_rows_read_log; + RESET transaction_rows_read_err; + `, + }, } // Make file sinks for the SQL perf logs. @@ -431,6 +702,14 @@ func TestPerfLogging(t *testing.T) { defer db.Exec(t, `DROP TABLE t, u`) for _, tc := range testCases { + if tc.setup != "" { + t.Log(tc.setup) + db.Exec(t, tc.setup) + if tc.query == "" { + continue + } + } + t.Log(tc.query) start := timeutil.Now().UnixNano() if tc.errRe != "" { @@ -467,5 +746,10 @@ func TestPerfLogging(t *testing.T) { )) } } + + if tc.cleanup != "" { + t.Log(tc.cleanup) + db.Exec(t, tc.cleanup) + } } } diff --git a/pkg/sql/exec_util.go b/pkg/sql/exec_util.go index 9db4789c7c2a..6f26b3c6f552 100644 --- a/pkg/sql/exec_util.go +++ b/pkg/sql/exec_util.go @@ -583,6 +583,42 @@ var dateStyleEnabled = settings.RegisterBoolSetting( false, ).WithPublic() +var txnRowsWrittenLog = settings.RegisterIntSetting( + "sql.defaults.transaction_rows_written_log", + "the threshold for the number of rows written by a SQL transaction "+ + "which - once reached - will trigger a logging event to SQL_PERF (or "+ + "SQL_INTERNAL_PERF for internal transactions); use 0 to disable", + 0, + settings.NonNegativeInt, +).WithPublic() + +var txnRowsWrittenErr = settings.RegisterIntSetting( + "sql.defaults.transaction_rows_written_err", + "the limit for the number of rows written by a SQL transaction which - "+ + "once reached - will fail the transaction (or will trigger a logging "+ + "event to SQL_INTERNAL_PERF for internal transactions); use 0 to disable", + 0, + settings.NonNegativeInt, +).WithPublic() + +var txnRowsReadLog = settings.RegisterIntSetting( + "sql.defaults.transaction_rows_read_log", + "the threshold for the number of rows read by a SQL transaction "+ + "which - once reached - will trigger a logging event to SQL_PERF (or "+ + "SQL_INTERNAL_PERF for internal transactions); use 0 to disable", + 0, + settings.NonNegativeInt, +).WithPublic() + +var txnRowsReadErr = settings.RegisterIntSetting( + "sql.defaults.transaction_rows_read_err", + "the limit for the number of rows read by a SQL transaction which - "+ + "once reached - will fail the transaction (or will trigger a logging "+ + "event to SQL_INTERNAL_PERF for internal transactions); use 0 to disable", + 0, + settings.NonNegativeInt, +).WithPublic() + var errNoTransactionInProgress = errors.New("there is no transaction in progress") var errTransactionInProgress = errors.New("there is already a transaction in progress") @@ -919,6 +955,30 @@ var ( Measurement: "SQL Stats Cleanup", Unit: metric.Unit_COUNT, } + MetaTxnRowsWrittenLog = metric.Metadata{ + Name: "sql.guardrails.transaction_rows_written_log.count", + Help: "Number of transactions logged because of transaction_rows_written_log guardrail", + Measurement: "Logged transactions", + Unit: metric.Unit_COUNT, + } + MetaTxnRowsWrittenErr = metric.Metadata{ + Name: "sql.guardrails.transaction_rows_written_err.count", + Help: "Number of transactions errored because of transaction_rows_written_err guardrail", + Measurement: "Errored transactions", + Unit: metric.Unit_COUNT, + } + MetaTxnRowsReadLog = metric.Metadata{ + Name: "sql.guardrails.transaction_rows_read_log.count", + Help: "Number of transactions logged because of transaction_rows_read_log guardrail", + Measurement: "Logged transactions", + Unit: metric.Unit_COUNT, + } + MetaTxnRowsReadErr = metric.Metadata{ + Name: "sql.guardrails.transaction_rows_read_err.count", + Help: "Number of transactions errored because of transaction_rows_read_err guardrail", + Measurement: "Errored transactions", + Unit: metric.Unit_COUNT, + } ) func getMetricMeta(meta metric.Metadata, internal bool) metric.Metadata { @@ -2712,6 +2772,22 @@ func (m *sessionDataMutator) SetPropagateInputOrdering(b bool) { m.data.PropagateInputOrdering = b } +func (m *sessionDataMutator) SetTxnRowsWrittenLog(val int64) { + m.data.TxnRowsWrittenLog = val +} + +func (m *sessionDataMutator) SetTxnRowsWrittenErr(val int64) { + m.data.TxnRowsWrittenErr = val +} + +func (m *sessionDataMutator) SetTxnRowsReadLog(val int64) { + m.data.TxnRowsReadLog = val +} + +func (m *sessionDataMutator) SetTxnRowsReadErr(val int64) { + m.data.TxnRowsReadErr = val +} + // Utility functions related to scrubbing sensitive information on SQL Stats. // quantizeCounts ensures that the Count field in the diff --git a/pkg/sql/execinfrapb/data.pb.go b/pkg/sql/execinfrapb/data.pb.go index 866034e95d91..53fdb30559bc 100644 --- a/pkg/sql/execinfrapb/data.pb.go +++ b/pkg/sql/execinfrapb/data.pb.go @@ -1129,6 +1129,8 @@ type RemoteProducerMetadata_Metrics struct { BytesRead int64 `protobuf:"varint,1,opt,name=bytes_read,json=bytesRead" json:"bytes_read"` // Total number of rows read while executing a statement. RowsRead int64 `protobuf:"varint,2,opt,name=rows_read,json=rowsRead" json:"rows_read"` + // Total number of rows modified while executing a statement. + RowsWritten int64 `protobuf:"varint,3,opt,name=rows_written,json=rowsWritten" json:"rows_written"` } func (m *RemoteProducerMetadata_Metrics) Reset() { *m = RemoteProducerMetadata_Metrics{} } @@ -1271,140 +1273,141 @@ func init() { func init() { proto.RegisterFile("sql/execinfrapb/data.proto", fileDescriptor_88f01b948ed44512) } var fileDescriptor_88f01b948ed44512 = []byte{ - // 2113 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x58, 0xbb, 0x73, 0x5b, 0xc7, - 0xd5, 0xc7, 0x8b, 0x78, 0x1c, 0xf0, 0x01, 0xee, 0x47, 0xcb, 0xf8, 0x10, 0x87, 0x94, 0xe1, 0x8c, - 0x47, 0x71, 0xec, 0x0b, 0x9b, 0x2a, 0xe4, 0x30, 0xc9, 0x48, 0x00, 0x01, 0x0a, 0x90, 0x29, 0x92, - 0xbe, 0xa0, 0xe2, 0x91, 0x1d, 0xcf, 0x9d, 0x8b, 0x7b, 0x17, 0xe0, 0xb5, 0xee, 0x4b, 0xbb, 0x7b, - 0x45, 0xb2, 0xc9, 0x64, 0x26, 0x29, 0x53, 0xa4, 0xca, 0xa4, 0x74, 0x9a, 0x34, 0x29, 0xd2, 0xe7, - 0x0f, 0xf0, 0xa8, 0x74, 0xa9, 0x49, 0xa1, 0x49, 0xa8, 0x26, 0x4d, 0x66, 0xd2, 0xc6, 0x55, 0x66, - 0x5f, 0x78, 0x89, 0x94, 0x42, 0xcb, 0x0d, 0xb0, 0x7b, 0xf6, 0xfc, 0x7e, 0xe7, 0xec, 0xd9, 0xb3, - 0x67, 0x77, 0x2f, 0xd4, 0xe8, 0x43, 0xbf, 0x81, 0x4f, 0xb0, 0xe3, 0x85, 0x43, 0x62, 0xc7, 0x83, - 0x86, 0x6b, 0x33, 0xdb, 0x88, 0x49, 0xc4, 0x22, 0x54, 0x75, 0x22, 0xe7, 0x01, 0x89, 0x6c, 0xe7, - 0xc8, 0xa0, 0x0f, 0x7d, 0xc3, 0xf5, 0x28, 0xa3, 0x0f, 0x7d, 0x92, 0x84, 0xb5, 0x2b, 0x5f, 0x44, - 0x03, 0xda, 0xe0, 0x3f, 0xf1, 0x40, 0xfc, 0x49, 0x44, 0x6d, 0x55, 0x68, 0xc7, 0x83, 0x86, 0x1d, - 0x7b, 0x4a, 0x84, 0xb4, 0x68, 0x42, 0x5c, 0x5b, 0xd3, 0x32, 0x4c, 0x48, 0x44, 0x34, 0xf8, 0x35, - 0xd9, 0x9b, 0x17, 0x6f, 0x70, 0x0f, 0xe3, 0xd1, 0xb1, 0x47, 0x70, 0x23, 0x1e, 0x89, 0xa1, 0x59, - 0x85, 0xb7, 0xb8, 0x82, 0x63, 0x33, 0xdb, 0x8f, 0x46, 0x0d, 0x17, 0x53, 0x27, 0x1e, 0x34, 0x28, - 0x23, 0x89, 0xc3, 0x12, 0x82, 0x5d, 0xa5, 0xf4, 0xf6, 0x39, 0x4a, 0x38, 0x74, 0x22, 0x17, 0xbb, - 0x96, 0x6b, 0xb3, 0x24, 0xd0, 0x4e, 0x70, 0x3d, 0x76, 0x1a, 0x63, 0x2a, 0x7f, 0x95, 0xf8, 0x9d, - 0x84, 0x79, 0x7e, 0x83, 0x11, 0xdb, 0xf1, 0xc2, 0x91, 0xfe, 0x8f, 0x07, 0x0d, 0x82, 0x9d, 0x88, - 0x70, 0x0e, 0x1a, 0xdb, 0xa1, 0x9e, 0xdd, 0x28, 0x1a, 0x45, 0xa2, 0xd9, 0xe0, 0x2d, 0x25, 0xad, - 0x0a, 0x86, 0x23, 0xdf, 0x69, 0x30, 0x2f, 0xc0, 0x94, 0xd9, 0x41, 0xac, 0x46, 0xfe, 0x7f, 0x14, - 0x45, 0x23, 0x1f, 0x37, 0x44, 0x6f, 0x90, 0x0c, 0x1b, 0x76, 0x78, 0xaa, 0xe7, 0x3e, 0x3f, 0x34, - 0x87, 0xad, 0x7f, 0x0a, 0x0b, 0x1d, 0x1e, 0x0b, 0x74, 0x13, 0x60, 0x98, 0xf8, 0xbe, 0x25, 0x22, - 0x53, 0xcd, 0x5e, 0x4d, 0x5f, 0x2b, 0x6f, 0x5e, 0x35, 0x26, 0x0b, 0xa8, 0x63, 0x6b, 0x74, 0xe4, - 0xa4, 0x05, 0xca, 0x2c, 0x71, 0x8c, 0x68, 0x6e, 0xe5, 0xfe, 0xf0, 0xe5, 0x46, 0xea, 0x4e, 0xae, - 0x98, 0xae, 0x64, 0xee, 0xe4, 0x8a, 0x99, 0x4a, 0xb6, 0x7e, 0x00, 0xd0, 0x39, 0x89, 0x09, 0xa6, - 0xd4, 0x8b, 0x42, 0xb4, 0x0e, 0x85, 0x47, 0x98, 0xf0, 0x66, 0x35, 0x7d, 0x35, 0x7d, 0xad, 0xd4, - 0xca, 0x3d, 0x7e, 0xba, 0x91, 0x32, 0xb5, 0x10, 0x55, 0x21, 0x87, 0x4f, 0x62, 0x52, 0xcd, 0x4c, - 0x0d, 0x0a, 0xc9, 0x56, 0x91, 0x33, 0xff, 0xfb, 0x8f, 0x1b, 0xa9, 0xfa, 0x6f, 0x32, 0x50, 0xdc, - 0x27, 0x2e, 0x26, 0x5e, 0x38, 0x42, 0x3d, 0x28, 0x38, 0x91, 0x9f, 0x04, 0x21, 0xad, 0xa6, 0xaf, - 0x66, 0xaf, 0x95, 0x37, 0x7f, 0x68, 0x5c, 0x94, 0x6f, 0x86, 0x06, 0x19, 0xdb, 0x02, 0xa1, 0x6d, - 0x2b, 0x7c, 0xed, 0x4f, 0x69, 0xc8, 0xcb, 0x11, 0xf4, 0x7d, 0xc1, 0x6a, 0x79, 0xee, 0x89, 0x70, - 0x73, 0x49, 0xa9, 0xe6, 0x9d, 0xc8, 0xef, 0xb9, 0x27, 0xe8, 0x13, 0x28, 0xb9, 0x1e, 0xc1, 0x0e, - 0xe3, 0xf3, 0xe0, 0xae, 0x2e, 0x6f, 0x5e, 0xff, 0x9f, 0xcd, 0x1a, 0x6d, 0x0d, 0x55, 0xac, 0x13, - 0xae, 0xfa, 0x3a, 0x94, 0xc6, 0xa3, 0xa8, 0x00, 0xd9, 0x66, 0x7f, 0xbb, 0x92, 0x42, 0x45, 0xc8, - 0xb5, 0x3b, 0xfd, 0xed, 0x4a, 0x7a, 0x2b, 0xf7, 0xcf, 0x2f, 0x37, 0xd4, 0x6f, 0xfd, 0xaf, 0x59, - 0x40, 0x7d, 0x46, 0xb0, 0x1d, 0x74, 0x42, 0x37, 0x8e, 0xbc, 0x90, 0xf5, 0x63, 0xec, 0xa0, 0x8f, - 0x20, 0xc7, 0x53, 0x4e, 0xf8, 0xbd, 0xbc, 0xf9, 0xc1, 0xc5, 0x6e, 0x3d, 0x8f, 0x35, 0x0e, 0x4f, - 0x63, 0xac, 0x83, 0xce, 0x49, 0xd0, 0x8f, 0xa1, 0x44, 0x85, 0x9a, 0xe5, 0xb9, 0x62, 0xa2, 0x0b, - 0xad, 0x37, 0xf8, 0xf0, 0xd9, 0xd3, 0x8d, 0xa2, 0xc4, 0xf7, 0xda, 0xdf, 0x4c, 0xb5, 0xcd, 0xa2, - 0x54, 0xef, 0xb9, 0xe8, 0x21, 0x2c, 0x33, 0x9b, 0x8c, 0x30, 0xb3, 0xc2, 0xc8, 0xc5, 0x1c, 0x9f, - 0x13, 0xf8, 0x8f, 0x14, 0x7e, 0xf1, 0x50, 0x8c, 0xee, 0x45, 0x2e, 0x16, 0x1c, 0xd7, 0x47, 0x1e, - 0x3b, 0x4a, 0x06, 0x86, 0x13, 0x05, 0x8d, 0xb1, 0xcf, 0xee, 0x60, 0xd2, 0x6e, 0xc4, 0x0f, 0x46, - 0x0d, 0xb5, 0xe5, 0x0d, 0x09, 0x33, 0x17, 0xd9, 0x84, 0x44, 0x98, 0x8c, 0x88, 0x37, 0xf2, 0xc2, - 0xb1, 0xc9, 0x85, 0x59, 0x93, 0xfb, 0x62, 0xf4, 0x15, 0x4d, 0x46, 0x13, 0x12, 0xb7, 0xfe, 0x3e, - 0xe4, 0x78, 0xd0, 0x50, 0x09, 0x16, 0x76, 0xf7, 0xb7, 0x9b, 0xbb, 0x95, 0x14, 0x02, 0xc8, 0x9b, - 0x9d, 0xbb, 0xfb, 0x87, 0x9d, 0x4a, 0x1a, 0xad, 0xc2, 0x52, 0xff, 0xfe, 0xde, 0xb6, 0x65, 0x76, - 0xfa, 0x07, 0xfb, 0x7b, 0xfd, 0x8e, 0xd8, 0x15, 0xd9, 0x4a, 0xae, 0xfe, 0xaf, 0x0c, 0x2c, 0xf5, - 0xc2, 0x38, 0x61, 0xfd, 0xd3, 0xd0, 0x11, 0xeb, 0xb6, 0x33, 0xb3, 0x6e, 0xef, 0x5e, 0xbc, 0x6e, - 0x33, 0xb0, 0xe7, 0x97, 0xac, 0x0d, 0xc5, 0x48, 0x25, 0x9c, 0x58, 0xb1, 0xf2, 0x66, 0xfd, 0xe5, - 0xa9, 0xa9, 0x18, 0xc6, 0x48, 0xb4, 0x0b, 0x05, 0xb9, 0x92, 0xb4, 0x9a, 0x15, 0xdb, 0xea, 0xdd, - 0xcb, 0x24, 0x92, 0xde, 0x59, 0x8a, 0x02, 0xfd, 0x0c, 0x16, 0xe5, 0x26, 0xb3, 0x44, 0x35, 0xac, - 0xe6, 0x04, 0x65, 0x6d, 0x8e, 0x92, 0xe2, 0xc0, 0x90, 0xd5, 0xf2, 0xd0, 0x2c, 0x4b, 0x7d, 0x3e, - 0x3b, 0x5a, 0x6f, 0xaa, 0x20, 0x5f, 0x01, 0x74, 0xd0, 0x34, 0x9b, 0xbb, 0xbb, 0x9d, 0x5d, 0xeb, - 0xde, 0xde, 0xbe, 0xd9, 0xee, 0x98, 0x9d, 0x76, 0x25, 0x85, 0xca, 0x50, 0xd0, 0x9d, 0x34, 0x5a, - 0x83, 0x4a, 0xbf, 0x63, 0xf6, 0x9a, 0xd3, 0x2a, 0x99, 0xfa, 0x7f, 0xf2, 0x50, 0xd9, 0x4f, 0x58, - 0x9c, 0x30, 0x33, 0x4a, 0x18, 0x26, 0x22, 0xe4, 0xbd, 0x99, 0x90, 0x37, 0x5e, 0x10, 0xa6, 0x39, - 0xe4, 0xf3, 0x51, 0x9f, 0x8a, 0x57, 0xe6, 0xd5, 0xe3, 0xf5, 0x26, 0x2c, 0x1e, 0xd9, 0xf4, 0xc8, - 0xd2, 0x95, 0x8d, 0x2f, 0xc1, 0x92, 0x59, 0xe6, 0x32, 0x59, 0x43, 0x28, 0xf2, 0x61, 0x95, 0xd8, - 0xe1, 0x08, 0x5b, 0x44, 0x78, 0x65, 0xd1, 0x18, 0x3b, 0x62, 0x87, 0x95, 0x37, 0xb7, 0x2e, 0x31, - 0x11, 0x93, 0x73, 0x4c, 0xfa, 0xca, 0x91, 0x15, 0x32, 0x2b, 0x46, 0x1f, 0xc0, 0xaa, 0xeb, 0x51, - 0x7b, 0xe0, 0x63, 0x6b, 0x90, 0x0c, 0x87, 0x32, 0xbb, 0xf8, 0xe6, 0x2a, 0x2a, 0x44, 0x45, 0x0d, - 0xb7, 0xf4, 0x68, 0xed, 0xab, 0x2c, 0xac, 0xcc, 0xb1, 0xa3, 0xcf, 0x60, 0x81, 0x9f, 0x70, 0xba, - 0x54, 0xdf, 0xfc, 0xf6, 0x8e, 0x1a, 0xfd, 0xd8, 0xd6, 0xf5, 0x53, 0x72, 0xf2, 0xa0, 0xb9, 0x78, - 0x68, 0x27, 0x3e, 0xb3, 0x5c, 0x4c, 0x99, 0x2c, 0x57, 0x66, 0x59, 0xc9, 0xda, 0x98, 0x32, 0x14, - 0x40, 0x49, 0x9c, 0xd6, 0x5e, 0x38, 0xd2, 0x79, 0xdd, 0x7b, 0x05, 0x1f, 0xe4, 0x5a, 0x74, 0x14, - 0xa3, 0xae, 0xe6, 0x63, 0x0b, 0xb5, 0x47, 0xb0, 0x3c, 0xab, 0x82, 0xde, 0x80, 0xbc, 0x5c, 0xd3, - 0xe7, 0x8e, 0x15, 0x7e, 0xea, 0xec, 0x40, 0x51, 0x83, 0xd5, 0xa9, 0xf2, 0x83, 0xf9, 0x2d, 0xf2, - 0xd0, 0x1f, 0xd8, 0x14, 0x1b, 0x6d, 0x7e, 0xd7, 0x98, 0x33, 0x3c, 0xc6, 0xd6, 0x76, 0x21, 0xc7, - 0xc3, 0x83, 0xd6, 0x60, 0x81, 0x32, 0x9b, 0x30, 0x61, 0x6c, 0xd1, 0x94, 0x1d, 0x54, 0x81, 0x2c, - 0x0e, 0x65, 0x35, 0x5f, 0x34, 0x79, 0x93, 0x7b, 0x25, 0x33, 0x4f, 0x9c, 0xf8, 0x0b, 0xda, 0x2b, - 0x29, 0xab, 0xdf, 0x54, 0xbb, 0xaf, 0x02, 0x8b, 0x07, 0xcd, 0x7e, 0xdf, 0x3a, 0xec, 0x9a, 0xfb, - 0xf7, 0x6e, 0x77, 0x65, 0xa5, 0xbb, 0xdb, 0x33, 0xcd, 0x7d, 0xb3, 0x92, 0xe6, 0x7b, 0xb0, 0x75, - 0xdf, 0xea, 0x36, 0xfb, 0xdd, 0x4a, 0x06, 0x2d, 0x42, 0xb1, 0x75, 0xdf, 0x32, 0x9b, 0x7b, 0xb7, - 0x3b, 0x95, 0x6c, 0xfd, 0xd7, 0x69, 0x28, 0x09, 0x87, 0x7b, 0xe1, 0x30, 0x9a, 0x99, 0x64, 0xfa, - 0xdb, 0x4f, 0x12, 0x19, 0x6a, 0xf3, 0xca, 0x1a, 0xf7, 0xa2, 0x5a, 0x22, 0xf4, 0xea, 0xbf, 0x84, - 0xe5, 0x03, 0x12, 0xb9, 0x89, 0x83, 0x49, 0x17, 0xdb, 0x2e, 0x26, 0xe8, 0x03, 0x28, 0x0c, 0xfd, - 0xe8, 0x98, 0x9f, 0x13, 0x22, 0x40, 0xad, 0x2a, 0x37, 0xf1, 0xb7, 0xa7, 0x1b, 0xf9, 0x1d, 0x3f, - 0x3a, 0xee, 0xb5, 0xcf, 0xc6, 0x2d, 0x33, 0xcf, 0x15, 0x7b, 0xee, 0x2b, 0x9c, 0x87, 0xf5, 0x3f, - 0xa7, 0x61, 0x51, 0x3b, 0xd0, 0xb6, 0x99, 0x8d, 0xbe, 0x07, 0x25, 0x62, 0x1f, 0x5b, 0x83, 0x53, - 0x86, 0xa9, 0x5a, 0xa1, 0x22, 0xb1, 0x8f, 0x5b, 0xbc, 0x8f, 0xde, 0x81, 0xe5, 0x30, 0x09, 0x2c, - 0x1c, 0xc4, 0xec, 0xd4, 0x22, 0xd1, 0x31, 0x9d, 0x59, 0x9a, 0xc5, 0x30, 0x09, 0x3a, 0x7c, 0xc8, - 0x8c, 0x8e, 0x29, 0x32, 0xa1, 0x18, 0x60, 0x66, 0xf3, 0x9b, 0xb1, 0x2a, 0x3e, 0xef, 0x5f, 0x9c, - 0xd4, 0x26, 0x0e, 0x22, 0x86, 0xb5, 0x23, 0x77, 0x15, 0x4e, 0x47, 0x57, 0xf3, 0xd4, 0x9f, 0xa4, - 0x61, 0x65, 0xa2, 0x44, 0xa9, 0x3d, 0xc2, 0xe8, 0x16, 0xe4, 0x8f, 0x44, 0xe4, 0x84, 0xb7, 0xe5, - 0xcd, 0x6b, 0x17, 0x5b, 0x99, 0x8d, 0xb4, 0xa9, 0x70, 0xa8, 0x09, 0x79, 0x76, 0x1a, 0xcb, 0xf4, - 0xe6, 0x7e, 0xbe, 0x75, 0x31, 0xc3, 0x38, 0x61, 0x74, 0x36, 0x4a, 0x20, 0xba, 0x05, 0x39, 0x31, - 0x51, 0x79, 0x37, 0x7d, 0xfb, 0xe5, 0x2e, 0xb4, 0x27, 0xd3, 0x13, 0xc8, 0xfa, 0x57, 0xcb, 0x70, - 0xe5, 0xfc, 0x28, 0xa0, 0x5f, 0x00, 0xc8, 0xa2, 0xea, 0x85, 0xc3, 0x48, 0xcd, 0xf2, 0x27, 0x97, - 0x8d, 0xa5, 0x2c, 0x13, 0xdc, 0x75, 0xda, 0x4d, 0x99, 0x25, 0xa2, 0x7b, 0xe8, 0x06, 0x2c, 0xc8, - 0x7b, 0xb5, 0x4c, 0xd9, 0x8d, 0x8b, 0x89, 0xc5, 0x5d, 0xba, 0x9b, 0x32, 0xa5, 0x3e, 0xfa, 0x0c, - 0x80, 0xbf, 0x15, 0xb0, 0x35, 0x35, 0xf3, 0xad, 0x4b, 0xbb, 0x75, 0xc8, 0x29, 0x78, 0x34, 0xb8, - 0x57, 0x4c, 0x77, 0xd0, 0x27, 0xb0, 0xe6, 0x63, 0x7b, 0x68, 0xb1, 0x93, 0xd0, 0x1a, 0x7a, 0xa1, - 0xed, 0x5b, 0x94, 0xd9, 0x0c, 0xab, 0xb3, 0x64, 0x7a, 0x6f, 0xea, 0x8b, 0xd0, 0x2e, 0xb6, 0x87, - 0x87, 0x27, 0xe1, 0x0e, 0x57, 0xee, 0x73, 0xdd, 0x6e, 0xca, 0x5c, 0xf5, 0xe7, 0x85, 0xc8, 0x84, - 0x02, 0x89, 0x8e, 0xad, 0x30, 0x09, 0xc4, 0x49, 0x51, 0xde, 0xbc, 0x71, 0xf9, 0x48, 0x46, 0xc7, - 0x7b, 0x49, 0xd0, 0x4d, 0x99, 0x79, 0x22, 0x5a, 0x28, 0x80, 0x0a, 0xb5, 0x83, 0xd8, 0xc7, 0xc4, - 0x8a, 0x49, 0x34, 0xe2, 0xaf, 0x8a, 0x6a, 0x41, 0x90, 0xdf, 0xba, 0x34, 0x79, 0x5f, 0x12, 0x1d, - 0x28, 0x9e, 0x6e, 0xca, 0x5c, 0xa1, 0xb3, 0x22, 0x74, 0x08, 0x85, 0x00, 0x33, 0xe2, 0x39, 0xb4, - 0x5a, 0x14, 0x56, 0x3e, 0xbc, 0xb4, 0x95, 0xbb, 0x12, 0xdf, 0x4d, 0x99, 0x9a, 0x0a, 0xfd, 0x2a, - 0x0d, 0xaf, 0x0f, 0x12, 0xff, 0x01, 0x9f, 0x82, 0x83, 0x29, 0x8d, 0xa6, 0x26, 0x53, 0x12, 0x66, - 0x76, 0x2e, 0x6d, 0xa6, 0x95, 0xf8, 0x0f, 0x0e, 0x34, 0xdd, 0xd4, 0x94, 0x5e, 0x1b, 0x9c, 0x37, - 0x50, 0xdb, 0x07, 0x98, 0x64, 0x29, 0x6a, 0xce, 0xa5, 0x3d, 0xdf, 0x9a, 0x6f, 0x9c, 0xb3, 0xf0, - 0x63, 0x88, 0x3e, 0xea, 0xc6, 0xb9, 0x5d, 0xfb, 0x02, 0x4a, 0xe3, 0xfc, 0x42, 0x9f, 0xc3, 0x8a, - 0x13, 0xf9, 0x3e, 0x76, 0x98, 0x7a, 0xd2, 0xea, 0x03, 0xdf, 0x98, 0x22, 0xe5, 0x0f, 0x59, 0x43, - 0x3d, 0x81, 0x8d, 0xf1, 0x53, 0xd8, 0x30, 0xd5, 0x53, 0x78, 0xea, 0x7c, 0x5f, 0x1e, 0x93, 0x71, - 0x21, 0xad, 0x1d, 0x43, 0x5e, 0x26, 0x06, 0x7a, 0x0f, 0x4a, 0x14, 0x87, 0x2e, 0x26, 0xba, 0x86, - 0x97, 0x5a, 0x95, 0x71, 0x39, 0x16, 0x03, 0xa2, 0x04, 0xcb, 0x96, 0xcb, 0x5f, 0x75, 0x3a, 0x23, - 0x33, 0xd3, 0x07, 0x9d, 0x4a, 0xae, 0x0d, 0x28, 0xfa, 0x36, 0x65, 0x56, 0x40, 0x47, 0x62, 0x93, - 0xe9, 0xbb, 0x4d, 0x81, 0x4b, 0xef, 0xd2, 0x51, 0x8d, 0xc2, 0xca, 0x5c, 0xd2, 0xa0, 0x1f, 0xc1, - 0x32, 0xaf, 0xce, 0x7a, 0x29, 0xb1, 0x74, 0x23, 0xa7, 0x90, 0x4b, 0x7c, 0xec, 0x40, 0x0f, 0xa1, - 0xeb, 0x80, 0x8e, 0x3c, 0xca, 0xa2, 0x11, 0xb1, 0x03, 0x4b, 0x5d, 0x98, 0xe4, 0x31, 0xa2, 0x4d, - 0xad, 0x8e, 0xc7, 0xdb, 0x6a, 0xb8, 0xf6, 0x97, 0x1c, 0xbc, 0x76, 0xee, 0xea, 0xa2, 0x1d, 0x1e, - 0x66, 0xee, 0xce, 0x7c, 0x98, 0x5f, 0x3f, 0x67, 0xed, 0x66, 0xe3, 0xa9, 0x50, 0x22, 0x9e, 0xe8, - 0xb7, 0x69, 0x40, 0x13, 0xa2, 0x21, 0xb1, 0xf5, 0xbb, 0x96, 0x73, 0x7d, 0xfe, 0xdd, 0xa4, 0xa2, - 0xb1, 0xad, 0x0d, 0xec, 0x28, 0xfe, 0x4e, 0xc8, 0xc8, 0xa9, 0xb9, 0xea, 0xcc, 0xcb, 0x11, 0x03, - 0x20, 0x98, 0x26, 0x01, 0xb6, 0xe2, 0x48, 0xdf, 0xd2, 0xee, 0x7d, 0x47, 0x5e, 0x98, 0x82, 0xf8, - 0x20, 0xa2, 0xd2, 0x7a, 0x89, 0xe8, 0x3e, 0xea, 0x40, 0x45, 0x6f, 0x42, 0xcb, 0xc5, 0xcc, 0xf6, - 0x7c, 0xaa, 0x4a, 0xe0, 0x9a, 0x21, 0x3f, 0x9f, 0x18, 0xfa, 0xf3, 0x89, 0xd1, 0x0c, 0x4f, 0xf5, - 0x45, 0x59, 0x63, 0xda, 0x12, 0x52, 0x6b, 0xc3, 0x95, 0xf3, 0x67, 0xca, 0xaf, 0x5d, 0x0f, 0xf0, - 0xa9, 0x48, 0x8f, 0x05, 0x93, 0x37, 0xf9, 0xf5, 0xec, 0x91, 0xed, 0x27, 0xf2, 0x0a, 0x93, 0x31, - 0x65, 0x67, 0x2b, 0xf3, 0x61, 0xba, 0xf6, 0x53, 0x58, 0x9e, 0xf5, 0xf4, 0x65, 0xe8, 0xec, 0x34, - 0xfa, 0x63, 0x28, 0xa8, 0xaa, 0x83, 0xde, 0x02, 0x10, 0xf7, 0x0b, 0x8b, 0x60, 0x5b, 0xa6, 0x66, - 0x56, 0xef, 0x5d, 0x21, 0x37, 0xb1, 0xed, 0xa2, 0x37, 0xa1, 0x24, 0x72, 0x58, 0xe8, 0x64, 0xa6, - 0x74, 0x8a, 0x5c, 0xcc, 0x55, 0x5a, 0x05, 0x65, 0xec, 0x4e, 0xae, 0x98, 0xaf, 0x14, 0xee, 0xe4, - 0x8a, 0x50, 0x29, 0xd7, 0x7f, 0x9f, 0x86, 0x6a, 0xdb, 0xa3, 0xac, 0xff, 0xf1, 0xee, 0xcf, 0xe5, - 0xe7, 0x9b, 0xdb, 0x11, 0xa5, 0x5e, 0x2c, 0x0e, 0xbb, 0xf7, 0x67, 0x3f, 0xf4, 0x2c, 0xb5, 0xae, - 0x70, 0xca, 0x6f, 0x9e, 0x6e, 0x2c, 0xcf, 0x42, 0x26, 0x9f, 0x7e, 0xba, 0xb0, 0x16, 0x78, 0xa1, - 0x65, 0x3b, 0x0e, 0x8e, 0x79, 0x22, 0x6a, 0x78, 0xe6, 0x85, 0x70, 0x14, 0x78, 0x61, 0x53, 0x41, - 0x94, 0xac, 0x7e, 0x03, 0xfe, 0x4f, 0x69, 0xb5, 0x89, 0xed, 0x85, 0x5e, 0x38, 0x12, 0x2e, 0x5d, - 0x85, 0xa2, 0xab, 0xfa, 0xc2, 0x27, 0xbd, 0xe9, 0xc6, 0xd2, 0xd6, 0x7b, 0x8f, 0xff, 0xb1, 0x9e, - 0x7a, 0x7c, 0xb6, 0x9e, 0xfe, 0xfa, 0x6c, 0x3d, 0xfd, 0xe4, 0x6c, 0x3d, 0xfd, 0xf7, 0xb3, 0xf5, - 0xf4, 0xef, 0x9e, 0xad, 0xa7, 0xbe, 0x7e, 0xb6, 0x9e, 0x7a, 0xf2, 0x6c, 0x3d, 0xf5, 0x69, 0x79, - 0xea, 0x23, 0xe7, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0x55, 0x75, 0x2d, 0x9b, 0xf6, 0x14, 0x00, - 0x00, + // 2131 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x58, 0xcd, 0x73, 0x1c, 0x47, + 0x15, 0xdf, 0x2f, 0xed, 0xc7, 0x5b, 0x7d, 0xac, 0x1a, 0xc5, 0x59, 0x96, 0x20, 0x39, 0x1b, 0x2a, + 0x98, 0x90, 0xcc, 0x26, 0xca, 0x21, 0x41, 0x40, 0xd9, 0xbb, 0xda, 0x95, 0x77, 0x1d, 0x59, 0x12, + 0xb3, 0x32, 0x2e, 0x27, 0xa4, 0xa6, 0x66, 0x67, 0x7a, 0x57, 0x13, 0xcf, 0x97, 0xbb, 0x7b, 0x2c, + 0x89, 0x03, 0x45, 0x15, 0x1c, 0x39, 0x70, 0xa2, 0x38, 0x86, 0x0b, 0x17, 0x0e, 0xdc, 0xf9, 0x03, + 0x28, 0x1f, 0x73, 0x74, 0x71, 0x70, 0x81, 0x7c, 0xe1, 0x42, 0xc1, 0x95, 0x9c, 0xa8, 0xfe, 0xda, + 0x2f, 0x4b, 0x36, 0x8a, 0x73, 0xd9, 0xed, 0x7e, 0xef, 0xfd, 0x7e, 0xfd, 0xfa, 0xf5, 0xeb, 0xd7, + 0xdd, 0x03, 0x35, 0xfa, 0xc0, 0x6f, 0xe0, 0x13, 0xec, 0x78, 0xe1, 0x90, 0xd8, 0xf1, 0xa0, 0xe1, + 0xda, 0xcc, 0x36, 0x62, 0x12, 0xb1, 0x08, 0x55, 0x9d, 0xc8, 0xb9, 0x4f, 0x22, 0xdb, 0x39, 0x32, + 0xe8, 0x03, 0xdf, 0x70, 0x3d, 0xca, 0xe8, 0x03, 0x9f, 0x24, 0x61, 0xed, 0xca, 0x67, 0xd1, 0x80, + 0x36, 0xf8, 0x4f, 0x3c, 0x10, 0x7f, 0x12, 0x51, 0x5b, 0x15, 0xd6, 0xf1, 0xa0, 0x61, 0xc7, 0x9e, + 0x12, 0x21, 0x2d, 0x9a, 0x10, 0xd7, 0xd6, 0xb4, 0x0c, 0x13, 0x12, 0x11, 0x0d, 0x7e, 0x45, 0xf6, + 0xe6, 0xc5, 0x1b, 0xdc, 0xc3, 0x78, 0x74, 0xec, 0x11, 0xdc, 0x88, 0x47, 0x42, 0x35, 0x6b, 0xf0, + 0x06, 0x37, 0x70, 0x6c, 0x66, 0xfb, 0xd1, 0xa8, 0xe1, 0x62, 0xea, 0xc4, 0x83, 0x06, 0x65, 0x24, + 0x71, 0x58, 0x42, 0xb0, 0xab, 0x8c, 0xde, 0x3c, 0xc7, 0x08, 0x87, 0x4e, 0xe4, 0x62, 0xd7, 0x72, + 0x6d, 0x96, 0x04, 0xda, 0x09, 0x6e, 0xc7, 0x4e, 0x63, 0x4c, 0xe5, 0xaf, 0x12, 0xbf, 0x95, 0x30, + 0xcf, 0x6f, 0x30, 0x62, 0x3b, 0x5e, 0x38, 0xd2, 0xff, 0xf1, 0xa0, 0x41, 0xb0, 0x13, 0x11, 0xce, + 0x41, 0x63, 0x3b, 0xd4, 0xb3, 0x1b, 0x45, 0xa3, 0x48, 0x34, 0x1b, 0xbc, 0xa5, 0xa4, 0x55, 0xc1, + 0x70, 0xe4, 0x3b, 0x0d, 0xe6, 0x05, 0x98, 0x32, 0x3b, 0x88, 0x95, 0xe6, 0x9b, 0xa3, 0x28, 0x1a, + 0xf9, 0xb8, 0x21, 0x7a, 0x83, 0x64, 0xd8, 0xb0, 0xc3, 0x53, 0x3d, 0xf7, 0x79, 0xd5, 0x1c, 0xb6, + 0xfe, 0x31, 0x2c, 0x74, 0x78, 0x2c, 0xd0, 0x75, 0x80, 0x61, 0xe2, 0xfb, 0x96, 0x88, 0x4c, 0x35, + 0x7b, 0x35, 0x7d, 0xad, 0xbc, 0x79, 0xd5, 0x98, 0x2c, 0xa0, 0x8e, 0xad, 0xd1, 0x91, 0x93, 0x16, + 0x28, 0xb3, 0xc4, 0x31, 0xa2, 0xb9, 0x95, 0xfb, 0xfd, 0xe7, 0x1b, 0xa9, 0x5b, 0xb9, 0x62, 0xba, + 0x92, 0xb9, 0x95, 0x2b, 0x66, 0x2a, 0xd9, 0xfa, 0x01, 0x40, 0xe7, 0x24, 0x26, 0x98, 0x52, 0x2f, + 0x0a, 0xd1, 0x3a, 0x14, 0x1e, 0x62, 0xc2, 0x9b, 0xd5, 0xf4, 0xd5, 0xf4, 0xb5, 0x52, 0x2b, 0xf7, + 0xe8, 0xc9, 0x46, 0xca, 0xd4, 0x42, 0x54, 0x85, 0x1c, 0x3e, 0x89, 0x49, 0x35, 0x33, 0xa5, 0x14, + 0x92, 0xad, 0x22, 0x67, 0xfe, 0xcf, 0x1f, 0x36, 0x52, 0xf5, 0x5f, 0x67, 0xa0, 0xb8, 0x4f, 0x5c, + 0x4c, 0xbc, 0x70, 0x84, 0x7a, 0x50, 0x70, 0x22, 0x3f, 0x09, 0x42, 0x5a, 0x4d, 0x5f, 0xcd, 0x5e, + 0x2b, 0x6f, 0x7e, 0xcf, 0xb8, 0x28, 0xdf, 0x0c, 0x0d, 0x32, 0xb6, 0x05, 0x42, 0x8f, 0xad, 0xf0, + 0xb5, 0x3f, 0xa6, 0x21, 0x2f, 0x35, 0xe8, 0xdb, 0x82, 0xd5, 0xf2, 0xdc, 0x13, 0xe1, 0xe6, 0x92, + 0x32, 0xcd, 0x3b, 0x91, 0xdf, 0x73, 0x4f, 0xd0, 0x5d, 0x28, 0xb9, 0x1e, 0xc1, 0x0e, 0xe3, 0xf3, + 0xe0, 0xae, 0x2e, 0x6f, 0xbe, 0xff, 0x7f, 0x0f, 0x6b, 0xb4, 0x35, 0x54, 0xb1, 0x4e, 0xb8, 0xea, + 0xeb, 0x50, 0x1a, 0x6b, 0x51, 0x01, 0xb2, 0xcd, 0xfe, 0x76, 0x25, 0x85, 0x8a, 0x90, 0x6b, 0x77, + 0xfa, 0xdb, 0x95, 0xf4, 0x56, 0xee, 0x9f, 0x9f, 0x6f, 0xa8, 0xdf, 0xfa, 0x5f, 0xb2, 0x80, 0xfa, + 0x8c, 0x60, 0x3b, 0xe8, 0x84, 0x6e, 0x1c, 0x79, 0x21, 0xeb, 0xc7, 0xd8, 0x41, 0x1f, 0x41, 0x8e, + 0xa7, 0x9c, 0xf0, 0x7b, 0x79, 0xf3, 0xbd, 0x8b, 0xdd, 0x7a, 0x16, 0x6b, 0x1c, 0x9e, 0xc6, 0x58, + 0x07, 0x9d, 0x93, 0xa0, 0x1f, 0x40, 0x89, 0x0a, 0x33, 0xcb, 0x73, 0xc5, 0x44, 0x17, 0x5a, 0xaf, + 0x71, 0xf5, 0xd9, 0x93, 0x8d, 0xa2, 0xc4, 0xf7, 0xda, 0x5f, 0x4e, 0xb5, 0xcd, 0xa2, 0x34, 0xef, + 0xb9, 0xe8, 0x01, 0x2c, 0x33, 0x9b, 0x8c, 0x30, 0xb3, 0xc2, 0xc8, 0xc5, 0x1c, 0x9f, 0x13, 0xf8, + 0x8f, 0x14, 0x7e, 0xf1, 0x50, 0x68, 0xf7, 0x22, 0x17, 0x0b, 0x8e, 0xf7, 0x47, 0x1e, 0x3b, 0x4a, + 0x06, 0x86, 0x13, 0x05, 0x8d, 0xb1, 0xcf, 0xee, 0x60, 0xd2, 0x6e, 0xc4, 0xf7, 0x47, 0x0d, 0xb5, + 0xe5, 0x0d, 0x09, 0x33, 0x17, 0xd9, 0x84, 0x44, 0x0c, 0x19, 0x11, 0x6f, 0xe4, 0x85, 0xe3, 0x21, + 0x17, 0x66, 0x87, 0xdc, 0x17, 0xda, 0x97, 0x1c, 0x32, 0x9a, 0x90, 0xb8, 0xf5, 0x77, 0x21, 0xc7, + 0x83, 0x86, 0x4a, 0xb0, 0xb0, 0xbb, 0xbf, 0xdd, 0xdc, 0xad, 0xa4, 0x10, 0x40, 0xde, 0xec, 0xdc, + 0xde, 0x3f, 0xec, 0x54, 0xd2, 0x68, 0x15, 0x96, 0xfa, 0xf7, 0xf6, 0xb6, 0x2d, 0xb3, 0xd3, 0x3f, + 0xd8, 0xdf, 0xeb, 0x77, 0xc4, 0xae, 0xc8, 0x56, 0x72, 0xf5, 0x7f, 0x65, 0x60, 0xa9, 0x17, 0xc6, + 0x09, 0xeb, 0x9f, 0x86, 0x8e, 0x58, 0xb7, 0x9d, 0x99, 0x75, 0x7b, 0xfb, 0xe2, 0x75, 0x9b, 0x81, + 0x3d, 0xbb, 0x64, 0x6d, 0x28, 0x46, 0x2a, 0xe1, 0xc4, 0x8a, 0x95, 0x37, 0xeb, 0x2f, 0x4e, 0x4d, + 0xc5, 0x30, 0x46, 0xa2, 0x5d, 0x28, 0xc8, 0x95, 0xa4, 0xd5, 0xac, 0xd8, 0x56, 0x6f, 0x5f, 0x26, + 0x91, 0xf4, 0xce, 0x52, 0x14, 0xe8, 0xc7, 0xb0, 0x28, 0x37, 0x99, 0x25, 0xaa, 0x61, 0x35, 0x27, + 0x28, 0x6b, 0x73, 0x94, 0x14, 0x07, 0x86, 0xac, 0x96, 0x87, 0x66, 0x59, 0xda, 0xf3, 0xd9, 0xd1, + 0x7a, 0x53, 0x05, 0xf9, 0x0a, 0xa0, 0x83, 0xa6, 0xd9, 0xdc, 0xdd, 0xed, 0xec, 0x5a, 0x77, 0xf6, + 0xf6, 0xcd, 0x76, 0xc7, 0xec, 0xb4, 0x2b, 0x29, 0x54, 0x86, 0x82, 0xee, 0xa4, 0xd1, 0x1a, 0x54, + 0xfa, 0x1d, 0xb3, 0xd7, 0x9c, 0x36, 0xc9, 0xd4, 0xff, 0x9b, 0x87, 0xca, 0x7e, 0xc2, 0xe2, 0x84, + 0x99, 0x51, 0xc2, 0x30, 0x11, 0x21, 0xef, 0xcd, 0x84, 0xbc, 0xf1, 0x9c, 0x30, 0xcd, 0x21, 0x9f, + 0x8d, 0xfa, 0x54, 0xbc, 0x32, 0x2f, 0x1f, 0xaf, 0xd7, 0x61, 0xf1, 0xc8, 0xa6, 0x47, 0x96, 0xae, + 0x6c, 0x7c, 0x09, 0x96, 0xcc, 0x32, 0x97, 0xc9, 0x1a, 0x42, 0x91, 0x0f, 0xab, 0xc4, 0x0e, 0x47, + 0xd8, 0x22, 0xc2, 0x2b, 0x8b, 0xc6, 0xd8, 0x11, 0x3b, 0xac, 0xbc, 0xb9, 0x75, 0x89, 0x89, 0x98, + 0x9c, 0x63, 0xd2, 0x57, 0x8e, 0xac, 0x90, 0x59, 0x31, 0x7a, 0x0f, 0x56, 0x5d, 0x8f, 0xda, 0x03, + 0x1f, 0x5b, 0x83, 0x64, 0x38, 0x94, 0xd9, 0xc5, 0x37, 0x57, 0x51, 0x21, 0x2a, 0x4a, 0xdd, 0xd2, + 0xda, 0xda, 0x5f, 0xb3, 0xb0, 0x32, 0xc7, 0x8e, 0x3e, 0x81, 0x05, 0x7e, 0xc2, 0xe9, 0x52, 0x7d, + 0xfd, 0xab, 0x3b, 0x6a, 0xf4, 0x63, 0x5b, 0xd7, 0x4f, 0xc9, 0xc9, 0x83, 0xe6, 0xe2, 0xa1, 0x9d, + 0xf8, 0xcc, 0x72, 0x31, 0x65, 0xb2, 0x5c, 0x99, 0x65, 0x25, 0x6b, 0x63, 0xca, 0x50, 0x00, 0x25, + 0x71, 0x5a, 0x7b, 0xe1, 0x48, 0xe7, 0x75, 0xef, 0x25, 0x7c, 0x90, 0x6b, 0xd1, 0x51, 0x8c, 0xba, + 0x9a, 0x8f, 0x47, 0xa8, 0x3d, 0x84, 0xe5, 0x59, 0x13, 0xf4, 0x1a, 0xe4, 0xe5, 0x9a, 0x3e, 0x73, + 0xac, 0xf0, 0x53, 0x67, 0x07, 0x8a, 0x1a, 0xac, 0x4e, 0x95, 0xef, 0xcc, 0x6f, 0x91, 0x07, 0xfe, + 0xc0, 0xa6, 0xd8, 0x68, 0xf3, 0xbb, 0xc6, 0xdc, 0xc0, 0x63, 0x6c, 0x6d, 0x17, 0x72, 0x3c, 0x3c, + 0x68, 0x0d, 0x16, 0x28, 0xb3, 0x09, 0x13, 0x83, 0x2d, 0x9a, 0xb2, 0x83, 0x2a, 0x90, 0xc5, 0xa1, + 0xac, 0xe6, 0x8b, 0x26, 0x6f, 0x72, 0xaf, 0x64, 0xe6, 0x89, 0x13, 0x7f, 0x41, 0x7b, 0x25, 0x65, + 0xf5, 0xeb, 0x6a, 0xf7, 0x55, 0x60, 0xf1, 0xa0, 0xd9, 0xef, 0x5b, 0x87, 0x5d, 0x73, 0xff, 0xce, + 0xcd, 0xae, 0xac, 0x74, 0xb7, 0x7b, 0xa6, 0xb9, 0x6f, 0x56, 0xd2, 0x7c, 0x0f, 0xb6, 0xee, 0x59, + 0xdd, 0x66, 0xbf, 0x5b, 0xc9, 0xa0, 0x45, 0x28, 0xb6, 0xee, 0x59, 0x66, 0x73, 0xef, 0x66, 0xa7, + 0x92, 0xad, 0xff, 0x2a, 0x0d, 0x25, 0xe1, 0x70, 0x2f, 0x1c, 0x46, 0x33, 0x93, 0x4c, 0x7f, 0xf5, + 0x49, 0x22, 0x43, 0x6d, 0x5e, 0x59, 0xe3, 0x9e, 0x57, 0x4b, 0x84, 0x5d, 0xfd, 0x17, 0xb0, 0x7c, + 0x40, 0x22, 0x37, 0x71, 0x30, 0xe9, 0x62, 0xdb, 0xc5, 0x04, 0xbd, 0x07, 0x85, 0xa1, 0x1f, 0x1d, + 0xf3, 0x73, 0x42, 0x04, 0xa8, 0x55, 0xe5, 0x43, 0xfc, 0xed, 0xc9, 0x46, 0x7e, 0xc7, 0x8f, 0x8e, + 0x7b, 0xed, 0xb3, 0x71, 0xcb, 0xcc, 0x73, 0xc3, 0x9e, 0xfb, 0x12, 0xe7, 0x61, 0xfd, 0x4f, 0x69, + 0x58, 0xd4, 0x0e, 0xb4, 0x6d, 0x66, 0xa3, 0x6f, 0x41, 0x89, 0xd8, 0xc7, 0xd6, 0xe0, 0x94, 0x61, + 0xaa, 0x56, 0xa8, 0x48, 0xec, 0xe3, 0x16, 0xef, 0xa3, 0xb7, 0x60, 0x39, 0x4c, 0x02, 0x0b, 0x07, + 0x31, 0x3b, 0xb5, 0x48, 0x74, 0x4c, 0x67, 0x96, 0x66, 0x31, 0x4c, 0x82, 0x0e, 0x57, 0x99, 0xd1, + 0x31, 0x45, 0x26, 0x14, 0x03, 0xcc, 0x6c, 0x7e, 0x33, 0x56, 0xc5, 0xe7, 0xdd, 0x8b, 0x93, 0xda, + 0xc4, 0x41, 0xc4, 0xb0, 0x76, 0xe4, 0xb6, 0xc2, 0xe9, 0xe8, 0x6a, 0x9e, 0xfa, 0xe3, 0x34, 0xac, + 0x4c, 0x8c, 0x28, 0xb5, 0x47, 0x18, 0xdd, 0x80, 0xfc, 0x91, 0x88, 0x9c, 0xf0, 0xb6, 0xbc, 0x79, + 0xed, 0xe2, 0x51, 0x66, 0x23, 0x6d, 0x2a, 0x1c, 0x6a, 0x42, 0x9e, 0x9d, 0xc6, 0x32, 0xbd, 0xb9, + 0x9f, 0x6f, 0x5c, 0xcc, 0x30, 0x4e, 0x18, 0x9d, 0x8d, 0x12, 0x88, 0x6e, 0x40, 0x4e, 0x4c, 0x54, + 0xde, 0x4d, 0xdf, 0x7c, 0xb1, 0x0b, 0xed, 0xc9, 0xf4, 0x04, 0xb2, 0xfe, 0xef, 0x65, 0xb8, 0x72, + 0x7e, 0x14, 0xd0, 0xcf, 0x00, 0x64, 0x51, 0xf5, 0xc2, 0x61, 0xa4, 0x66, 0xf9, 0xc3, 0xcb, 0xc6, + 0x52, 0x96, 0x09, 0xee, 0x3a, 0xed, 0xa6, 0xcc, 0x12, 0xd1, 0x3d, 0xf4, 0x01, 0x2c, 0xc8, 0x7b, + 0xb5, 0x4c, 0xd9, 0x8d, 0x8b, 0x89, 0xc5, 0x5d, 0xba, 0x9b, 0x32, 0xa5, 0x3d, 0xfa, 0x04, 0x80, + 0xbf, 0x15, 0xb0, 0x35, 0x35, 0xf3, 0xad, 0x4b, 0xbb, 0x75, 0xc8, 0x29, 0x78, 0x34, 0xb8, 0x57, + 0x4c, 0x77, 0xd0, 0x5d, 0x58, 0xf3, 0xb1, 0x3d, 0xb4, 0xd8, 0x49, 0x68, 0x0d, 0xbd, 0xd0, 0xf6, + 0x2d, 0xca, 0x6c, 0x86, 0xd5, 0x59, 0x32, 0xbd, 0x37, 0xf5, 0x45, 0x68, 0x17, 0xdb, 0xc3, 0xc3, + 0x93, 0x70, 0x87, 0x1b, 0xf7, 0xb9, 0x6d, 0x37, 0x65, 0xae, 0xfa, 0xf3, 0x42, 0x64, 0x42, 0x81, + 0x44, 0xc7, 0x56, 0x98, 0x04, 0xe2, 0xa4, 0x28, 0x6f, 0x7e, 0x70, 0xf9, 0x48, 0x46, 0xc7, 0x7b, + 0x49, 0xd0, 0x4d, 0x99, 0x79, 0x22, 0x5a, 0x28, 0x80, 0x0a, 0xb5, 0x83, 0xd8, 0xc7, 0xc4, 0x8a, + 0x49, 0x34, 0xe2, 0xaf, 0x8a, 0x6a, 0x41, 0x90, 0xdf, 0xb8, 0x34, 0x79, 0x5f, 0x12, 0x1d, 0x28, + 0x9e, 0x6e, 0xca, 0x5c, 0xa1, 0xb3, 0x22, 0x74, 0x08, 0x85, 0x00, 0x33, 0xe2, 0x39, 0xb4, 0x5a, + 0x14, 0xa3, 0x7c, 0x78, 0xe9, 0x51, 0x6e, 0x4b, 0x7c, 0x37, 0x65, 0x6a, 0x2a, 0xf4, 0xcb, 0x34, + 0xbc, 0x3a, 0x48, 0xfc, 0xfb, 0x7c, 0x0a, 0x0e, 0xa6, 0x34, 0x9a, 0x9a, 0x4c, 0x49, 0x0c, 0xb3, + 0x73, 0xe9, 0x61, 0x5a, 0x89, 0x7f, 0xff, 0x40, 0xd3, 0x4d, 0x4d, 0xe9, 0x95, 0xc1, 0x79, 0x8a, + 0xda, 0x3e, 0xc0, 0x24, 0x4b, 0x51, 0x73, 0x2e, 0xed, 0xf9, 0xd6, 0x7c, 0xed, 0x9c, 0x85, 0x1f, + 0x43, 0xf4, 0x51, 0x37, 0xce, 0xed, 0xda, 0x67, 0x50, 0x1a, 0xe7, 0x17, 0xfa, 0x14, 0x56, 0x9c, + 0xc8, 0xf7, 0xb1, 0xc3, 0xd4, 0x93, 0x56, 0x1f, 0xf8, 0xc6, 0x14, 0x29, 0x7f, 0xc8, 0x1a, 0xea, + 0x09, 0x6c, 0x8c, 0x9f, 0xc2, 0x86, 0xa9, 0x9e, 0xc2, 0x53, 0xe7, 0xfb, 0xf2, 0x98, 0x8c, 0x0b, + 0x69, 0xed, 0x18, 0xf2, 0x32, 0x31, 0xd0, 0x3b, 0x50, 0xa2, 0x38, 0x74, 0x31, 0xd1, 0x35, 0xbc, + 0xd4, 0xaa, 0x8c, 0xcb, 0xb1, 0x50, 0x88, 0x12, 0x2c, 0x5b, 0x2e, 0x7f, 0xd5, 0xe9, 0x8c, 0xcc, + 0x4c, 0x1f, 0x74, 0x2a, 0xb9, 0x36, 0xa0, 0xe8, 0xdb, 0x94, 0x59, 0x01, 0x1d, 0x89, 0x4d, 0xa6, + 0xef, 0x36, 0x05, 0x2e, 0xbd, 0x4d, 0x47, 0x35, 0x0a, 0x2b, 0x73, 0x49, 0x83, 0xbe, 0x0f, 0xcb, + 0xbc, 0x3a, 0xeb, 0xa5, 0xc4, 0xd2, 0x8d, 0x9c, 0x42, 0x2e, 0x71, 0xdd, 0x81, 0x56, 0xa1, 0xf7, + 0x01, 0x1d, 0x79, 0x94, 0x45, 0x23, 0x62, 0x07, 0x96, 0xba, 0x30, 0xc9, 0x63, 0x44, 0x0f, 0xb5, + 0x3a, 0xd6, 0xb7, 0x95, 0xba, 0xf6, 0xe7, 0x1c, 0xbc, 0x72, 0xee, 0xea, 0xa2, 0x1d, 0x1e, 0x66, + 0xee, 0xce, 0x7c, 0x98, 0x5f, 0x3d, 0x67, 0xed, 0x66, 0xe3, 0xa9, 0x50, 0x22, 0x9e, 0xe8, 0x37, + 0x69, 0x40, 0x13, 0xa2, 0x21, 0xb1, 0xf5, 0xbb, 0x96, 0x73, 0x7d, 0xfa, 0xf5, 0xa4, 0xa2, 0xb1, + 0xad, 0x07, 0xd8, 0x51, 0xfc, 0x9d, 0x90, 0x91, 0x53, 0x73, 0xd5, 0x99, 0x97, 0x23, 0x06, 0x40, + 0x30, 0x4d, 0x02, 0x6c, 0xc5, 0x91, 0xbe, 0xa5, 0xdd, 0xf9, 0x9a, 0xbc, 0x30, 0x05, 0xf1, 0x41, + 0x44, 0xe5, 0xe8, 0x25, 0xa2, 0xfb, 0xa8, 0x03, 0x15, 0xbd, 0x09, 0x2d, 0x17, 0x33, 0xdb, 0xf3, + 0xa9, 0x2a, 0x81, 0x6b, 0x86, 0xfc, 0x7c, 0x62, 0xe8, 0xcf, 0x27, 0x46, 0x33, 0x3c, 0xd5, 0x17, + 0x65, 0x8d, 0x69, 0x4b, 0x48, 0xad, 0x0d, 0x57, 0xce, 0x9f, 0x29, 0xbf, 0x76, 0xdd, 0xc7, 0xa7, + 0x22, 0x3d, 0x16, 0x4c, 0xde, 0xe4, 0xd7, 0xb3, 0x87, 0xb6, 0x9f, 0xc8, 0x2b, 0x4c, 0xc6, 0x94, + 0x9d, 0xad, 0xcc, 0x87, 0xe9, 0xda, 0x8f, 0x60, 0x79, 0xd6, 0xd3, 0x17, 0xa1, 0xb3, 0xd3, 0xe8, + 0x9f, 0x43, 0x41, 0x55, 0x1d, 0xf4, 0x06, 0x80, 0xb8, 0x5f, 0x58, 0x04, 0xdb, 0x32, 0x35, 0xb3, + 0x7a, 0xef, 0x0a, 0xb9, 0x89, 0x6d, 0x17, 0xbd, 0x0e, 0x25, 0x91, 0xc3, 0xc2, 0x26, 0x33, 0x65, + 0x53, 0xe4, 0x62, 0x61, 0xf2, 0x5d, 0x58, 0x14, 0x26, 0xc7, 0xc4, 0x63, 0x0c, 0x87, 0x62, 0x7b, + 0x68, 0xab, 0x32, 0xd7, 0xdc, 0x95, 0x8a, 0x56, 0x41, 0x79, 0x75, 0x2b, 0x57, 0xcc, 0x57, 0x0a, + 0xb7, 0x72, 0x45, 0xa8, 0x94, 0xeb, 0xbf, 0x4b, 0x43, 0xb5, 0xed, 0x51, 0xd6, 0xff, 0xc9, 0xee, + 0x4f, 0xe5, 0x77, 0x9e, 0x9b, 0x11, 0xa5, 0x5e, 0x2c, 0x4e, 0xc5, 0x77, 0x67, 0xbf, 0x08, 0x2d, + 0xb5, 0xae, 0x70, 0xd6, 0x2f, 0x9f, 0x6c, 0x2c, 0xcf, 0x42, 0x26, 0xdf, 0x88, 0xba, 0xb0, 0x16, + 0x78, 0xa1, 0x65, 0x3b, 0x0e, 0x8e, 0x79, 0xc6, 0x6a, 0x78, 0xe6, 0xb9, 0x70, 0x14, 0x78, 0x61, + 0x53, 0x41, 0x94, 0xac, 0xfe, 0x01, 0x7c, 0x43, 0x59, 0xb5, 0x89, 0xed, 0x85, 0x5e, 0x38, 0x12, + 0x2e, 0x5d, 0x85, 0xa2, 0xab, 0xfa, 0xc2, 0x27, 0xbd, 0x3b, 0xc7, 0xd2, 0xd6, 0x3b, 0x8f, 0xfe, + 0xb1, 0x9e, 0x7a, 0x74, 0xb6, 0x9e, 0xfe, 0xe2, 0x6c, 0x3d, 0xfd, 0xf8, 0x6c, 0x3d, 0xfd, 0xf7, + 0xb3, 0xf5, 0xf4, 0x6f, 0x9f, 0xae, 0xa7, 0xbe, 0x78, 0xba, 0x9e, 0x7a, 0xfc, 0x74, 0x3d, 0xf5, + 0x71, 0x79, 0xea, 0x6b, 0xe8, 0xff, 0x02, 0x00, 0x00, 0xff, 0xff, 0xfe, 0xe5, 0xaa, 0x84, 0x1f, + 0x15, 0x00, 0x00, } func (this *Ordering) Equal(that interface{}) bool { @@ -2521,6 +2524,9 @@ func (m *RemoteProducerMetadata_Metrics) MarshalToSizedBuffer(dAtA []byte) (int, _ = i var l int _ = l + i = encodeVarintData(dAtA, i, uint64(m.RowsWritten)) + i-- + dAtA[i] = 0x18 i = encodeVarintData(dAtA, i, uint64(m.RowsRead)) i-- dAtA[i] = 0x10 @@ -3037,6 +3043,7 @@ func (m *RemoteProducerMetadata_Metrics) Size() (n int) { _ = l n += 1 + sovData(uint64(m.BytesRead)) n += 1 + sovData(uint64(m.RowsRead)) + n += 1 + sovData(uint64(m.RowsWritten)) return n } @@ -5910,6 +5917,25 @@ func (m *RemoteProducerMetadata_Metrics) Unmarshal(dAtA []byte) error { break } } + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field RowsWritten", wireType) + } + m.RowsWritten = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowData + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.RowsWritten |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } default: iNdEx = preIndex skippy, err := skipData(dAtA[iNdEx:]) diff --git a/pkg/sql/execinfrapb/data.proto b/pkg/sql/execinfrapb/data.proto index f888e1e58396..ce1fa35b4078 100644 --- a/pkg/sql/execinfrapb/data.proto +++ b/pkg/sql/execinfrapb/data.proto @@ -292,6 +292,8 @@ message RemoteProducerMetadata { optional int64 bytes_read = 1 [(gogoproto.nullable) = false]; // Total number of rows read while executing a statement. optional int64 rows_read = 2 [(gogoproto.nullable) = false]; + // Total number of rows modified while executing a statement. + optional int64 rows_written = 3 [(gogoproto.nullable) = false]; } oneof value { RangeInfos range_info = 1; diff --git a/pkg/sql/executor_statement_metrics.go b/pkg/sql/executor_statement_metrics.go index bfc829e98ac4..ad7d0ad7c428 100644 --- a/pkg/sql/executor_statement_metrics.go +++ b/pkg/sql/executor_statement_metrics.go @@ -78,6 +78,20 @@ var _ metric.Struct = StatsMetrics{} // MetricStruct is part of the metric.Struct interface. func (StatsMetrics) MetricStruct() {} +// GuardrailMetrics groups metrics related to different guardrails in the SQL +// layer. +type GuardrailMetrics struct { + TxnRowsWrittenLogCount *metric.Counter + TxnRowsWrittenErrCount *metric.Counter + TxnRowsReadLogCount *metric.Counter + TxnRowsReadErrCount *metric.Counter +} + +var _ metric.Struct = GuardrailMetrics{} + +// MetricStruct is part of the metric.Struct interface. +func (GuardrailMetrics) MetricStruct() {} + // recordStatementSummery gathers various details pertaining to the // last executed statement/query and performs the associated // accounting in the passed-in EngineMetrics. diff --git a/pkg/sql/insert.go b/pkg/sql/insert.go index f8c3b49dcd5c..24a93de4dcdd 100644 --- a/pkg/sql/insert.go +++ b/pkg/sql/insert.go @@ -46,8 +46,9 @@ type insertNode struct { // insertRun contains the run-time state of insertNode during local execution. type insertRun struct { - ti tableInserter - rowsNeeded bool + ti tableInserter + rowsNeeded bool + rowsInserted int64 checkOrds checkSet @@ -177,6 +178,7 @@ func (r *insertRun) processSourceRow(params runParams, rowVals tree.Datums) erro } } + r.rowsInserted++ return nil } @@ -284,3 +286,7 @@ func (n *insertNode) Close(ctx context.Context) { func (n *insertNode) enableAutoCommit() { n.run.ti.enableAutoCommit() } + +func (n *insertNode) rowsWritten() int64 { + return n.run.rowsInserted +} diff --git a/pkg/sql/insert_fast_path.go b/pkg/sql/insert_fast_path.go index 6795adca9890..5a0b28936ca7 100644 --- a/pkg/sql/insert_fast_path.go +++ b/pkg/sql/insert_fast_path.go @@ -326,6 +326,10 @@ func (n *insertFastPathNode) Close(ctx context.Context) { insertFastPathNodePool.Put(n) } +func (n *insertFastPathNode) rowsWritten() int64 { + return n.run.rowsInserted +} + // See planner.autoCommit. func (n *insertFastPathNode) enableAutoCommit() { n.run.ti.enableAutoCommit() diff --git a/pkg/sql/logictest/testdata/logic_test/information_schema b/pkg/sql/logictest/testdata/logic_test/information_schema index 020202815666..4f037a127b93 100644 --- a/pkg/sql/logictest/testdata/logic_test/information_schema +++ b/pkg/sql/logictest/testdata/logic_test/information_schema @@ -4601,6 +4601,10 @@ tracing off transaction_isolation serializable transaction_priority normal transaction_read_only off +transaction_rows_read_err 0 +transaction_rows_read_log 0 +transaction_rows_written_err 0 +transaction_rows_written_log 0 transaction_status NoTxn # information_schema can be used with the anonymous database. diff --git a/pkg/sql/logictest/testdata/logic_test/pg_catalog b/pkg/sql/logictest/testdata/logic_test/pg_catalog index 3e286b18ab48..0f51faf54595 100644 --- a/pkg/sql/logictest/testdata/logic_test/pg_catalog +++ b/pkg/sql/logictest/testdata/logic_test/pg_catalog @@ -3938,6 +3938,10 @@ tracing off NULL transaction_isolation serializable NULL NULL NULL string transaction_priority normal NULL NULL NULL string transaction_read_only off NULL NULL NULL string +transaction_rows_read_err 0 NULL NULL NULL string +transaction_rows_read_log 0 NULL NULL NULL string +transaction_rows_written_err 0 NULL NULL NULL string +transaction_rows_written_log 0 NULL NULL NULL string transaction_status NoTxn NULL NULL NULL string vectorize on NULL NULL NULL string @@ -4026,6 +4030,10 @@ tracing off NULL transaction_isolation serializable NULL user NULL serializable serializable transaction_priority normal NULL user NULL normal normal transaction_read_only off NULL user NULL off off +transaction_rows_read_err 0 NULL user NULL 0 0 +transaction_rows_read_log 0 NULL user NULL 0 0 +transaction_rows_written_err 0 NULL user NULL 0 0 +transaction_rows_written_log 0 NULL user NULL 0 0 transaction_status NoTxn NULL user NULL NoTxn NoTxn vectorize on NULL user NULL on on @@ -4112,6 +4120,10 @@ tracing NULL NULL NULL transaction_isolation NULL NULL NULL NULL NULL transaction_priority NULL NULL NULL NULL NULL transaction_read_only NULL NULL NULL NULL NULL +transaction_rows_read_err NULL NULL NULL NULL NULL +transaction_rows_read_log NULL NULL NULL NULL NULL +transaction_rows_written_err NULL NULL NULL NULL NULL +transaction_rows_written_log NULL NULL NULL NULL NULL transaction_status NULL NULL NULL NULL NULL vectorize NULL NULL NULL NULL NULL diff --git a/pkg/sql/logictest/testdata/logic_test/show_source b/pkg/sql/logictest/testdata/logic_test/show_source index b200e2dfb9d2..e229ca63784a 100644 --- a/pkg/sql/logictest/testdata/logic_test/show_source +++ b/pkg/sql/logictest/testdata/logic_test/show_source @@ -102,6 +102,10 @@ tracing off transaction_isolation serializable transaction_priority normal transaction_read_only off +transaction_rows_read_err 0 +transaction_rows_read_log 0 +transaction_rows_written_err 0 +transaction_rows_written_log 0 transaction_status NoTxn vectorize on diff --git a/pkg/sql/opt/exec/execbuilder/builder.go b/pkg/sql/opt/exec/execbuilder/builder.go index 30e65d4b3864..e490824bb486 100644 --- a/pkg/sql/opt/exec/execbuilder/builder.go +++ b/pkg/sql/opt/exec/execbuilder/builder.go @@ -106,9 +106,9 @@ type Builder struct { // catalog is only needed if the statement contains an EXPLAIN (OPT, CATALOG). // // If allowAutoCommit is true, mutation operators can pass the auto commit flag -// to the factory (when the optimizer determines it is correct to do so). It -// should be false if the statement is executed as part of an explicit -// transaction. +// to the factory (when the optimizer determines it is correct to do so and the +// txn row count limits are disabled.). It should be false if the statement is +// executed as part of an explicit transaction. func New( factory exec.Factory, optimizer *xform.Optimizer, @@ -129,10 +129,15 @@ func New( initialAllowAutoCommit: allowAutoCommit, } if evalCtx != nil { - if evalCtx.SessionData.SaveTablesPrefix != "" { - b.nameGen = memo.NewExprNameGenerator(evalCtx.SessionData.SaveTablesPrefix) + sd := evalCtx.SessionData + if sd.SaveTablesPrefix != "" { + b.nameGen = memo.NewExprNameGenerator(sd.SaveTablesPrefix) } - b.allowInsertFastPath = evalCtx.SessionData.InsertFastPath + // If we have the limits on the number of rows written/read by a single + // txn, we cannot auto commit. + b.allowAutoCommit = b.allowAutoCommit && sd.TxnRowsWrittenErr == 0 && sd.TxnRowsReadErr == 0 + b.initialAllowAutoCommit = b.allowAutoCommit + b.allowInsertFastPath = sd.InsertFastPath } return b } diff --git a/pkg/sql/opt/exec/execbuilder/testdata/autocommit_nonmetamorphic b/pkg/sql/opt/exec/execbuilder/testdata/autocommit_nonmetamorphic index 94c5ac3bb07c..180efb51506b 100644 --- a/pkg/sql/opt/exec/execbuilder/testdata/autocommit_nonmetamorphic +++ b/pkg/sql/opt/exec/execbuilder/testdata/autocommit_nonmetamorphic @@ -777,3 +777,42 @@ WHERE message LIKE '%r$rangeid: sending batch%' dist sender send r42: sending batch 2 CPut to (n1,s1):1 dist sender send r42: sending batch 2 CPut to (n1,s1):1 dist sender send r42: sending batch 1 EndTxn to (n1,s1):1 + +# Check that the statement that can usually be auto-committed isn't when the txn +# row count erring guardrails are enabled. +statement ok +CREATE TABLE guardrails (i INT PRIMARY KEY); +SET transaction_rows_written_err = 1 + +query B +SELECT count(*) > 0 FROM [ + EXPLAIN (VERBOSE) INSERT INTO guardrails VALUES (1) +] WHERE info LIKE '%auto commit%' +---- +false + +statement ok +RESET transaction_rows_written_err + +# Check that the auto commit is enabled when the logging guardrail is enabled +# but the erring one is not. +statement ok +SET transaction_rows_written_log = 1 + +query B +SELECT count(*) > 0 FROM [ + EXPLAIN (VERBOSE) INSERT INTO guardrails VALUES (1) +] WHERE info LIKE '%auto commit%' +---- +true + +statement ok +RESET transaction_rows_written_log + +# Check that the auto commit is enabled when the guardrails are disabled. +query B +SELECT count(*) > 0 FROM [ + EXPLAIN (VERBOSE) INSERT INTO guardrails VALUES (1) +] WHERE info LIKE '%auto commit%' +---- +true diff --git a/pkg/sql/pgwire/server.go b/pkg/sql/pgwire/server.go index 97c8fd9c0279..e6103f8e2816 100644 --- a/pkg/sql/pgwire/server.go +++ b/pkg/sql/pgwire/server.go @@ -357,10 +357,12 @@ func (s *Server) Metrics() (res []interface{}) { &s.SQLServer.Metrics.ExecutedStatementCounters, &s.SQLServer.Metrics.EngineMetrics, &s.SQLServer.Metrics.StatsMetrics, + &s.SQLServer.Metrics.GuardrailMetrics, &s.SQLServer.InternalMetrics.StartedStatementCounters, &s.SQLServer.InternalMetrics.ExecutedStatementCounters, &s.SQLServer.InternalMetrics.EngineMetrics, &s.SQLServer.InternalMetrics.StatsMetrics, + &s.SQLServer.InternalMetrics.GuardrailMetrics, } } diff --git a/pkg/sql/plan.go b/pkg/sql/plan.go index f43e2a1dc3e5..5f498ae46312 100644 --- a/pkg/sql/plan.go +++ b/pkg/sql/plan.go @@ -103,6 +103,16 @@ type planNode interface { Close(ctx context.Context) } +// mutationPlanNode is a specification of planNode for mutations operations +// (those that insert/update/detele/etc rows). +type mutationPlanNode interface { + planNode + + // rowsWritten returns the number of rows modified by this planNode. It + // should only be called once Next returns false. + rowsWritten() int64 +} + // PlanNode is the exported name for planNode. Useful for CCL hooks. type PlanNode = planNode diff --git a/pkg/sql/plan_batch.go b/pkg/sql/plan_batch.go index e374e20ff7ec..707ba88b8d69 100644 --- a/pkg/sql/plan_batch.go +++ b/pkg/sql/plan_batch.go @@ -96,6 +96,9 @@ type serializeNode struct { rowIdx int } +// serializeNode is not a mutationPlanNode itself, but it might wrap one. +var _ mutationPlanNode = &serializeNode{} + func (s *serializeNode) startExec(params runParams) error { if f, ok := s.source.(planNodeFastPath); ok { s.rowCount, s.fastPath = f.FastPathResults() @@ -129,6 +132,14 @@ func (s *serializeNode) FastPathResults() (int, bool) { return s.rowCount, s.fastPath } +func (s *serializeNode) rowsWritten() int64 { + m, ok := s.source.(mutationPlanNode) + if !ok { + return 0 + } + return m.rowsWritten() +} + // requireSpool implements the planNodeRequireSpool interface. func (s *serializeNode) requireSpool() {} @@ -149,6 +160,9 @@ type rowCountNode struct { rowCount int } +// rowCountNode is not a mutationPlanNode itself, but it might wrap one. +var _ mutationPlanNode = &rowCountNode{} + func (r *rowCountNode) startExec(params runParams) error { done := false if f, ok := r.source.(planNodeFastPath); ok { @@ -171,3 +185,11 @@ func (r *rowCountNode) Close(ctx context.Context) { r.source.Close(ctx // FastPathResults implements the planNodeFastPath interface. func (r *rowCountNode) FastPathResults() (int, bool) { return r.rowCount, true } + +func (r *rowCountNode) rowsWritten() int64 { + m, ok := r.source.(mutationPlanNode) + if !ok { + return 0 + } + return m.rowsWritten() +} diff --git a/pkg/sql/plan_node_to_row_source.go b/pkg/sql/plan_node_to_row_source.go index b71bc6d608d4..0639b1af63a3 100644 --- a/pkg/sql/plan_node_to_row_source.go +++ b/pkg/sql/plan_node_to_row_source.go @@ -91,7 +91,21 @@ func (p *planNodeToRowSource) InitWithOutput( 0, /* processorID */ output, nil, /* memMonitor */ - execinfra.ProcStateOpts{}, + execinfra.ProcStateOpts{ + TrailingMetaCallback: func() []execinfrapb.ProducerMetadata { + var meta []execinfrapb.ProducerMetadata + if p.InternalClose() { + // Check if we're wrapping a mutation and emit the rows + // written metric if so. + if m, ok := p.node.(mutationPlanNode); ok { + metrics := execinfrapb.GetMetricsMeta() + metrics.RowsWritten = m.rowsWritten() + meta = []execinfrapb.ProducerMetadata{{Metrics: metrics}} + } + } + return meta + }, + }, ) } diff --git a/pkg/sql/sessiondatapb/local_only_session_data.pb.go b/pkg/sql/sessiondatapb/local_only_session_data.pb.go index a592285991ae..d070ba7813ce 100644 --- a/pkg/sql/sessiondatapb/local_only_session_data.pb.go +++ b/pkg/sql/sessiondatapb/local_only_session_data.pb.go @@ -182,6 +182,24 @@ type LocalOnlySessionData struct { // This is only populated when SET ROLE is used, otherwise the session_user // is the same as the UserProto in SessionData. SessionUserProto github_com_cockroachdb_cockroach_pkg_security.SQLUsernameProto `protobuf:"bytes,46,opt,name=session_user_proto,json=sessionUserProto,proto3,casttype=github.com/cockroachdb/cockroach/pkg/security.SQLUsernameProto" json:"session_user_proto,omitempty"` + // TxnRowsWrittenLog is the threshold for the number of rows written by a SQL + // transaction which - once reached - will trigger a logging event to SQL_PERF + // (or SQL_INTERNAL_PERF for internal transactions); 0 means disabled. + TxnRowsWrittenLog int64 `protobuf:"varint,47,opt,name=txn_rows_written_log,json=txnRowsWrittenLog,proto3" json:"txn_rows_written_log,omitempty"` + // TxnRowsWrittenErr is the limit for the number of rows written by a SQL + // transaction which - once reached - will fail the transaction (or will + // trigger a logging event to SQL_INTERNAL_PERF for internal transactions); 0 + // means disabled. + TxnRowsWrittenErr int64 `protobuf:"varint,48,opt,name=txn_rows_written_err,json=txnRowsWrittenErr,proto3" json:"txn_rows_written_err,omitempty"` + // TxnRowsReadLog is the threshold for the number of rows read by a SQL + // transaction which - once reached - will trigger a logging event to SQL_PERF + // (or SQL_INTERNAL_PERF for internal transactions); 0 means disabled. + TxnRowsReadLog int64 `protobuf:"varint,49,opt,name=txn_rows_read_log,json=txnRowsReadLog,proto3" json:"txn_rows_read_log,omitempty"` + // TxnRowsReadErr is the limit for the number of rows read by a SQL + // transaction which - once reached - will fail the transaction (or will + // trigger a logging event to SQL_INTERNAL_PERF for internal transactions); 0 + // means disabled. + TxnRowsReadErr int64 `protobuf:"varint,50,opt,name=txn_rows_read_err,json=txnRowsReadErr,proto3" json:"txn_rows_read_err,omitempty"` } func (m *LocalOnlySessionData) Reset() { *m = LocalOnlySessionData{} } @@ -269,116 +287,121 @@ func init() { } var fileDescriptor_21ead158cf36da28 = []byte{ - // 1744 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x97, 0xdd, 0x72, 0x1b, 0xb7, - 0x15, 0xc7, 0xcd, 0x38, 0x49, 0x63, 0xc8, 0xb4, 0x65, 0x44, 0x0e, 0x57, 0x96, 0x4d, 0x4a, 0xb2, - 0x1d, 0x2b, 0x75, 0x42, 0xb5, 0xe9, 0xc7, 0xb8, 0xe9, 0xf4, 0x23, 0xa2, 0xc4, 0xda, 0xb1, 0x12, - 0xd1, 0xa4, 0x14, 0x4f, 0xd3, 0xce, 0x60, 0xa0, 0xdd, 0x43, 0x12, 0x15, 0x16, 0x58, 0x02, 0x58, - 0x49, 0xd4, 0x45, 0x9f, 0xa1, 0x33, 0xbd, 0xee, 0x4c, 0x1f, 0x27, 0x97, 0xb9, 0xcc, 0x95, 0xa6, - 0x95, 0xdf, 0x42, 0x57, 0x1d, 0x1c, 0xec, 0x92, 0x94, 0xad, 0xa4, 0x77, 0xd2, 0xf9, 0xff, 0xce, - 0x7f, 0x81, 0x83, 0x83, 0x0f, 0x92, 0x75, 0x3b, 0x92, 0xeb, 0x16, 0xac, 0x15, 0x5a, 0x25, 0xdc, - 0xf1, 0x6c, 0x7f, 0x5d, 0xea, 0x98, 0x4b, 0xa6, 0x95, 0x1c, 0xb3, 0x42, 0x60, 0x5e, 0x69, 0x66, - 0x46, 0x3b, 0x4d, 0x97, 0x62, 0x1d, 0x1f, 0x18, 0xcd, 0xe3, 0x61, 0xd3, 0x8e, 0x64, 0xf3, 0x42, - 0xea, 0x9d, 0x85, 0x81, 0x1e, 0x68, 0xe4, 0xd6, 0xfd, 0x5f, 0x21, 0x65, 0xf5, 0xdf, 0x8b, 0x64, - 0x61, 0xdb, 0x9b, 0xee, 0x28, 0x39, 0xee, 0x85, 0x84, 0x4d, 0xee, 0x38, 0xfd, 0x98, 0x50, 0xcb, - 0x0f, 0x81, 0x39, 0xbe, 0x2f, 0xc1, 0xb2, 0xcc, 0x40, 0x5f, 0x1c, 0x47, 0x95, 0xe5, 0xca, 0xda, - 0xb5, 0xee, 0xbc, 0x57, 0x76, 0x51, 0xe8, 0x60, 0x9c, 0xfe, 0x85, 0x2c, 0xe9, 0xcc, 0x89, 0x54, - 0x9c, 0x80, 0x61, 0xfd, 0x03, 0x16, 0x73, 0x1b, 0xf3, 0x04, 0x2c, 0x93, 0x22, 0x15, 0x2e, 0x7a, - 0x6b, 0xb9, 0xb2, 0x76, 0x75, 0xe3, 0xee, 0xd9, 0x69, 0x23, 0xda, 0x29, 0xb1, 0xf6, 0xf3, 0x56, - 0x01, 0x6d, 0x7b, 0xa6, 0x1b, 0x4d, 0x0c, 0xda, 0x07, 0x17, 0x14, 0xfa, 0x4b, 0x72, 0xdd, 0xba, - 0xd4, 0x31, 0x27, 0x52, 0xd0, 0xb9, 0x8b, 0xae, 0xa2, 0xdb, 0xad, 0xf3, 0xd3, 0x46, 0xd5, 0x87, - 0x9a, 0x9b, 0xb9, 0xe1, 0x4e, 0x68, 0xd5, 0x9d, 0xf3, 0xd8, 0x6e, 0xa0, 0xe8, 0x53, 0x52, 0x13, - 0x89, 0x04, 0x26, 0xd4, 0xa4, 0x54, 0xa5, 0xc1, 0xdb, 0x3f, 0x64, 0xb0, 0xe0, 0x33, 0x9e, 0xa9, - 0xa2, 0x0e, 0xa5, 0x13, 0x23, 0xf7, 0x4b, 0x27, 0x67, 0xb8, 0xb2, 0x3c, 0xf6, 0xf0, 0x1b, 0xae, - 0xef, 0xfc, 0x90, 0x6b, 0x23, 0xb8, 0xee, 0x4e, 0x73, 0x5f, 0xfb, 0xc0, 0xaf, 0x49, 0x4d, 0x69, - 0x27, 0x62, 0x60, 0x89, 0xb0, 0x99, 0xe4, 0x7e, 0x71, 0x0f, 0xc1, 0x08, 0x37, 0x8e, 0xde, 0x5d, - 0xae, 0xac, 0x55, 0xbb, 0xb7, 0x83, 0xbc, 0x19, 0xd4, 0x5e, 0x21, 0xd2, 0x26, 0x79, 0xdf, 0x80, - 0x36, 0x09, 0x18, 0xf6, 0x37, 0x2d, 0x54, 0x59, 0xed, 0x9f, 0xf8, 0x81, 0x74, 0x6f, 0x15, 0xd2, - 0x17, 0x5e, 0x09, 0x85, 0xfc, 0x19, 0x59, 0x48, 0xa0, 0xcf, 0x73, 0xe9, 0x98, 0x3b, 0x56, 0x2c, - 0x33, 0x42, 0xe3, 0x47, 0xde, 0xc3, 0x04, 0x5a, 0x68, 0xbb, 0xc7, 0xaa, 0x53, 0x28, 0xf4, 0xe7, - 0xe4, 0xf6, 0x6c, 0x86, 0x01, 0x9e, 0x60, 0xf7, 0x45, 0xd7, 0x96, 0x2b, 0x6b, 0xef, 0xcd, 0xa6, - 0x74, 0x81, 0x27, 0xbe, 0x87, 0xe8, 0x06, 0xa9, 0xcf, 0xa6, 0xe4, 0x16, 0x58, 0x5f, 0x4b, 0xa9, - 0x8f, 0xc0, 0x60, 0xbe, 0x8d, 0x08, 0xe6, 0xde, 0x99, 0xe6, 0xee, 0x59, 0x68, 0x17, 0x88, 0xb7, - 0xb1, 0x74, 0x87, 0x3c, 0xc8, 0xb8, 0x71, 0x82, 0x4b, 0x39, 0xf6, 0x35, 0x71, 0x46, 0xec, 0xe7, - 0x0e, 0x12, 0x96, 0x49, 0xae, 0xac, 0x8f, 0xf8, 0xe6, 0x4b, 0xa2, 0x39, 0x74, 0x5a, 0x99, 0xb0, - 0x9b, 0x53, 0xb4, 0xe3, 0xc9, 0xcd, 0x02, 0xa4, 0x4f, 0xc8, 0xb4, 0xbd, 0x70, 0x48, 0x43, 0x61, - 0x9d, 0x1e, 0x18, 0x9e, 0xda, 0xe8, 0x3a, 0x9a, 0x7c, 0x30, 0xd1, 0xf7, 0x2c, 0x3c, 0x9d, 0xa8, - 0xf4, 0x8f, 0xe4, 0xde, 0xc5, 0xcc, 0x34, 0x97, 0x4e, 0xb0, 0x58, 0x4b, 0x66, 0x1d, 0x77, 0x36, - 0xaa, 0x62, 0xfa, 0xe2, 0x6c, 0xfa, 0x97, 0x1e, 0x69, 0x69, 0xd9, 0xf3, 0x00, 0xfd, 0x8c, 0x2c, - 0xe2, 0xb6, 0x15, 0x6e, 0xcc, 0x4a, 0x2a, 0x61, 0x16, 0xb8, 0x89, 0x87, 0xd1, 0x0d, 0xcc, 0xae, - 0x95, 0x40, 0xb9, 0x3b, 0x92, 0x1e, 0xca, 0x74, 0x85, 0x5c, 0xb7, 0xbc, 0x0f, 0x2c, 0xcf, 0x12, - 0xee, 0xc0, 0x46, 0x37, 0x11, 0x9f, 0xf3, 0xb1, 0xbd, 0x10, 0xa2, 0x7f, 0x26, 0x4b, 0x7e, 0x73, - 0x82, 0x61, 0x52, 0xeb, 0x83, 0x3c, 0x2b, 0x5a, 0xa1, 0xaf, 0xfd, 0x46, 0xb4, 0xd1, 0xbc, 0xcf, - 0xd8, 0x58, 0x3a, 0x3b, 0x6d, 0xd4, 0x3a, 0x88, 0x6d, 0x23, 0x85, 0x5d, 0xd1, 0xd6, 0xa6, 0xfd, - 0xdc, 0x76, 0x6b, 0xd9, 0x65, 0xc2, 0x81, 0xf5, 0xfd, 0x75, 0x22, 0x06, 0x27, 0x7c, 0x80, 0x9e, - 0x0c, 0x54, 0xa8, 0xfa, 0x2d, 0x1c, 0xc4, 0xad, 0x20, 0x79, 0x7e, 0x2b, 0x08, 0xf4, 0x73, 0x72, - 0xcf, 0xc0, 0x28, 0x17, 0x06, 0x18, 0x1c, 0x67, 0x52, 0xc4, 0xc2, 0xf9, 0x26, 0x4b, 0xb9, 0x19, - 0xb3, 0x03, 0x18, 0xdb, 0x88, 0x86, 0x95, 0x2f, 0xa0, 0xad, 0x82, 0xe9, 0x04, 0xe4, 0x39, 0x8c, - 0xad, 0xdf, 0x0a, 0x7d, 0x6d, 0x62, 0x60, 0xfe, 0x88, 0xc9, 0xb4, 0x50, 0x8e, 0x19, 0xb0, 0x8e, - 0x1b, 0x17, 0xbd, 0x8f, 0xc9, 0xb7, 0x51, 0xee, 0x95, 0x6a, 0x37, 0x88, 0xf4, 0x09, 0x59, 0xe4, - 0xbe, 0x83, 0xfc, 0x41, 0x95, 0x71, 0x03, 0x8c, 0x5b, 0x5f, 0x6c, 0x6c, 0x98, 0x68, 0x21, 0x64, - 0x22, 0xd0, 0x09, 0xfa, 0xe7, 0x76, 0x27, 0x73, 0xbe, 0x47, 0xfc, 0x24, 0x1d, 0xa4, 0x59, 0x79, - 0xd0, 0x95, 0x93, 0xbc, 0x1d, 0x26, 0xe9, 0xa5, 0x70, 0xd2, 0x95, 0x93, 0xdc, 0x21, 0x0f, 0x44, - 0x5a, 0x4c, 0x2e, 0xd6, 0x32, 0x4f, 0x15, 0xc3, 0xfe, 0xf3, 0xfb, 0x5a, 0xa8, 0xc1, 0xc4, 0xe0, - 0x83, 0xd0, 0x9b, 0x25, 0xdb, 0x42, 0xb4, 0x33, 0x43, 0x96, 0x86, 0xbf, 0x22, 0xb5, 0xc4, 0xe8, - 0x8c, 0x81, 0xca, 0x53, 0x76, 0xc8, 0x65, 0x0e, 0x13, 0x8f, 0x1a, 0x7a, 0x2c, 0x78, 0x79, 0x4b, - 0xe5, 0xe9, 0xd7, 0x5e, 0x2c, 0xd3, 0x5e, 0x92, 0x8f, 0xf4, 0x21, 0x18, 0x23, 0x92, 0xb2, 0x27, - 0x0d, 0x0c, 0xfc, 0x79, 0x74, 0xa2, 0x15, 0xb0, 0x58, 0xab, 0xbe, 0x98, 0x0e, 0x26, 0x42, 0xa3, - 0x07, 0x65, 0x02, 0x36, 0x68, 0x17, 0xf1, 0x6f, 0xb4, 0x82, 0x16, 0xc2, 0xa5, 0xf1, 0x1f, 0xc8, - 0xdd, 0x21, 0xb7, 0x43, 0x66, 0x87, 0xdc, 0x24, 0x90, 0x30, 0xa1, 0x12, 0x38, 0x9e, 0xa9, 0xcc, - 0x62, 0x68, 0x78, 0xcf, 0xf4, 0x02, 0xf2, 0x2c, 0x10, 0xa5, 0xc1, 0x6f, 0xc8, 0xa2, 0xdf, 0xa1, - 0xb8, 0x1c, 0xfd, 0x5c, 0xca, 0x50, 0x5a, 0x66, 0x63, 0xae, 0x6c, 0x74, 0x27, 0xec, 0xb6, 0x12, - 0x68, 0xe7, 0x52, 0x62, 0x7d, 0x7b, 0x5e, 0xa5, 0xbf, 0x25, 0x77, 0x26, 0xc5, 0xb5, 0x20, 0x21, - 0x76, 0xd8, 0xc8, 0xa1, 0xfd, 0xa3, 0xa5, 0xb0, 0x59, 0x4a, 0xa2, 0x87, 0x40, 0x5b, 0x9b, 0xb0, - 0x15, 0xe8, 0x1a, 0x99, 0x17, 0xca, 0x82, 0x71, 0xac, 0xcf, 0xad, 0x63, 0x19, 0x77, 0xc3, 0xe8, - 0x2e, 0xa6, 0xdc, 0x08, 0xf1, 0x36, 0xb7, 0xae, 0xc3, 0xdd, 0x90, 0x3e, 0x25, 0x2b, 0x5c, 0x3a, - 0x30, 0xe5, 0x02, 0xba, 0x71, 0x06, 0x6c, 0x00, 0x0a, 0x0c, 0x97, 0x93, 0x79, 0xde, 0xc3, 0xd4, - 0x7b, 0x08, 0x86, 0xd5, 0xdb, 0x1d, 0x67, 0xf0, 0xa7, 0x40, 0x95, 0x73, 0xfd, 0x84, 0x50, 0x3b, - 0x56, 0xf1, 0xd0, 0x68, 0xa5, 0x73, 0xcb, 0x62, 0x9d, 0xfa, 0x13, 0xb8, 0x1e, 0x9a, 0x67, 0x46, - 0x69, 0xa1, 0x40, 0x3f, 0x24, 0x37, 0x83, 0x3d, 0xb3, 0x30, 0xc2, 0x8a, 0x44, 0x0d, 0x64, 0xab, - 0x21, 0xdc, 0x83, 0x91, 0x2f, 0x04, 0xdd, 0x25, 0x8f, 0x0a, 0x2e, 0x57, 0x62, 0x94, 0x03, 0x3b, - 0x12, 0x6e, 0xa8, 0x73, 0x17, 0x16, 0xc3, 0xaf, 0xae, 0x75, 0x86, 0x0b, 0xe5, 0x6c, 0xb4, 0x82, - 0xf9, 0xf7, 0x03, 0xbe, 0x87, 0xf4, 0xcb, 0x00, 0xe3, 0xb2, 0xb4, 0xa6, 0x28, 0xfd, 0x1d, 0x59, - 0xb2, 0x2e, 0xdf, 0x67, 0x31, 0x77, 0x5c, 0xea, 0xc1, 0xeb, 0x2d, 0xbf, 0x8a, 0x4e, 0x91, 0x47, - 0x5a, 0x81, 0xb8, 0xd8, 0xf9, 0x2f, 0xc8, 0x43, 0x38, 0xce, 0xc0, 0x88, 0x14, 0x94, 0xe3, 0xd2, - 0x4f, 0x36, 0xc3, 0x53, 0xb9, 0xa8, 0xa2, 0x81, 0x23, 0x23, 0xfc, 0x29, 0x75, 0x1f, 0x5f, 0x09, - 0xab, 0xb3, 0x70, 0xab, 0x60, 0x43, 0x21, 0xbb, 0x05, 0x49, 0xff, 0x4a, 0x1e, 0xc7, 0x3a, 0x1b, - 0x5f, 0xdc, 0x41, 0x47, 0x43, 0x50, 0x2c, 0x01, 0xa1, 0x1c, 0x18, 0x09, 0xfc, 0xd0, 0xc7, 0x70, - 0xa8, 0xd1, 0x03, 0x1c, 0xe1, 0x23, 0x9f, 0x32, 0xbb, 0x93, 0x5e, 0x0e, 0x41, 0x6d, 0x5e, 0xe0, - 0x71, 0xe0, 0xfe, 0xe4, 0x2d, 0xab, 0xed, 0x0c, 0xf0, 0x94, 0x19, 0xf0, 0x9d, 0x83, 0xb7, 0x72, - 0xf4, 0x30, 0x34, 0x53, 0x51, 0x77, 0xd4, 0xbb, 0x53, 0x39, 0xdc, 0xad, 0x36, 0x97, 0xce, 0xb2, - 0xfd, 0xbc, 0xef, 0x8f, 0x57, 0x2b, 0x4e, 0x20, 0xfa, 0xb0, 0xbc, 0x5b, 0x51, 0xda, 0x40, 0xa5, - 0x27, 0x4e, 0xc0, 0xdf, 0x30, 0x99, 0xd1, 0x19, 0x1f, 0x70, 0xe7, 0x5f, 0x0a, 0x59, 0xee, 0x18, - 0x5e, 0xbf, 0x42, 0x0d, 0xa2, 0x47, 0xa1, 0xe7, 0x27, 0xfa, 0x33, 0x2f, 0xef, 0x14, 0x2a, 0xfd, - 0x67, 0x85, 0x5c, 0x28, 0x15, 0x5e, 0x78, 0x76, 0x24, 0xf1, 0xec, 0xc2, 0x82, 0xa4, 0x3a, 0x81, - 0x68, 0x0d, 0x9f, 0x17, 0xed, 0xb3, 0xd3, 0x46, 0x63, 0x6b, 0x86, 0xf6, 0x57, 0x5e, 0xef, 0xc5, - 0x76, 0xa7, 0x60, 0xbf, 0xd4, 0x09, 0x9c, 0xff, 0x7f, 0xa4, 0xdb, 0x80, 0xd7, 0x00, 0x3b, 0x92, - 0xb3, 0x00, 0x6d, 0x93, 0xaa, 0x1f, 0x07, 0xf3, 0x03, 0xc1, 0xef, 0x7f, 0x84, 0xdf, 0x5f, 0x3d, - 0x3b, 0x6d, 0xcc, 0x15, 0x86, 0xc5, 0xb7, 0x6e, 0x16, 0xff, 0x6e, 0x1d, 0x43, 0x8c, 0xde, 0x73, - 0x3e, 0xb1, 0x37, 0x92, 0xe8, 0xf3, 0x92, 0x2c, 0x5a, 0x30, 0x82, 0x4b, 0xa6, 0xb4, 0x49, 0xb9, - 0x14, 0x27, 0x58, 0xdf, 0xe0, 0xf9, 0x53, 0xf4, 0x5c, 0x3a, 0x3f, 0x6d, 0xd4, 0x7a, 0x08, 0x7d, - 0x35, 0xcb, 0xa0, 0x59, 0xcd, 0x5e, 0x2e, 0xd0, 0x1d, 0x52, 0x53, 0x70, 0xc4, 0x6c, 0x3c, 0x84, - 0x94, 0xb3, 0x78, 0xc8, 0xd5, 0x00, 0x4c, 0xb0, 0x7d, 0x8c, 0xb6, 0xd1, 0xf9, 0x69, 0x63, 0xe1, - 0x2b, 0x38, 0xea, 0x21, 0xd1, 0x0a, 0x00, 0x7a, 0x2e, 0xa8, 0x4b, 0xa2, 0xf4, 0xef, 0xe4, 0x86, - 0x85, 0x51, 0x0e, 0x2a, 0x06, 0x16, 0xf3, 0x78, 0x08, 0xd1, 0xc7, 0xcb, 0x57, 0xd7, 0xe6, 0x3e, - 0xdd, 0x6c, 0xfe, 0xc8, 0xb3, 0xba, 0x79, 0xd9, 0xe3, 0xb9, 0xd9, 0x2b, 0x7c, 0x5a, 0xde, 0x66, - 0x4b, 0x39, 0x33, 0x0e, 0xef, 0xc2, 0x0b, 0xf1, 0x6e, 0xd5, 0xce, 0xfe, 0x4b, 0x1f, 0x93, 0x5b, - 0x99, 0xe4, 0x31, 0xf8, 0x35, 0x99, 0xec, 0xc9, 0x4f, 0xb0, 0x75, 0xe6, 0x27, 0x42, 0xb9, 0x17, - 0x33, 0x42, 0xcb, 0xf7, 0x67, 0x6e, 0xc1, 0x30, 0x7c, 0xcd, 0x47, 0x4d, 0xbf, 0xf1, 0x36, 0x36, - 0xce, 0x4f, 0x1b, 0xbf, 0x1f, 0x08, 0x37, 0xcc, 0xf7, 0x9b, 0xb1, 0x4e, 0xd7, 0x27, 0xc3, 0x4f, - 0xf6, 0xa7, 0x7f, 0xaf, 0x67, 0x07, 0x83, 0x75, 0x0b, 0x71, 0xee, 0xdf, 0x79, 0xcd, 0xde, 0x8b, - 0xed, 0x3d, 0x0b, 0x46, 0xf1, 0x14, 0x3a, 0xde, 0xa9, 0x3b, 0x5f, 0xb8, 0xfb, 0x28, 0x46, 0xee, - 0x8c, 0x08, 0x7d, 0x73, 0x5a, 0x74, 0x9e, 0x5c, 0x3d, 0x80, 0x31, 0xfe, 0x2e, 0xa8, 0x76, 0xfd, - 0x9f, 0x74, 0x8b, 0xbc, 0x83, 0x97, 0x18, 0x3e, 0xfa, 0xe7, 0x3e, 0x5d, 0xff, 0xd1, 0xea, 0xbd, - 0xe9, 0xd8, 0x0d, 0xd9, 0x9f, 0xbd, 0xf5, 0xa4, 0xf2, 0xc5, 0xdb, 0xef, 0x2d, 0xcf, 0xaf, 0xac, - 0xfe, 0xab, 0x72, 0xe9, 0x97, 0x1f, 0x92, 0x1b, 0xb8, 0x4a, 0x09, 0x3b, 0x04, 0xe3, 0x2d, 0x8b, - 0x41, 0x54, 0x43, 0xf4, 0xeb, 0x10, 0xa4, 0xf7, 0x49, 0x35, 0xce, 0x8d, 0xf1, 0x35, 0x9d, 0x0e, - 0xeb, 0x6a, 0xf7, 0x7a, 0x11, 0xc4, 0x2b, 0x95, 0xde, 0x25, 0xd7, 0x84, 0x8a, 0x0d, 0x56, 0x38, - 0xfc, 0xbc, 0xe8, 0x4e, 0x03, 0xf4, 0x1e, 0x21, 0x93, 0xab, 0xd9, 0x86, 0x1f, 0x0f, 0xdd, 0x6b, - 0xe5, 0x75, 0x6c, 0x37, 0xd6, 0xbf, 0xfd, 0x6f, 0xfd, 0xca, 0xb7, 0x67, 0xf5, 0xca, 0x77, 0x67, - 0xf5, 0xca, 0xf7, 0x67, 0xf5, 0xca, 0x7f, 0xce, 0xea, 0x95, 0x7f, 0xbc, 0xaa, 0x5f, 0xf9, 0xee, - 0x55, 0xfd, 0xca, 0xf7, 0xaf, 0xea, 0x57, 0xbe, 0xa9, 0x5e, 0x98, 0xf4, 0xfe, 0xbb, 0xb8, 0x58, - 0xbf, 0xf8, 0x5f, 0x00, 0x00, 0x00, 0xff, 0xff, 0x70, 0x71, 0xf6, 0x16, 0xe0, 0x0d, 0x00, 0x00, + // 1812 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x97, 0x5d, 0x73, 0x1b, 0xb7, + 0xd5, 0xc7, 0xcd, 0x38, 0xc9, 0x63, 0x43, 0x96, 0x2d, 0x21, 0x72, 0xb4, 0x92, 0x6c, 0x51, 0x7e, + 0x8b, 0xe5, 0xc7, 0x09, 0x99, 0xb8, 0x2f, 0xe3, 0xa6, 0xd3, 0x97, 0x88, 0x12, 0x6b, 0xc7, 0x4a, + 0x44, 0x2f, 0xe5, 0x78, 0x9a, 0x76, 0x06, 0x03, 0xed, 0x1e, 0x92, 0xa8, 0xb0, 0xc0, 0x12, 0xc0, + 0x4a, 0xa2, 0x2e, 0xfa, 0x19, 0x3a, 0xd3, 0xeb, 0x7e, 0x9f, 0x5c, 0xe6, 0xd2, 0x57, 0x9a, 0x56, + 0xfe, 0x16, 0xbe, 0xea, 0xe0, 0x60, 0x97, 0xa4, 0x6c, 0x25, 0xbd, 0x23, 0xf1, 0xff, 0x9d, 0xff, + 0x02, 0x07, 0xe7, 0x60, 0xb1, 0xa4, 0x69, 0x87, 0xb2, 0x69, 0xc1, 0x5a, 0xa1, 0x55, 0xca, 0x1d, + 0xcf, 0xf7, 0x9a, 0x52, 0x27, 0x5c, 0x32, 0xad, 0xe4, 0x88, 0x95, 0x02, 0xf3, 0x4a, 0x23, 0x37, + 0xda, 0x69, 0xba, 0x92, 0xe8, 0x64, 0xdf, 0x68, 0x9e, 0x0c, 0x1a, 0x76, 0x28, 0x1b, 0x67, 0x42, + 0x97, 0x17, 0xfa, 0xba, 0xaf, 0x91, 0x6b, 0xfa, 0x5f, 0x21, 0xe4, 0xf6, 0xab, 0x65, 0xb2, 0xb0, + 0xed, 0x4d, 0x77, 0x94, 0x1c, 0x75, 0x43, 0xc0, 0x26, 0x77, 0x9c, 0x7e, 0x4a, 0xa8, 0xe5, 0x07, + 0xc0, 0x1c, 0xdf, 0x93, 0x60, 0x59, 0x6e, 0xa0, 0x27, 0x8e, 0xa2, 0xda, 0x5a, 0x6d, 0xfd, 0x72, + 0x3c, 0xe7, 0x95, 0x5d, 0x14, 0x3a, 0x38, 0x4e, 0xff, 0x42, 0x56, 0x74, 0xee, 0x44, 0x26, 0x8e, + 0xc1, 0xb0, 0xde, 0x3e, 0x4b, 0xb8, 0x4d, 0x78, 0x0a, 0x96, 0x49, 0x91, 0x09, 0x17, 0xbd, 0xb7, + 0x56, 0x5b, 0xbf, 0xb8, 0x71, 0xe3, 0xf4, 0xa4, 0x1e, 0xed, 0x54, 0x58, 0xfb, 0x59, 0xab, 0x84, + 0xb6, 0x3d, 0x13, 0x47, 0x63, 0x83, 0xf6, 0xfe, 0x19, 0x85, 0xfe, 0x92, 0x5c, 0xb1, 0x2e, 0x73, + 0xcc, 0x89, 0x0c, 0x74, 0xe1, 0xa2, 0x8b, 0xe8, 0x36, 0xff, 0xe6, 0xa4, 0x3e, 0xeb, 0x87, 0x1a, + 0x9b, 0x85, 0xe1, 0x4e, 0x68, 0x15, 0xcf, 0x78, 0x6c, 0x37, 0x50, 0xf4, 0x09, 0x59, 0x14, 0xa9, + 0x04, 0x26, 0xd4, 0x38, 0x55, 0x95, 0xc1, 0xfb, 0x3f, 0x65, 0xb0, 0xe0, 0x23, 0x9e, 0xaa, 0x32, + 0x0f, 0x95, 0x13, 0x23, 0x77, 0x2a, 0x27, 0x67, 0xb8, 0xb2, 0x3c, 0xf1, 0xf0, 0x3b, 0xae, 0x1f, + 0xfc, 0x94, 0x6b, 0x3d, 0xb8, 0xee, 0x4e, 0x62, 0xdf, 0x7a, 0xc0, 0xaf, 0xc9, 0xa2, 0xd2, 0x4e, + 0x24, 0xc0, 0x52, 0x61, 0x73, 0xc9, 0xfd, 0xe6, 0x1e, 0x80, 0x11, 0x6e, 0x14, 0x7d, 0xb8, 0x56, + 0x5b, 0x9f, 0x8d, 0xaf, 0x07, 0x79, 0x33, 0xa8, 0xdd, 0x52, 0xa4, 0x0d, 0xf2, 0x91, 0x01, 0x6d, + 0x52, 0x30, 0xec, 0x6f, 0x5a, 0xa8, 0x2a, 0xdb, 0xff, 0xe7, 0x27, 0x12, 0xcf, 0x97, 0xd2, 0xd7, + 0x5e, 0x09, 0x89, 0xfc, 0x9c, 0x2c, 0xa4, 0xd0, 0xe3, 0x85, 0x74, 0xcc, 0x1d, 0x29, 0x96, 0x1b, + 0xa1, 0xf1, 0x21, 0x97, 0x30, 0x80, 0x96, 0xda, 0xee, 0x91, 0xea, 0x94, 0x0a, 0xfd, 0x82, 0x5c, + 0x9f, 0x8e, 0x30, 0xc0, 0x53, 0xac, 0xbe, 0xe8, 0xf2, 0x5a, 0x6d, 0xfd, 0xd2, 0x74, 0x48, 0x0c, + 0x3c, 0xf5, 0x35, 0x44, 0x37, 0xc8, 0xea, 0x74, 0x48, 0x61, 0x81, 0xf5, 0xb4, 0x94, 0xfa, 0x10, + 0x0c, 0xc6, 0xdb, 0x88, 0x60, 0xec, 0xf2, 0x24, 0xf6, 0x85, 0x85, 0x76, 0x89, 0x78, 0x1b, 0x4b, + 0x77, 0xc8, 0xdd, 0x9c, 0x1b, 0x27, 0xb8, 0x94, 0x23, 0x9f, 0x13, 0x67, 0xc4, 0x5e, 0xe1, 0x20, + 0x65, 0xb9, 0xe4, 0xca, 0xfa, 0x11, 0x5f, 0x7c, 0x69, 0x34, 0x83, 0x4e, 0xb7, 0xc6, 0xec, 0xe6, + 0x04, 0xed, 0x78, 0x72, 0xb3, 0x04, 0xe9, 0x63, 0x32, 0x29, 0x2f, 0x9c, 0xd2, 0x40, 0x58, 0xa7, + 0xfb, 0x86, 0x67, 0x36, 0xba, 0x82, 0x26, 0x1f, 0x8f, 0xf5, 0x17, 0x16, 0x9e, 0x8c, 0x55, 0xfa, + 0x47, 0x72, 0xf3, 0x6c, 0x64, 0x56, 0x48, 0x27, 0x58, 0xa2, 0x25, 0xb3, 0x8e, 0x3b, 0x1b, 0xcd, + 0x62, 0xf8, 0xd2, 0x74, 0xf8, 0x37, 0x1e, 0x69, 0x69, 0xd9, 0xf5, 0x00, 0xfd, 0x92, 0x2c, 0x61, + 0xdb, 0x0a, 0x37, 0x62, 0x15, 0x95, 0x32, 0x0b, 0xdc, 0x24, 0x83, 0xe8, 0x2a, 0x46, 0x2f, 0x56, + 0x40, 0xd5, 0x1d, 0x69, 0x17, 0x65, 0x7a, 0x8b, 0x5c, 0xb1, 0xbc, 0x07, 0xac, 0xc8, 0x53, 0xee, + 0xc0, 0x46, 0xd7, 0x10, 0x9f, 0xf1, 0x63, 0x2f, 0xc2, 0x10, 0xfd, 0x33, 0x59, 0xf1, 0xcd, 0x09, + 0x86, 0x49, 0xad, 0xf7, 0x8b, 0xbc, 0x2c, 0x85, 0x9e, 0xf6, 0x8d, 0x68, 0xa3, 0x39, 0x1f, 0xb1, + 0xb1, 0x72, 0x7a, 0x52, 0x5f, 0xec, 0x20, 0xb6, 0x8d, 0x14, 0x56, 0x45, 0x5b, 0x9b, 0xf6, 0x33, + 0x1b, 0x2f, 0xe6, 0xe7, 0x09, 0xfb, 0xd6, 0xd7, 0xd7, 0xb1, 0xe8, 0x1f, 0xf3, 0x3e, 0x7a, 0x32, + 0x50, 0x21, 0xeb, 0xf3, 0x38, 0x89, 0xf9, 0x20, 0x79, 0x7e, 0x2b, 0x08, 0xf4, 0x2b, 0x72, 0xd3, + 0xc0, 0xb0, 0x10, 0x06, 0x18, 0x1c, 0xe5, 0x52, 0x24, 0xc2, 0xf9, 0x22, 0xcb, 0xb8, 0x19, 0xb1, + 0x7d, 0x18, 0xd9, 0x88, 0x86, 0x9d, 0x2f, 0xa1, 0xad, 0x92, 0xe9, 0x04, 0xe4, 0x19, 0x8c, 0xac, + 0x6f, 0x85, 0x9e, 0x36, 0x09, 0x30, 0x7f, 0xc4, 0xe4, 0x5a, 0x28, 0xc7, 0x0c, 0x58, 0xc7, 0x8d, + 0x8b, 0x3e, 0xc2, 0xe0, 0xeb, 0x28, 0x77, 0x2b, 0x35, 0x0e, 0x22, 0x7d, 0x4c, 0x96, 0xb8, 0xaf, + 0x20, 0x7f, 0x50, 0xe5, 0xdc, 0x00, 0xe3, 0xd6, 0x27, 0x1b, 0x0b, 0x26, 0x5a, 0x08, 0x91, 0x08, + 0x74, 0x82, 0xfe, 0x95, 0xdd, 0xc9, 0x9d, 0xaf, 0x11, 0xbf, 0x48, 0x07, 0x59, 0x5e, 0x1d, 0x74, + 0xd5, 0x22, 0xaf, 0x87, 0x45, 0x7a, 0x29, 0x9c, 0x74, 0xd5, 0x22, 0x77, 0xc8, 0x5d, 0x91, 0x95, + 0x8b, 0x4b, 0xb4, 0x2c, 0x32, 0xc5, 0xb0, 0xfe, 0x7c, 0x5f, 0x0b, 0xd5, 0x1f, 0x1b, 0x7c, 0x1c, + 0x6a, 0xb3, 0x62, 0x5b, 0x88, 0x76, 0xa6, 0xc8, 0xca, 0xf0, 0x57, 0x64, 0x31, 0x35, 0x3a, 0x67, + 0xa0, 0x8a, 0x8c, 0x1d, 0x70, 0x59, 0xc0, 0xd8, 0x63, 0x11, 0x3d, 0x16, 0xbc, 0xbc, 0xa5, 0x8a, + 0xec, 0x3b, 0x2f, 0x56, 0x61, 0x2f, 0xc9, 0x03, 0x7d, 0x00, 0xc6, 0x88, 0xb4, 0xaa, 0x49, 0x03, + 0x7d, 0x7f, 0x1e, 0x1d, 0x6b, 0x05, 0x2c, 0xd1, 0xaa, 0x27, 0x26, 0x93, 0x89, 0xd0, 0xe8, 0x6e, + 0x15, 0x80, 0x05, 0x1a, 0x23, 0xfe, 0xbd, 0x56, 0xd0, 0x42, 0xb8, 0x32, 0xfe, 0x03, 0xb9, 0x31, + 0xe0, 0x76, 0xc0, 0xec, 0x80, 0x9b, 0x14, 0x52, 0x26, 0x54, 0x0a, 0x47, 0x53, 0x99, 0x59, 0x0a, + 0x05, 0xef, 0x99, 0x6e, 0x40, 0x9e, 0x06, 0xa2, 0x32, 0xf8, 0x0d, 0x59, 0xf2, 0x1d, 0x8a, 0xdb, + 0xd1, 0x2b, 0xa4, 0x0c, 0xa9, 0x65, 0x36, 0xe1, 0xca, 0x46, 0xcb, 0xa1, 0xdb, 0x2a, 0xa0, 0x5d, + 0x48, 0x89, 0xf9, 0xed, 0x7a, 0x95, 0xfe, 0x96, 0x2c, 0x8f, 0x93, 0x6b, 0x41, 0x42, 0xe2, 0xb0, + 0x90, 0x43, 0xf9, 0x47, 0x2b, 0xa1, 0x59, 0x2a, 0xa2, 0x8b, 0x40, 0x5b, 0x9b, 0xd0, 0x0a, 0x74, + 0x9d, 0xcc, 0x09, 0x65, 0xc1, 0x38, 0xd6, 0xe3, 0xd6, 0xb1, 0x9c, 0xbb, 0x41, 0x74, 0x03, 0x43, + 0xae, 0x86, 0xf1, 0x36, 0xb7, 0xae, 0xc3, 0xdd, 0x80, 0x3e, 0x21, 0xb7, 0xb8, 0x74, 0x60, 0xaa, + 0x0d, 0x74, 0xa3, 0x1c, 0x58, 0x1f, 0x14, 0x18, 0x2e, 0xc7, 0xeb, 0xbc, 0x89, 0xa1, 0x37, 0x11, + 0x0c, 0xbb, 0xb7, 0x3b, 0xca, 0xe1, 0x4f, 0x81, 0xaa, 0xd6, 0xfa, 0x19, 0xa1, 0x76, 0xa4, 0x92, + 0x81, 0xd1, 0x4a, 0x17, 0x96, 0x25, 0x3a, 0xf3, 0x27, 0xf0, 0x6a, 0x28, 0x9e, 0x29, 0xa5, 0x85, + 0x02, 0xfd, 0x84, 0x5c, 0x0b, 0xf6, 0xcc, 0xc2, 0x10, 0x33, 0x12, 0xd5, 0x91, 0x9d, 0x0d, 0xc3, + 0x5d, 0x18, 0xfa, 0x44, 0xd0, 0x5d, 0x72, 0xbf, 0xe4, 0x0a, 0x25, 0x86, 0x05, 0xb0, 0x43, 0xe1, + 0x06, 0xba, 0x70, 0x61, 0x33, 0xfc, 0xee, 0x5a, 0x67, 0xb8, 0x50, 0xce, 0x46, 0xb7, 0x30, 0xfe, + 0x4e, 0xc0, 0x5f, 0x20, 0xfd, 0x32, 0xc0, 0xb8, 0x2d, 0xad, 0x09, 0x4a, 0x7f, 0x47, 0x56, 0xac, + 0x2b, 0xf6, 0x58, 0xc2, 0x1d, 0x97, 0xba, 0xff, 0x76, 0xc9, 0xdf, 0x46, 0xa7, 0xc8, 0x23, 0xad, + 0x40, 0x9c, 0xad, 0xfc, 0xe7, 0xe4, 0x1e, 0x1c, 0xe5, 0x60, 0x44, 0x06, 0xca, 0x71, 0xe9, 0x17, + 0x9b, 0xe3, 0xa9, 0x5c, 0x66, 0xd1, 0xc0, 0xa1, 0x11, 0xfe, 0x94, 0xba, 0x83, 0xb7, 0x84, 0xdb, + 0xd3, 0x70, 0xab, 0x64, 0x43, 0x22, 0xe3, 0x92, 0xa4, 0x7f, 0x25, 0x0f, 0x13, 0x9d, 0x8f, 0xce, + 0x76, 0xd0, 0xe1, 0x00, 0x14, 0x4b, 0x41, 0x28, 0x07, 0x46, 0x02, 0x3f, 0xf0, 0x63, 0x38, 0xd5, + 0xe8, 0x2e, 0xce, 0xf0, 0xbe, 0x0f, 0x99, 0xee, 0xa4, 0x97, 0x03, 0x50, 0x9b, 0x67, 0x78, 0x9c, + 0xb8, 0x3f, 0x79, 0xab, 0x6c, 0x3b, 0x03, 0x3c, 0x63, 0x06, 0x7c, 0xe5, 0xe0, 0x5b, 0x39, 0xba, + 0x17, 0x8a, 0xa9, 0xcc, 0x3b, 0xea, 0xf1, 0x44, 0x0e, 0xef, 0x56, 0x5b, 0x48, 0x67, 0xd9, 0x5e, + 0xd1, 0xf3, 0xc7, 0xab, 0x15, 0xc7, 0x10, 0x7d, 0x52, 0xbd, 0x5b, 0x51, 0xda, 0x40, 0xa5, 0x2b, + 0x8e, 0xc1, 0xbf, 0x61, 0x72, 0xa3, 0x73, 0xde, 0xe7, 0xce, 0xdf, 0x14, 0xf2, 0xc2, 0x31, 0x7c, + 0xfd, 0x0a, 0xd5, 0x8f, 0xee, 0x87, 0x9a, 0x1f, 0xeb, 0x4f, 0xbd, 0xbc, 0x53, 0xaa, 0xf4, 0x9f, + 0x35, 0x72, 0x26, 0x55, 0xf8, 0xc2, 0xb3, 0x43, 0x89, 0x67, 0x17, 0x26, 0x24, 0xd3, 0x29, 0x44, + 0xeb, 0x78, 0xbd, 0x68, 0x9f, 0x9e, 0xd4, 0xeb, 0x5b, 0x53, 0xb4, 0x7f, 0xe5, 0x75, 0x9f, 0x6f, + 0x77, 0x4a, 0xf6, 0x1b, 0x9d, 0xc2, 0x9b, 0xff, 0x8d, 0xc4, 0x75, 0x78, 0x0b, 0xb0, 0x43, 0x39, + 0x0d, 0xd0, 0x36, 0x99, 0xf5, 0xf3, 0x60, 0x7e, 0x22, 0xf8, 0xfc, 0x07, 0xf8, 0xfc, 0xdb, 0xa7, + 0x27, 0xf5, 0x99, 0xd2, 0xb0, 0x7c, 0xd6, 0xb5, 0xf2, 0xef, 0xd6, 0x11, 0x24, 0xe8, 0x3d, 0xe3, + 0x03, 0xbb, 0x43, 0x89, 0x3e, 0x2f, 0xc9, 0x92, 0x05, 0x23, 0xb8, 0x64, 0x4a, 0x9b, 0x8c, 0x4b, + 0x71, 0x8c, 0xf9, 0x0d, 0x9e, 0xff, 0x8f, 0x9e, 0x2b, 0x6f, 0x4e, 0xea, 0x8b, 0x5d, 0x84, 0xbe, + 0x9d, 0x66, 0xd0, 0x6c, 0xd1, 0x9e, 0x2f, 0xd0, 0x1d, 0xb2, 0xa8, 0xe0, 0x90, 0xd9, 0x64, 0x00, + 0x19, 0x67, 0xc9, 0x80, 0xab, 0x3e, 0x98, 0x60, 0xfb, 0x10, 0x6d, 0xa3, 0x37, 0x27, 0xf5, 0x85, + 0x6f, 0xe1, 0xb0, 0x8b, 0x44, 0x2b, 0x00, 0xe8, 0xb9, 0xa0, 0xce, 0x19, 0xa5, 0x7f, 0x27, 0x57, + 0x2d, 0x0c, 0x0b, 0x50, 0x09, 0xb0, 0x84, 0x27, 0x03, 0x88, 0x3e, 0x5d, 0xbb, 0xb8, 0x3e, 0xf3, + 0x68, 0xb3, 0xf1, 0x33, 0xd7, 0xea, 0xc6, 0x79, 0x97, 0xe7, 0x46, 0xb7, 0xf4, 0x69, 0x79, 0x9b, + 0x2d, 0xe5, 0xcc, 0x28, 0xdc, 0x0b, 0xcf, 0x8c, 0xc7, 0xb3, 0x76, 0xfa, 0x2f, 0x7d, 0x48, 0xe6, + 0x73, 0xc9, 0x13, 0xf0, 0x7b, 0x32, 0xee, 0xc9, 0xcf, 0xb0, 0x74, 0xe6, 0xc6, 0x42, 0xd5, 0x8b, + 0x39, 0xa1, 0xd5, 0xfd, 0xb3, 0xb0, 0x60, 0x18, 0xde, 0xe6, 0xa3, 0x86, 0x6f, 0xbc, 0x8d, 0x8d, + 0x37, 0x27, 0xf5, 0xdf, 0xf7, 0x85, 0x1b, 0x14, 0x7b, 0x8d, 0x44, 0x67, 0xcd, 0xf1, 0xf4, 0xd3, + 0xbd, 0xc9, 0xef, 0x66, 0xbe, 0xdf, 0x6f, 0x5a, 0x48, 0x0a, 0x7f, 0xcf, 0x6b, 0x74, 0x9f, 0x6f, + 0xbf, 0xb0, 0x60, 0x14, 0xcf, 0xa0, 0xe3, 0x9d, 0xe2, 0xb9, 0xd2, 0xdd, 0x8f, 0xe2, 0x08, 0x6d, + 0x92, 0x05, 0xbc, 0x02, 0xea, 0x43, 0xcb, 0x7c, 0xf7, 0x3a, 0x50, 0x4c, 0xea, 0x7e, 0xd4, 0x0c, + 0x1d, 0xe1, 0x8e, 0x54, 0xac, 0x0f, 0xed, 0xcb, 0xa0, 0x6c, 0xeb, 0xfe, 0xb9, 0x01, 0x60, 0x4c, + 0xf4, 0xf9, 0x79, 0x01, 0x5b, 0xc6, 0xd0, 0x07, 0x64, 0x7e, 0x1c, 0x80, 0x37, 0x4d, 0x6f, 0xff, + 0x05, 0xd2, 0x57, 0x4b, 0xda, 0x5f, 0x0f, 0xbd, 0xf7, 0x3b, 0xa8, 0x37, 0x7e, 0xf4, 0x0e, 0xba, + 0x65, 0xcc, 0xf2, 0x90, 0xd0, 0x77, 0xb7, 0x83, 0xce, 0x91, 0x8b, 0xfb, 0x30, 0xc2, 0xef, 0x99, + 0xd9, 0xd8, 0xff, 0xa4, 0x5b, 0xe4, 0x03, 0x7c, 0xf9, 0xe2, 0xc7, 0xca, 0xcc, 0xa3, 0xe6, 0xcf, + 0xee, 0xfa, 0xbb, 0x8e, 0x71, 0x88, 0xfe, 0xf2, 0xbd, 0xc7, 0xb5, 0xaf, 0xdf, 0xbf, 0xb4, 0x36, + 0x77, 0xeb, 0xf6, 0xbf, 0x6a, 0xe7, 0x3e, 0xf9, 0x1e, 0xb9, 0x8a, 0xd5, 0x95, 0xb2, 0x03, 0x30, + 0xde, 0xb2, 0x9c, 0xc4, 0x6c, 0x18, 0xfd, 0x2e, 0x0c, 0xd2, 0x3b, 0x64, 0x36, 0x29, 0x8c, 0xf1, + 0xb5, 0x30, 0x99, 0xd6, 0xc5, 0xf8, 0x4a, 0x39, 0x88, 0x57, 0x01, 0x7a, 0x83, 0x5c, 0x16, 0x2a, + 0x31, 0x58, 0x19, 0xe1, 0xb3, 0x28, 0x9e, 0x0c, 0xd0, 0x9b, 0x84, 0x8c, 0xaf, 0x14, 0x36, 0x7c, + 0xf4, 0xc4, 0x97, 0xab, 0x6b, 0x84, 0xdd, 0x68, 0xfe, 0xf0, 0x9f, 0xd5, 0x0b, 0x3f, 0x9c, 0xae, + 0xd6, 0x7e, 0x3c, 0x5d, 0xad, 0xbd, 0x3a, 0x5d, 0xad, 0xfd, 0xfb, 0x74, 0xb5, 0xf6, 0x8f, 0xd7, + 0xab, 0x17, 0x7e, 0x7c, 0xbd, 0x7a, 0xe1, 0xd5, 0xeb, 0xd5, 0x0b, 0xdf, 0xcf, 0x9e, 0x59, 0xf4, + 0xde, 0x87, 0x58, 0x64, 0xbf, 0xf8, 0x6f, 0x00, 0x00, 0x00, 0xff, 0xff, 0xbb, 0x24, 0x73, 0x19, + 0x98, 0x0e, 0x00, 0x00, } func (m *LocalOnlySessionData) Marshal() (dAtA []byte, err error) { @@ -401,6 +424,34 @@ func (m *LocalOnlySessionData) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l + if m.TxnRowsReadErr != 0 { + i = encodeVarintLocalOnlySessionData(dAtA, i, uint64(m.TxnRowsReadErr)) + i-- + dAtA[i] = 0x3 + i-- + dAtA[i] = 0x90 + } + if m.TxnRowsReadLog != 0 { + i = encodeVarintLocalOnlySessionData(dAtA, i, uint64(m.TxnRowsReadLog)) + i-- + dAtA[i] = 0x3 + i-- + dAtA[i] = 0x88 + } + if m.TxnRowsWrittenErr != 0 { + i = encodeVarintLocalOnlySessionData(dAtA, i, uint64(m.TxnRowsWrittenErr)) + i-- + dAtA[i] = 0x3 + i-- + dAtA[i] = 0x80 + } + if m.TxnRowsWrittenLog != 0 { + i = encodeVarintLocalOnlySessionData(dAtA, i, uint64(m.TxnRowsWrittenLog)) + i-- + dAtA[i] = 0x2 + i-- + dAtA[i] = 0xf8 + } if len(m.SessionUserProto) > 0 { i -= len(m.SessionUserProto) copy(dAtA[i:], m.SessionUserProto) @@ -1072,6 +1123,18 @@ func (m *LocalOnlySessionData) Size() (n int) { if l > 0 { n += 2 + l + sovLocalOnlySessionData(uint64(l)) } + if m.TxnRowsWrittenLog != 0 { + n += 2 + sovLocalOnlySessionData(uint64(m.TxnRowsWrittenLog)) + } + if m.TxnRowsWrittenErr != 0 { + n += 2 + sovLocalOnlySessionData(uint64(m.TxnRowsWrittenErr)) + } + if m.TxnRowsReadLog != 0 { + n += 2 + sovLocalOnlySessionData(uint64(m.TxnRowsReadLog)) + } + if m.TxnRowsReadErr != 0 { + n += 2 + sovLocalOnlySessionData(uint64(m.TxnRowsReadErr)) + } return n } @@ -2150,6 +2213,82 @@ func (m *LocalOnlySessionData) Unmarshal(dAtA []byte) error { } m.SessionUserProto = github_com_cockroachdb_cockroach_pkg_security.SQLUsernameProto(dAtA[iNdEx:postIndex]) iNdEx = postIndex + case 47: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field TxnRowsWrittenLog", wireType) + } + m.TxnRowsWrittenLog = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowLocalOnlySessionData + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.TxnRowsWrittenLog |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 48: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field TxnRowsWrittenErr", wireType) + } + m.TxnRowsWrittenErr = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowLocalOnlySessionData + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.TxnRowsWrittenErr |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 49: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field TxnRowsReadLog", wireType) + } + m.TxnRowsReadLog = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowLocalOnlySessionData + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.TxnRowsReadLog |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 50: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field TxnRowsReadErr", wireType) + } + m.TxnRowsReadErr = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowLocalOnlySessionData + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.TxnRowsReadErr |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } default: iNdEx = preIndex skippy, err := skipLocalOnlySessionData(dAtA[iNdEx:]) diff --git a/pkg/sql/sessiondatapb/local_only_session_data.proto b/pkg/sql/sessiondatapb/local_only_session_data.proto index 702247743d04..f9e1b081d1a8 100644 --- a/pkg/sql/sessiondatapb/local_only_session_data.proto +++ b/pkg/sql/sessiondatapb/local_only_session_data.proto @@ -176,6 +176,24 @@ message LocalOnlySessionData { // This is only populated when SET ROLE is used, otherwise the session_user // is the same as the UserProto in SessionData. string session_user_proto = 46 [(gogoproto.casttype) = "github.com/cockroachdb/cockroach/pkg/security.SQLUsernameProto"]; + // TxnRowsWrittenLog is the threshold for the number of rows written by a SQL + // transaction which - once reached - will trigger a logging event to SQL_PERF + // (or SQL_INTERNAL_PERF for internal transactions); 0 means disabled. + int64 txn_rows_written_log = 47; + // TxnRowsWrittenErr is the limit for the number of rows written by a SQL + // transaction which - once reached - will fail the transaction (or will + // trigger a logging event to SQL_INTERNAL_PERF for internal transactions); 0 + // means disabled. + int64 txn_rows_written_err = 48; + // TxnRowsReadLog is the threshold for the number of rows read by a SQL + // transaction which - once reached - will trigger a logging event to SQL_PERF + // (or SQL_INTERNAL_PERF for internal transactions); 0 means disabled. + int64 txn_rows_read_log = 49; + // TxnRowsReadErr is the limit for the number of rows read by a SQL + // transaction which - once reached - will fail the transaction (or will + // trigger a logging event to SQL_INTERNAL_PERF for internal transactions); 0 + // means disabled. + int64 txn_rows_read_err = 50; /////////////////////////////////////////////////////////////////////////// // WARNING: consider whether a session parameter you're adding needs to // diff --git a/pkg/sql/spool.go b/pkg/sql/spool.go index 4535b6c5cf77..5b41c044da6b 100644 --- a/pkg/sql/spool.go +++ b/pkg/sql/spool.go @@ -30,6 +30,9 @@ type spoolNode struct { curRowIdx int } +// spoolNode is not a mutationPlanNode itself, but it might wrap one. +var _ mutationPlanNode = &spoolNode{} + func (s *spoolNode) startExec(params runParams) error { // If FastPathResults() on the source indicates that the results are // already available (2nd value true), then the computation is @@ -104,3 +107,11 @@ func (s *spoolNode) Close(ctx context.Context) { s.rows = nil } } + +func (s *spoolNode) rowsWritten() int64 { + m, ok := s.source.(mutationPlanNode) + if !ok { + return 0 + } + return m.rowsWritten() +} diff --git a/pkg/sql/tablewriter_upsert_opt.go b/pkg/sql/tablewriter_upsert_opt.go index a4f6f1fde8a1..03a239b75e4b 100644 --- a/pkg/sql/tablewriter_upsert_opt.go +++ b/pkg/sql/tablewriter_upsert_opt.go @@ -50,7 +50,8 @@ type optTableUpserter struct { ri row.Inserter // Should we collect the rows for a RETURNING clause? - rowsNeeded bool + rowsNeeded bool + rowsUpserted int64 // A mapping of column IDs to the return index used to shape the resulting // rows to those required by the returning clause. Only required if @@ -164,6 +165,7 @@ func (tu *optTableUpserter) row( ctx context.Context, row tree.Datums, pm row.PartialIndexUpdateHelper, traceKV bool, ) error { tu.currentBatchSize++ + tu.rowsUpserted++ // Consult the canary column to determine whether to insert or update. For // more details on how canary columns work, see the block comment on diff --git a/pkg/sql/update.go b/pkg/sql/update.go index 98afd1dbe9a0..be04a3d2e45f 100644 --- a/pkg/sql/update.go +++ b/pkg/sql/update.go @@ -43,8 +43,9 @@ type updateNode struct { // updateRun contains the run-time state of updateNode during local execution. type updateRun struct { - tu tableUpdater - rowsNeeded bool + tu tableUpdater + rowsNeeded bool + rowsUpdated int64 checkOrds checkSet @@ -352,6 +353,7 @@ func (u *updateNode) processSourceRow(params runParams, sourceVals tree.Datums) } } + u.run.rowsUpdated++ return nil } @@ -368,6 +370,10 @@ func (u *updateNode) Close(ctx context.Context) { updateNodePool.Put(u) } +func (u *updateNode) rowsWritten() int64 { + return u.run.rowsUpdated +} + func (u *updateNode) enableAutoCommit() { u.run.tu.enableAutoCommit() } diff --git a/pkg/sql/upsert.go b/pkg/sql/upsert.go index 598b183f446b..f1f01137c8ba 100644 --- a/pkg/sql/upsert.go +++ b/pkg/sql/upsert.go @@ -191,6 +191,10 @@ func (n *upsertNode) Close(ctx context.Context) { upsertNodePool.Put(n) } +func (n *upsertNode) rowsWritten() int64 { + return n.run.tw.rowsUpserted +} + func (n *upsertNode) enableAutoCommit() { n.run.tw.enableAutoCommit() } diff --git a/pkg/sql/vars.go b/pkg/sql/vars.go index 423d446c0405..154d0e774dba 100644 --- a/pkg/sql/vars.go +++ b/pkg/sql/vars.go @@ -1520,6 +1520,98 @@ var varGen = map[string]sessionVar{ return formatBoolAsPostgresSetting(propagateInputOrdering.Get(sv)) }, }, + + // CockroachDB extension. + `transaction_rows_written_log`: { + GetStringVal: makeIntGetStringValFn(`transaction_rows_written_log`), + Set: func(_ context.Context, m *sessionDataMutator, s string) error { + b, err := strconv.ParseInt(s, 10, 64) + if err != nil { + return err + } + if b < 0 { + return pgerror.Newf(pgcode.InvalidParameterValue, + "cannot set transaction_rows_written_log to a negative value: %d", b) + } + m.SetTxnRowsWrittenLog(b) + return nil + }, + Get: func(evalCtx *extendedEvalContext) string { + return strconv.FormatInt(evalCtx.SessionData.TxnRowsWrittenLog, 10) + }, + GlobalDefault: func(sv *settings.Values) string { + return strconv.FormatInt(txnRowsWrittenLog.Get(sv), 10) + }, + }, + + // CockroachDB extension. + `transaction_rows_written_err`: { + GetStringVal: makeIntGetStringValFn(`transaction_rows_written_err`), + Set: func(_ context.Context, m *sessionDataMutator, s string) error { + b, err := strconv.ParseInt(s, 10, 64) + if err != nil { + return err + } + if b < 0 { + return pgerror.Newf(pgcode.InvalidParameterValue, + "cannot set transaction_rows_written_err to a negative value: %d", b) + } + m.SetTxnRowsWrittenErr(b) + return nil + }, + Get: func(evalCtx *extendedEvalContext) string { + return strconv.FormatInt(evalCtx.SessionData.TxnRowsWrittenErr, 10) + }, + GlobalDefault: func(sv *settings.Values) string { + return strconv.FormatInt(txnRowsWrittenErr.Get(sv), 10) + }, + }, + + // CockroachDB extension. + `transaction_rows_read_log`: { + GetStringVal: makeIntGetStringValFn(`transaction_rows_read_log`), + Set: func(_ context.Context, m *sessionDataMutator, s string) error { + b, err := strconv.ParseInt(s, 10, 64) + if err != nil { + return err + } + if b < 0 { + return pgerror.Newf(pgcode.InvalidParameterValue, + "cannot set transaction_rows_read_log to a negative value: %d", b) + } + m.SetTxnRowsReadLog(b) + return nil + }, + Get: func(evalCtx *extendedEvalContext) string { + return strconv.FormatInt(evalCtx.SessionData.TxnRowsReadLog, 10) + }, + GlobalDefault: func(sv *settings.Values) string { + return strconv.FormatInt(txnRowsReadLog.Get(sv), 10) + }, + }, + + // CockroachDB extension. + `transaction_rows_read_err`: { + GetStringVal: makeIntGetStringValFn(`transaction_rows_read_err`), + Set: func(_ context.Context, m *sessionDataMutator, s string) error { + b, err := strconv.ParseInt(s, 10, 64) + if err != nil { + return err + } + if b < 0 { + return pgerror.Newf(pgcode.InvalidParameterValue, + "cannot set transaction_rows_read_err to a negative value: %d", b) + } + m.SetTxnRowsReadErr(b) + return nil + }, + Get: func(evalCtx *extendedEvalContext) string { + return strconv.FormatInt(evalCtx.SessionData.TxnRowsReadErr, 10) + }, + GlobalDefault: func(sv *settings.Values) string { + return strconv.FormatInt(txnRowsReadErr.Get(sv), 10) + }, + }, } const compatErrMsg = "this parameter is currently recognized only for compatibility and has no effect in CockroachDB." diff --git a/pkg/ts/catalog/chart_catalog.go b/pkg/ts/catalog/chart_catalog.go index 1536695ef8c0..1cb6e82cf1ed 100644 --- a/pkg/ts/catalog/chart_catalog.go +++ b/pkg/ts/catalog/chart_catalog.go @@ -2257,6 +2257,25 @@ var charts = []sectionDescription{ }, }, }, + { + Organization: [][]string{{SQLLayer, "Guardrails"}}, + Charts: []chartDescription{ + { + Title: "Transaction Row Count Limit Violations", + Metrics: []string{ + "sql.guardrails.transaction_rows_written_log.count", + "sql.guardrails.transaction_rows_written_log.count.internal", + "sql.guardrails.transaction_rows_written_err.count", + "sql.guardrails.transaction_rows_written_err.count.internal", + "sql.guardrails.transaction_rows_read_log.count", + "sql.guardrails.transaction_rows_read_log.count.internal", + "sql.guardrails.transaction_rows_read_err.count", + "sql.guardrails.transaction_rows_read_err.count.internal", + }, + AxisLabel: "Transactions", + }, + }, + }, { Organization: [][]string{{StorageLayer, "RocksDB", "Block Cache"}}, Charts: []chartDescription{ diff --git a/pkg/util/log/eventpb/eventlog_channels_generated.go b/pkg/util/log/eventpb/eventlog_channels_generated.go index 6eddaeb9cd36..b3b422fb709d 100644 --- a/pkg/util/log/eventpb/eventlog_channels_generated.go +++ b/pkg/util/log/eventpb/eventlog_channels_generated.go @@ -223,12 +223,28 @@ func (m *LargeRow) LoggingChannel() logpb.Channel { return logpb.Channel_SQL_PER // LoggingChannel implements the EventPayload interface. func (m *SlowQuery) LoggingChannel() logpb.Channel { return logpb.Channel_SQL_PERF } +// LoggingChannel implements the EventPayload interface. +func (m *TxnRowsReadLimit) LoggingChannel() logpb.Channel { return logpb.Channel_SQL_PERF } + +// LoggingChannel implements the EventPayload interface. +func (m *TxnRowsWrittenLimit) LoggingChannel() logpb.Channel { return logpb.Channel_SQL_PERF } + // LoggingChannel implements the EventPayload interface. func (m *LargeRowInternal) LoggingChannel() logpb.Channel { return logpb.Channel_SQL_INTERNAL_PERF } // LoggingChannel implements the EventPayload interface. func (m *SlowQueryInternal) LoggingChannel() logpb.Channel { return logpb.Channel_SQL_INTERNAL_PERF } +// LoggingChannel implements the EventPayload interface. +func (m *TxnRowsReadLimitInternal) LoggingChannel() logpb.Channel { + return logpb.Channel_SQL_INTERNAL_PERF +} + +// LoggingChannel implements the EventPayload interface. +func (m *TxnRowsWrittenLimitInternal) LoggingChannel() logpb.Channel { + return logpb.Channel_SQL_INTERNAL_PERF +} + // LoggingChannel implements the EventPayload interface. func (m *AlterRole) LoggingChannel() logpb.Channel { return logpb.Channel_USER_ADMIN } diff --git a/pkg/util/log/eventpb/json_encode_generated.go b/pkg/util/log/eventpb/json_encode_generated.go index e43c1f0e88ca..9861ab19d14e 100644 --- a/pkg/util/log/eventpb/json_encode_generated.go +++ b/pkg/util/log/eventpb/json_encode_generated.go @@ -1554,6 +1554,57 @@ func (m *CommonSessionDetails) AppendJSONFields(printComma bool, b redact.Redact return printComma, b } +// AppendJSONFields implements the EventPayload interface. +func (m *CommonTxnRowsLimitDetails) AppendJSONFields(printComma bool, b redact.RedactableBytes) (bool, redact.RedactableBytes) { + + if m.TxnID != "" { + if printComma { + b = append(b, ',') + } + printComma = true + b = append(b, "\"TxnID\":\""...) + b = redact.RedactableBytes(jsonbytes.EncodeString([]byte(b), string(m.TxnID))) + b = append(b, '"') + } + + if m.SessionID != "" { + if printComma { + b = append(b, ',') + } + printComma = true + b = append(b, "\"SessionID\":\""...) + b = redact.RedactableBytes(jsonbytes.EncodeString([]byte(b), string(m.SessionID))) + b = append(b, '"') + } + + if m.Limit != 0 { + if printComma { + b = append(b, ',') + } + printComma = true + b = append(b, "\"Limit\":"...) + b = strconv.AppendInt(b, int64(m.Limit), 10) + } + + if m.ViolatesTxnRowsLimitErr { + if printComma { + b = append(b, ',') + } + printComma = true + b = append(b, "\"ViolatesTxnRowsLimitErr\":true"...) + } + + if m.IsRead { + if printComma { + b = append(b, ',') + } + printComma = true + b = append(b, "\"IsRead\":true"...) + } + + return printComma, b +} + // AppendJSONFields implements the EventPayload interface. func (m *CommonZoneConfigDetails) AppendJSONFields(printComma bool, b redact.RedactableBytes) (bool, redact.RedactableBytes) { @@ -2862,6 +2913,54 @@ func (m *TruncateTable) AppendJSONFields(printComma bool, b redact.RedactableByt return printComma, b } +// AppendJSONFields implements the EventPayload interface. +func (m *TxnRowsReadLimit) AppendJSONFields(printComma bool, b redact.RedactableBytes) (bool, redact.RedactableBytes) { + + printComma, b = m.CommonEventDetails.AppendJSONFields(printComma, b) + + printComma, b = m.CommonSQLEventDetails.AppendJSONFields(printComma, b) + + printComma, b = m.CommonTxnRowsLimitDetails.AppendJSONFields(printComma, b) + + return printComma, b +} + +// AppendJSONFields implements the EventPayload interface. +func (m *TxnRowsReadLimitInternal) AppendJSONFields(printComma bool, b redact.RedactableBytes) (bool, redact.RedactableBytes) { + + printComma, b = m.CommonEventDetails.AppendJSONFields(printComma, b) + + printComma, b = m.CommonSQLEventDetails.AppendJSONFields(printComma, b) + + printComma, b = m.CommonTxnRowsLimitDetails.AppendJSONFields(printComma, b) + + return printComma, b +} + +// AppendJSONFields implements the EventPayload interface. +func (m *TxnRowsWrittenLimit) AppendJSONFields(printComma bool, b redact.RedactableBytes) (bool, redact.RedactableBytes) { + + printComma, b = m.CommonEventDetails.AppendJSONFields(printComma, b) + + printComma, b = m.CommonSQLEventDetails.AppendJSONFields(printComma, b) + + printComma, b = m.CommonTxnRowsLimitDetails.AppendJSONFields(printComma, b) + + return printComma, b +} + +// AppendJSONFields implements the EventPayload interface. +func (m *TxnRowsWrittenLimitInternal) AppendJSONFields(printComma bool, b redact.RedactableBytes) (bool, redact.RedactableBytes) { + + printComma, b = m.CommonEventDetails.AppendJSONFields(printComma, b) + + printComma, b = m.CommonSQLEventDetails.AppendJSONFields(printComma, b) + + printComma, b = m.CommonTxnRowsLimitDetails.AppendJSONFields(printComma, b) + + return printComma, b +} + // AppendJSONFields implements the EventPayload interface. func (m *UnsafeDeleteDescriptor) AppendJSONFields(printComma bool, b redact.RedactableBytes) (bool, redact.RedactableBytes) { diff --git a/pkg/util/log/eventpb/sql_audit_events.go b/pkg/util/log/eventpb/sql_audit_events.go index 15eab18fedaf..0af30ebe7f40 100644 --- a/pkg/util/log/eventpb/sql_audit_events.go +++ b/pkg/util/log/eventpb/sql_audit_events.go @@ -14,6 +14,7 @@ import ( "fmt" "github.com/cockroachdb/errors" + "github.com/cockroachdb/redact" ) var _ error = &CommonLargeRowDetails{} @@ -54,3 +55,48 @@ func (r *CommonLargeRowDetails) SafeFormatError(p errors.Printer) (next error) { } return nil } + +var _ error = &CommonTxnRowsLimitDetails{} +var _ errors.SafeDetailer = &CommonTxnRowsLimitDetails{} +var _ fmt.Formatter = &CommonTxnRowsLimitDetails{} +var _ errors.SafeFormatter = &CommonTxnRowsLimitDetails{} + +func (d *CommonTxnRowsLimitDetails) kind() string { + if d.IsRead { + return "read" + } + return "written" +} + +// Error is part of the error interface, which CommonTxnRowsLimitDetails +// implements. +func (d *CommonTxnRowsLimitDetails) Error() string { + return fmt.Sprintf( + "txn reached the number of rows %s (%d): TxnID %v SessionID %v", + d.kind(), d.Limit, redact.SafeString(d.TxnID), redact.SafeString(d.SessionID), + ) +} + +// SafeDetails is part of the errors.SafeDetailer interface, which +// CommonTxnRowsLimitDetails implements. +func (d *CommonTxnRowsLimitDetails) SafeDetails() []string { + return []string{d.TxnID, d.SessionID, fmt.Sprintf("%d", d.Limit), d.kind()} +} + +// Format is part of the fmt.Formatter interface, which +// CommonTxnRowsLimitDetails implements. +func (d *CommonTxnRowsLimitDetails) Format(s fmt.State, verb rune) { + errors.FormatError(d, s, verb) +} + +// SafeFormatError is part of the errors.SafeFormatter interface, which +// CommonTxnRowsLimitDetails implements. +func (d *CommonTxnRowsLimitDetails) SafeFormatError(p errors.Printer) (next error) { + if p.Detail() { + p.Printf( + "txn reached the number of rows %s (%d): TxnID %v SessionID %v", + d.kind(), d.Limit, redact.SafeString(d.TxnID), redact.SafeString(d.SessionID), + ) + } + return nil +} diff --git a/pkg/util/log/eventpb/sql_audit_events.pb.go b/pkg/util/log/eventpb/sql_audit_events.pb.go index 35abb8e1d508..641ff279a26c 100644 --- a/pkg/util/log/eventpb/sql_audit_events.pb.go +++ b/pkg/util/log/eventpb/sql_audit_events.pb.go @@ -276,6 +276,132 @@ func (m *LargeRow) XXX_DiscardUnknown() { var xxx_messageInfo_LargeRow proto.InternalMessageInfo +// CommonTxnRowsLimitDetails contains the fields common to all messages related +// to reaching the limits on the number of rows written/read by a transaction. +type CommonTxnRowsLimitDetails struct { + // TxnID is the ID of the transaction that hit the row count limit. + TxnID string `protobuf:"bytes,1,opt,name=txn_id,json=txnId,proto3" json:",omitempty" redact:"nonsensitive"` + // SessionID is the ID of the session that initiated the transaction. + SessionID string `protobuf:"bytes,2,opt,name=session_id,json=sessionId,proto3" json:",omitempty" redact:"nonsensitive"` + // Limit indicates the value of the transaction row count limit that was + // reached. + Limit int64 `protobuf:"varint,3,opt,name=limit,proto3" json:",omitempty"` + // ViolatesTxnRowsLimitErr if true indicates that + // 'transaction_rows_{written|read}_err' limit is violated. + ViolatesTxnRowsLimitErr bool `protobuf:"varint,4,opt,name=violates_txn_rows_limit_err,json=violatesTxnRowsLimitErr,proto3" json:",omitempty"` + // IsRead if true indicates that the "rows read" limit is reached and the + // "rows written" limit otherwise. + IsRead bool `protobuf:"varint,5,opt,name=is_read,json=isRead,proto3" json:",omitempty"` +} + +func (m *CommonTxnRowsLimitDetails) Reset() { *m = CommonTxnRowsLimitDetails{} } +func (m *CommonTxnRowsLimitDetails) String() string { return proto.CompactTextString(m) } +func (*CommonTxnRowsLimitDetails) ProtoMessage() {} +func (*CommonTxnRowsLimitDetails) Descriptor() ([]byte, []int) { + return fileDescriptor_b7a82d5e93041841, []int{6} +} +func (m *CommonTxnRowsLimitDetails) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *CommonTxnRowsLimitDetails) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *CommonTxnRowsLimitDetails) XXX_Merge(src proto.Message) { + xxx_messageInfo_CommonTxnRowsLimitDetails.Merge(m, src) +} +func (m *CommonTxnRowsLimitDetails) XXX_Size() int { + return m.Size() +} +func (m *CommonTxnRowsLimitDetails) XXX_DiscardUnknown() { + xxx_messageInfo_CommonTxnRowsLimitDetails.DiscardUnknown(m) +} + +var xxx_messageInfo_CommonTxnRowsLimitDetails proto.InternalMessageInfo + +// TxnRowsWrittenLimit is recorded when a transaction tries to write more rows +// than cluster setting `sql.defaults.transaction_rows_written_log`. There will +// only be a single record for a single transaction (unless it is retried) even +// if there are more mutation statements within the transaction that haven't +// been executed yet. +type TxnRowsWrittenLimit struct { + CommonEventDetails `protobuf:"bytes,1,opt,name=common,proto3,embedded=common" json:""` + CommonSQLEventDetails `protobuf:"bytes,2,opt,name=sql,proto3,embedded=sql" json:""` + CommonTxnRowsLimitDetails `protobuf:"bytes,3,opt,name=info,proto3,embedded=info" json:""` +} + +func (m *TxnRowsWrittenLimit) Reset() { *m = TxnRowsWrittenLimit{} } +func (m *TxnRowsWrittenLimit) String() string { return proto.CompactTextString(m) } +func (*TxnRowsWrittenLimit) ProtoMessage() {} +func (*TxnRowsWrittenLimit) Descriptor() ([]byte, []int) { + return fileDescriptor_b7a82d5e93041841, []int{7} +} +func (m *TxnRowsWrittenLimit) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TxnRowsWrittenLimit) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *TxnRowsWrittenLimit) XXX_Merge(src proto.Message) { + xxx_messageInfo_TxnRowsWrittenLimit.Merge(m, src) +} +func (m *TxnRowsWrittenLimit) XXX_Size() int { + return m.Size() +} +func (m *TxnRowsWrittenLimit) XXX_DiscardUnknown() { + xxx_messageInfo_TxnRowsWrittenLimit.DiscardUnknown(m) +} + +var xxx_messageInfo_TxnRowsWrittenLimit proto.InternalMessageInfo + +// TxnRowsReadLimit is recorded when a transaction tries to read more rows than +// cluster setting `sql.defaults.transaction_rows_read_log`. There will only be +// a single record for a single transaction (unless it is retried) even if there +// are more statement within the transaction that haven't been executed yet. +type TxnRowsReadLimit struct { + CommonEventDetails `protobuf:"bytes,1,opt,name=common,proto3,embedded=common" json:""` + CommonSQLEventDetails `protobuf:"bytes,2,opt,name=sql,proto3,embedded=sql" json:""` + CommonTxnRowsLimitDetails `protobuf:"bytes,3,opt,name=info,proto3,embedded=info" json:""` +} + +func (m *TxnRowsReadLimit) Reset() { *m = TxnRowsReadLimit{} } +func (m *TxnRowsReadLimit) String() string { return proto.CompactTextString(m) } +func (*TxnRowsReadLimit) ProtoMessage() {} +func (*TxnRowsReadLimit) Descriptor() ([]byte, []int) { + return fileDescriptor_b7a82d5e93041841, []int{8} +} +func (m *TxnRowsReadLimit) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TxnRowsReadLimit) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *TxnRowsReadLimit) XXX_Merge(src proto.Message) { + xxx_messageInfo_TxnRowsReadLimit.Merge(m, src) +} +func (m *TxnRowsReadLimit) XXX_Size() int { + return m.Size() +} +func (m *TxnRowsReadLimit) XXX_DiscardUnknown() { + xxx_messageInfo_TxnRowsReadLimit.DiscardUnknown(m) +} + +var xxx_messageInfo_TxnRowsReadLimit proto.InternalMessageInfo + // SlowQueryInternal is recorded when a query triggers the "slow query" condition, // and the cluster setting `sql.log.slow_query.internal_queries.enabled` is // set. @@ -291,7 +417,7 @@ func (m *SlowQueryInternal) Reset() { *m = SlowQueryInternal{} } func (m *SlowQueryInternal) String() string { return proto.CompactTextString(m) } func (*SlowQueryInternal) ProtoMessage() {} func (*SlowQueryInternal) Descriptor() ([]byte, []int) { - return fileDescriptor_b7a82d5e93041841, []int{6} + return fileDescriptor_b7a82d5e93041841, []int{9} } func (m *SlowQueryInternal) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -328,7 +454,7 @@ func (m *LargeRowInternal) Reset() { *m = LargeRowInternal{} } func (m *LargeRowInternal) String() string { return proto.CompactTextString(m) } func (*LargeRowInternal) ProtoMessage() {} func (*LargeRowInternal) Descriptor() ([]byte, []int) { - return fileDescriptor_b7a82d5e93041841, []int{7} + return fileDescriptor_b7a82d5e93041841, []int{10} } func (m *LargeRowInternal) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -353,6 +479,87 @@ func (m *LargeRowInternal) XXX_DiscardUnknown() { var xxx_messageInfo_LargeRowInternal proto.InternalMessageInfo +// TxnRowsWrittenLimitInternal is recorded when an internal transaction tries to +// write more rows than cluster setting +// `sql.defaults.transaction_rows_written_log` or +// `sql.defaults.transaction_rows_written_err`. There will only be a single +// record for a single transaction (unless it is retried) even if there are more +// mutation statements within the transaction that haven't been executed yet. +type TxnRowsWrittenLimitInternal struct { + CommonEventDetails `protobuf:"bytes,1,opt,name=common,proto3,embedded=common" json:""` + CommonSQLEventDetails `protobuf:"bytes,2,opt,name=sql,proto3,embedded=sql" json:""` + CommonTxnRowsLimitDetails `protobuf:"bytes,3,opt,name=info,proto3,embedded=info" json:""` +} + +func (m *TxnRowsWrittenLimitInternal) Reset() { *m = TxnRowsWrittenLimitInternal{} } +func (m *TxnRowsWrittenLimitInternal) String() string { return proto.CompactTextString(m) } +func (*TxnRowsWrittenLimitInternal) ProtoMessage() {} +func (*TxnRowsWrittenLimitInternal) Descriptor() ([]byte, []int) { + return fileDescriptor_b7a82d5e93041841, []int{11} +} +func (m *TxnRowsWrittenLimitInternal) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TxnRowsWrittenLimitInternal) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *TxnRowsWrittenLimitInternal) XXX_Merge(src proto.Message) { + xxx_messageInfo_TxnRowsWrittenLimitInternal.Merge(m, src) +} +func (m *TxnRowsWrittenLimitInternal) XXX_Size() int { + return m.Size() +} +func (m *TxnRowsWrittenLimitInternal) XXX_DiscardUnknown() { + xxx_messageInfo_TxnRowsWrittenLimitInternal.DiscardUnknown(m) +} + +var xxx_messageInfo_TxnRowsWrittenLimitInternal proto.InternalMessageInfo + +// TxnRowsReadLimitInternal is recorded when an internal transaction tries to +// read more rows than cluster setting `sql.defaults.transaction_rows_read_log` +// or `sql.defaults.transaction_rows_read_err`. There will only be a single +// record for a single transaction (unless it is retried) even if there are more +// mutation statements within the transaction that haven't been executed yet. +type TxnRowsReadLimitInternal struct { + CommonEventDetails `protobuf:"bytes,1,opt,name=common,proto3,embedded=common" json:""` + CommonSQLEventDetails `protobuf:"bytes,2,opt,name=sql,proto3,embedded=sql" json:""` + CommonTxnRowsLimitDetails `protobuf:"bytes,3,opt,name=info,proto3,embedded=info" json:""` +} + +func (m *TxnRowsReadLimitInternal) Reset() { *m = TxnRowsReadLimitInternal{} } +func (m *TxnRowsReadLimitInternal) String() string { return proto.CompactTextString(m) } +func (*TxnRowsReadLimitInternal) ProtoMessage() {} +func (*TxnRowsReadLimitInternal) Descriptor() ([]byte, []int) { + return fileDescriptor_b7a82d5e93041841, []int{12} +} +func (m *TxnRowsReadLimitInternal) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TxnRowsReadLimitInternal) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil +} +func (m *TxnRowsReadLimitInternal) XXX_Merge(src proto.Message) { + xxx_messageInfo_TxnRowsReadLimitInternal.Merge(m, src) +} +func (m *TxnRowsReadLimitInternal) XXX_Size() int { + return m.Size() +} +func (m *TxnRowsReadLimitInternal) XXX_DiscardUnknown() { + xxx_messageInfo_TxnRowsReadLimitInternal.DiscardUnknown(m) +} + +var xxx_messageInfo_TxnRowsReadLimitInternal proto.InternalMessageInfo + // QueryExecute is recorded when a query is executed, // and the cluster setting `sql.trace.log_statement_execute` is set. type QueryExecute struct { @@ -365,7 +572,7 @@ func (m *QueryExecute) Reset() { *m = QueryExecute{} } func (m *QueryExecute) String() string { return proto.CompactTextString(m) } func (*QueryExecute) ProtoMessage() {} func (*QueryExecute) Descriptor() ([]byte, []int) { - return fileDescriptor_b7a82d5e93041841, []int{8} + return fileDescriptor_b7a82d5e93041841, []int{13} } func (m *QueryExecute) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -397,8 +604,13 @@ func init() { proto.RegisterType((*SlowQuery)(nil), "cockroach.util.log.eventpb.SlowQuery") proto.RegisterType((*CommonLargeRowDetails)(nil), "cockroach.util.log.eventpb.CommonLargeRowDetails") proto.RegisterType((*LargeRow)(nil), "cockroach.util.log.eventpb.LargeRow") + proto.RegisterType((*CommonTxnRowsLimitDetails)(nil), "cockroach.util.log.eventpb.CommonTxnRowsLimitDetails") + proto.RegisterType((*TxnRowsWrittenLimit)(nil), "cockroach.util.log.eventpb.TxnRowsWrittenLimit") + proto.RegisterType((*TxnRowsReadLimit)(nil), "cockroach.util.log.eventpb.TxnRowsReadLimit") proto.RegisterType((*SlowQueryInternal)(nil), "cockroach.util.log.eventpb.SlowQueryInternal") proto.RegisterType((*LargeRowInternal)(nil), "cockroach.util.log.eventpb.LargeRowInternal") + proto.RegisterType((*TxnRowsWrittenLimitInternal)(nil), "cockroach.util.log.eventpb.TxnRowsWrittenLimitInternal") + proto.RegisterType((*TxnRowsReadLimitInternal)(nil), "cockroach.util.log.eventpb.TxnRowsReadLimitInternal") proto.RegisterType((*QueryExecute)(nil), "cockroach.util.log.eventpb.QueryExecute") } @@ -407,57 +619,70 @@ func init() { } var fileDescriptor_b7a82d5e93041841 = []byte{ - // 792 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x96, 0xcf, 0x6f, 0xe3, 0x44, - 0x14, 0xc7, 0xe3, 0xa4, 0xdb, 0x38, 0x2f, 0x5b, 0x7e, 0x58, 0xad, 0xe4, 0x8d, 0x84, 0x13, 0xf9, - 0xb2, 0xa9, 0x04, 0x09, 0x74, 0x11, 0x48, 0xdc, 0x9a, 0x6d, 0xd0, 0x46, 0x74, 0x41, 0xf9, 0x71, - 0xe2, 0x62, 0x4d, 0xed, 0xb7, 0xc1, 0x5a, 0x7b, 0x26, 0x9d, 0x19, 0xd7, 0xce, 0xfe, 0x05, 0x20, - 0x38, 0xec, 0x1f, 0xc2, 0x8d, 0x23, 0xff, 0x40, 0x8f, 0x3d, 0xf6, 0x14, 0x41, 0x7a, 0xeb, 0x91, - 0x2b, 0x17, 0x34, 0xe3, 0xa4, 0x40, 0x42, 0x44, 0x91, 0xe8, 0xa9, 0x7b, 0x4b, 0x9c, 0xef, 0xf7, - 0x3b, 0x99, 0xf7, 0x3e, 0xef, 0xc9, 0xf0, 0x38, 0x91, 0x61, 0xd4, 0x8e, 0xd8, 0xb8, 0x8d, 0x67, - 0x48, 0xe5, 0xe4, 0xa4, 0x2d, 0x4e, 0x23, 0x8f, 0x24, 0x41, 0x28, 0x3d, 0xfd, 0x44, 0xb4, 0x26, - 0x9c, 0x49, 0x66, 0xd5, 0x7c, 0xe6, 0xbf, 0xe4, 0x8c, 0xf8, 0xdf, 0xb4, 0x94, 0xa5, 0x15, 0xb1, - 0x71, 0x6b, 0x61, 0xa9, 0xed, 0x8e, 0xd9, 0x98, 0x69, 0x59, 0x5b, 0x7d, 0xca, 0x1d, 0xb5, 0xf7, - 0xd6, 0xa2, 0xff, 0x1a, 0xe8, 0xfe, 0x5e, 0x82, 0xdd, 0xa7, 0x2c, 0x8e, 0x19, 0x1d, 0xf6, 0x8f, - 0xbb, 0x19, 0xfa, 0x47, 0x28, 0x49, 0x18, 0x09, 0xeb, 0x08, 0x2a, 0x98, 0xa1, 0xef, 0xc5, 0x2c, - 0x40, 0xdb, 0x68, 0x18, 0xcd, 0x4a, 0xe7, 0xf1, 0xf5, 0xac, 0x0e, 0xef, 0xb3, 0x38, 0x94, 0x18, - 0x4f, 0xe4, 0xf4, 0xb7, 0x59, 0x7d, 0x8f, 0x63, 0x40, 0x7c, 0xf9, 0x99, 0x4b, 0x19, 0x15, 0x48, - 0x45, 0x28, 0xc3, 0x33, 0x74, 0x07, 0xa6, 0x72, 0x3e, 0x67, 0x01, 0x5a, 0xfb, 0x60, 0xd2, 0x24, - 0xf6, 0x38, 0x4b, 0x85, 0x5d, 0x6c, 0x18, 0xcd, 0xad, 0xce, 0x5b, 0x7f, 0x0f, 0x19, 0x94, 0x69, - 0x12, 0x0f, 0x58, 0x2a, 0xac, 0xaf, 0xc0, 0x14, 0xa7, 0x91, 0x90, 0x44, 0xa2, 0x5d, 0xd2, 0xe7, - 0x3d, 0x99, 0xcf, 0xea, 0xe6, 0xb0, 0x7f, 0x3c, 0x1c, 0x1d, 0x8e, 0xba, 0xb7, 0x3e, 0x7b, 0x19, - 0x62, 0x7d, 0x00, 0x80, 0x9c, 0x33, 0xee, 0x49, 0xcc, 0xa4, 0xbd, 0xa5, 0x23, 0x57, 0x4f, 0xaf, - 0x68, 0xc5, 0x08, 0x33, 0x69, 0x35, 0xa0, 0x44, 0xc6, 0x68, 0x3f, 0x68, 0x18, 0xcd, 0xe2, 0x9a, - 0x4e, 0xfd, 0x64, 0xb5, 0xa1, 0xaa, 0x2f, 0x83, 0x92, 0x87, 0x28, 0xec, 0xed, 0x86, 0xd1, 0xdc, - 0x59, 0x53, 0x82, 0xba, 0x4f, 0xae, 0xb0, 0x3e, 0x81, 0xb7, 0x5f, 0x24, 0x51, 0xe4, 0x49, 0x72, - 0x12, 0xa1, 0x27, 0x7c, 0x42, 0xed, 0x72, 0xc3, 0x68, 0x9a, 0x6b, 0xa6, 0x1d, 0x25, 0x1b, 0x29, - 0xd5, 0xd0, 0x27, 0xf4, 0xc6, 0x17, 0xd2, 0x00, 0xb3, 0xdc, 0x67, 0x6e, 0xf6, 0xf5, 0x94, 0x4a, - 0xfb, 0xda, 0x50, 0x95, 0x19, 0xf5, 0x7c, 0x96, 0x50, 0x89, 0xdc, 0xae, 0xfc, 0xf3, 0x1f, 0x94, - 0x19, 0x7d, 0x9a, 0x2b, 0xdc, 0x1f, 0x4a, 0xb0, 0x3b, 0x5c, 0xd6, 0x4e, 0x9f, 0x7f, 0xe8, 0xfb, - 0x28, 0x84, 0x35, 0x82, 0x6d, 0x5f, 0x53, 0xa1, 0x5b, 0x5f, 0x3d, 0x68, 0xb5, 0x36, 0x83, 0xd7, - 0xca, 0xf9, 0xe9, 0xaa, 0x6f, 0x0b, 0x7a, 0x3a, 0x0f, 0xcf, 0x67, 0xf5, 0xc2, 0xc5, 0xac, 0x6e, - 0x5c, 0xcf, 0xea, 0x85, 0xc1, 0x22, 0xcb, 0xea, 0x43, 0x49, 0x9c, 0x46, 0x1a, 0x84, 0xea, 0xc1, - 0x47, 0xff, 0x1e, 0xa9, 0x90, 0xdc, 0x9c, 0xaa, 0xb2, 0xac, 0x01, 0x6c, 0x29, 0xd8, 0x34, 0x31, - 0xd5, 0x83, 0x0f, 0x6f, 0x97, 0xf9, 0x27, 0xe6, 0x2b, 0x91, 0x3a, 0x4b, 0x81, 0x93, 0x77, 0x8c, - 0x92, 0x18, 0x37, 0x81, 0xa3, 0x15, 0x5f, 0x92, 0x18, 0xad, 0x67, 0x50, 0x25, 0xba, 0x6a, 0xf9, - 0xac, 0x3c, 0xf8, 0x6f, 0xb3, 0x02, 0xb9, 0x57, 0x4d, 0x8b, 0xfb, 0x5d, 0x11, 0xe0, 0x30, 0x88, - 0x43, 0xda, 0x4f, 0x90, 0x4f, 0xef, 0x75, 0x13, 0xdc, 0x6f, 0x8b, 0x50, 0x19, 0x46, 0x2c, 0x7d, - 0x53, 0x0a, 0xf7, 0xc7, 0x22, 0xec, 0xe5, 0xe2, 0x63, 0xc2, 0xc7, 0x38, 0x60, 0xe9, 0x72, 0x49, - 0xef, 0x83, 0xc9, 0x59, 0xea, 0x89, 0xf0, 0x55, 0xbe, 0xa3, 0xd7, 0xa7, 0xbd, 0xcc, 0x59, 0x3a, - 0x0c, 0x5f, 0xa1, 0xf5, 0x31, 0x98, 0x39, 0xd4, 0x61, 0xa0, 0x2f, 0xbc, 0xd3, 0x79, 0x34, 0x9f, - 0xd5, 0xcb, 0x7a, 0xe8, 0x7b, 0x47, 0xab, 0x2e, 0x2d, 0xed, 0x05, 0xd6, 0xa7, 0x50, 0x79, 0x41, - 0xe2, 0x30, 0x9a, 0x2a, 0x5b, 0x49, 0xdb, 0x6a, 0x6a, 0x2b, 0x7f, 0xae, 0x1f, 0xae, 0xf9, 0xcc, - 0x5c, 0xdc, 0x0b, 0xd4, 0x2a, 0x9a, 0xf0, 0x30, 0x26, 0x7c, 0xea, 0xbd, 0xc4, 0xe9, 0x86, 0x21, - 0x82, 0x85, 0xe4, 0x0b, 0x9c, 0x5a, 0xcf, 0xe0, 0xd1, 0x59, 0xc8, 0x22, 0x22, 0x51, 0x78, 0x31, - 0xc9, 0xbc, 0xe5, 0xbd, 0x3c, 0xe4, 0x5c, 0xcf, 0xd4, 0xfa, 0xf6, 0xdb, 0x5b, 0x1a, 0x9e, 0x93, - 0x6c, 0x90, 0x5f, 0xb3, 0xcb, 0xb9, 0xfb, 0x93, 0x01, 0xe6, 0xb2, 0x50, 0x77, 0x07, 0x0e, 0x67, - 0xe9, 0xed, 0xc1, 0x59, 0xe9, 0xdb, 0x2a, 0x38, 0x9c, 0xa5, 0xee, 0xeb, 0x22, 0xbc, 0x7b, 0xc3, - 0x7b, 0x4f, 0x6d, 0x67, 0x4a, 0xa2, 0xfb, 0xcd, 0xfd, 0xcf, 0x06, 0xbc, 0xb3, 0xac, 0xdc, 0xdd, - 0x57, 0xe4, 0xff, 0x6e, 0xe8, 0xf7, 0x45, 0x78, 0xa8, 0x9b, 0xa9, 0xae, 0x99, 0x48, 0xbc, 0xd7, - 0xbd, 0xec, 0xec, 0x9f, 0xff, 0xea, 0x14, 0xce, 0xe7, 0x8e, 0x71, 0x31, 0x77, 0x8c, 0xcb, 0xb9, - 0x63, 0xfc, 0x32, 0x77, 0x8c, 0xd7, 0x57, 0x4e, 0xe1, 0xe2, 0xca, 0x29, 0x5c, 0x5e, 0x39, 0x85, - 0xaf, 0xcb, 0x8b, 0xcc, 0x93, 0x6d, 0xfd, 0x66, 0xfa, 0xe4, 0x8f, 0x00, 0x00, 0x00, 0xff, 0xff, - 0x06, 0x20, 0x2f, 0x65, 0x15, 0x0b, 0x00, 0x00, + // 995 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x58, 0x41, 0x6f, 0x1b, 0x45, + 0x18, 0xf5, 0xae, 0x93, 0x78, 0xfd, 0xb9, 0x85, 0x32, 0x24, 0xc2, 0x49, 0x85, 0x6d, 0xad, 0x90, + 0x92, 0x48, 0x60, 0x97, 0xb4, 0x80, 0xc4, 0x2d, 0x6e, 0x02, 0xb5, 0x48, 0x41, 0xb1, 0x2d, 0x55, + 0xe2, 0xb2, 0x9a, 0xec, 0x4e, 0xcc, 0xa8, 0xbb, 0x33, 0xc9, 0xcc, 0x38, 0x5e, 0xf7, 0x17, 0x80, + 0xe0, 0xd0, 0x03, 0x12, 0x17, 0x24, 0xfe, 0x00, 0x37, 0x8e, 0xfc, 0x81, 0x1c, 0x73, 0x42, 0x3d, + 0x59, 0xe0, 0xdc, 0x7a, 0xe4, 0xca, 0x05, 0xcd, 0xec, 0x6e, 0x28, 0x76, 0xac, 0x06, 0x89, 0x1c, + 0xaa, 0xe4, 0x96, 0xec, 0xbe, 0xf7, 0x66, 0xe6, 0xfb, 0xde, 0xf7, 0x66, 0x65, 0x58, 0xed, 0x2b, + 0x1a, 0x36, 0x42, 0xde, 0x6b, 0x90, 0x23, 0xc2, 0xd4, 0xc1, 0x5e, 0x43, 0x1e, 0x86, 0x1e, 0xee, + 0x07, 0x54, 0x79, 0xe6, 0x89, 0xac, 0x1f, 0x08, 0xae, 0x38, 0x5a, 0xf1, 0xb9, 0xff, 0x58, 0x70, + 0xec, 0x7f, 0x55, 0xd7, 0x94, 0x7a, 0xc8, 0x7b, 0xf5, 0x94, 0xb2, 0xb2, 0xd8, 0xe3, 0x3d, 0x6e, + 0x60, 0x0d, 0xfd, 0x57, 0xc2, 0x58, 0x79, 0x7b, 0x4a, 0xfa, 0x45, 0x41, 0xf7, 0xaf, 0x3c, 0x2c, + 0xde, 0xe7, 0x51, 0xc4, 0x59, 0x67, 0x77, 0x67, 0x3b, 0x26, 0xfe, 0x16, 0x51, 0x98, 0x86, 0x12, + 0x6d, 0x41, 0x91, 0xc4, 0xc4, 0xf7, 0x22, 0x1e, 0x90, 0xb2, 0x55, 0xb3, 0xd6, 0x8a, 0xcd, 0xd5, + 0xe7, 0xa3, 0x2a, 0xbc, 0xcb, 0x23, 0xaa, 0x48, 0x74, 0xa0, 0x86, 0x7f, 0x8e, 0xaa, 0x4b, 0x82, + 0x04, 0xd8, 0x57, 0x1f, 0xbb, 0x8c, 0x33, 0x49, 0x98, 0xa4, 0x8a, 0x1e, 0x11, 0xb7, 0xed, 0x68, + 0xe6, 0x43, 0x1e, 0x10, 0xb4, 0x0e, 0x0e, 0xeb, 0x47, 0x9e, 0xe0, 0x03, 0x59, 0xb6, 0x6b, 0xd6, + 0xda, 0x5c, 0xf3, 0xb5, 0x7f, 0x8b, 0xb4, 0x0b, 0xac, 0x1f, 0xb5, 0xf9, 0x40, 0xa2, 0x2f, 0xc0, + 0x91, 0x87, 0xa1, 0x54, 0x58, 0x91, 0x72, 0xde, 0xac, 0x77, 0x77, 0x3c, 0xaa, 0x3a, 0x9d, 0xdd, + 0x9d, 0x4e, 0x77, 0xb3, 0xbb, 0x7d, 0xe1, 0xb5, 0x33, 0x11, 0xf4, 0x1e, 0x00, 0x11, 0x82, 0x0b, + 0x4f, 0x91, 0x58, 0x95, 0xe7, 0x8c, 0xe4, 0xe4, 0xea, 0x45, 0x83, 0xe8, 0x92, 0x58, 0xa1, 0x1a, + 0xe4, 0x71, 0x8f, 0x94, 0xe7, 0x6b, 0xd6, 0x9a, 0x3d, 0x85, 0xd3, 0xaf, 0x50, 0x03, 0x4a, 0xe6, + 0x30, 0x44, 0x09, 0x4a, 0x64, 0x79, 0xa1, 0x66, 0xad, 0xdd, 0x9c, 0x42, 0x82, 0x3e, 0x4f, 0x82, + 0x40, 0x1f, 0xc2, 0xeb, 0xfb, 0xfd, 0x30, 0xf4, 0x14, 0xde, 0x0b, 0x89, 0x27, 0x7d, 0xcc, 0xca, + 0x85, 0x9a, 0xb5, 0xe6, 0x4c, 0x91, 0x6e, 0x6a, 0x58, 0x57, 0xa3, 0x3a, 0x3e, 0x66, 0x67, 0x3c, + 0xca, 0x02, 0x12, 0x27, 0x3c, 0x67, 0x36, 0xaf, 0xa5, 0x51, 0x86, 0xd7, 0x80, 0x92, 0x8a, 0x99, + 0xe7, 0xf3, 0x3e, 0x53, 0x44, 0x94, 0x8b, 0xe7, 0x6f, 0x50, 0xc5, 0xec, 0x7e, 0x82, 0x70, 0xbf, + 0xcb, 0xc3, 0x62, 0x27, 0xab, 0x9d, 0x59, 0x7f, 0xd3, 0xf7, 0x89, 0x94, 0xa8, 0x0b, 0x0b, 0xbe, + 0x71, 0x85, 0x69, 0x7d, 0x69, 0xa3, 0x5e, 0x9f, 0x6d, 0xbc, 0x7a, 0xe2, 0x9f, 0x6d, 0xfd, 0x5f, + 0xea, 0x9e, 0xe6, 0x8d, 0xe3, 0x51, 0x35, 0x77, 0x32, 0xaa, 0x5a, 0xcf, 0x47, 0xd5, 0x5c, 0x3b, + 0xd5, 0x42, 0xbb, 0x90, 0x97, 0x87, 0xa1, 0x31, 0x42, 0x69, 0xe3, 0xfd, 0x97, 0x4b, 0x6a, 0x4b, + 0xce, 0x56, 0xd5, 0x5a, 0xa8, 0x0d, 0x73, 0xda, 0x6c, 0xc6, 0x31, 0xa5, 0x8d, 0x3b, 0x17, 0xd3, + 0xfc, 0xc7, 0xe6, 0x13, 0x92, 0x46, 0x4b, 0x1b, 0x27, 0xe9, 0x18, 0xc3, 0x11, 0x99, 0x65, 0x1c, + 0x83, 0xf8, 0x1c, 0x47, 0x04, 0x3d, 0x80, 0x12, 0x36, 0x55, 0x4b, 0x66, 0x65, 0xfe, 0xbf, 0xcd, + 0x0a, 0x24, 0x5c, 0x3d, 0x2d, 0xee, 0x37, 0x36, 0xc0, 0x66, 0x10, 0x51, 0xb6, 0xdb, 0x27, 0x62, + 0x78, 0xa5, 0x9b, 0xe0, 0x7e, 0x6d, 0x43, 0xb1, 0x13, 0xf2, 0xc1, 0x75, 0x29, 0xdc, 0x9f, 0x6d, + 0x58, 0x4a, 0xc0, 0x3b, 0x58, 0xf4, 0x48, 0x9b, 0x0f, 0xb2, 0x90, 0x5e, 0x07, 0x47, 0xf0, 0x81, + 0x27, 0xe9, 0x93, 0x24, 0xa3, 0xa7, 0xa7, 0xbd, 0x20, 0xf8, 0xa0, 0x43, 0x9f, 0x10, 0x74, 0x0f, + 0x9c, 0xc4, 0xd4, 0x34, 0x30, 0x07, 0xbe, 0xd9, 0x5c, 0x1e, 0x8f, 0xaa, 0x05, 0x33, 0xf4, 0xad, + 0xad, 0x49, 0x96, 0x81, 0xb6, 0x02, 0xf4, 0x11, 0x14, 0xf7, 0x71, 0x44, 0xc3, 0xa1, 0xa6, 0xe5, + 0x0d, 0x6d, 0x45, 0xa7, 0xf2, 0x27, 0xe6, 0xe1, 0x14, 0xcf, 0x49, 0xc0, 0xad, 0x40, 0x47, 0xd1, + 0x81, 0xa0, 0x11, 0x16, 0x43, 0xef, 0x31, 0x19, 0xce, 0x18, 0x22, 0x48, 0x21, 0x9f, 0x91, 0x21, + 0x7a, 0x00, 0xcb, 0x47, 0x94, 0x87, 0x58, 0x11, 0xe9, 0x45, 0x38, 0xf6, 0xb2, 0x73, 0x79, 0x44, + 0x08, 0x33, 0x53, 0xd3, 0xe9, 0xb7, 0x94, 0x11, 0x1e, 0xe2, 0xb8, 0x9d, 0x1c, 0x73, 0x5b, 0x08, + 0xf7, 0x17, 0x0b, 0x9c, 0xac, 0x50, 0x97, 0x67, 0x1c, 0xc1, 0x07, 0x17, 0x37, 0xce, 0x44, 0xdf, + 0x26, 0x8d, 0x23, 0xf8, 0xc0, 0xfd, 0xcd, 0x86, 0xe5, 0x04, 0xdc, 0x8d, 0x99, 0xbe, 0x10, 0x77, + 0x68, 0x44, 0xb3, 0x6d, 0xa0, 0x4f, 0x61, 0x41, 0x27, 0x3b, 0x0d, 0xd2, 0xab, 0xf8, 0xce, 0x78, + 0x54, 0x9d, 0xef, 0xc6, 0x6c, 0xb2, 0x03, 0xb3, 0x73, 0x66, 0x5e, 0xc5, 0xac, 0x15, 0xa0, 0x0e, + 0x80, 0x24, 0x52, 0x52, 0xce, 0x32, 0x23, 0x14, 0x9b, 0xf7, 0xc6, 0xa3, 0x6a, 0xb1, 0x93, 0x3c, + 0xbd, 0xb8, 0x60, 0x31, 0xd5, 0x69, 0x05, 0xe8, 0x1d, 0x98, 0x0f, 0xf5, 0x6e, 0x8d, 0x43, 0xf2, + 0x53, 0x7d, 0x4a, 0x5e, 0xa2, 0x1d, 0xb8, 0x7d, 0xd6, 0x61, 0x7d, 0x18, 0xfd, 0x51, 0xe0, 0x99, + 0x57, 0xa6, 0xc7, 0x73, 0xe7, 0xf6, 0xf8, 0xad, 0x8c, 0xf2, 0x62, 0x55, 0xb6, 0x85, 0x40, 0xab, + 0x50, 0xa0, 0xd2, 0x13, 0x04, 0x07, 0x33, 0xdc, 0xb1, 0x40, 0x65, 0x9b, 0xe0, 0xc0, 0xfd, 0xc1, + 0x86, 0x37, 0x53, 0xf2, 0x23, 0x41, 0x95, 0x22, 0xcc, 0x68, 0xbc, 0x3a, 0x91, 0xf2, 0x08, 0xe6, + 0x28, 0xdb, 0xe7, 0x69, 0xa4, 0x7c, 0xf0, 0x72, 0xcd, 0x73, 0x0c, 0x34, 0x99, 0x2b, 0x5a, 0xd0, + 0xfd, 0xde, 0x86, 0x5b, 0x29, 0x56, 0x57, 0xea, 0xba, 0x2c, 0x49, 0x59, 0x9e, 0xda, 0xf0, 0xc6, + 0xd9, 0xcd, 0xd3, 0xd2, 0xdf, 0x49, 0x0c, 0x87, 0x57, 0xfb, 0x06, 0xfa, 0xd5, 0x82, 0x5b, 0x59, + 0x86, 0x5d, 0x7e, 0x45, 0xfe, 0xef, 0x68, 0xfd, 0xc9, 0x86, 0xdb, 0xe7, 0x24, 0xc0, 0xab, 0xd7, + 0xda, 0x4b, 0xb3, 0xfc, 0x8f, 0x36, 0x94, 0x27, 0x93, 0xe0, 0xba, 0x3c, 0x67, 0xe5, 0xf9, 0xd6, + 0x86, 0x1b, 0x26, 0x0d, 0xf4, 0x9c, 0xf4, 0x15, 0xb9, 0xd2, 0x61, 0xd0, 0x5c, 0x3f, 0xfe, 0xa3, + 0x92, 0x3b, 0x1e, 0x57, 0xac, 0x93, 0x71, 0xc5, 0x7a, 0x36, 0xae, 0x58, 0xbf, 0x8f, 0x2b, 0xd6, + 0xd3, 0xd3, 0x4a, 0xee, 0xe4, 0xb4, 0x92, 0x7b, 0x76, 0x5a, 0xc9, 0x7d, 0x59, 0x48, 0x35, 0xf7, + 0x16, 0xcc, 0x8f, 0x0c, 0x77, 0xff, 0x0e, 0x00, 0x00, 0xff, 0xff, 0x4e, 0xf3, 0x41, 0x1e, 0xe0, + 0x10, 0x00, 0x00, } func (m *CommonSQLExecDetails) Marshal() (dAtA []byte, err error) { @@ -816,7 +1041,7 @@ func (m *LargeRow) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } -func (m *SlowQueryInternal) Marshal() (dAtA []byte, err error) { +func (m *CommonTxnRowsLimitDetails) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -826,18 +1051,80 @@ func (m *SlowQueryInternal) Marshal() (dAtA []byte, err error) { return dAtA[:n], nil } -func (m *SlowQueryInternal) MarshalTo(dAtA []byte) (int, error) { +func (m *CommonTxnRowsLimitDetails) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *SlowQueryInternal) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *CommonTxnRowsLimitDetails) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.IsRead { + i-- + if m.IsRead { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x28 + } + if m.ViolatesTxnRowsLimitErr { + i-- + if m.ViolatesTxnRowsLimitErr { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x20 + } + if m.Limit != 0 { + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(m.Limit)) + i-- + dAtA[i] = 0x18 + } + if len(m.SessionID) > 0 { + i -= len(m.SessionID) + copy(dAtA[i:], m.SessionID) + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(len(m.SessionID))) + i-- + dAtA[i] = 0x12 + } + if len(m.TxnID) > 0 { + i -= len(m.TxnID) + copy(dAtA[i:], m.TxnID) + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(len(m.TxnID))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *TxnRowsWrittenLimit) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TxnRowsWrittenLimit) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TxnRowsWrittenLimit) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int _ = l { - size, err := m.CommonSQLExecDetails.MarshalToSizedBuffer(dAtA[:i]) + size, err := m.CommonTxnRowsLimitDetails.MarshalToSizedBuffer(dAtA[:i]) if err != nil { return 0, err } @@ -869,7 +1156,7 @@ func (m *SlowQueryInternal) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } -func (m *LargeRowInternal) Marshal() (dAtA []byte, err error) { +func (m *TxnRowsReadLimit) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -879,18 +1166,28 @@ func (m *LargeRowInternal) Marshal() (dAtA []byte, err error) { return dAtA[:n], nil } -func (m *LargeRowInternal) MarshalTo(dAtA []byte) (int, error) { +func (m *TxnRowsReadLimit) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *LargeRowInternal) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *TxnRowsReadLimit) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int _ = l { - size, err := m.CommonLargeRowDetails.MarshalToSizedBuffer(dAtA[:i]) + size, err := m.CommonTxnRowsLimitDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + { + size, err := m.CommonSQLEventDetails.MarshalToSizedBuffer(dAtA[:i]) if err != nil { return 0, err } @@ -912,7 +1209,7 @@ func (m *LargeRowInternal) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } -func (m *QueryExecute) Marshal() (dAtA []byte, err error) { +func (m *SlowQueryInternal) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -922,12 +1219,12 @@ func (m *QueryExecute) Marshal() (dAtA []byte, err error) { return dAtA[:n], nil } -func (m *QueryExecute) MarshalTo(dAtA []byte) (int, error) { +func (m *SlowQueryInternal) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *QueryExecute) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *SlowQueryInternal) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int @@ -965,66 +1262,268 @@ func (m *QueryExecute) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } -func encodeVarintSqlAuditEvents(dAtA []byte, offset int, v uint64) int { - offset -= sovSqlAuditEvents(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ +func (m *LargeRowInternal) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err } - dAtA[offset] = uint8(v) - return base + return dAtA[:n], nil } -func (m *CommonSQLExecDetails) Size() (n int) { - if m == nil { - return 0 - } + +func (m *LargeRowInternal) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *LargeRowInternal) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i var l int _ = l - l = len(m.ExecMode) - if l > 0 { - n += 1 + l + sovSqlAuditEvents(uint64(l)) - } - if m.NumRows != 0 { - n += 1 + sovSqlAuditEvents(uint64(m.NumRows)) - } - l = len(m.SQLSTATE) - if l > 0 { - n += 1 + l + sovSqlAuditEvents(uint64(l)) - } - l = len(m.ErrorText) - if l > 0 { - n += 1 + l + sovSqlAuditEvents(uint64(l)) - } - if m.Age != 0 { - n += 5 - } - if m.NumRetries != 0 { - n += 1 + sovSqlAuditEvents(uint64(m.NumRetries)) - } - if m.FullTableScan { - n += 2 - } - if m.FullIndexScan { - n += 2 + { + size, err := m.CommonLargeRowDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) } - if m.TxnCounter != 0 { - n += 1 + sovSqlAuditEvents(uint64(m.TxnCounter)) + i-- + dAtA[i] = 0x12 + { + size, err := m.CommonEventDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) } - return n + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil } -func (m *SensitiveTableAccess) Size() (n int) { - if m == nil { - return 0 +func (m *TxnRowsWrittenLimitInternal) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err } + return dAtA[:n], nil +} + +func (m *TxnRowsWrittenLimitInternal) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TxnRowsWrittenLimitInternal) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i var l int _ = l - l = m.CommonEventDetails.Size() - n += 1 + l + sovSqlAuditEvents(uint64(l)) - l = m.CommonSQLEventDetails.Size() - n += 1 + l + sovSqlAuditEvents(uint64(l)) + { + size, err := m.CommonTxnRowsLimitDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + { + size, err := m.CommonSQLEventDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.CommonEventDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *TxnRowsReadLimitInternal) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TxnRowsReadLimitInternal) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TxnRowsReadLimitInternal) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.CommonTxnRowsLimitDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + { + size, err := m.CommonSQLEventDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.CommonEventDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *QueryExecute) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *QueryExecute) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryExecute) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.CommonSQLExecDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + { + size, err := m.CommonSQLEventDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + { + size, err := m.CommonEventDetails.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintSqlAuditEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func encodeVarintSqlAuditEvents(dAtA []byte, offset int, v uint64) int { + offset -= sovSqlAuditEvents(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *CommonSQLExecDetails) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.ExecMode) + if l > 0 { + n += 1 + l + sovSqlAuditEvents(uint64(l)) + } + if m.NumRows != 0 { + n += 1 + sovSqlAuditEvents(uint64(m.NumRows)) + } + l = len(m.SQLSTATE) + if l > 0 { + n += 1 + l + sovSqlAuditEvents(uint64(l)) + } + l = len(m.ErrorText) + if l > 0 { + n += 1 + l + sovSqlAuditEvents(uint64(l)) + } + if m.Age != 0 { + n += 5 + } + if m.NumRetries != 0 { + n += 1 + sovSqlAuditEvents(uint64(m.NumRetries)) + } + if m.FullTableScan { + n += 2 + } + if m.FullIndexScan { + n += 2 + } + if m.TxnCounter != 0 { + n += 1 + sovSqlAuditEvents(uint64(m.TxnCounter)) + } + return n +} + +func (m *SensitiveTableAccess) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.CommonEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonSQLEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) l = m.CommonSQLExecDetails.Size() n += 1 + l + sovSqlAuditEvents(uint64(l)) l = len(m.TableName) @@ -1106,6 +1605,62 @@ func (m *LargeRow) Size() (n int) { return n } +func (m *CommonTxnRowsLimitDetails) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.TxnID) + if l > 0 { + n += 1 + l + sovSqlAuditEvents(uint64(l)) + } + l = len(m.SessionID) + if l > 0 { + n += 1 + l + sovSqlAuditEvents(uint64(l)) + } + if m.Limit != 0 { + n += 1 + sovSqlAuditEvents(uint64(m.Limit)) + } + if m.ViolatesTxnRowsLimitErr { + n += 2 + } + if m.IsRead { + n += 2 + } + return n +} + +func (m *TxnRowsWrittenLimit) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.CommonEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonSQLEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonTxnRowsLimitDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + return n +} + +func (m *TxnRowsReadLimit) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.CommonEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonSQLEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonTxnRowsLimitDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + return n +} + func (m *SlowQueryInternal) Size() (n int) { if m == nil { return 0 @@ -1125,37 +1680,832 @@ func (m *LargeRowInternal) Size() (n int) { if m == nil { return 0 } - var l int - _ = l - l = m.CommonEventDetails.Size() - n += 1 + l + sovSqlAuditEvents(uint64(l)) - l = m.CommonLargeRowDetails.Size() - n += 1 + l + sovSqlAuditEvents(uint64(l)) - return n -} + var l int + _ = l + l = m.CommonEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonLargeRowDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + return n +} + +func (m *TxnRowsWrittenLimitInternal) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.CommonEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonSQLEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonTxnRowsLimitDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + return n +} + +func (m *TxnRowsReadLimitInternal) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.CommonEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonSQLEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonTxnRowsLimitDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + return n +} + +func (m *QueryExecute) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.CommonEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonSQLEventDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + l = m.CommonSQLExecDetails.Size() + n += 1 + l + sovSqlAuditEvents(uint64(l)) + return n +} + +func sovSqlAuditEvents(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozSqlAuditEvents(x uint64) (n int) { + return sovSqlAuditEvents(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *CommonSQLExecDetails) 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 ErrIntOverflowSqlAuditEvents + } + 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: CommonSQLExecDetails: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: CommonSQLExecDetails: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ExecMode", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ExecMode = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field NumRows", wireType) + } + m.NumRows = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.NumRows |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field SQLSTATE", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.SQLSTATE = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ErrorText", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ErrorText = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 5 { + return fmt.Errorf("proto: wrong wireType = %d for field Age", wireType) + } + var v uint32 + if (iNdEx + 4) > l { + return io.ErrUnexpectedEOF + } + v = uint32(encoding_binary.LittleEndian.Uint32(dAtA[iNdEx:])) + iNdEx += 4 + m.Age = float32(math.Float32frombits(v)) + case 6: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field NumRetries", wireType) + } + m.NumRetries = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.NumRetries |= uint32(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 7: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field FullTableScan", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.FullTableScan = bool(v != 0) + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field FullIndexScan", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.FullIndexScan = bool(v != 0) + case 9: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field TxnCounter", wireType) + } + m.TxnCounter = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.TxnCounter |= uint32(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipSqlAuditEvents(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *SensitiveTableAccess) 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 ErrIntOverflowSqlAuditEvents + } + 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: SensitiveTableAccess: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: SensitiveTableAccess: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonEventDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLEventDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonSQLEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLExecDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonSQLExecDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TableName", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.TableName = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AccessMode", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AccessMode = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipSqlAuditEvents(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *AdminQuery) 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 ErrIntOverflowSqlAuditEvents + } + 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: AdminQuery: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: AdminQuery: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonEventDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLEventDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonSQLEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLExecDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonSQLExecDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipSqlAuditEvents(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *SlowQuery) 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 ErrIntOverflowSqlAuditEvents + } + 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: SlowQuery: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: SlowQuery: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonEventDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLEventDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonSQLEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLExecDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonSQLExecDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipSqlAuditEvents(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } -func (m *QueryExecute) Size() (n int) { - if m == nil { - return 0 + if iNdEx > l { + return io.ErrUnexpectedEOF } - var l int - _ = l - l = m.CommonEventDetails.Size() - n += 1 + l + sovSqlAuditEvents(uint64(l)) - l = m.CommonSQLEventDetails.Size() - n += 1 + l + sovSqlAuditEvents(uint64(l)) - l = m.CommonSQLExecDetails.Size() - n += 1 + l + sovSqlAuditEvents(uint64(l)) - return n -} - -func sovSqlAuditEvents(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozSqlAuditEvents(x uint64) (n int) { - return sovSqlAuditEvents(uint64((x << 1) ^ uint64((int64(x) >> 63)))) + return nil } -func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { +func (m *CommonLargeRowDetails) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -1178,17 +2528,17 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: CommonSQLExecDetails: wiretype end group for non-group") + return fmt.Errorf("proto: CommonLargeRowDetails: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: CommonSQLExecDetails: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: CommonLargeRowDetails: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ExecMode", wireType) + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field RowSize", wireType) } - var stringLen uint64 + m.RowSize = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1198,29 +2548,16 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + m.RowSize |= uint32(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthSqlAuditEvents - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSqlAuditEvents - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ExecMode = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex case 2: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NumRows", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field TableID", wireType) } - m.NumRows = 0 + m.TableID = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1230,16 +2567,16 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.NumRows |= uint64(b&0x7F) << shift + m.TableID |= uint32(b&0x7F) << shift if b < 0x80 { break } } case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field SQLSTATE", wireType) + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field FamilyID", wireType) } - var stringLen uint64 + m.FamilyID = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1249,27 +2586,14 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + m.FamilyID |= uint32(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthSqlAuditEvents - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSqlAuditEvents - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.SQLSTATE = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex case 4: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ErrorText", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field PrimaryKey", wireType) } var stringLen uint64 for shift := uint(0); ; shift += 7 { @@ -1297,41 +2621,11 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - m.ErrorText = string(dAtA[iNdEx:postIndex]) + m.PrimaryKey = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex case 5: - if wireType != 5 { - return fmt.Errorf("proto: wrong wireType = %d for field Age", wireType) - } - var v uint32 - if (iNdEx + 4) > l { - return io.ErrUnexpectedEOF - } - v = uint32(encoding_binary.LittleEndian.Uint32(dAtA[iNdEx:])) - iNdEx += 4 - m.Age = float32(math.Float32frombits(v)) - case 6: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NumRetries", wireType) - } - m.NumRetries = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSqlAuditEvents - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.NumRetries |= uint32(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 7: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field FullTableScan", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field ViolatesMaxRowSizeErr", wireType) } var v int for shift := uint(0); ; shift += 7 { @@ -1348,12 +2642,62 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { break } } - m.FullTableScan = bool(v != 0) - case 8: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field FullIndexScan", wireType) + m.ViolatesMaxRowSizeErr = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipSqlAuditEvents(dAtA[iNdEx:]) + if err != nil { + return err } - var v int + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *LargeRow) 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 ErrIntOverflowSqlAuditEvents + } + 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: LargeRow: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: LargeRow: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonEventDetails", wireType) + } + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1363,17 +2707,30 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - v |= int(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } - m.FullIndexScan = bool(v != 0) - case 9: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field TxnCounter", wireType) + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents } - m.TxnCounter = 0 + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonLargeRowDetails", wireType) + } + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1383,11 +2740,25 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.TxnCounter |= uint32(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonLargeRowDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipSqlAuditEvents(dAtA[iNdEx:]) @@ -1409,7 +2780,7 @@ func (m *CommonSQLExecDetails) Unmarshal(dAtA []byte) error { } return nil } -func (m *SensitiveTableAccess) Unmarshal(dAtA []byte) error { +func (m *CommonTxnRowsLimitDetails) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -1432,17 +2803,17 @@ func (m *SensitiveTableAccess) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: SensitiveTableAccess: wiretype end group for non-group") + return fmt.Errorf("proto: CommonTxnRowsLimitDetails: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: SensitiveTableAccess: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: CommonTxnRowsLimitDetails: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field CommonEventDetails", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field TxnID", wireType) } - var msglen int + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1452,30 +2823,29 @@ func (m *SensitiveTableAccess) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + intStringLen := int(stringLen) + if intStringLen < 0 { return ErrInvalidLengthSqlAuditEvents } - postIndex := iNdEx + msglen + postIndex := iNdEx + intStringLen if postIndex < 0 { return ErrInvalidLengthSqlAuditEvents } if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.CommonEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } + m.TxnID = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLEventDetails", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field SessionID", wireType) } - var msglen int + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1485,30 +2855,29 @@ func (m *SensitiveTableAccess) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + intStringLen := int(stringLen) + if intStringLen < 0 { return ErrInvalidLengthSqlAuditEvents } - postIndex := iNdEx + msglen + postIndex := iNdEx + intStringLen if postIndex < 0 { return ErrInvalidLengthSqlAuditEvents } if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.CommonSQLEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } + m.SessionID = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLExecDetails", wireType) + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Limit", wireType) } - var msglen int + m.Limit = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1518,30 +2887,16 @@ func (m *SensitiveTableAccess) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + m.Limit |= int64(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { - return ErrInvalidLengthSqlAuditEvents - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthSqlAuditEvents - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.CommonSQLExecDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TableName", wireType) + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ViolatesTxnRowsLimitErr", wireType) } - var stringLen uint64 + var v int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1551,29 +2906,17 @@ func (m *SensitiveTableAccess) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + v |= int(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthSqlAuditEvents - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSqlAuditEvents - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.TableName = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex + m.ViolatesTxnRowsLimitErr = bool(v != 0) case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AccessMode", wireType) + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field IsRead", wireType) } - var stringLen uint64 + var v int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1583,24 +2926,12 @@ func (m *SensitiveTableAccess) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + v |= int(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthSqlAuditEvents - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSqlAuditEvents - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AccessMode = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex + m.IsRead = bool(v != 0) default: iNdEx = preIndex skippy, err := skipSqlAuditEvents(dAtA[iNdEx:]) @@ -1622,7 +2953,7 @@ func (m *SensitiveTableAccess) Unmarshal(dAtA []byte) error { } return nil } -func (m *AdminQuery) Unmarshal(dAtA []byte) error { +func (m *TxnRowsWrittenLimit) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -1645,10 +2976,10 @@ func (m *AdminQuery) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: AdminQuery: wiretype end group for non-group") + return fmt.Errorf("proto: TxnRowsWrittenLimit: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: AdminQuery: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: TxnRowsWrittenLimit: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -1719,7 +3050,7 @@ func (m *AdminQuery) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 3: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLExecDetails", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field CommonTxnRowsLimitDetails", wireType) } var msglen int for shift := uint(0); ; shift += 7 { @@ -1746,7 +3077,7 @@ func (m *AdminQuery) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.CommonSQLExecDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + if err := m.CommonTxnRowsLimitDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } iNdEx = postIndex @@ -1771,7 +3102,7 @@ func (m *AdminQuery) Unmarshal(dAtA []byte) error { } return nil } -func (m *SlowQuery) Unmarshal(dAtA []byte) error { +func (m *TxnRowsReadLimit) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -1794,10 +3125,10 @@ func (m *SlowQuery) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: SlowQuery: wiretype end group for non-group") + return fmt.Errorf("proto: TxnRowsReadLimit: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: SlowQuery: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: TxnRowsReadLimit: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -1868,7 +3199,7 @@ func (m *SlowQuery) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 3: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLExecDetails", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field CommonTxnRowsLimitDetails", wireType) } var msglen int for shift := uint(0); ; shift += 7 { @@ -1895,7 +3226,7 @@ func (m *SlowQuery) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.CommonSQLExecDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + if err := m.CommonTxnRowsLimitDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } iNdEx = postIndex @@ -1920,7 +3251,7 @@ func (m *SlowQuery) Unmarshal(dAtA []byte) error { } return nil } -func (m *CommonLargeRowDetails) Unmarshal(dAtA []byte) error { +func (m *SlowQueryInternal) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -1943,17 +3274,17 @@ func (m *CommonLargeRowDetails) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: CommonLargeRowDetails: wiretype end group for non-group") + return fmt.Errorf("proto: SlowQueryInternal: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: CommonLargeRowDetails: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: SlowQueryInternal: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field RowSize", wireType) + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonEventDetails", wireType) } - m.RowSize = 0 + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -1963,54 +3294,30 @@ func (m *CommonLargeRowDetails) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.RowSize |= uint32(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field TableID", wireType) + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents } - m.TableID = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSqlAuditEvents - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.TableID |= uint32(b&0x7F) << shift - if b < 0x80 { - break - } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents } - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field FamilyID", wireType) + if postIndex > l { + return io.ErrUnexpectedEOF } - m.FamilyID = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSqlAuditEvents - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.FamilyID |= uint32(b&0x7F) << shift - if b < 0x80 { - break - } + if err := m.CommonEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err } - case 4: + iNdEx = postIndex + case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PrimaryKey", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLEventDetails", wireType) } - var stringLen uint64 + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -2020,29 +3327,30 @@ func (m *CommonLargeRowDetails) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { + if msglen < 0 { return ErrInvalidLengthSqlAuditEvents } - postIndex := iNdEx + intStringLen + postIndex := iNdEx + msglen if postIndex < 0 { return ErrInvalidLengthSqlAuditEvents } if postIndex > l { return io.ErrUnexpectedEOF } - m.PrimaryKey = string(dAtA[iNdEx:postIndex]) + if err := m.CommonSQLEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } iNdEx = postIndex - case 5: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field ViolatesMaxRowSizeErr", wireType) + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLExecDetails", wireType) } - var v int + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowSqlAuditEvents @@ -2052,12 +3360,25 @@ func (m *CommonLargeRowDetails) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - v |= int(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } - m.ViolatesMaxRowSizeErr = bool(v != 0) + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonSQLExecDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipSqlAuditEvents(dAtA[iNdEx:]) @@ -2079,7 +3400,7 @@ func (m *CommonLargeRowDetails) Unmarshal(dAtA []byte) error { } return nil } -func (m *LargeRow) Unmarshal(dAtA []byte) error { +func (m *LargeRowInternal) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -2102,10 +3423,10 @@ func (m *LargeRow) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: LargeRow: wiretype end group for non-group") + return fmt.Errorf("proto: LargeRowInternal: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: LargeRow: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: LargeRowInternal: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -2195,7 +3516,7 @@ func (m *LargeRow) Unmarshal(dAtA []byte) error { } return nil } -func (m *SlowQueryInternal) Unmarshal(dAtA []byte) error { +func (m *TxnRowsWrittenLimitInternal) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -2218,10 +3539,10 @@ func (m *SlowQueryInternal) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: SlowQueryInternal: wiretype end group for non-group") + return fmt.Errorf("proto: TxnRowsWrittenLimitInternal: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: SlowQueryInternal: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: TxnRowsWrittenLimitInternal: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -2292,7 +3613,7 @@ func (m *SlowQueryInternal) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 3: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLExecDetails", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field CommonTxnRowsLimitDetails", wireType) } var msglen int for shift := uint(0); ; shift += 7 { @@ -2319,7 +3640,7 @@ func (m *SlowQueryInternal) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.CommonSQLExecDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + if err := m.CommonTxnRowsLimitDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } iNdEx = postIndex @@ -2344,7 +3665,7 @@ func (m *SlowQueryInternal) Unmarshal(dAtA []byte) error { } return nil } -func (m *LargeRowInternal) Unmarshal(dAtA []byte) error { +func (m *TxnRowsReadLimitInternal) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -2367,10 +3688,10 @@ func (m *LargeRowInternal) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: LargeRowInternal: wiretype end group for non-group") + return fmt.Errorf("proto: TxnRowsReadLimitInternal: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: LargeRowInternal: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: TxnRowsReadLimitInternal: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -2408,7 +3729,7 @@ func (m *LargeRowInternal) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field CommonLargeRowDetails", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field CommonSQLEventDetails", wireType) } var msglen int for shift := uint(0); ; shift += 7 { @@ -2435,7 +3756,40 @@ func (m *LargeRowInternal) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.CommonLargeRowDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + if err := m.CommonSQLEventDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field CommonTxnRowsLimitDetails", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowSqlAuditEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthSqlAuditEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthSqlAuditEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.CommonTxnRowsLimitDetails.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } iNdEx = postIndex diff --git a/pkg/util/log/eventpb/sql_audit_events.proto b/pkg/util/log/eventpb/sql_audit_events.proto index f5580b114990..53f799f5fd35 100644 --- a/pkg/util/log/eventpb/sql_audit_events.proto +++ b/pkg/util/log/eventpb/sql_audit_events.proto @@ -121,6 +121,45 @@ message LargeRow { CommonLargeRowDetails row = 2 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; } +// CommonTxnRowsLimitDetails contains the fields common to all messages related +// to reaching the limits on the number of rows written/read by a transaction. +message CommonTxnRowsLimitDetails { + // TxnID is the ID of the transaction that hit the row count limit. + string txn_id = 1 [(gogoproto.customname) = "TxnID", (gogoproto.jsontag) = ",omitempty", (gogoproto.moretags) = "redact:\"nonsensitive\""]; + // SessionID is the ID of the session that initiated the transaction. + string session_id = 2 [(gogoproto.customname) = "SessionID", (gogoproto.jsontag) = ",omitempty", (gogoproto.moretags) = "redact:\"nonsensitive\""]; + // Limit indicates the value of the transaction row count limit that was + // reached. + int64 limit = 3 [(gogoproto.jsontag) = ",omitempty"]; + // ViolatesTxnRowsLimitErr if true indicates that + // 'transaction_rows_{written|read}_err' limit is violated. + bool violates_txn_rows_limit_err = 4 [(gogoproto.jsontag) = ",omitempty"]; + // IsRead if true indicates that the "rows read" limit is reached and the + // "rows written" limit otherwise. + bool is_read = 5 [(gogoproto.jsontag) = ",omitempty"]; +} + +// TxnRowsWrittenLimit is recorded when a transaction tries to write more rows +// than cluster setting `sql.defaults.transaction_rows_written_log`. There will +// only be a single record for a single transaction (unless it is retried) even +// if there are more mutation statements within the transaction that haven't +// been executed yet. +message TxnRowsWrittenLimit { + CommonEventDetails common = 1 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; + CommonSQLEventDetails sql = 2 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; + CommonTxnRowsLimitDetails info = 3 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; +} + +// TxnRowsReadLimit is recorded when a transaction tries to read more rows than +// cluster setting `sql.defaults.transaction_rows_read_log`. There will only be +// a single record for a single transaction (unless it is retried) even if there +// are more statement within the transaction that haven't been executed yet. +message TxnRowsReadLimit { + CommonEventDetails common = 1 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; + CommonSQLEventDetails sql = 2 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; + CommonTxnRowsLimitDetails info = 3 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; +} + // Category: SQL Slow Query Log (Internal) // Channel: SQL_INTERNAL_PERF // @@ -151,6 +190,29 @@ message LargeRowInternal { CommonLargeRowDetails row = 2 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; } +// TxnRowsWrittenLimitInternal is recorded when an internal transaction tries to +// write more rows than cluster setting +// `sql.defaults.transaction_rows_written_log` or +// `sql.defaults.transaction_rows_written_err`. There will only be a single +// record for a single transaction (unless it is retried) even if there are more +// mutation statements within the transaction that haven't been executed yet. +message TxnRowsWrittenLimitInternal { + CommonEventDetails common = 1 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; + CommonSQLEventDetails sql = 2 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; + CommonTxnRowsLimitDetails info = 3 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; +} + +// TxnRowsReadLimitInternal is recorded when an internal transaction tries to +// read more rows than cluster setting `sql.defaults.transaction_rows_read_log` +// or `sql.defaults.transaction_rows_read_err`. There will only be a single +// record for a single transaction (unless it is retried) even if there are more +// mutation statements within the transaction that haven't been executed yet. +message TxnRowsReadLimitInternal { + CommonEventDetails common = 1 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; + CommonSQLEventDetails sql = 2 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; + CommonTxnRowsLimitDetails info = 3 [(gogoproto.nullable) = false, (gogoproto.jsontag) = "", (gogoproto.embed) = true]; +} + // Category: SQL Execution Log // Channel: SQL_EXEC //