Spaces:
Running on Zero
Running on Zero
| """NEXUS Visual Weaver - Build Small Hackathon command center.""" | |
| from __future__ import annotations | |
| import os | |
| import sys | |
| import hashlib | |
| import secrets | |
| from pathlib import Path | |
| from typing import Any | |
| from urllib.parse import urlparse | |
| import gradio as gr | |
| ROOT = Path(__file__).resolve().parent | |
| SRC = ROOT / "src" | |
| if str(SRC) not in sys.path: | |
| sys.path.insert(0, str(SRC)) | |
| try: | |
| import spaces | |
| except Exception: | |
| spaces = None | |
| from nexus_visual_weaver.catalog import catalog_summary | |
| from nexus_visual_weaver.exporter import write_export_packet | |
| from nexus_visual_weaver.hf_runtime import generate_flux_image | |
| from nexus_visual_weaver.model_relay import WeaverModelRelay | |
| from nexus_visual_weaver.planner import build_command_center_run | |
| from nexus_visual_weaver.provider_runtime import judge_with_minicpm, judge_with_nemotron | |
| from nexus_visual_weaver.render import render_catalog_table, render_dashboard_regions | |
| from nexus_visual_weaver.security import scan_file | |
| from nexus_visual_weaver.styles import APP_CSS | |
| APP_THEME = gr.themes.Soft() | |
| DEFAULT_PROMPT = ( | |
| "A Slavic archivist in a rain-slick neon city, wearing a structured black patent " | |
| "leather long coat with faux fur collar, Chantilly lace neckline, glowing crimson " | |
| "hardware, platform boots, NEXUS sigils and floating code streams behind her." | |
| ) | |
| MODEL_RELAY = WeaverModelRelay() | |
| STYLE_MODIFIERS = { | |
| "Balanced": "balanced editorial lighting, precise garment detail, clean composition", | |
| "High Fashion": "haute couture editorial styling, premium material finish, runway-grade silhouette", | |
| "Cinematic": "cinematic rain-lit atmosphere, dramatic lensing, high contrast neon reflections", | |
| } | |
| ASPECT_DIMENSIONS = { | |
| "Square": (1024, 1024), | |
| "Portrait": (832, 1216), | |
| } | |
| def _default_operator_state() -> dict[str, Any]: | |
| return { | |
| "provider_state": "idle", | |
| "checkpoint": "pending", | |
| "export": "pending", | |
| "message": "No operator action yet.", | |
| } | |
| def _zero_gpu_entrypoint(fn: Any) -> Any: | |
| gpu_decorator = getattr(spaces, "GPU", None) if spaces is not None else None | |
| if gpu_decorator is None: | |
| return fn | |
| return gpu_decorator(duration=300)(fn) | |
| def _relay_snapshot(adult_mode: bool = False) -> dict[str, Any]: | |
| return MODEL_RELAY.dashboard_snapshot(public_demo=not adult_mode) | |
| def _file_path(uploaded: Any) -> str | None: | |
| if uploaded is None: | |
| return None | |
| if isinstance(uploaded, str): | |
| return uploaded | |
| path = getattr(uploaded, "name", None) | |
| return str(path) if path else None | |
| def _safe_file_hash(path: str | None) -> tuple[str | None, int | None]: | |
| if not path: | |
| return None, None | |
| try: | |
| target = Path(path) | |
| sha256 = hashlib.sha256() | |
| size = 0 | |
| with target.open("rb") as handle: | |
| while chunk := handle.read(1024 * 1024): | |
| sha256.update(chunk) | |
| size += len(chunk) | |
| except OSError: | |
| return None, None | |
| return sha256.hexdigest(), size | |
| def _safe_reference_url_metadata(reference_url: str | None) -> dict[str, Any] | None: | |
| if not reference_url: | |
| return None | |
| parsed = urlparse(reference_url.strip()) | |
| if parsed.scheme not in {"http", "https"} or not parsed.netloc: | |
| return {"source": "url", "status": "invalid_url", "message": "Reference URL must be http(s)."} | |
| url_hash = hashlib.sha256(reference_url.strip().encode("utf-8")).hexdigest() | |
| return { | |
| "source": "url", | |
| "status": "metadata_only", | |
| "domain": parsed.netloc.lower(), | |
| "url_hash": url_hash, | |
| "message": "URL stored as metadata only; Space runtime does not crawl or copy shop images.", | |
| } | |
| def _reference_metadata(uploaded: Any, reference_url: str | None, scan: dict[str, Any]) -> list[dict[str, Any]]: | |
| records: list[dict[str, Any]] = [] | |
| path = _file_path(uploaded) | |
| if path: | |
| file_hash, size = _safe_file_hash(path) | |
| records.append({ | |
| "source": "upload", | |
| "basename": Path(path).name, | |
| "sha256": file_hash, | |
| "size_bytes": size, | |
| "st3gg_status": scan.get("status"), | |
| "export_gate": scan.get("export_gate"), | |
| "magic": scan.get("magic"), | |
| "extension": scan.get("extension"), | |
| }) | |
| url_record = _safe_reference_url_metadata(reference_url) | |
| if url_record: | |
| records.append(url_record) | |
| return records | |
| def _creator_controls( | |
| reasoning_mode: str, | |
| video_preset: str, | |
| silhouette: str | None = None, | |
| outerwear: str | None = None, | |
| upper_body: str | None = None, | |
| footwear: str | None = None, | |
| palette: str | None = None, | |
| hardware: str | None = None, | |
| locate_focus: list[str] | None = None, | |
| seed: int | None = None, | |
| style_strength: str = "High Fashion", | |
| aspect: str = "Portrait", | |
| ) -> dict[str, Any]: | |
| wardrobe = { | |
| "silhouette": silhouette or "structured long coat", | |
| "outerwear": outerwear or "black patent leather long coat", | |
| "upper_body": upper_body or "Chantilly lace neckline", | |
| "footwear": footwear or "platform boots", | |
| "palette": palette or "black, crimson, cyan neon", | |
| "hardware": hardware or "crimson hardware", | |
| "locked_slots": ["outerwear", "upper_body", "footwear", "jewelry"], | |
| "locate_focus": locate_focus or ["outerwear", "footwear", "jewelry"], | |
| } | |
| return { | |
| "reasoning_mode": reasoning_mode, | |
| "video_preset": video_preset, | |
| "wardrobe": wardrobe, | |
| "generation": { | |
| "flux_primary": "black-forest-labs/FLUX.2-klein-9B", | |
| "flux_sidecar": "black-forest-labs/FLUX.2-klein-4B", | |
| "lora_policy": "attempt compatible runtime adapter; report loaded/skipped/failed", | |
| "seed": seed, | |
| "style_strength": style_strength, | |
| "aspect": aspect, | |
| }, | |
| } | |
| def _resolve_seed(seed_value: Any) -> int: | |
| try: | |
| if seed_value is None or str(seed_value).strip() == "": | |
| return secrets.randbelow(1_000_000_000) | |
| seed = int(float(seed_value)) | |
| except (TypeError, ValueError): | |
| return secrets.randbelow(1_000_000_000) | |
| return secrets.randbelow(1_000_000_000) if seed < 0 else seed | |
| def _generation_dimensions(aspect: str | None) -> tuple[int, int]: | |
| return ASPECT_DIMENSIONS.get(str(aspect or "Portrait"), ASPECT_DIMENSIONS["Portrait"]) | |
| def _style_modifier(style_strength: str | None) -> str: | |
| return STYLE_MODIFIERS.get(str(style_strength or "High Fashion"), STYLE_MODIFIERS["High Fashion"]) | |
| def _prompt_with_controls(prompt: str, controls: dict[str, Any]) -> str: | |
| wardrobe = controls.get("wardrobe", {}) | |
| additions = [ | |
| wardrobe.get("silhouette"), | |
| wardrobe.get("outerwear"), | |
| wardrobe.get("upper_body"), | |
| wardrobe.get("footwear"), | |
| wardrobe.get("palette"), | |
| wardrobe.get("hardware"), | |
| ] | |
| suffix = ", ".join(str(item) for item in additions if item) | |
| generation = controls.get("generation", {}) | |
| if not suffix and not generation: | |
| return prompt | |
| style = _style_modifier(str(generation.get("style_strength", "High Fashion"))) | |
| prompt = f"{prompt}\nWardrobe controls: {suffix}" if suffix else prompt | |
| return f"{prompt}\nStyle direction: {style}" | |
| def _generated_output_path(operator_state: dict[str, Any] | None) -> str | None: | |
| generation = (operator_state or {}).get("generation") or {} | |
| output_path = generation.get("output_path") | |
| return str(output_path) if output_path else None | |
| def _authoritative_generated_scan(operator_state: dict[str, Any] | None) -> dict[str, Any]: | |
| output_path = _generated_output_path(operator_state) | |
| if output_path: | |
| return scan_file(output_path) | |
| stored_scan = (operator_state or {}).get("generated_scan") | |
| return stored_scan if isinstance(stored_scan, dict) else scan_file(None) | |
| def _checkpoint_seed(checkpoint_id: str) -> int: | |
| suffix = "".join(char for char in checkpoint_id[-8:] if char in "0123456789abcdefABCDEF") | |
| if not suffix: | |
| return 0 | |
| try: | |
| return int(suffix, 16) % 1_000_000 | |
| except ValueError: | |
| return 0 | |
| def _wardrobe_summary(run: Any) -> str: | |
| slots = getattr(getattr(run, "outfit", None), "slots", []) or [] | |
| return "; ".join( | |
| f"{slot.name}: {slot.description}, material={slot.material}, palette={slot.palette}, locked={slot.locked}" | |
| for slot in slots | |
| ) | |
| SECTIONS = ["Forge", "Wardrobe", "Lore", "Models", "Security", "Runs"] | |
| def _button_updates(run: Any | None, operator_state: dict[str, Any] | None) -> tuple[Any, Any, Any]: | |
| state = operator_state or {} | |
| generated = bool(_generated_output_path(state)) and (state.get("generation") or {}).get("status") == "success" | |
| checkpoint_approved = state.get("checkpoint") == "approved" | |
| exported = state.get("provider_state") == "exported" | |
| return ( | |
| gr.update(interactive=generated and not checkpoint_approved and not exported), | |
| gr.update(interactive=generated and checkpoint_approved and not exported), | |
| gr.update(interactive=False), | |
| ) | |
| def _dashboard_regions( | |
| run: Any | None = None, | |
| adult_mode: bool = False, | |
| scan: dict[str, Any] | None = None, | |
| active_section: str = "Forge", | |
| operator_state: dict[str, Any] | None = None, | |
| ) -> dict[str, str]: | |
| return render_dashboard_regions( | |
| run=run, | |
| adult_mode=adult_mode, | |
| scan=scan, | |
| relay_status=_relay_snapshot(adult_mode), | |
| active_section=active_section, | |
| operator_state=operator_state, | |
| ) | |
| # βββ Modal Integration βββ | |
| MODAL_AVAILABLE = False | |
| try: | |
| import modal | |
| MODAL_AVAILABLE = True | |
| except ImportError: | |
| pass | |
| LORA_ADAPTERS = { | |
| "garment": {"repo": "NO8D/BodyControl", "desc": "Body/garment shape control", "weight": 0.75}, | |
| "hardware": {"repo": "NO8D/ExpressionControl", "desc": "Expression/hardware detail", "weight": 0.70}, | |
| "realism": {"repo": "fal/realism-detailer", "desc": "Photorealistic detail boost", "weight": 0.60}, | |
| "metallic": {"repo": "ilkerzgi/metallic", "desc": "Metallic material finish", "weight": 0.55}, | |
| "glittering": {"repo": "ilkerzgi/glittering-portrait", "desc": "Glittering portrait effects", "weight": 0.55}, | |
| "embroidery": {"repo": "ilkerzgi/embroidery-patch", "desc": "Embroidery/patch textures", "weight": 0.55}, | |
| } | |
| GPU_OPTIONS = { | |
| "A100-80GB": {"price": 1.80, "modal_gpu": "A100"}, | |
| "A100-40GB": {"price": 1.10, "modal_gpu": "A10G"}, | |
| "L40S": {"price": 1.05, "modal_gpu": "L40S"}, | |
| "T4": {"price": 0.40, "modal_gpu": "T4"}, | |
| } | |
| MODAL_COST_TRACKER = {"credits_remaining": 250.88, "total_spent": 0.0, "refinements": 0} | |
| def _modal_refine_image(image_bytes: bytes, user_addition: str, gpu_type: str = "A100-80GB", | |
| strength: float = 0.58, steps: int = 32, guidance_scale: float = 3.8, | |
| seed: int = -1, lora_adapters: list | None = None, | |
| negative_prompt: str = "blurry, low quality, deformed, extra limbs") -> tuple: | |
| if not MODAL_AVAILABLE: | |
| return None, "β Modal not installed" | |
| try: | |
| fn = modal.Function.lookup("nexus-couture-refine-v2", "refine_couture") | |
| result_bytes = fn.remote( | |
| image_bytes=image_bytes, | |
| user_addition=user_addition, | |
| strength=strength, | |
| steps=steps, | |
| guidance_scale=guidance_scale, | |
| seed=seed, | |
| lora_adapters=lora_adapters or ["garment"], | |
| negative_prompt=negative_prompt, | |
| gpu_type=gpu_type, | |
| ) | |
| gpu_info = GPU_OPTIONS.get(gpu_type, GPU_OPTIONS["A100-80GB"]) | |
| est_cost = round(gpu_info["price"] * (steps / 60), 4) | |
| MODAL_COST_TRACKER["total_spent"] += est_cost | |
| MODAL_COST_TRACKER["credits_remaining"] -= est_cost | |
| MODAL_COST_TRACKER["refinements"] += 1 | |
| return result_bytes, f"β Modal refinement complete on {gpu_type}" | |
| except Exception as e: | |
| return None, f"β Modal error: {str(e)[:200]}" | |
| def _modal_health_check() -> dict: | |
| if not MODAL_AVAILABLE: | |
| return {"status": "unavailable", "message": "Modal not installed"} | |
| try: | |
| fn = modal.Function.lookup("nexus-couture-refine-v2", "check_modal_health") | |
| return fn.remote() | |
| except Exception as e: | |
| return {"status": "error", "message": str(e)[:200]} | |
| def run_weave( | |
| prompt, reasoning_mode, video_preset, adult_mode, upload, active_section, | |
| silhouette=None, outerwear=None, upper_body=None, footwear=None, palette=None, | |
| hardware=None, reference_url=None, seed_value=-1, style_strength="High Fashion", aspect="Portrait", | |
| ): | |
| prompt = prompt.strip() or DEFAULT_PROMPT | |
| resolved_seed = _resolve_seed(seed_value) | |
| width, height = _generation_dimensions(aspect) | |
| controls = _creator_controls( | |
| reasoning_mode=reasoning_mode, video_preset=video_preset, | |
| silhouette=silhouette, outerwear=outerwear, upper_body=upper_body, | |
| footwear=footwear, palette=palette, hardware=hardware, | |
| seed=resolved_seed, style_strength=style_strength, aspect=aspect, | |
| ) | |
| controlled_prompt = _prompt_with_controls(prompt, controls) | |
| reference_scan = scan_file(_file_path(upload)) | |
| reference_metadata = _reference_metadata(upload, reference_url, reference_scan) | |
| run = build_command_center_run( | |
| prompt=controlled_prompt, mode=reasoning_mode, video_preset=video_preset, | |
| adult_mode=adult_mode, creator_controls=controls, reference_metadata=reference_metadata, | |
| ) | |
| generation = generate_flux_image( | |
| run.refined_prompt.refined, seed=resolved_seed, width=width, height=height, adult_mode=adult_mode, | |
| ) | |
| generated_scan = scan_file(generation.output_path) if generation.output_path else scan_file(None) | |
| minicpm = judge_with_minicpm( | |
| prompt=run.refined_prompt.refined, image_path=generation.output_path, | |
| scan=generated_scan, wardrobe_summary=_wardrobe_summary(run), | |
| ) | |
| nemotron = judge_with_nemotron( | |
| prompt=run.refined_prompt.refined, run_packet=run.to_dict(), minicpm_result=minicpm.to_dict(), | |
| ) | |
| if generation.status == "success": | |
| provider_state = "generated" | |
| elif generation.status in {"disabled", "missing_runtime", "no_cuda", "error"}: | |
| provider_state = generation.provider_state | |
| else: | |
| provider_state = "checkpointed" | |
| operator_state = { | |
| "provider_state": provider_state, | |
| "checkpoint": "pending_review", | |
| "export": generated_scan.get("export_gate", "pending"), | |
| "message": generation.message or "Image run complete. Human checkpoint required before export.", | |
| "generation": generation.to_dict(), | |
| "creator_controls": controls, | |
| "reference_metadata": reference_metadata, | |
| "reference_scan": reference_scan, | |
| "generated_scan": generated_scan, | |
| "minicpm_judge": minicpm.to_dict(), | |
| "nemotron_evidence": nemotron.to_dict(), | |
| } | |
| regions = _dashboard_regions( | |
| run=run, adult_mode=adult_mode, scan=generated_scan, | |
| active_section=active_section, operator_state=operator_state, | |
| ) | |
| catalog = render_catalog_table(adult_mode=adult_mode) | |
| return ( | |
| regions["topbar"], regions["command_rail"], regions["workflow"], | |
| regions["operations"], regions["inspector"], regions["drawer"], | |
| regions["status"], regions["artifacts"], regions["providers"], | |
| catalog, run.to_dict(), catalog_summary(adult_mode), | |
| generated_scan, run, generated_scan, operator_state, | |
| *_button_updates(run, operator_state), | |
| ) | |
| def toggle_adult_visibility(adult_mode, active_section, upload): | |
| scan = scan_file(_file_path(upload)) | |
| operator_state = { | |
| **_default_operator_state(), | |
| "message": "Adult catalog visibility changed. ST3GG, consent, and export gates remain active.", | |
| } | |
| regions = _dashboard_regions(adult_mode=adult_mode, scan=scan, active_section=active_section, operator_state=operator_state) | |
| return ( | |
| regions["topbar"], regions["command_rail"], regions["operations"], | |
| regions["inspector"], regions["artifacts"], regions["providers"], | |
| render_catalog_table(adult_mode=adult_mode), catalog_summary(adult_mode), scan, operator_state, | |
| ) | |
| def refresh_section(active_section, adult_mode, run, scan, operator_state): | |
| scan = scan or scan_file(None) | |
| regions = _dashboard_regions( | |
| run=run, adult_mode=adult_mode, scan=scan, | |
| active_section=active_section, operator_state=operator_state or _default_operator_state(), | |
| ) | |
| return regions["command_rail"], regions["operations"], regions["inspector"], regions["artifacts"], regions["providers"], scan | |
| def _render_stateful(run, adult_mode, scan, active_section, operator_state): | |
| scan = scan or scan_file(None) | |
| regions = _dashboard_regions( | |
| run=run, adult_mode=adult_mode, scan=scan, | |
| active_section=active_section, operator_state=operator_state, | |
| ) | |
| return ( | |
| regions["topbar"], regions["command_rail"], regions["workflow"], | |
| regions["operations"], regions["inspector"], regions["drawer"], | |
| regions["status"], regions["artifacts"], regions["providers"], | |
| render_catalog_table(adult_mode=adult_mode), | |
| run.to_dict() if hasattr(run, "to_dict") else {}, | |
| catalog_summary(adult_mode), scan, operator_state, | |
| *_button_updates(run, operator_state), | |
| ) | |
| def scan_reference(run, adult_mode, upload, active_section, operator_state, reference_url=None): | |
| state = operator_state or _default_operator_state() | |
| reference_path = _file_path(upload) | |
| reference_scan = scan_file(reference_path) | |
| reference_metadata = _reference_metadata(upload, reference_url, reference_scan) | |
| generated_scan = _authoritative_generated_scan(state) | |
| minicpm = None | |
| if run is not None and reference_path: | |
| minicpm = judge_with_minicpm( | |
| prompt=getattr(getattr(run, "refined_prompt", None), "refined", DEFAULT_PROMPT), | |
| image_path=reference_path, scan=reference_scan, wardrobe_summary=_wardrobe_summary(run), | |
| ) | |
| next_state = { | |
| **state, | |
| **({"reference_judge": minicpm.to_dict()} if minicpm else {}), | |
| "reference_metadata": reference_metadata, | |
| "reference_scan": reference_scan, | |
| "reference_export_gate": reference_scan.get("export_gate", "pending"), | |
| "export": state.get("export", generated_scan.get("export_gate", "pending")), | |
| "message": ( | |
| "Reference scan complete. Generated artifact export gate is unchanged." | |
| if reference_scan.get("export_gate") == "clear" | |
| else "Reference scan requires review. Generated artifact export gate is unchanged." | |
| ), | |
| } | |
| rendered = _render_stateful(run, adult_mode, generated_scan, active_section, next_state) | |
| return (*rendered, generated_scan) | |
| def approve_checkpoint(run, adult_mode, scan, active_section, operator_state): | |
| state = operator_state or _default_operator_state() | |
| scan = _authoritative_generated_scan(state) | |
| if run is None: | |
| next_state = {**_default_operator_state(), "provider_state": "blocked", "message": "No run exists yet. Generate an image first."} | |
| elif not _generated_output_path(state): | |
| next_state = {**state, "provider_state": "blocked", "checkpoint": "pending", "message": "Checkpoint blocked: no generated artifact exists yet."} | |
| else: | |
| export_state = scan.get("export_gate", "pending") | |
| next_state = { | |
| **state, | |
| "provider_state": "export_ready" if export_state == "clear" else "checkpointed", | |
| "checkpoint": "approved", "generated_scan": scan, "export": export_state, | |
| "message": ( | |
| "Checkpoint approved. Export is ready after clear ST3GG scan." | |
| if export_state == "clear" | |
| else "Checkpoint approved. Add an override reason and click Prepare Audit Export to write an audit packet." | |
| ), | |
| } | |
| return _render_stateful(run, adult_mode, scan, active_section, next_state) | |
| def export_packet(run, adult_mode, scan, active_section, operator_state, override_reason=None): | |
| state = operator_state or _default_operator_state() | |
| scan = _authoritative_generated_scan(state) | |
| override_reason = (override_reason or "").strip() | |
| if run is None: | |
| next_state = {**state, "provider_state": "blocked", "export": "blocked", "message": "Export waits for review: generate an image before preparing an audit packet."} | |
| elif state.get("checkpoint") != "approved": | |
| next_state = {**state, "provider_state": "blocked", "export": "blocked", "message": "Export gate active: approve the human checkpoint before release."} | |
| elif not _generated_output_path(state): | |
| next_state = {**state, "provider_state": "blocked", "export": "blocked", "message": "Export waits for review: generate an artifact before preparing evidence."} | |
| elif scan.get("export_gate") != "clear" and not override_reason: | |
| next_state = {**state, "provider_state": "blocked", "export": scan.get("export_gate", "blocked"), "message": "Export gate active: ST3GG is not clear. Add an explicit override reason to write an audit packet."} | |
| else: | |
| export_state = "clear" if scan.get("export_gate") == "clear" else "override" | |
| override_applies = scan.get("export_gate") != "clear" and bool(override_reason) | |
| export_operator_state = {**state, **({"st3gg_override_reason": override_reason} if override_applies else {}), "export": export_state} | |
| export = write_export_packet(run=run, scan=scan, operator_state=export_operator_state, adult_mode=adult_mode) | |
| next_state = { | |
| **export_operator_state, "provider_state": "exported", "export": export_state, | |
| "export_packet": {"path": export["path"]}, | |
| "message": f"Governed export packet prepared: {export['path']}" if export_state == "clear" else f"ST3GG override audit packet prepared: {export['path']}", | |
| } | |
| return _render_stateful(run, adult_mode, scan, active_section, next_state) | |
| def stop_provider_job(run, adult_mode, scan, active_section, operator_state): | |
| scan = scan or scan_file(None) | |
| next_state = { | |
| **(operator_state or _default_operator_state()), | |
| "provider_state": "stopped", | |
| "message": "Provider handoff stopped. Local run packet and evidence remain available.", | |
| } | |
| return _render_stateful(run, adult_mode, scan, active_section, next_state) | |
| def reset_demo(adult_mode, active_section): | |
| scan = scan_file(None) | |
| operator_state = _default_operator_state() | |
| regions = _dashboard_regions(adult_mode=adult_mode, scan=scan, active_section=active_section, operator_state=operator_state) | |
| return ( | |
| regions["topbar"], regions["command_rail"], regions["workflow"], | |
| regions["operations"], regions["inspector"], regions["drawer"], | |
| regions["status"], regions["artifacts"], regions["providers"], | |
| render_catalog_table(adult_mode=adult_mode), | |
| {}, catalog_summary(adult_mode), scan, None, scan, operator_state, | |
| gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=False), | |
| ) | |
| # βββ Modal Tab Handlers βββ | |
| def modal_refine_handler(input_image, user_addition, gpu_type, strength, steps, guidance, seed, lora_choices, negative_prompt): | |
| if input_image is None: | |
| return None, "β No input image provided" | |
| from PIL import Image as PILImage | |
| from io import BytesIO | |
| buf = BytesIO() | |
| if isinstance(input_image, str): | |
| img = PILImage.open(input_image) | |
| else: | |
| img = PILImage.open(input_image) | |
| img.save(buf, format="PNG") | |
| image_bytes = buf.getvalue() | |
| result_bytes, message = _modal_refine_image( | |
| image_bytes=image_bytes, user_addition=user_addition, | |
| gpu_type=gpu_type, strength=strength, steps=int(steps), | |
| guidance_scale=guidance, seed=int(seed), | |
| lora_adapters=lora_choices if lora_choices else ["garment"], | |
| negative_prompt=negative_prompt, | |
| ) | |
| if result_bytes: | |
| result_img = PILImage.open(BytesIO(result_bytes)) | |
| cost_info = f"Credits remaining: ${MODAL_COST_TRACKER['credits_remaining']:.2f} | Refinements: {MODAL_COST_TRACKER['refinements']}" | |
| return result_img, f"{message}\n{cost_info}" | |
| return None, message | |
| def modal_health_handler(): | |
| result = _modal_health_check() | |
| if result.get("status") == "healthy": | |
| return f"β Modal connected\nGPU: {result.get('gpu', 'N/A')}" | |
| elif result.get("status") == "unavailable": | |
| return f"β οΈ {result.get('message', 'Modal not available')}" | |
| else: | |
| return f"β Modal error: {result.get('message', 'Unknown')}" | |
| initial_operator_state = _default_operator_state() | |
| initial_regions = _dashboard_regions(scan=scan_file(None), operator_state=initial_operator_state) | |
| with gr.Blocks(title="NEXUS Visual Weaver") as demo: | |
| active_run_state = gr.State(None) | |
| scan_state = gr.State(scan_file(None)) | |
| operator_state = gr.State(initial_operator_state) | |
| topbar_html = gr.HTML(initial_regions["topbar"], container=False, visible=False) | |
| with gr.Tabs(): | |
| # βββ Tab 1: Studio βββ | |
| with gr.Tab("π§΅ Studio"): | |
| with gr.Row(elem_id="nw-creator-workbench", elem_classes=["nw-creator-workbench"]): | |
| with gr.Column(scale=5, min_width=520, elem_id="nw-creator-panel"): | |
| gr.Markdown("### Create Couture Image") | |
| gr.Markdown("Describe the look, choose wardrobe controls, then generate. Reference upload is optional.") | |
| prompt = gr.Textbox(value=DEFAULT_PROMPT, label="Describe the look", lines=4, max_lines=6) | |
| with gr.Row(): | |
| seed_value = gr.Number(value=-1, precision=0, label="Seed (-1 randomizes)") | |
| style_strength = gr.Dropdown(["Balanced", "High Fashion", "Cinematic"], value="High Fashion", label="Style Strength") | |
| aspect = gr.Dropdown(["Portrait", "Square"], value="Portrait", label="Aspect") | |
| with gr.Row(elem_classes=["nw-primary-actions"]): | |
| run_btn = gr.Button("Generate Image", variant="primary", scale=2) | |
| reset_btn = gr.Button("Reset", scale=1) | |
| with gr.Row(): | |
| silhouette = gr.Dropdown(["structured long coat", "fitted gothic bodice", "layered tactical silhouette"], value="structured long coat", label="Silhouette") | |
| outerwear = gr.Dropdown(["black patent leather long coat", "faux fur collar coat", "tailored rain slicker"], value="black patent leather long coat", label="Outerwear") | |
| with gr.Row(): | |
| upper_body = gr.Dropdown(["Chantilly lace neckline", "black mesh layer", "structured corset bodice"], value="Chantilly lace neckline", label="Upper Body") | |
| footwear = gr.Dropdown(["platform boots", "patent leather heels", "armored couture boots"], value="platform boots", label="Footwear") | |
| with gr.Row(): | |
| palette = gr.Dropdown(["black, crimson, cyan neon", "obsidian, pearl, crimson", "graphite, magenta, cold blue"], value="black, crimson, cyan neon", label="Palette") | |
| hardware = gr.Dropdown(["crimson hardware", "silver occult buckles", "holographic NEXUS sigils"], value="crimson hardware", label="Hardware") | |
| with gr.Accordion("Advanced: scan external file", open=False): | |
| gr.Markdown("Optional. Generate directly unless you need ST3GG to inspect an uploaded reference or output file.") | |
| with gr.Row(): | |
| reasoning_mode = gr.Radio(["Strict", "Frontier"], value="Strict", label="Reasoning Mode") | |
| video_preset = gr.Dropdown(["Wan2.2 I2V", "LTX-2.3"], value="Wan2.2 I2V", label="Video preset (deferred)") | |
| with gr.Row(): | |
| adult_mode = gr.Checkbox(value=False, label="Adult Mode 18+ catalog scope", info="Off by default. Never disables security, consent, or export gates.") | |
| reference_url = gr.Textbox(label="Reference URL (metadata only)", placeholder="https://shop.example/reference-garment") | |
| upload = gr.File(label="Optional file for ST3GG scan", file_count="single", type="filepath") | |
| with gr.Row(): | |
| scan_btn = gr.Button("Scan Uploaded File", scale=1) | |
| stop_btn = gr.Button("Stop Job", variant="stop", interactive=False, scale=1) | |
| with gr.Column(scale=4, min_width=460, elem_id="nw-output-panel"): | |
| gr.Markdown("### Output") | |
| artifact_html = gr.HTML(initial_regions["artifacts"], container=False) | |
| with gr.Row(elem_id="nw-checkpoint-actions", elem_classes=["nw-checkpoint-actions"]): | |
| checkpoint_btn = gr.Button("Approve Checkpoint", scale=1, interactive=False) | |
| export_btn = gr.Button("Prepare Audit Export", scale=1, interactive=False) | |
| override_reason = gr.Textbox( | |
| label="ST3GG Override Reason", | |
| placeholder="Required only when ST3GG asks for review; explain why this audit packet may be written.", | |
| lines=2, max_lines=3, | |
| ) | |
| gr.Markdown("Generation is not export. Every artifact stays behind ST3GG review and human checkpoint.") | |
| # βββ Tab 2: Modal Refinement (ACTIVE) βββ | |
| with gr.Tab("β‘ Modal"): | |
| gr.Markdown("## β‘ Modal GPU Refinement") | |
| gr.Markdown("Send a generated image to Modal for FLUX.1-Kontext-dev refinement with multi-LoRA on dedicated GPU.") | |
| with gr.Row(): | |
| with gr.Column(scale=1): | |
| modal_input_image = gr.Image(label="Input Image (from Studio or upload)", type="filepath") | |
| modal_user_addition = gr.Textbox(label="Additional prompt text", placeholder="glowing crimson buckles, wet pavement reflection", value="") | |
| modal_gpu = gr.Dropdown(choices=list(GPU_OPTIONS.keys()), value="A100-80GB", label="GPU Type") | |
| modal_loras = gr.CheckboxGroup(choices=list(LORA_ADAPTERS.keys()), value=["garment", "realism"], label="LoRA Adapters") | |
| with gr.Row(): | |
| modal_strength = gr.Slider(0.1, 1.0, value=0.58, step=0.02, label="Strength") | |
| modal_steps = gr.Slider(10, 64, value=32, step=2, label="Steps") | |
| with gr.Row(): | |
| modal_guidance = gr.Slider(1.0, 15.0, value=3.8, step=0.2, label="Guidance Scale") | |
| modal_seed = gr.Number(value=-1, precision=0, label="Seed (-1 random)") | |
| modal_negative = gr.Textbox(label="Negative Prompt", value="blurry, low quality, deformed, extra limbs, bad anatomy, watermark, text") | |
| with gr.Row(): | |
| modal_refine_btn = gr.Button("π¨ Refine on Modal", variant="primary") | |
| modal_health_btn = gr.Button("π Health Check", variant="secondary") | |
| with gr.Column(scale=1): | |
| modal_output_image = gr.Image(label="Refined Output") | |
| modal_status = gr.Textbox(label="Status", lines=3, interactive=False) | |
| modal_cost_display = gr.Markdown( | |
| f"**Credits Remaining:** ${MODAL_COST_TRACKER['credits_remaining']:.2f} | " | |
| f"**Spent:** ${MODAL_COST_TRACKER['total_spent']:.4f} | " | |
| f"**Refinements:** {MODAL_COST_TRACKER['refinements']}" | |
| ) | |
| modal_refine_btn.click( | |
| fn=modal_refine_handler, | |
| inputs=[modal_input_image, modal_user_addition, modal_gpu, modal_strength, | |
| modal_steps, modal_guidance, modal_seed, modal_loras, modal_negative], | |
| outputs=[modal_output_image, modal_status], | |
| ) | |
| modal_health_btn.click(fn=modal_health_handler, inputs=[], outputs=[modal_status]) | |
| # βββ Tab 3: LoRA Lab (ACTIVE) βββ | |
| with gr.Tab("π§ͺ LoRA Lab"): | |
| gr.Markdown("## π§ͺ LoRA Training Lab") | |
| gr.Markdown("Train custom LoRA adapters on Modal GPU. Connect a dataset repo and configure training parameters.") | |
| with gr.Row(): | |
| with gr.Column(scale=1): | |
| lora_dataset_repo = gr.Textbox(label="Dataset Repo (HF)", value="specimba/nexus-couture-training", placeholder="username/dataset-name") | |
| lora_output_name = gr.Textbox(label="Output Adapter Name", value="nexus-couture-v1") | |
| with gr.Row(): | |
| lora_rank = gr.Slider(4, 64, value=16, step=4, label="Rank") | |
| lora_lr = gr.Textbox(label="Learning Rate", value="1e-4") | |
| with gr.Row(): | |
| lora_steps = gr.Slider(100, 3000, value=800, step=100, label="Training Steps") | |
| lora_batch = gr.Slider(1, 16, value=4, step=1, label="Batch Size") | |
| lora_push = gr.Checkbox(label="Push to Hub after training", value=False) | |
| lora_hub_repo = gr.Textbox(label="Hub Repo (if pushing)", value="build-small-hackathon/nexus-couture-lora") | |
| lora_train_btn = gr.Button("π Start Training on Modal", variant="primary") | |
| with gr.Column(scale=1): | |
| lora_train_status = gr.Textbox(label="Training Status", lines=8, interactive=False) | |
| gr.Markdown("### Available LoRA Adapters") | |
| lora_catalog_md = "\n".join( | |
| f"- **{k}**: {v['desc']} (`{v['repo']}`, weight={v['weight']})" | |
| for k, v in LORA_ADAPTERS.items() | |
| ) | |
| gr.Markdown(lora_catalog_md) | |
| def lora_train_handler(dataset_repo, output_name, rank, lr, steps, batch, push, hub_repo): | |
| if not MODAL_AVAILABLE: | |
| return "β Modal not installed" | |
| try: | |
| fn = modal.Function.lookup("nexus-couture-lora-trainer", "train_nexus_couture_lora") | |
| fn.remote( | |
| dataset_repo=dataset_repo, output_name=output_name, | |
| rank=int(rank), steps=int(steps), learning_rate=float(lr), | |
| batch_size=int(batch), push_to_hub=push, hub_repo=hub_repo, | |
| ) | |
| return f"β Training triggered on Modal!\nDataset: {dataset_repo}\nOutput: {output_name}\nRank: {rank}, Steps: {steps}, LR: {lr}" | |
| except Exception as e: | |
| return f"β Training error: {str(e)[:300]}" | |
| lora_train_btn.click( | |
| fn=lora_train_handler, | |
| inputs=[lora_dataset_repo, lora_output_name, lora_rank, lora_lr, | |
| lora_steps, lora_batch, lora_push, lora_hub_repo], | |
| outputs=[lora_train_status], | |
| ) | |
| # βββ Tab 4: Technical Evidence βββ | |
| with gr.Tab("π Evidence"): | |
| with gr.Accordion("Run Anatomy", open=False): | |
| with gr.Row(elem_id="nw-workspace", elem_classes=["nw-workspace"]): | |
| with gr.Column(scale=1, min_width=160, elem_id="nw-native-rail"): | |
| section_nav = gr.Radio(SECTIONS, value="Forge", label="Technical Section", elem_id="nw-section-nav") | |
| command_rail_html = gr.HTML(initial_regions["command_rail"], container=False) | |
| with gr.Column(scale=5, min_width=620, elem_id="nw-main-column"): | |
| workflow_html = gr.HTML(initial_regions["workflow"], container=False) | |
| with gr.Accordion("Wardrobe Evidence", open=False): | |
| operations_html = gr.HTML(initial_regions["operations"], container=False) | |
| drawer_html = gr.HTML(initial_regions["drawer"], container=False) | |
| with gr.Accordion("Technical Evidence", open=False): | |
| status_html = gr.HTML(initial_regions["status"], container=False) | |
| inspector_html = gr.HTML(initial_regions["inspector"], container=False) | |
| with gr.Accordion("Provider Diagnostics", open=False): | |
| provider_html = gr.HTML(initial_regions["providers"], container=False) | |
| with gr.Accordion("Catalog, run record, and security evidence", open=False): | |
| catalog_html = gr.HTML(render_catalog_table(False), container=False) | |
| with gr.Row(): | |
| run_json = gr.JSON(label="GenerationRun") | |
| catalog_json = gr.JSON(label="Catalog Summary") | |
| scan_json = gr.JSON(label="ST3GG Scan") | |
| dashboard_outputs = [ | |
| topbar_html, command_rail_html, workflow_html, operations_html, | |
| inspector_html, drawer_html, status_html, artifact_html, | |
| provider_html, catalog_html, run_json, catalog_json, scan_json, | |
| ] | |
| stateful_outputs = dashboard_outputs + [active_run_state, scan_state, operator_state, checkpoint_btn, export_btn, stop_btn] | |
| operator_outputs = dashboard_outputs + [operator_state, checkpoint_btn, export_btn, stop_btn] | |
| run_click = run_btn.click( | |
| fn=run_weave, | |
| inputs=[prompt, reasoning_mode, video_preset, adult_mode, upload, section_nav, | |
| silhouette, outerwear, upper_body, footwear, palette, hardware, | |
| reference_url, seed_value, style_strength, aspect], | |
| outputs=stateful_outputs, api_name="run_active_weave", | |
| concurrency_limit=1, concurrency_id="flux-gpu", | |
| ) | |
| run_submit = prompt.submit( | |
| fn=run_weave, | |
| inputs=[prompt, reasoning_mode, video_preset, adult_mode, upload, section_nav, | |
| silhouette, outerwear, upper_body, footwear, palette, hardware, | |
| reference_url, seed_value, style_strength, aspect], | |
| outputs=stateful_outputs, api_name=False, | |
| concurrency_limit=1, concurrency_id="flux-gpu", | |
| ) | |
| adult_mode.change( | |
| fn=toggle_adult_visibility, | |
| inputs=[adult_mode, section_nav, upload], | |
| outputs=[topbar_html, command_rail_html, operations_html, inspector_html, | |
| artifact_html, provider_html, catalog_html, catalog_json, scan_json, operator_state], | |
| api_name="toggle_adult_catalog", queue=False, | |
| ) | |
| section_nav.change( | |
| fn=refresh_section, | |
| inputs=[section_nav, adult_mode, active_run_state, scan_state, operator_state], | |
| outputs=[command_rail_html, operations_html, inspector_html, artifact_html, provider_html, scan_json], | |
| api_name=False, queue=False, | |
| ) | |
| scan_btn.click( | |
| fn=scan_reference, | |
| inputs=[active_run_state, adult_mode, upload, section_nav, operator_state, reference_url], | |
| outputs=dashboard_outputs + [operator_state, checkpoint_btn, export_btn, stop_btn, scan_state], | |
| api_name="scan_reference", queue=False, | |
| ) | |
| checkpoint_btn.click( | |
| fn=approve_checkpoint, | |
| inputs=[active_run_state, adult_mode, scan_state, section_nav, operator_state], | |
| outputs=operator_outputs, api_name="approve_checkpoint", queue=False, | |
| ) | |
| export_btn.click( | |
| fn=export_packet, | |
| inputs=[active_run_state, adult_mode, scan_state, section_nav, operator_state, override_reason], | |
| outputs=operator_outputs, api_name="prepare_export_packet", queue=False, | |
| ) | |
| stop_btn.click( | |
| fn=stop_provider_job, | |
| inputs=[active_run_state, adult_mode, scan_state, section_nav, operator_state], | |
| outputs=operator_outputs, api_name="stop_provider_job", queue=False, | |
| cancels=[run_click, run_submit], | |
| ) | |
| reset_btn.click( | |
| fn=reset_demo, | |
| inputs=[adult_mode, section_nav], | |
| outputs=stateful_outputs, api_name="reset_demo_state", queue=False, | |
| cancels=[run_click, run_submit], | |
| ) | |
| demo.load( | |
| fn=lambda: (render_catalog_table(False), catalog_summary(False), scan_file(None), scan_file(None), _default_operator_state()), | |
| outputs=[catalog_html, catalog_json, scan_json, scan_state, operator_state], | |
| api_name=False, | |
| ) | |
| if __name__ == "__main__": | |
| if hasattr(sys.stdout, "reconfigure"): | |
| sys.stdout.reconfigure(encoding="utf-8", errors="replace") | |
| if hasattr(sys.stderr, "reconfigure"): | |
| sys.stderr.reconfigure(encoding="utf-8", errors="replace") | |
| demo.launch( | |
| server_name="0.0.0.0", | |
| server_port=int(os.environ.get("NEXUS_PORT", os.environ.get("PORT", "7860"))), | |
| quiet=True, | |
| mcp_server=True, | |
| ssr_mode=False, | |
| css=APP_CSS, | |
| ) |