whatap-python 1.7.3__tar.gz → 1.7.4__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of whatap-python might be problematic. Click here for more details.

Files changed (129) hide show
  1. {whatap_python-1.7.3 → whatap_python-1.7.4}/PKG-INFO +1 -1
  2. whatap_python-1.7.4/whatap/build.py +4 -0
  3. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/amqp_pika.py +21 -12
  4. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/database_mongo.py +1 -1
  5. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/database_redis.py +38 -19
  6. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/database_toolkit.py +1 -1
  7. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap_python.egg-info/PKG-INFO +1 -1
  8. whatap_python-1.7.3/whatap/build.py +0 -4
  9. {whatap_python-1.7.3 → whatap_python-1.7.4}/README.md +0 -0
  10. {whatap_python-1.7.3 → whatap_python-1.7.4}/setup.cfg +0 -0
  11. {whatap_python-1.7.3 → whatap_python-1.7.4}/setup.py +0 -0
  12. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/LICENSE +0 -0
  13. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/README.rst +0 -0
  14. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/__init__.py +0 -0
  15. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/__main__.py +0 -0
  16. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/agent/darwin/amd64/whatap_python +0 -0
  17. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/agent/darwin/arm64/whatap_python +0 -0
  18. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/agent/linux/amd64/whatap_python +0 -0
  19. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/agent/linux/arm64/whatap_python +0 -0
  20. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/bootstrap/__init__.py +0 -0
  21. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/bootstrap/sitecustomize.py +0 -0
  22. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/conf/__init__.py +0 -0
  23. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/conf/configuration.py +0 -0
  24. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/conf/configure.py +0 -0
  25. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/conf/license.py +0 -0
  26. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/control/__init__.py +0 -0
  27. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/counter/__init__.py +0 -0
  28. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/counter/counter_manager.py +0 -0
  29. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/counter/tasks/__init__.py +0 -0
  30. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/counter/tasks/openfiledescriptor.py +0 -0
  31. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/io/__init__.py +0 -0
  32. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/io/data_inputx.py +0 -0
  33. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/io/data_outputx.py +0 -0
  34. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/net/__init__.py +0 -0
  35. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/net/async_sender.py +0 -0
  36. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/net/packet_enum.py +0 -0
  37. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/net/packet_type_enum.py +0 -0
  38. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/net/param_def.py +0 -0
  39. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/net/stackhelper.py +0 -0
  40. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/net/udp_session.py +0 -0
  41. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/net/udp_thread.py +0 -0
  42. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/pack/__init__.py +0 -0
  43. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/pack/logSinkPack.py +0 -0
  44. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/pack/pack.py +0 -0
  45. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/pack/pack_enum.py +0 -0
  46. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/pack/tagCountPack.py +0 -0
  47. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/scripts/__init__.py +0 -0
  48. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/__init__.py +0 -0
  49. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/__init__.py +0 -0
  50. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/amqp_kombu.py +0 -0
  51. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_bottle.py +0 -0
  52. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_celery.py +0 -0
  53. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_cherrypy.py +0 -0
  54. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_django.py +0 -0
  55. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_django_asgi.py +0 -0
  56. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_django_py3.py +0 -0
  57. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_fastapi.py +0 -0
  58. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_flask.py +0 -0
  59. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_frappe.py +0 -0
  60. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_graphql.py +0 -0
  61. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_nameko.py +0 -0
  62. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_tornado.py +0 -0
  63. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/application_wsgi.py +0 -0
  64. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/database_cxoracle.py +0 -0
  65. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/database_mysql.py +0 -0
  66. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/database_postgresql.py +0 -0
  67. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/email_smtp.py +0 -0
  68. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/httpc_django.py +0 -0
  69. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/httpc_httplib.py +0 -0
  70. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/httpc_requests.py +0 -0
  71. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/httpc_urllib3.py +0 -0
  72. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/logging.py +0 -0
  73. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/mod/plugin.py +0 -0
  74. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/simple_trace_context.py +0 -0
  75. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/trace_context.py +0 -0
  76. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/trace_context_manager.py +0 -0
  77. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/trace_import.py +0 -0
  78. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/trace/trace_module_definition.py +0 -0
  79. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/__init__.py +0 -0
  80. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/bit_util.py +0 -0
  81. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/cardinality/__init__.py +0 -0
  82. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/cardinality/hyperloglog.py +0 -0
  83. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/cardinality/murmurhash.py +0 -0
  84. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/cardinality/registerset.py +0 -0
  85. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/compare_util.py +0 -0
  86. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/date_util.py +0 -0
  87. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/debug_util.py +0 -0
  88. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/escape_literal_sql.py +0 -0
  89. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/hash_util.py +0 -0
  90. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/hexa32.py +0 -0
  91. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/int_set.py +0 -0
  92. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/ip_util.py +0 -0
  93. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/keygen.py +0 -0
  94. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/linked_list.py +0 -0
  95. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/linked_map.py +0 -0
  96. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/metering_util.py +0 -0
  97. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/request_double_queue.py +0 -0
  98. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/request_queue.py +0 -0
  99. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/string_util.py +0 -0
  100. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/throttle_util.py +0 -0
  101. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/util/userid_util.py +0 -0
  102. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/__init__.py +0 -0
  103. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/blob_value.py +0 -0
  104. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/boolean_value.py +0 -0
  105. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/decimal_value.py +0 -0
  106. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/double_summary.py +0 -0
  107. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/double_value.py +0 -0
  108. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/float_array.py +0 -0
  109. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/float_value.py +0 -0
  110. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/int_array.py +0 -0
  111. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/ip4_value.py +0 -0
  112. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/list_value.py +0 -0
  113. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/long_array.py +0 -0
  114. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/long_summary.py +0 -0
  115. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/map_value.py +0 -0
  116. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/null_value.py +0 -0
  117. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/number_value.py +0 -0
  118. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/summary_value.py +0 -0
  119. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/text_array.py +0 -0
  120. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/text_hash_value.py +0 -0
  121. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/text_value.py +0 -0
  122. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/value.py +0 -0
  123. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/value/value_enum.py +0 -0
  124. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap/whatap.conf +0 -0
  125. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap_python.egg-info/SOURCES.txt +0 -0
  126. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap_python.egg-info/dependency_links.txt +0 -0
  127. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap_python.egg-info/entry_points.txt +0 -0
  128. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap_python.egg-info/not-zip-safe +0 -0
  129. {whatap_python-1.7.3 → whatap_python-1.7.4}/whatap_python.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: whatap-python
