PraisonAI 2.2.17__tar.gz → 2.2.19__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 PraisonAI might be problematic. Click here for more details.

Files changed (79) hide show
  1. {praisonai-2.2.17 → praisonai-2.2.19}/PKG-INFO +3 -3
  2. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/deploy.py +1 -1
  3. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/inc/models.py +24 -4
  4. praisonai-2.2.19/praisonai/ui/database_config.py +56 -0
  5. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/db.py +3 -4
  6. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/sql_alchemy.py +3 -5
  7. {praisonai-2.2.17 → praisonai-2.2.19}/pyproject.toml +5 -5
  8. {praisonai-2.2.17 → praisonai-2.2.19}/README.md +0 -0
  9. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/README.md +0 -0
  10. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/__init__.py +0 -0
  11. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/__main__.py +0 -0
  12. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/agents_generator.py +0 -0
  13. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/api/call.py +0 -0
  14. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/auto.py +0 -0
  15. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/chainlit_ui.py +0 -0
  16. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/cli.py +0 -0
  17. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/inbuilt_tools/__init__.py +0 -0
  18. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/inbuilt_tools/autogen_tools.py +0 -0
  19. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/inc/__init__.py +0 -0
  20. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/inc/config.py +0 -0
  21. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/android-chrome-192x192.png +0 -0
  22. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/android-chrome-512x512.png +0 -0
  23. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/apple-touch-icon.png +0 -0
  24. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/fantasy.svg +0 -0
  25. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/favicon-16x16.png +0 -0
  26. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/favicon-32x32.png +0 -0
  27. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/favicon.ico +0 -0
  28. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/game.svg +0 -0
  29. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/logo_dark.png +0 -0
  30. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/logo_light.png +0 -0
  31. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/movie.svg +0 -0
  32. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/praison-ai-agents-architecture-dark.png +0 -0
  33. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/praison-ai-agents-architecture.png +0 -0
  34. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/public/thriller.svg +0 -0
  35. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/setup/__init__.py +0 -0
  36. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/setup/build.py +0 -0
  37. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/setup/config.yaml +0 -0
  38. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/setup/post_install.py +0 -0
  39. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/setup/setup_conda_env.py +0 -0
  40. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/setup/setup_conda_env.sh +0 -0
  41. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/setup.py +0 -0
  42. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/test.py +0 -0
  43. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/train.py +0 -0
  44. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/train_vision.py +0 -0
  45. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/README.md +0 -0
  46. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/agents.py +0 -0
  47. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/callbacks.py +0 -0
  48. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/chat.py +0 -0
  49. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/code.py +0 -0
  50. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/colab.py +0 -0
  51. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/colab_chainlit.py +0 -0
  52. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/components/aicoder.py +0 -0
  53. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/chainlit.md +0 -0
  54. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/bn.json +0 -0
  55. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/en-US.json +0 -0
  56. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/gu.json +0 -0
  57. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/he-IL.json +0 -0
  58. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/hi.json +0 -0
  59. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/kn.json +0 -0
  60. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/ml.json +0 -0
  61. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/mr.json +0 -0
  62. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/ta.json +0 -0
  63. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/te.json +0 -0
  64. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/config/translations/zh-CN.json +0 -0
  65. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/context.py +0 -0
  66. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/public/fantasy.svg +0 -0
  67. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/public/game.svg +0 -0
  68. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/public/logo_dark.png +0 -0
  69. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/public/logo_light.png +0 -0
  70. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/public/movie.svg +0 -0
  71. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/public/praison.css +0 -0
  72. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/public/thriller.svg +0 -0
  73. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/realtime.py +0 -0
  74. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/realtimeclient/__init__.py +0 -0
  75. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/realtimeclient/realtimedocs.txt +0 -0
  76. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/realtimeclient/tools.py +0 -0
  77. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/ui/tools.md +0 -0
  78. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/upload_vision.py +0 -0
  79. {praisonai-2.2.17 → praisonai-2.2.19}/praisonai/version.py +0 -0
