2fb067ecbf
checklocks / checklocks (push) Has been cancelled
CodeQL / Analyze (go) (push) Has been cancelled
natlab-integrationtest / natlab-integrationtest (push) Has been cancelled
CI / gomod-cache (push) Has been cancelled
CI / race-root-integration (1/4) (push) Has been cancelled
CI / race-root-integration (2/4) (push) Has been cancelled
CI / race-root-integration (3/4) (push) Has been cancelled
CI / race-root-integration (4/4) (push) Has been cancelled
CI / test (-race, amd64, 1/3) (push) Has been cancelled
CI / test (-race, amd64, 2/3) (push) Has been cancelled
CI / test (-race, amd64, 3/3) (push) Has been cancelled
CI / test (386) (push) Has been cancelled
CI / test (amd64) (push) Has been cancelled
CI / Windows (benchmarks) (push) Has been cancelled
CI / Windows (1/2) (push) Has been cancelled
CI / Windows (2/2) (push) Has been cancelled
CI / macos (push) Has been cancelled
CI / privileged (push) Has been cancelled
CI / vm (push) Has been cancelled
CI / cross (386, linux) (push) Has been cancelled
CI / cross (amd64, darwin) (push) Has been cancelled
CI / cross (amd64, freebsd) (push) Has been cancelled
CI / cross (amd64, openbsd) (push) Has been cancelled
CI / cross (amd64, windows) (push) Has been cancelled
CI / cross (arm, 5, linux) (push) Has been cancelled
CI / cross (arm, 7, linux) (push) Has been cancelled
CI / cross (arm64, darwin) (push) Has been cancelled
CI / cross (arm64, linux) (push) Has been cancelled
CI / cross (arm64, windows) (push) Has been cancelled
CI / cross (loong64, linux) (push) Has been cancelled
CI / ios (push) Has been cancelled
CI / crossmin (amd64, illumos) (push) Has been cancelled
CI / crossmin (amd64, plan9) (push) Has been cancelled
CI / crossmin (amd64, solaris) (push) Has been cancelled
CI / crossmin (ppc64, aix) (push) Has been cancelled
CI / android (push) Has been cancelled
CI / wasm (push) Has been cancelled
CI / tailscale_go (push) Has been cancelled
CI / fuzz (push) Has been cancelled
CI / depaware (push) Has been cancelled
CI / go_generate (push) Has been cancelled
CI / make_tidy (push) Has been cancelled
CI / licenses (push) Has been cancelled
CI / staticcheck (macOS) (push) Has been cancelled
CI / staticcheck (Linux) (push) Has been cancelled
CI / staticcheck (Windows) (push) Has been cancelled
CI / staticcheck (Portable (1/4)) (push) Has been cancelled
CI / staticcheck (Portable (2/4)) (push) Has been cancelled
CI / staticcheck (Portable (3/4)) (push) Has been cancelled
CI / staticcheck (Portable (4/4)) (push) Has been cancelled
CI / notify_slack (push) Has been cancelled
CI / merge_blocker (push) Has been cancelled
CI / check_mergeability_strict (push) Has been cancelled
CI / check_mergeability (push) Has been cancelled
Dockerfile build / deploy (push) Has been cancelled
test installer.sh / test (curl, alpine:3.21) (push) Has been cancelled
test installer.sh / test (curl, alpine:edge) (push) Has been cancelled
test installer.sh / test (curl, alpine:latest) (push) Has been cancelled
test installer.sh / test (curl, amazonlinux:latest) (push) Has been cancelled
test installer.sh / test (curl, archlinux:latest) (push) Has been cancelled
test installer.sh / test (curl, debian:oldstable-slim) (push) Has been cancelled
test installer.sh / test (curl, debian:sid-slim) (push) Has been cancelled
test installer.sh / test (curl, debian:stable-slim, 1.80.0) (push) Has been cancelled
test installer.sh / test (curl, debian:testing-slim) (push) Has been cancelled
test installer.sh / test (curl, elementary/docker:stable) (push) Has been cancelled
test installer.sh / test (curl, elementary/docker:unstable) (push) Has been cancelled
test installer.sh / test (curl, fedora:latest, 1.80.0) (push) Has been cancelled
test installer.sh / test (curl, kalilinux/kali-dev) (push) Has been cancelled
test installer.sh / test (curl, kalilinux/kali-rolling) (push) Has been cancelled
test installer.sh / test (curl, opensuse/leap:latest) (push) Has been cancelled
test installer.sh / test (curl, opensuse/tumbleweed:latest) (push) Has been cancelled
test installer.sh / test (curl, oraclelinux:8) (push) Has been cancelled
test installer.sh / test (curl, oraclelinux:9) (push) Has been cancelled
test installer.sh / test (curl, parrotsec/core:latest) (push) Has been cancelled
test installer.sh / test (curl, rockylinux:8.7) (push) Has been cancelled
test installer.sh / test (curl, rockylinux:9) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:20.04) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:22.04) (push) Has been cancelled
test installer.sh / test (curl, ubuntu:24.04, 1.80.0) (push) Has been cancelled
test installer.sh / test (wget, debian:oldstable-slim) (push) Has been cancelled
test installer.sh / test (wget, debian:sid-slim) (push) Has been cancelled
update-flake / update-flake (push) Has been cancelled
tailscale.com/cmd/vet / vet (push) Has been cancelled
test installer.sh / notify-slack (push) Has been cancelled
Client security fixes (cmd/tailscale-tray/main.go): - SSRF protection in Add Server dialog (validateControlURL): reject private/loopback/link-local/cloud-metadata IPs via DNS resolution - RCE gate on AuthURL/BrowseToURL exec paths (validateAuthURL) - Sanitized URL logging (sanitizeURLForLog drops query auth tokens) - Error handling on exec.Command with user-facing showError() Admin panel security (web-admin): - Bcrypt password hashing (replaces SHA256) - Rate limiting: 5 failed logins → 15-min lockout - Session + login attempt cleanup goroutine (hourly) - url.QueryEscape / encodeURIComponent for all API params - Fail-hard startup when no TLS and non-loopback bind - ADMIN_PASSWORD required (no default), password min 12 chars - Username regex whitelist Installer hardening (Setup.wxs): - util:PermissionEx restricts SCM access: only Administrators + SYSTEM can start/stop/reconfigure service. Authenticated Users limited to QueryStatus/QueryConfig/Interrogate - Vital="yes" on ServiceInstall Docs & roadmap: - PRODUCTION_ROADMAP.md: 5-milestone plan (security + features + distribution + ops) with granular tasks, effort, done-when - CLIENT_SECURITY_AUDIT.md, SECURITY_FIXES.md, DEPLOYMENT.md - AI assistant rules (.cursorrules, .antigravityrules, etc.) Build & distribution: - build-msi.ps1, deploy-and-sign.ps1, sign-release.ps1 - redeploy.ps1, tray-deploy.ps1, test-msi.ps1 - installer/msi/ alternative WXS setup - Restored .github/workflows/ removed in mirror cleanup .gitignore hardened: *.pfx, *.p12, *.key, *.pem, .env*
121 lines
4.1 KiB
Python
121 lines
4.1 KiB
Python
#!/usr/bin/env python3
|
|
"""
|
|
Session Manager - Antigravity Kit
|
|
=================================
|
|
Analyzes project state, detects tech stack, tracks file statistics, and provides
|
|
a summary of the current session.
|
|
|
|
Usage:
|
|
python .agent/scripts/session_manager.py status [path]
|
|
python .agent/scripts/session_manager.py info [path]
|
|
"""
|
|
|
|
import os
|
|
import json
|
|
import argparse
|
|
from pathlib import Path
|
|
from typing import Dict, Any, List
|
|
|
|
def get_project_root(path: str) -> Path:
|
|
return Path(path).resolve()
|
|
|
|
def analyze_package_json(root: Path) -> Dict[str, Any]:
|
|
pkg_file = root / "package.json"
|
|
if not pkg_file.exists():
|
|
return {"type": "unknown", "dependencies": {}}
|
|
|
|
try:
|
|
with open(pkg_file, 'r', encoding='utf-8') as f:
|
|
data = json.load(f)
|
|
|
|
deps = data.get("dependencies", {})
|
|
dev_deps = data.get("devDependencies", {})
|
|
all_deps = {**deps, **dev_deps}
|
|
|
|
stack = []
|
|
if "next" in all_deps: stack.append("Next.js")
|
|
elif "react" in all_deps: stack.append("React")
|
|
elif "vue" in all_deps: stack.append("Vue")
|
|
elif "svelte" in all_deps: stack.append("Svelte")
|
|
elif "express" in all_deps: stack.append("Express")
|
|
elif "nestjs" in all_deps or "@nestjs/core" in all_deps: stack.append("NestJS")
|
|
|
|
if "tailwindcss" in all_deps: stack.append("Tailwind CSS")
|
|
if "prisma" in all_deps: stack.append("Prisma")
|
|
if "typescript" in all_deps: stack.append("TypeScript")
|
|
|
|
return {
|
|
"name": data.get("name", "unnamed"),
|
|
"version": data.get("version", "0.0.0"),
|
|
"stack": stack,
|
|
"scripts": list(data.get("scripts", {}).keys())
|
|
}
|
|
except Exception as e:
|
|
return {"error": str(e)}
|
|
|
|
def count_files(root: Path) -> Dict[str, int]:
|
|
stats = {"created": 0, "modified": 0, "total": 0}
|
|
# Simple count for now, comprehensive tracking would require git diff or extensive history
|
|
exclude = {".git", "node_modules", ".next", "dist", "build", ".agent", ".gemini", "__pycache__"}
|
|
|
|
for root_dir, dirs, files in os.walk(root):
|
|
dirs[:] = [d for d in dirs if d not in exclude]
|
|
stats["total"] += len(files)
|
|
|
|
return stats
|
|
|
|
def detect_features(root: Path) -> List[str]:
|
|
# Heuristic: look at folder names in src/
|
|
features = []
|
|
src = root / "src"
|
|
if src.exists():
|
|
possible_dirs = ["components", "modules", "features", "app", "pages", "services"]
|
|
for d in possible_dirs:
|
|
p = src / d
|
|
if p.exists() and p.is_dir():
|
|
# List subdirectories as likely features
|
|
for child in p.iterdir():
|
|
if child.is_dir():
|
|
features.append(child.name)
|
|
return features[:10] # Limit to top 10
|
|
|
|
def print_status(root: Path):
|
|
info = analyze_package_json(root)
|
|
stats = count_files(root)
|
|
features = detect_features(root)
|
|
|
|
print("\n=== Project Status ===")
|
|
print(f"\n📁 Project: {info.get('name', root.name)}")
|
|
print(f"📂 Path: {root}")
|
|
print(f"🏷️ Type: {', '.join(info.get('stack', ['Generic']))}")
|
|
print(f"📊 Status: Active")
|
|
|
|
print("\n🔧 Tech Stack:")
|
|
for tech in info.get('stack', []):
|
|
print(f" • {tech}")
|
|
|
|
print(f"\n✅ Detected Modules/Features ({len(features)}):")
|
|
for feat in features:
|
|
print(f" • {feat}")
|
|
if not features:
|
|
print(" (No distinct feature modules detected)")
|
|
|
|
print(f"\n📄 Files: {stats['total']} total files tracked")
|
|
print("\n====================\n")
|
|
|
|
def main():
|
|
parser = argparse.ArgumentParser(description="Session Manager")
|
|
parser.add_argument("command", choices=["status", "info"], help="Command to run")
|
|
parser.add_argument("path", nargs="?", default=".", help="Project path")
|
|
|
|
args = parser.parse_args()
|
|
root = get_project_root(args.path)
|
|
|
|
if args.command == "status":
|
|
print_status(root)
|
|
elif args.command == "info":
|
|
print(json.dumps(analyze_package_json(root), indent=2))
|
|
|
|
if __name__ == "__main__":
|
|
main()
|