davidkhala.ai 0.0.2__tar.gz → 0.0.3__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.
Files changed (21) hide show
  1. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/PKG-INFO +4 -3
  2. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/api/__init__.py +1 -2
  3. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/api/open.py +1 -1
  4. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/api/siliconflow.py +0 -2
  5. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/pyproject.toml +5 -5
  6. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/.gitignore +0 -0
  7. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/README.md +0 -0
  8. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/__init__.py +0 -0
  9. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/agent/__init__.py +0 -0
  10. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/agent/dify.py +0 -0
  11. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/agent/langgraph.py +0 -0
  12. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/ali/__init__.py +0 -0
  13. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/ali/dashscope.py +0 -0
  14. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/google/__init__.py +0 -0
  15. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/google/adk.py +0 -0
  16. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/google/gemini.py +0 -0
  17. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/model.py +0 -0
  18. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/openai/__init__.py +0 -0
  19. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/openai/azure.py +0 -0
  20. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/openai/native.py +0 -0
  21. {davidkhala_ai-0.0.2 → davidkhala_ai-0.0.3}/davidkhala/ai/opik.py +0 -0
@@ -1,9 +1,8 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: davidkhala.ai
3
- Version: 0.0.2
3
+ Version: 0.0.3
4
4
  Summary: misc AI modules
5
- Requires-Python: ==3.13.*
6
- Requires-Dist: opik
5
+ Requires-Python: >=3.13
7
6
  Provides-Extra: ali
8
7
  Requires-Dist: dashscope; extra == 'ali'
9
8
  Provides-Extra: api
@@ -17,3 +16,5 @@ Requires-Dist: langchain-openai; extra == 'langchain'
17
16
  Requires-Dist: langgraph; extra == 'langchain'
18
17
  Provides-Extra: openai
19
18
  Requires-Dist: openai; extra == 'openai'
19
+ Provides-Extra: telemetry
20
+ Requires-Dist: opik; (python_version < '3.14') and extra == 'telemetry'
@@ -3,7 +3,7 @@ from abc import abstractmethod, ABC
3
3
 
4
4
  import requests
5
5
 
6
-
6
+ # TODO Think openrouter as exceptional case
7
7
  class API(ABC):
8
8
  def __init__(self, api_key: str, base_url: str):
9
9
  self.base_url = base_url+'/v1'
@@ -16,7 +16,6 @@ class API(ABC):
16
16
  def free_models(self)->list[str]:
17
17
  ...
18
18
 
19
- @abstractmethod
20
19
  def pre_request(self, headers: dict, data: dict):
21
20
  data["model"] = self.model
22
21
  def chat(self, prompt, system_prompt: str = None):
@@ -24,7 +24,7 @@ class OpenRouter(API):
24
24
  if models is None:
25
25
  models = [self.free_models[0]]
26
26
  self.models = models
27
-
27
+ # TODO Hard to multi-model supports here
28
28
  def pre_request(self, headers: dict, data: dict):
29
29
  if self.leaderboard is not None:
30
30
  headers["HTTP-Referer"] = self.leaderboard['url'], # Optional. Site URL for rankings on openrouter.ai.
@@ -35,5 +35,3 @@ class SiliconFlow(API):
35
35
  def __init__(self, api_key: str, model: str):
36
36
  super().__init__(api_key, 'https://api.siliconflow.cn')
37
37
  self.model = model
38
- def pre_request(self, headers: dict, data: dict):
39
- super().pre_request(headers, data)
@@ -1,12 +1,9 @@
1
1
  [project]
2
2
  name = "davidkhala.ai"
3
- version = "0.0.2"
3
+ version = "0.0.3"
4
4
  description = "misc AI modules"
5
5
  readme = "README.md"
6
- requires-python = "==3.13.*"
7
- dependencies = [
8
- "opik", # limit py version: PyO3 v0.22.6 currently supports up to Python 3.13.
9
- ]
6
+ requires-python = ">=3.13"
10
7
 
11
8
  [project.optional-dependencies]
12
9
  langchain = [
@@ -25,6 +22,9 @@ ali = [
25
22
  openai = [
26
23
  "openai"
27
24
  ]
25
+ telemetry =[
26
+ "opik ; python_version < '3.14'" # limit py version: PyO3 v0.22.6 currently supports up to Python 3.13.
27
+ ]
28
28
  [tool.hatch.build.targets.sdist]
29
29
  include = ["davidkhala"]
30
30
 
File without changes
File without changes