@@ -1,9 +1,9 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: PraisonAI
3
- Version: 2.2.17
3
+ Version: 2.2.19
4
4
  Summary: PraisonAI is an AI Agents Framework with Self Reflection. PraisonAI application combines PraisonAI Agents, AutoGen, and CrewAI into a low-code solution for building and managing multi-agent LLM systems, focusing on simplicity, customisation, and efficient human-agent collaboration.
5
5
  Author: Mervin Praison
6
- Requires-Python: >=3.10,<3.13
6
+ Requires-Python: >=3.10
7
7
  Classifier: Programming Language :: Python :: 3
8
8
  Classifier: Programming Language :: Python :: 3.10
9
9
  Classifier: Programming Language :: Python :: 3.11
@@ -63,7 +63,7 @@ Requires-Dist: playwright (>=1.47.0) ; extra == "code"
63
63
  Requires-Dist: plotly (>=5.24.0) ; extra == "realtime"
64
64
  Requires-Dist: praisonai-tools (>=0.0.15) ; extra == "autogen"
65
65
  Requires-Dist: praisonai-tools (>=0.0.15) ; extra == "crewai"
66
- Requires-Dist: praisonaiagents (>=0.0.90)
66
+ Requires-Dist: praisonaiagents (>=0.0.91)
67
67
  Requires-Dist: pyautogen (>=0.2.19) ; extra == "autogen"
68
68
  Requires-Dist: pydantic (<=2.10.1) ; extra == "chat"
69
69
  Requires-Dist: pydantic (<=2.10.1) ; extra == "code"
@@ -56,7 +56,7 @@ class CloudDeployer:
56
56
  file.write("FROM python:3.11-slim\n")
57
57
  file.write("WORKDIR /app\n")
58
58
  file.write("COPY . .\n")
59
- file.write("RUN pip install flask praisonai==2.2.17 gunicorn markdown\n")
59
+ file.write("RUN pip install flask praisonai==2.2.19 gunicorn markdown\n")
60
60
  file.write("EXPOSE 8080\n")
61
61
  file.write('CMD ["gunicorn", "-b", "0.0.0.0:8080", "api:app"]\n')
62
62
 
@@ -1,9 +1,13 @@
1
1
  # praisonai/inc/models.py
2
2
  import os
3
3
  import logging
4
+ from urllib.parse import urlparse
4
5
  logger = logging.getLogger(__name__)
5
6
  logging.basicConfig(level=os.environ.get('LOGLEVEL', 'INFO').upper(), format='%(asctime)s - %(levelname)s - %(message)s')
6
7
 
8
+ # Constants
9
+ LOCAL_SERVER_API_KEY_PLACEHOLDER = "not-needed"
10
+
7
11
  # Conditionally import modules based on availability
8
12
  try:
9
13
  from langchain_openai import ChatOpenAI # pip install langchain-openai
@@ -71,11 +75,27 @@ class PraisonAIModel:
71
75
  self.model_name = self.model.replace("openrouter/", "")
72
76
  else:
73
77
  self.api_key_var = api_key_var or "OPENAI_API_KEY"
74
- self.base_url = base_url or os.environ.get("OPENAI_API_BASE", "https://api.openai.com/v1")
78
+ self.base_url = base_url or os.environ.get("OPENAI_API_BASE") or os.environ.get("OPENAI_BASE_URL") or "https://api.openai.com/v1"
75
79
  self.model_name = self.model
76
80
  logger.debug(f"Initialized PraisonAIModel with model {self.model_name}, api_key_var {self.api_key_var}, and base_url {self.base_url}")
