prediction-market-agent-tooling 0.56.2.dev146__py3-none-any.whl → 0.56.2.dev148__py3-none-any.whl

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.
@@ -22,7 +22,6 @@ from sqlmodel import Field, Session, SQLModel, create_engine, desc, select
22
22
  from prediction_market_agent_tooling.config import APIKeys
23
23
  from prediction_market_agent_tooling.loggers import logger
24
24
  from prediction_market_agent_tooling.tools.datetime_utc import DatetimeUTC
25
- from prediction_market_agent_tooling.tools.pickle_utils import InitialiseNonPickable
26
25
  from prediction_market_agent_tooling.tools.utils import utcnow
27
26
 
28
27
  FunctionT = TypeVar("FunctionT", bound=Callable[..., Any])
@@ -91,17 +90,6 @@ def db_cache(
91
90
  return decorator
92
91
 
93
92
  api_keys = api_keys if api_keys is not None else APIKeys()
94
- wrapped_engine = InitialiseNonPickable(
95
- lambda: create_engine(
96
- api_keys.sqlalchemy_db_url.get_secret_value(),
97
- # Use custom json serializer and deserializer, because otherwise, for example `datetime` serialization would fail.
98
- json_serializer=json_serializer,
99
- json_deserializer=json_deserializer,
100
- )
101
- )
102
-
103
- if api_keys.ENABLE_CACHE:
104
- SQLModel.metadata.create_all(wrapped_engine.get_value())
105
93
 
106
94
  @wraps(func)
107
95
  def wrapper(*args: Any, **kwargs: Any) -> Any:
@@ -109,7 +97,14 @@ def db_cache(
109
97
  if not api_keys.ENABLE_CACHE:
110
98
  return func(*args, **kwargs)
111
99
 
112
- engine = wrapped_engine.get_value()
100
+ engine = create_engine(
101
+ api_keys.sqlalchemy_db_url.get_secret_value(),
102
+ # Use custom json serializer and deserializer, because otherwise, for example `datetime` serialization would fail.
103
+ json_serializer=json_serializer,
104
+ json_deserializer=json_deserializer,
105
+ pool_size=1,
106
+ )
107
+ SQLModel.metadata.create_all(engine)
113
108
 
114
109
  # Convert *args and **kwargs to a single dictionary, where we have names for arguments passed as args as well.
115
110
  signature = inspect.signature(func)
@@ -213,6 +208,7 @@ def db_cache(
213
208
  session.add(cache_entry)
214
209
  session.commit()
215
210
 
211
+ engine.dispose()
216
212
  return computed_result
217
213
 
218
214
  return cast(FunctionT, wrapper)
@@ -25,9 +25,12 @@ class RelevantNewsCacheModel(SQLModel, table=True):
25
25
  class RelevantNewsResponseCache:
26
26
  def __init__(self, sqlalchemy_db_url: str | None = None):
27
27
  self.engine = create_engine(
28
- sqlalchemy_db_url
29
- if sqlalchemy_db_url
30
- else APIKeys().sqlalchemy_db_url.get_secret_value()
28
+ (
29
+ sqlalchemy_db_url
30
+ if sqlalchemy_db_url
31
+ else APIKeys().sqlalchemy_db_url.get_secret_value()
32
+ ),
33
+ pool_size=1,
31
34
  )
32
35
  self._initialize_db()
33
36
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: prediction-market-agent-tooling
3
- Version: 0.56.2.dev146
3
+ Version: 0.56.2.dev148
4
4
  Summary: Tools to benchmark, deploy and monitor prediction market agents.
5
5
  Author: Gnosis
6
6
  Requires-Python: >=3.10,<3.12
@@ -71,7 +71,7 @@ prediction_market_agent_tooling/tools/betting_strategies/market_moving.py,sha256
71
71
  prediction_market_agent_tooling/tools/betting_strategies/minimum_bet_to_win.py,sha256=-FUSuQQgjcWSSnoFxnlAyTeilY6raJABJVM2QKkFqAY,438
72
72
  prediction_market_agent_tooling/tools/betting_strategies/stretch_bet_between.py,sha256=THMXwFlskvzbjnX_OiYtDSzI8XVFyULWfP2525_9UGc,429
73
73
  prediction_market_agent_tooling/tools/betting_strategies/utils.py,sha256=kpIb-ci67Vc1Yqqaa-_S4OUkbhWSIYog4_Iwp69HU_k,97
74
- prediction_market_agent_tooling/tools/caches/db_cache.py,sha256=x3v-ZnMpnSzmdwnzubh9oQ7ebExONXjWSFqY48CYQwc,12847
74
+ prediction_market_agent_tooling/tools/caches/db_cache.py,sha256=0VNJ190QWWN7WsS35l7KNs_VNQ2Il0kgdtC7WscdfTg,12668
75
75
  prediction_market_agent_tooling/tools/caches/inmemory_cache.py,sha256=tGHHd9HCiE_hCCtPtloHZQdDfBuiow9YsqJNYi2Tx_0,499
76
76
  prediction_market_agent_tooling/tools/contract.py,sha256=s3yo8IbXTcvAJcPfLM0_NbgaEsWwLsPmyVnOgyjq_xI,20919
77
77
  prediction_market_agent_tooling/tools/costs.py,sha256=EaAJ7v9laD4VEV3d8B44M4u3_oEO_H16jRVCdoZ93Uw,954
@@ -89,10 +89,9 @@ prediction_market_agent_tooling/tools/langfuse_.py,sha256=jI_4ROxqo41CCnWGS1vN_A
89
89
  prediction_market_agent_tooling/tools/langfuse_client_utils.py,sha256=B0PhAQyviFnVbtOCYMxYmcCn66cu9nbqAOIAZcdgiRI,5771
90
90
  prediction_market_agent_tooling/tools/omen/reality_accuracy.py,sha256=M1SF7iSW1gVlQSTskdVFTn09uPLST23YeipVIWj54io,2236
91
91
  prediction_market_agent_tooling/tools/parallelism.py,sha256=6Gou0hbjtMZrYvxjTDFUDZuxmE2nqZVbb6hkg1hF82A,1022
92
- prediction_market_agent_tooling/tools/pickle_utils.py,sha256=PUNRJGdURUnLlzbZoSCiOrikRbEC596hi--Z3q8Wt84,1144
93
92
  prediction_market_agent_tooling/tools/relevant_news_analysis/data_models.py,sha256=95l84aztFaxcRLLcRQ46yKJbIlOEuDAbIGLouyliDzA,1316
94
93
  prediction_market_agent_tooling/tools/relevant_news_analysis/relevant_news_analysis.py,sha256=CddJem7tk15NAudJDwmuL8znTycbR-YI8kTNtd3LzG8,5474
95
- prediction_market_agent_tooling/tools/relevant_news_analysis/relevant_news_cache.py,sha256=2yxtBIDyMT_6CsTpZyuIv_2dy2B9WgEOaTT1fSloBu0,3223
94
+ prediction_market_agent_tooling/tools/relevant_news_analysis/relevant_news_cache.py,sha256=Dcde74ZwoZuohhJ8gIO5GQkdAz1YrAKlvrM8CNgRqWw,3289
96
95
  prediction_market_agent_tooling/tools/safe.py,sha256=9vxGGLvSPnfy-sxUFDpBTe8omqpGXP7MzvGPp6bRxrU,5197
97
96
  prediction_market_agent_tooling/tools/singleton.py,sha256=CiIELUiI-OeS7U7eeHEt0rnVhtQGzwoUdAgn_7u_GBM,729
98
97
  prediction_market_agent_tooling/tools/streamlit_user_login.py,sha256=NXEqfjT9Lc9QtliwSGRASIz1opjQ7Btme43H4qJbzgE,3010
@@ -100,8 +99,8 @@ prediction_market_agent_tooling/tools/tavily/tavily_models.py,sha256=5ldQs1pZe6u
100
99
  prediction_market_agent_tooling/tools/tavily/tavily_search.py,sha256=Kw2mXNkMTYTEe1MBSTqhQmLoeXtgb6CkmHlcAJvhtqE,3809
101
100
  prediction_market_agent_tooling/tools/utils.py,sha256=1VvunbTmzGzpIlRukFhArreFNxJPbsg4lLtQNk0r2bY,7185
102
101
  prediction_market_agent_tooling/tools/web3_utils.py,sha256=44W8siSLNQxeib98bbwAe7V5C609NHNlUuxwuWIRDiY,11838
103
- prediction_market_agent_tooling-0.56.2.dev146.dist-info/LICENSE,sha256=6or154nLLU6bELzjh0mCreFjt0m2v72zLi3yHE0QbeE,7650
104
- prediction_market_agent_tooling-0.56.2.dev146.dist-info/METADATA,sha256=hip-pKuofFriAygKgWq5Af5ppLtNNW0oom1nnrTDqcg,8113
105
- prediction_market_agent_tooling-0.56.2.dev146.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
106
- prediction_market_agent_tooling-0.56.2.dev146.dist-info/entry_points.txt,sha256=m8PukHbeH5g0IAAmOf_1Ahm-sGAMdhSSRQmwtpmi2s8,81
107
- prediction_market_agent_tooling-0.56.2.dev146.dist-info/RECORD,,
102
+ prediction_market_agent_tooling-0.56.2.dev148.dist-info/LICENSE,sha256=6or154nLLU6bELzjh0mCreFjt0m2v72zLi3yHE0QbeE,7650
103
+ prediction_market_agent_tooling-0.56.2.dev148.dist-info/METADATA,sha256=aaL2Ayno3ldz0rbtWTW8bYvKZJ-ipo_tLGIamuCETd0,8113
104
+ prediction_market_agent_tooling-0.56.2.dev148.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
105
+ prediction_market_agent_tooling-0.56.2.dev148.dist-info/entry_points.txt,sha256=m8PukHbeH5g0IAAmOf_1Ahm-sGAMdhSSRQmwtpmi2s8,81
106
+ prediction_market_agent_tooling-0.56.2.dev148.dist-info/RECORD,,
@@ -1,31 +0,0 @@
1
- import typing as t
2
-
3
- InitialisedValue = t.TypeVar("InitialisedValue")
4
-
5
-
6
- class InitialiseNonPickable(t.Generic[InitialisedValue]):
7
- """
8
- Use this class to wrap values that you want to be shared within a thread,
9
- but they are re-initialised for a new processes.
10
-
11
- Initialiser for the value still needs to be pickable.
12
- """
13
-
14
- def __init__(self, initialiser: t.Callable[[], InitialisedValue]) -> None:
15
- self.value: InitialisedValue | None = None
16
- self.initialiser = initialiser
17
-
18
- def __getstate__(self) -> dict[str, t.Any]:
19
- # During pickling, always return `value` as just None, which is pickable and this class will re-initialise it in `get_value` when called.
20
- return {"value": None, "initialiser": self.initialiser}
21
-
22
- def __setstate__(self, d: dict[str, t.Any]) -> None:
23
- self.value = d["value"]
24
- self.initialiser = d["initialiser"]
25
-
26
- def get_value(self) -> InitialisedValue:
27
- """Use this function to get the wrapped value, which will be initialised if necessary."""
28
- if self.value is None:
29
- self.value = self.initialiser()
30
-
31
- return self.value