epi-recorder 2.1.0__py3-none-any.whl → 2.1.1__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.
epi_cli/__main__.py CHANGED
@@ -1,5 +1,10 @@
1
1
  """
2
- EPI CLI entry point for python -m epi_cli
2
+ EPI CLI - Main entry point for python -m epi_cli
3
+
4
+ This allows users to run the CLI even if 'epi' is not in PATH:
5
+ python -m epi_cli run script.py
6
+ python -m epi_cli view recording.epi
7
+ etc.
3
8
  """
4
9
  from epi_cli.main import cli_main
5
10
 
epi_cli/main.py CHANGED
@@ -231,43 +231,79 @@ def doctor():
231
231
  """
232
232
  [Doctor] Self-healing doctor. Fixes common issues silently.
233
233
  """
234
- console.print("\n[bold blue]EPI Doctor[/bold blue]\n")
234
+ console.print("\n[bold blue]EPI Doctor - System Health Check[/bold blue]\n")
235
235
 
236
236
  issues = 0
237
+ fixed = 0
237
238
 
238
239
  # Check 1: Keys
239
240
  console.print("1. Security Keys: ", end="")
240
241
  from epi_cli.keys import generate_default_keypair_if_missing
241
242
  if generate_default_keypair_if_missing(console_output=False):
242
- console.print("[green]FIXED (Generated)[/green]")
243
- issues += 1
243
+ console.print("[green][OK] FIXED (Generated)[/green]")
244
+ fixed += 1
244
245
  else:
245
- console.print("[green]OK[/green]")
246
+ console.print("[green][OK][/green]")
246
247
 
247
248
  # Check 2: Command on PATH
248
249
  console.print("2. 'epi' command: ", end="")
249
250
  import shutil
250
251
  if shutil.which("epi"):
251
- console.print("[green]OK[/green]")
252
+ console.print("[green][OK][/green]")
252
253
  else:
253
- console.print("[red]MISSING[/red]")
254
- console.print(" [yellow]Run: python epi_setup.py[/yellow]")
254
+ console.print("[red][X] NOT IN PATH[/red]")
255
255
  issues += 1
256
+
257
+ # Try to auto-fix on Windows
258
+ import platform
259
+ if platform.system() == "Windows":
260
+ console.print(" [cyan]→ Attempting automatic PATH fix...[/cyan]")
261
+ try:
262
+ import epi_postinstall
263
+ from pathlib import Path
264
+
265
+ scripts_dir = epi_postinstall.get_scripts_dir()
266
+ if scripts_dir and scripts_dir.exists():
267
+ console.print(f" [dim]Scripts directory: {scripts_dir}[/dim]")
268
+
269
+ if epi_postinstall.add_to_user_path_windows(scripts_dir):
270
+ console.print(" [green][OK] PATH updated successfully![/green]")
271
+ console.print(" [yellow][!] Please restart your terminal for changes to take effect[/yellow]")
272
+ fixed += 1
273
+ else:
274
+ console.print(" [yellow][!] Could not update PATH automatically[/yellow]")
275
+ console.print(" [dim]Manual fix: Use 'python -m epi_cli' instead[/dim]")
276
+ else:
277
+ console.print(" [red][X] Could not locate Scripts directory[/red]")
278
+ except Exception as e:
279
+ console.print(f" [red][X] Auto-fix failed: {e}[/red]")
280
+ console.print(" [dim]Workaround: Use 'python -m epi_cli' instead[/dim]")
281
+ else:
282
+ console.print(" [dim]Workaround: Use 'python -m epi_cli' instead[/dim]")
256
283
 
257
284
  # Check 3: Browser
258
285
  console.print("3. Browser Check: ", end="")
259
286
  try:
260
287
  import webbrowser
261
288
  webbrowser.get()
262
- console.print("[green]OK[/green]")
289
+ console.print("[green][OK][/green]")
263
290
  except:
264
- console.print("[yellow]WARNING (Headless?)[/yellow]")
291
+ console.print("[yellow][!] WARNING (Headless?)[/yellow]")
265
292
 
293
+ # Summary
266
294
  print()
295
+ console.print("[bold]" + "="*70 + "[/bold]")
267
296
  if issues == 0:
268
297
  console.print("[bold green][OK] System Healthy![/bold green]")
269
298
  else:
270
- console.print(f"[bold yellow][!] Found {issues} issues.[/bold yellow]")
299
+ if fixed > 0:
300
+ console.print(f"[bold yellow][!] Fixed {fixed}/{issues} issues[/bold yellow]")
301
+ if fixed < issues:
302
+ console.print("[dim]Some issues require manual attention (see above)[/dim]")
303
+ else:
304
+ console.print(f"[bold yellow][!] Found {issues} issues[/bold yellow]")
305
+ console.print("[dim]See suggestions above[/dim]")
306
+ console.print("[bold]" + "="*70 + "[/bold]\n")
271
307
 
272
308
 
273
309
  # Entry point for CLI
epi_postinstall.py ADDED
@@ -0,0 +1,197 @@
1
+ """
2
+ Post-installation script for EPI Recorder
3
+ Automatically fixes PATH issues on Windows for better UX
4
+ """
5
+ import sys
6
+ import os
7
+ import platform
8
+ import subprocess
9
+ from pathlib import Path
10
+
11
+
12
+ def get_scripts_dir():
13
+ """Get the Scripts directory where pip installs executables"""
14
+ if platform.system() == "Windows":
15
+ # Get the site-packages directory
16
+ import site
17
+ user_site = site.getusersitepackages()
18
+ if user_site:
19
+ # Scripts is typically ../Scripts relative to site-packages
20
+ scripts_dir = Path(user_site).parent / "Scripts"
21
+ if scripts_dir.exists():
22
+ return scripts_dir
23
+
24
+ # Fallback: try to find it from pip
25
+ try:
26
+ result = subprocess.run(
27
+ [sys.executable, "-m", "pip", "show", "epi-recorder"],
28
+ capture_output=True,
29
+ text=True
30
+ )
31
+ if result.returncode == 0:
32
+ for line in result.stdout.split('\n'):
33
+ if line.startswith('Location:'):
34
+ location = line.split(':', 1)[1].strip()
35
+ scripts_dir = Path(location).parent / "Scripts"
36
+ if scripts_dir.exists():
37
+ return scripts_dir
38
+ except Exception:
39
+ pass
40
+
41
+ return None
42
+
43
+
44
+ def is_in_path(directory):
45
+ """Check if directory is in PATH"""
46
+ path_env = os.environ.get('PATH', '')
47
+ path_dirs = path_env.split(os.pathsep)
48
+ dir_str = str(directory)
49
+ return any(os.path.normcase(p) == os.path.normcase(dir_str) for p in path_dirs)
50
+
51
+
52
+ def add_to_user_path_windows(directory):
53
+ """Add directory to user PATH on Windows"""
54
+ try:
55
+ import winreg
56
+
57
+ # Open the user environment variables key
58
+ key = winreg.OpenKey(
59
+ winreg.HKEY_CURRENT_USER,
60
+ 'Environment',
61
+ 0,
62
+ winreg.KEY_READ | winreg.KEY_WRITE
63
+ )
64
+
65
+ try:
66
+ # Get current PATH
67
+ current_path, _ = winreg.QueryValueEx(key, 'Path')
68
+ except WindowsError:
69
+ current_path = ''
70
+
71
+ # Add our directory if not already there
72
+ path_parts = current_path.split(os.pathsep)
73
+ dir_str = str(directory)
74
+
75
+ if not any(os.path.normcase(p) == os.path.normcase(dir_str) for p in path_parts):
76
+ new_path = current_path + os.pathsep + dir_str
77
+ winreg.SetValueEx(key, 'Path', 0, winreg.REG_EXPAND_SZ, new_path)
78
+ winreg.CloseKey(key)
79
+
80
+ # Broadcast WM_SETTINGCHANGE to notify the system
81
+ try:
82
+ import ctypes
83
+ HWND_BROADCAST = 0xFFFF
84
+ WM_SETTINGCHANGE = 0x1A
85
+ ctypes.windll.user32.SendMessageW(
86
+ HWND_BROADCAST, WM_SETTINGCHANGE, 0, 'Environment'
87
+ )
88
+ except Exception:
89
+ pass
90
+
91
+ return True
92
+
93
+ winreg.CloseKey(key)
94
+ return False
95
+
96
+ except Exception as e:
97
+ print(f"Warning: Could not modify PATH: {e}")
98
+ return False
99
+
100
+
101
+ def check_epi_command():
102
+ """Check if 'epi' command is accessible"""
103
+ try:
104
+ result = subprocess.run(
105
+ ['epi', '--version'],
106
+ capture_output=True,
107
+ timeout=2
108
+ )
109
+ return result.returncode == 0
110
+ except (FileNotFoundError, subprocess.TimeoutExpired):
111
+ return False
112
+
113
+
114
+ def post_install():
115
+ """Main post-install function"""
116
+ print("\n" + "="*70)
117
+ print("🎉 EPI Recorder Installation Complete!")
118
+ print("="*70)
119
+
120
+ # Check if epi command works
121
+ if check_epi_command():
122
+ print("\n✅ The 'epi' command is ready to use!")
123
+ print("\nTry it now:")
124
+ print(" epi --help")
125
+ print(" epi init")
126
+ return
127
+
128
+ # If not, try to fix it (Windows only for now)
129
+ if platform.system() == "Windows":
130
+ print("\n⚠️ 'epi' command not found in PATH")
131
+ print("🔧 Attempting automatic fix...")
132
+
133
+ scripts_dir = get_scripts_dir()
134
+
135
+ if scripts_dir and scripts_dir.exists():
136
+ print(f"📁 Found Scripts directory: {scripts_dir}")
137
+
138
+ if not is_in_path(scripts_dir):
139
+ print("➕ Adding to your user PATH...")
140
+
141
+ try:
142
+ if add_to_user_path_windows(scripts_dir):
143
+ print("\n✅ SUCCESS! PATH updated.")
144
+ print("\n⚠️ IMPORTANT: You must restart your terminal for changes to take effect!")
145
+ print("\nAfter restarting your terminal, try:")
146
+ print(" epi --help")
147
+ print(" epi init")
148
+ else:
149
+ print("\n⚠️ Scripts directory already in PATH, but 'epi' not found.")
150
+ print("This might require a terminal restart.")
151
+ print("\nIf 'epi' still doesn't work after restarting, use:")
152
+ print(f" python -m epi_cli")
153
+ except Exception as e:
154
+ print(f"\n❌ Automatic fix failed: {e}")
155
+ show_manual_instructions(scripts_dir)
156
+ else:
157
+ print("✅ Scripts directory is in PATH")
158
+ print("⚠️ You may need to restart your terminal for the command to work.")
159
+ else:
160
+ print("❌ Could not locate Scripts directory")
161
+ show_fallback_instructions()
162
+ else:
163
+ # Linux/Mac
164
+ print("\n⚠️ 'epi' command not found in PATH")
165
+ print("\nIf 'epi' doesn't work, use:")
166
+ print(" python -m epi_cli")
167
+ print("\nOr add pip's user base bin directory to PATH:")
168
+ print(" export PATH=$PATH:$(python -m site --user-base)/bin")
169
+
170
+ print("\n" + "="*70 + "\n")
171
+
172
+
173
+ def show_manual_instructions(scripts_dir):
174
+ """Show manual PATH update instructions"""
175
+ print("\n📖 MANUAL FIX REQUIRED:")
176
+ print("\nOption 1: Update PATH (Permanent)")
177
+ print(" 1. Press Win + R, type: sysdm.cpl")
178
+ print(" 2. Advanced → Environment Variables")
179
+ print(" 3. Under 'User variables', select 'Path' → Edit")
180
+ print(" 4. Click 'New' and add:")
181
+ print(f" {scripts_dir}")
182
+ print(" 5. Click OK, restart your terminal")
183
+ print("\nOption 2: Use python -m (Always works)")
184
+ print(" python -m epi_cli run script.py")
185
+
186
+
187
+ def show_fallback_instructions():
188
+ """Show fallback instructions if automatic fix fails"""
189
+ print("\n📖 WORKAROUND:")
190
+ print("\nUse 'python -m epi_cli' instead of 'epi':")
191
+ print(" python -m epi_cli --help")
192
+ print(" python -m epi_cli run script.py")
193
+ print(" python -m epi_cli view recording.epi")
194
+
195
+
196
+ if __name__ == "__main__":
197
+ post_install()
@@ -1,7 +1,7 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: epi-recorder
3
- Version: 2.1.0
4
- Summary: Executable Package for AI workflows - Record, Verify, and Replay AI runs
3
+ Version: 2.1.1
4
+ Summary: Executable Package for AI workflows - Record, Verify, and Replay AI runs with automatic PATH setup
5
5
  Author-email: Mohd Ibrahim Afridi <epitechforworld@outlook.com>