3
- Version: 1.7.3
3
+ Version: 1.7.4
4
4
  Summary: Monitoring and Profiling Service
5
5
  Home-page: https://www.whatap.io
6
6
  Author: whatap
@@ -0,0 +1,4 @@
1
+ app = 'Python'
2
+ name = 'whatap-python'
3
+ version = '1.7.4'
4
+ release_date = '20250120'
@@ -7,8 +7,8 @@ import whatap.net.async_sender as async_sender
7
7
  from whatap.net.packet_type_enum import PacketTypeEnum
8
8
  from whatap.util.date_util import DateUtil
9
9
 
10
- def parseConnection(conn):
11
10
 
11
+ def parseConnection(conn):
12
12
  connstr = ''
13
13
  if conn.host:
14
14
  connstr += conn.host
@@ -16,6 +16,7 @@ def parseConnection(conn):
16
16
  connstr += "/" + conn.virtual_host
17
17
  return connstr
18
18
 
19
+
19
20
  def intercept_publish(fn, *args, **kwargs):
20
21
  ctx = TraceContextManager.getLocalContext()
21
22
 
@@ -30,22 +31,30 @@ def intercept_publish(fn, *args, **kwargs):
30
31
  ctx.active_dbc = text
31
32
  ctx.lctx['dbc'] = text
32
33
 
33
- ctx.active_dbc = 0
34
- ctx.db_opening = True
35
- ctx.elapsed = DateUtil.nowSystem() - start_time
36
- datas = [' ', ' ', 'MQ SESSION INFO: ' + text]
37
- async_sender.send_packet(PacketTypeEnum.TX_MSG, ctx, datas)
34
+ try:
35
+ result = fn(*args, **kwargs)
36
+
37
+ ctx.active_dbc = 0
38
+ ctx.db_opening = True
39
+ ctx.elapsed = DateUtil.nowSystem() - start_time
40
+ datas = [' ', ' ', 'MQ SESSION INFO: ' + text]
41
+ async_sender.send_packet(PacketTypeEnum.TX_MSG, ctx, datas)
42
+
43
+ return result
44
+ except Exception as e:
45
+ ctx.active_dbc = 0
46
+ ctx.db_opening = False
47
+ ctx.elapsed = DateUtil.nowSystem() - start_time
48
+ raise e
49
+
38
50
 
