You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

hook.go 2.1 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. package exec
  18. import (
  19. "context"
  20. "database/sql/driver"
  21. "github.com/seata/seata-go/pkg/datasource/sql/types"
  22. )
  23. var (
  24. commonHook = make([]SQLHook, 0, 4)
  25. // todo support distinguish between different db type
  26. hookSolts = map[types.SQLType][]SQLHook{}
  27. )
  28. // RegisCommonHook not goroutine safe
  29. func RegisCommonHook(hook SQLHook) {
  30. commonHook = append(commonHook, hook)
  31. }
  32. func CleanCommonHook() {
  33. commonHook = make([]SQLHook, 0, 4)
  34. }
  35. // RegisHook not goroutine safe
  36. func RegisHook(hook SQLHook) {
  37. _, ok := hookSolts[hook.Type()]
  38. if !ok {
  39. hookSolts[hook.Type()] = make([]SQLHook, 0, 4)
  40. }
  41. hookSolts[hook.Type()] = append(hookSolts[hook.Type()], hook)
  42. }
  43. // ExecContext
  44. type ExecContext struct {
  45. TxCtx *types.TransactionContext
  46. Query string
  47. NamedValues []driver.NamedValue
  48. Values []driver.Value
  49. // metaData
  50. MetaData types.TableMeta
  51. Conn driver.Conn
  52. }
  53. // SQLHook SQL execution front and back interceptor
  54. // case 1. Used to intercept SQL to achieve the generation of front and rear mirrors
  55. // case 2. Burning point to report
  56. // case 3. SQL black and white list
  57. type SQLHook interface {
  58. Type() types.SQLType
  59. // Before
  60. Before(ctx context.Context, execCtx *ExecContext) error
  61. // After
  62. After(ctx context.Context, execCtx *ExecContext) error
  63. }