6
6
  Maintainer-email: Mohd Ibrahim Afridi <epitechforworld@outlook.com>
7
7
  License: Apache-2.0
@@ -1,8 +1,9 @@
1
+ epi_postinstall.py,sha256=9MVuFeA8S25jAp9VMZrAE0M1k2QHC1PeJxful7jcMd8,7066
1
2
  epi_cli/__init__.py,sha256=SSpuDlDqVBbPvR21CCRcNOB61EyB8jAUzNd8XISADa8,98
2
- epi_cli/__main__.py,sha256=MjqwHrWaEjeXDQf5EK-N4F-1VVTX0BnrtWBhMCkPou4,134
3
+ epi_cli/__main__.py,sha256=wQWpc9XXhXnPyy2hw-WQFGaPM1qNhpKiel2jQm7MhKQ,296
3
4
  epi_cli/keys.py,sha256=bHR6knfGR4g7uGuR2cu5VTcGXVyvtZzVtnRBbgPSaTE,9111
4
5
  epi_cli/ls.py,sha256=Ip6OyubkXb_Ba9S7p-U1seWMcWpFeiV-fHhl9ocUy9k,5015
5
- epi_cli/main.py,sha256=qwJnWiOKezKEmdUyPiWeeY6046bbTyEkonzRltEIPoY,9970
6
+ epi_cli/main.py,sha256=2HiIBkq0AFricMV5vLBzWyYVKLTnbIUDQ15u7UAs-mw,11923
6
7
  epi_cli/record.py,sha256=QtDrjr-7WbfcYXwPRrDDujrubUNrHhp062EcW8DZPNk,7321