39
51
  def instrument_pika(module):
40
52
  def wrapper(fn):
41
53
  @trace_handler(fn)
42
54
  def trace(*args, **kwargs):
43
- callback = intercept_publish(fn, *args, **kwargs)
44
- return callback
45
-
55
+ return intercept_publish(fn, *args, **kwargs)
56
+
46
57
  return trace
47
58
 
48
59
  if hasattr(module, 'Channel') and hasattr(module.Channel, 'basic_publish'):
49
- module.Channel.basic_publish = wrapper(module.Channel.basic_publish)
50
-
51
-
60
+ module.Channel.basic_publish = wrapper(module.Channel.basic_publish)
@@ -70,7 +70,7 @@ class WhatapMongoCmdEventListener(pymongo.monitoring.CommandListener):
70
70
  query +=' query: {}'.format(ctx.active_sqlhash)
71
71
 
72
72
  ctx.db_opening = False
73
- datas = [ctx.lctx.get('dbc', ''), query]
73
+ datas = [ctx.lctx.get('dbc', ''), query, 0]
74
74
  ctx.elapsed = int(event.duration_micros / 1000)
75
75
  async_sender.send_packet(PacketTypeEnum.TX_SQL, ctx,
76
76
  datas)
@@ -1,23 +1,32 @@
1
1
  from whatap.trace import get_dict
2
- from whatap.trace.mod.application_wsgi import trace_handler, \
3
- interceptor_step_error
2
+ from whatap.trace.mod.application_wsgi import trace_handler, interceptor_step_error
4
3
  from whatap.trace.trace_context_manager import TraceContextManager
5
4
  import whatap.net.async_sender as async_sender
6
5
  from whatap.net.packet_type_enum import PacketTypeEnum
7
6
  from whatap.util.date_util import DateUtil
8
7
  import numbers
9
8
 
9
+ _current_command = None
10
+
11
+
10
12
  def intercept_send_command(fn, instance, *args, **kwargs):
13
+ global _current_command
14
+ command = str(args[0]).upper() if args else None
15
+ _current_command = command
16
+
17
+ if command not in {'SET', 'GET', 'DEL', 'HSET', 'HGET'}:
18
+ return fn(instance, *args, **kwargs)
19
+
11
20
  ctx = TraceContextManager.getLocalContext()
12
21
  if not ctx:
13
-
14
22
  return fn(instance, *args, **kwargs)
23
+
15
24
  start_time = DateUtil.nowSystem()
16
25
  ctx.start_time = start_time
17
26
 
18
27
  port_or_path = getattr(instance, 'port', getattr(instance, 'path', None))
19
28
  text = 'redis://'
20
- text += getattr(instance, 'host','localhost')
29
+ text += getattr(instance, 'host', 'localhost')
21
30
  text += ':{}'.format(port_or_path)
22
31
  text += '/'
23
32
  text += str(getattr(instance, 'db', 0))
@@ -29,8 +38,8 @@ def intercept_send_command(fn, instance, *args, **kwargs):
29
38
  datas = [text]
30
39
  ctx.elapsed = DateUtil.nowSystem() - start_time
31
40
  async_sender.send_packet(PacketTypeEnum.TX_DB_CONN, ctx, datas)
32
- query = " ".join([ str(arg)[:20] for arg in args])
33
-
41
+ query = f"{command} " + " ".join([str(arg)[:20] for arg in args[1:]])
42
+
34
43
  start_time = DateUtil.nowSystem()
35
44
  ctx.start_time = start_time
36
45
  ctx.active_sqlhash = query
@@ -42,26 +51,29 @@ def intercept_send_command(fn, instance, *args, **kwargs):
42
51
  interceptor_step_error(e)
43
52
  finally:
44
53
  ctx.db_opening = False
45
- datas = [ctx.lctx.get('dbc', ''), query]
54
+ datas = [ctx.lctx.get('dbc', ''), query, 0]
46
55
  ctx.elapsed = DateUtil.nowSystem() - start_time