77
- # Use explicit API key if provided, otherwise fall back to environment variable
78
- self.api_key = api_key or os.environ.get(self.api_key_var, "nokey")
81
+
82
+ # Get API key from environment
83
+ self.api_key = api_key or os.environ.get(self.api_key_var)
84
+
85
+ # For local servers, allow placeholder API key if base_url is set to non-OpenAI endpoint
86
+ if not self.api_key and self.base_url:
87
+ parsed_url = urlparse(self.base_url)
88
+ is_local = (parsed_url.hostname in ["localhost", "127.0.0.1"] or
89
+ "api.openai.com" not in self.base_url)
90
+ if is_local:
91
+ self.api_key = LOCAL_SERVER_API_KEY_PLACEHOLDER
92
+
93
+ if not self.api_key:
94
+ raise ValueError(
95
+ f"{self.api_key_var} environment variable is required for the default OpenAI service. "
96
+ f"For local servers, set {self.api_key_var}='{LOCAL_SERVER_API_KEY_PLACEHOLDER}' and OPENAI_API_BASE to your local endpoint."
97
+ )
98
+
79
99
 
80
100
  def get_model(self):
81
101
  """
@@ -127,4 +147,4 @@ class PraisonAIModel:
127
147
  raise ImportError(
128
148
  "Required Langchain Integration 'langchain-openai' not found. "
129
149
  "Please install with 'pip install langchain-openai'"
130
- )
150
+ )
@@ -0,0 +1,56 @@
1
+ """
2
+ Database configuration utilities for PraisonAI UI components.
3
+
4
+ This module provides centralized database configuration functionality,
5
+ particularly for handling the FORCE_SQLITE environment variable.
6
+ """
7
+
8
+ import os
9
+ from typing import Optional, Tuple
10
+
11
+
12
+ def should_force_sqlite() -> bool:
13
+ """
14
+ Check if FORCE_SQLITE environment variable is set to true.
15
+
16
+ Returns:
17
+ bool: True if FORCE_SQLITE is set to "true" (case-insensitive), False otherwise.
18
+ """
19
+ return os.getenv("FORCE_SQLITE", "false").lower() == "true"
20
+
21
+
22
+ def get_database_url_with_sqlite_override() -> Optional[str]:
23
+ """
24
+ Get database URL respecting FORCE_SQLITE flag.
25
+
26
+ When FORCE_SQLITE=true, this function returns None to force SQLite usage.
27
+ Otherwise, it returns the appropriate database URL from environment variables.
28
+
29
+ Returns:
30
+ Optional[str]: Database URL if external database should be used, None for SQLite.
31
+ """
32
+ if should_force_sqlite():
33
+ return None
34
+
35
+ database_url = os.getenv("DATABASE_URL")
36
+ supabase_url = os.getenv("SUPABASE_DATABASE_URL")
37
+ return supabase_url if supabase_url else database_url
38
+
39
+
40
+ def get_database_config_for_sqlalchemy() -> Tuple[Optional[str], Optional[str]]:
41
+ """
42
+ Get database configuration for SQLAlchemy module respecting FORCE_SQLITE flag.
43
+
44
+ Returns:
45
+ Tuple[Optional[str], Optional[str]]: (DATABASE_URL, SUPABASE_DATABASE_URL)
46
+ Both will be None if FORCE_SQLITE=true, otherwise original values.
47
+ """
48
+ if should_force_sqlite():
49
+ return None, None
50
+ else:
51
+ database_url = os.getenv("DATABASE_URL")
52
+ supabase_url = os.getenv("SUPABASE_DATABASE_URL")
53
+ # Apply Supabase override logic
54
+ if supabase_url:
55
+ database_url = supabase_url
56
+ return database_url, supabase_url
@@ -9,6 +9,7 @@ from sqlalchemy.orm import sessionmaker
9
9
  from sql_alchemy import SQLAlchemyDataLayer
10
10
  import chainlit.data as cl_data
11
11
  from chainlit.types import ThreadDict
12
+ from database_config import get_database_url_with_sqlite_override
12
13
 
13
14
  def ensure_directories():
14
15
  """Ensure required directories exist"""
@@ -57,10 +58,8 @@ ensure_directories()
57
58
 
58
59
  class DatabaseManager(SQLAlchemyDataLayer):
59
60
  def __init__(self):
60
- self.database_url = os.getenv("DATABASE_URL")
61
- supabase_url = os.getenv("SUPABASE_DATABASE_URL")
62
- if supabase_url:
63
- self.database_url = supabase_url
61
+ # Check FORCE_SQLITE flag to bypass external database detection
62
+ self.database_url = get_database_url_with_sqlite_override()
64
63
 
65
64
  if self.database_url:
66
65
  self.conninfo = self.database_url
@@ -29,16 +29,14 @@ from sqlalchemy import text
29
29
  from sqlalchemy.exc import SQLAlchemyError
30
30
  from sqlalchemy.ext.asyncio import AsyncEngine, AsyncSession, create_async_engine
31
31
  from sqlalchemy.orm import sessionmaker
32
+ from database_config import get_database_config_for_sqlalchemy
32
33
 
33
34
  if TYPE_CHECKING:
34
35
  from chainlit.element import Element
35
36
  from chainlit.step import StepDict
36
37
 
37
- DATABASE_URL = os.getenv("DATABASE_URL")
38
- SUPABASE_DATABASE_URL = os.getenv("SUPABASE_DATABASE_URL")
39
- if SUPABASE_DATABASE_URL:
40
- # If a Supabase database URL is provided, use it.
41
- DATABASE_URL = SUPABASE_DATABASE_URL
38
+ # Check FORCE_SQLITE flag to bypass external database detection
39
+ DATABASE_URL, SUPABASE_DATABASE_URL = get_database_config_for_sqlalchemy()
42
40
 
43
41
  class SQLAlchemyDataLayer(BaseDataLayer):
44
42
  def __init__(
@@ -1,10 +1,10 @@
1
1
  [project]
2
2
  name = "PraisonAI"
3
- version = "2.2.17"
3
+ version = "2.2.19"
4
4
  description = "PraisonAI is an AI Agents Framework with Self Reflection. PraisonAI application combines PraisonAI Agents, AutoGen, and CrewAI into a low-code solution for building and managing multi-agent LLM systems, focusing on simplicity, customisation, and efficient human-agent collaboration."
5
5
  readme = "README.md"
6
6
  license = ""
7
- requires-python = ">=3.10,<3.13"
7
+ requires-python = ">=3.10"
8
8
  authors = [
9
9
  { name = "Mervin Praison" }
10
10
  ]
@@ -12,7 +12,7 @@ dependencies = [
12
12
  "rich>=13.7",
13
13
  "markdown>=3.5",
14
14
  "pyparsing>=3.0.0",
15
- "praisonaiagents>=0.0.90",
15
+ "praisonaiagents>=0.0.91",
16
16
  "python-dotenv>=0.19.0",
17
17
  "instructor>=1.3.3",
18
18
  "PyYAML>=6.0",
@@ -89,7 +89,7 @@ autogen = ["pyautogen>=0.2.19", "praisonai-tools>=0.0.15", "crewai"]
89
89
 
90
90
  [tool.poetry]
91
91
  name = "PraisonAI"
92
- version = "2.2.17"
92
+ version = "2.2.19"
93
93
  description = "PraisonAI is an AI Agents Framework with Self Reflection. PraisonAI application combines PraisonAI Agents, AutoGen, and CrewAI into a low-code solution for building and managing multi-agent LLM systems, focusing on simplicity, customisation, and efficient human-agent collaboration."
94
94
  authors = ["Mervin Praison"]
95
95
  license = ""
@@ -107,7 +107,7 @@ python = ">=3.10,<3.13"
107
107
  rich = ">=13.7"
108
108
  markdown = ">=3.5"
109
109
  pyparsing = ">=3.0.0"
110
- praisonaiagents = ">=0.0.90"
110
+ praisonaiagents = ">=0.0.91"
111
111
  python-dotenv = ">=0.19.0"
112
112
  instructor = ">=1.3.3"
113
113
  PyYAML = ">=6.0"
File without changes
File without changes
File without changes
File without changes