7
8
  epi_cli/run.py,sha256=dM_AYC3LzDBc_DzVKlb8obZBE52sAe3wYAnce0PLGT4,14101
8
9
  epi_cli/verify.py,sha256=Rq34rw-zM_vZmYDsfg8cLlvW76_wJ99Pu-arjGRE9bw,8238
@@ -20,12 +21,12 @@ epi_recorder/environment.py,sha256=NCz_Pckc6GU1kQsYF3oXDsN46k5LVuYWbMEhTj1FRXo,6
20
21
  epi_recorder/patcher.py,sha256=tEAlDfH_rz3TblASn9xvMsadXgobvrenQe2Pq1M_xvA,14570
21
22
  epi_recorder/test_import.py,sha256=Dhjkj8qYZR4d4w-bshClV6S-naCcS5srW7wsp7jW-cM,459
22
23
  epi_recorder/test_script.py,sha256=4uUheXOfqC28NYICyaAxm3gnhfrkdDZtaXnwfjG-qhQ,92
23
- epi_recorder-2.1.0.dist-info/licenses/LICENSE,sha256=aUgjAzBUkmKIZy3AZ_XAZWoh3kzkRlkOc3JHLVfyF-A,11540
24
+ epi_recorder-2.1.1.dist-info/licenses/LICENSE,sha256=aUgjAzBUkmKIZy3AZ_XAZWoh3kzkRlkOc3JHLVfyF-A,11540
24
25
  epi_viewer_static/app.js,sha256=KLWM68U4hN-fcmkKbnz7mqML5GrdnYJwNeTAgKsmV2I,13023
25
26
  epi_viewer_static/index.html,sha256=JxdsgzjJ5nGeDD1ROXI00w8rwsD7wXXOwitizxe8AWs,3298
26
27
  epi_viewer_static/viewer_lite.css,sha256=oCEiEYbvdlaMwz-MPlrk3LoTVOad-bDLlP-X49Yw0o0,4691
27
- epi_recorder-2.1.0.dist-info/METADATA,sha256=2PZhBdcsJp3Wpva5FRUDu6P7P5S9cwk0JDqkL5G8YvM,5894
28
- epi_recorder-2.1.0.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
29
- epi_recorder-2.1.0.dist-info/entry_points.txt,sha256=MfMwqVRx_yMGbuPpiyjz2f8fQp8TUbHmRC1H_bupoyM,41
30
- epi_recorder-2.1.0.dist-info/top_level.txt,sha256=nKpWVQUoGWK-gyLLVbrxibQUlIzI0TowNzMDondlHpI,48
31
- epi_recorder-2.1.0.dist-info/RECORD,,
28
+ epi_recorder-2.1.1.dist-info/METADATA,sha256=lb9k94VwoeBhB1czYeDnZ1v9A37IyGWgg45BtK1PB1w,5920
29
+ epi_recorder-2.1.1.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
30
+ epi_recorder-2.1.1.dist-info/entry_points.txt,sha256=MfMwqVRx_yMGbuPpiyjz2f8fQp8TUbHmRC1H_bupoyM,41
31
+ epi_recorder-2.1.1.dist-info/top_level.txt,sha256=kvGAjj3uNol1hxRi29Ec-B4HuYK6t-MD7wflkENQA6g,64
32
+ epi_recorder-2.1.1.dist-info/RECORD,,
@@ -1,4 +1,5 @@
1
1
  epi_cli
2
2
  epi_core
3
+ epi_postinstall
3
4
  epi_recorder
4
5
  epi_viewer_static