47
- async_sender.send_packet(PacketTypeEnum.TX_SQL, ctx,
48
- datas)
56
+ async_sender.send_packet(PacketTypeEnum.TX_SQL, ctx, datas)
49
57
 
50
58
 
51
59
  def interceptor_read_response(fn, *args, **kwargs):
60
+ global _current_command
61
+
62
+ if _current_command not in {'SET', 'GET', 'DEL', 'HSET', 'HGET'}:
63
+ _current_command = None
64
+ return fn(*args, **kwargs)
65
+
52
66
  ctx = TraceContextManager.getLocalContext()
53
67
  if not ctx:
68
+ _current_command = None
54
69
  return fn(*args, **kwargs)
70
+
55
71
  start_time = DateUtil.nowSystem()
56
72
  ctx.start_time = start_time
57
73
 
58
- callback = None
59
74
  try:
60
75
  callback = fn(*args, **kwargs)
61
- return callback
62
- except Exception as e:
63
- interceptor_step_error(e)
64
- finally:
76
+
65
77
  if callback:
66
78
  count = -1
67
79
  if isinstance(callback, int):
@@ -71,11 +83,15 @@ def interceptor_read_response(fn, *args, **kwargs):
71
83
 
72
84
  if count > -1:
73
85
  msg = '{0}: {1}'.format('Fetch bytes', count)
74
- datas = [ msg,' ', ' ']
86
+ datas = [msg, ' ', ' ']
75
87
  ctx.elapsed = 0
76
88
  async_sender.send_packet(PacketTypeEnum.TX_MSG, ctx, datas)
77
89
 
78
90
  ctx.active_sqlhash = 0
91
+ return callback
92
+ finally:
93
+ _current_command = None
94
+
79
95
 
80
96
  def instrument_redis_connection(module):
81
97
  def wrapper(fn):
@@ -83,11 +99,13 @@ def instrument_redis_connection(module):
83
99
  def trace(*args, **kwargs):
84
100
  callback = intercept_send_command(fn, args[0], *args[1:], **kwargs)
85
101
  return callback
86
-
102
+
87
103
  return trace
88
104
 
89
105
  if hasattr(module, 'Connection') and hasattr(module.Connection, 'send_command'):
90
- module.Connection.send_command = wrapper(module.Connection.send_command)
106
+ if not getattr(module.Connection.send_command, '_wrapped', False):
107
+ module.Connection.send_command = wrapper(module.Connection.send_command)
108
+ module.Connection.send_command._wrapped = True
91
109
 
92
110
  def wrapper(fn):
93
111
  @trace_handler(fn)
@@ -98,5 +116,6 @@ def instrument_redis_connection(module):
98
116
  return trace
99
117
 
100
118
  if hasattr(module, 'Connection') and hasattr(module.Connection, 'read_response'):
101
- module.Connection.read_response= wrapper(module.Connection.read_response)
102
-
119
+ if not getattr(module.Connection.read_response, '_wrapped', False):
120
+ module.Connection.read_response = wrapper(module.Connection.read_response)
121
+ module.Connection.read_response._wrapped = True
@@ -85,7 +85,7 @@ def instrument_sqlalchemy_engine(module):
85
85
  # print('instrument_sqlalchemy_engine 6')
86
86
  ctx = TraceContextManager.getLocalContext()
87
87
  if ctx:
88
- datas = [ctx.lctx.get('dbc', ''), query]
88
+ datas = [ctx.lctx.get('dbc', ''), query, 0]
89
89
  ctx.elapsed = DateUtil.nowSystem() - start_time
90
90
  # print('instrument_sqlalchemy_engine 6.1', datas)
91
91
  async_sender.send_packet(PacketTypeEnum.TX_SQL, ctx,
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: whatap-python
3
- Version: 1.7.3
3
+ Version: 1.7.4
4
4
  Summary: Monitoring and Profiling Service
5
5
  Home-page: https://www.whatap.io
6
6
  Author: whatap
@@ -1,4 +0,0 @@
1
- app = 'Python'
2
- name = 'whatap-python'
3
- version = '1.7.3'
4
- release_date = '20241219'
File without changes
File without changes
File without changes