SkillAgentSearch skills...

PANO

๐Ÿ” PANO: Advanced OSINT investigation platform combining graph visualization, timeline analysis, and AI assistance to uncover hidden connections in data. Built with Python and modern Qt.

Install / Use

/learn @ALW1EZ/PANO
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

PANO - Platform for Analysis and Network Operations

<div align="center">

PANO Logo

License: CC BY-NC Python 3.11+ PySide6 Platform

PANO is a powerful OSINT investigation platform that combines graph visualization, timeline analysis, and AI-powered tools to help you uncover hidden connections and patterns in your data.

Getting Started โ€ข Features โ€ข Documentation โ€ข Contributing


https://github.com/user-attachments/assets/6b95e97a-ffdd-4056-b12b-f268d8e5d565

https://github.com/user-attachments/assets/af0c0f65-7b79-417c-a678-a789d42a6003

https://github.com/user-attachments/assets/568b4c28-be78-4559-a607-899fca2f9613

https://github.com/user-attachments/assets/6aa191eb-09de-41d5-b96f-4a2e32d6a0c2

https://github.com/user-attachments/assets/96377b80-e137-4eb4-9387-a0db4e49c2c1

https://github.com/user-attachments/assets/4228bda0-6c13-4ea9-bc07-d87abe367e10

</div>

๐Ÿš€ Getting Started

  1. Clone the repository:

    git clone https://github.com/ALW1EZ/PANO.git
    cd PANO
    
  2. Run the application:

    • Linux: ./start_pano.sh
    • Windows: start_pano.bat

The startup script will automatically:

  • Check for updates
  • Set up the Python environment
  • Install dependencies
  • Launch PANO

In order to use Email Lookup transform You need to login with GHunt first. After starting the pano via starter scripts;

  1. Select venv manually
    • Linux: source venv/bin/activate
    • Windows: call venv\Scripts\activate
  2. See how to login here

๐Ÿ’ก Quick Start Guide

  1. Create Investigation: Start a new investigation or load an existing one
  2. Add Entities: Drag entities from the sidebar onto the graph
  3. Discover Connections: Use transforms to automatically find relationships
  4. Analyze: Use timeline and map views to understand patterns
  5. Save: Export your investigation for later use

๐Ÿ” Features

๐Ÿ•ธ๏ธ Core Functionality

  • Interactive Graph Visualization

    • Drag-and-drop entity creation
    • Multiple layout algorithms (Circular, Hierarchical, Radial, Force-Directed)
    • Dynamic relationship mapping
    • Visual node and edge styling
  • Timeline Analysis

    • Chronological event visualization
    • Interactive timeline navigation
    • Event filtering and grouping
    • Temporal relationship analysis
  • Map Integration

    • Geographic data visualization
    • Location-based analysis
    • Interactive mapping features
    • Coordinate plotting and tracking

๐ŸŽฏ Entity Management

  • Supported Entity Types
    • ๐Ÿ“ง Email addresses
    • ๐Ÿ‘ค Usernames
    • ๐ŸŒ Websites
    • ๐Ÿ–ผ๏ธ Images
    • ๐Ÿ“ Locations
    • โฐ Events
    • ๐Ÿ“ Text content
    • ๐Ÿ”ง Custom entity types

๐Ÿ”„ Transform System

  • Email Analysis

    • Google account investigation
    • Calendar event extraction
    • Location history analysis
    • Connected services discovery
  • Username Analysis

    • Cross-platform username search
    • Social media profile discovery
    • Platform correlation
    • Web presence analysis
  • Image Analysis

    • Reverse image search
    • Visual content analysis
    • Metadata extraction
    • Related image discovery

๐Ÿค– AI Integration

  • PANAI
    • Natural language investigation assistant
    • Automated entity extraction and relationship mapping
    • Pattern recognition and anomaly detection
    • Multi-language support
    • Context-aware suggestions
    • Timeline and graph analysis

๐Ÿงฉ Core Components

๐Ÿ“ฆ Entities

Entities are the fundamental building blocks of PANO. They represent distinct pieces of information that can be connected and analyzed:

  • Built-in Types

    • ๐Ÿ“ง Email: Email addresses with service detection
    • ๐Ÿ‘ค Username: Social media and platform usernames
    • ๐ŸŒ Website: Web pages with metadata
    • ๐Ÿ–ผ๏ธ Image: Images with EXIF and analysis
    • ๐Ÿ“ Location: Geographic coordinates and addresses
    • โฐ Event: Time-based occurrences
    • ๐Ÿ“ Text: Generic text content
  • Properties System

    • Type-safe property validation
    • Automatic property getters
    • Dynamic property updates
    • Custom property types
    • Metadata support

โšก Transforms

Transforms are automated operations that process entities to discover new information and relationships:

  • Operation Types

    • ๐Ÿ” Discovery: Find new entities from existing ones
    • ๐Ÿ”— Correlation: Connect related entities
    • ๐Ÿ“Š Analysis: Extract insights from entity data
    • ๐ŸŒ OSINT: Gather open-source intelligence
    • ๐Ÿ”„ Enrichment: Add data to existing entities
  • Features

    • Async operation support
    • Progress tracking
    • Error handling
    • Rate limiting
    • Result validation

๐Ÿ› ๏ธ Helpers

Helpers are specialized tools with dedicated UIs for specific investigation tasks:

  • Available Helpers

    • ๐Ÿ” Cross-Examination: Analyze statements and testimonies
    • ๐Ÿ‘ค Portrait Creator: Generate facial composites
    • ๐Ÿ“ธ Media Analyzer: Advanced image processing and analysis
    • ๐Ÿ” Base Searcher: Search near places of interest
    • ๐Ÿ”„ Translator: Translate text between languages
  • Helper Features

    • Custom Qt interfaces
    • Real-time updates
    • Graph integration
    • Data visualization
    • Export capabilities

๐Ÿ‘ฅ Contributing

We welcome contributions! To contribute to PANO:

  1. Fork the repository at https://github.com/ALW1EZ/PANO/
  2. Make your changes in your fork
  3. Test your changes thoroughly
  4. Create a Pull Request to our main branch
  5. In your PR description, include:
    • What the changes do
    • Why you made these changes
    • Any testing you've done
    • Screenshots if applicable

Note: We use a single main branch for development. All pull requests should be made directly to main.

๐Ÿ“– Development Guide

<details> <summary>Click to expand development documentation</summary>

System Requirements

  • Operating System: Windows or Linux
  • Python 3.11+
  • PySide6 for GUI
  • Internet connection for online features

Custom Entities

Entities are the core data structures in PANO. Each entity represents a piece of information with specific properties and behaviors. To create a custom entity:

  1. Create a new file in the entities folder (e.g., entities/phone_number.py)
  2. Implement your entity class:
from dataclasses import dataclass
from typing import ClassVar, Dict, Any
from .base import Entity

@dataclass
class PhoneNumber(Entity):
    name: ClassVar[str] = "Phone Number"
    description: ClassVar[str] = "A phone number entity with country code and validation"
    
    def init_properties(self):
        """Initialize phone number properties"""
        self.setup_properties({
            "number": str,
            "country_code": str,
            "carrier": str,
            "type": str,  # mobile, landline, etc.
            "verified": bool
        })
    
    def update_label(self):
        """Update the display label"""
        self.label = self.format_label(["country_code", "number"])

Custom Transforms

Transforms are operations that process entities and generate new insights or relationships. To create a custom transform:

  1. Create a new file in the transforms folder (e.g., transforms/phone_lookup.py)
  2. Implement your transform class:
from dataclasses import dataclass
from typing import ClassVar, List
from .base import Transform
from entities.base import Entity
from entities.phone_number import PhoneNumber
from entities.location import Location
from ui.managers.status_manager import StatusManager

@dataclass
class PhoneLookup(Transform):
    name: ClassVar[str] = "Phone Number Lookup"
    description: ClassVar[str] = "Lookup phone number details and location"
    input_types: ClassVar[List[str]] = ["PhoneNumber"]
    output_types: ClassVar[List[str]] = ["Location"]
    
    async def run(self, entity: PhoneNumber, graph) -> List[Entity]:
        if not isinstance(entity, PhoneNumber):
            return []
            
        status = StatusManager.get()
        operation_id = status.start_loading("Phone Lookup")
        
        try:
            # Your phone number lookup logic here
            # Example: query an API for phone number details
            location = Location(properties={
                "country": "Example Country",
                "region": "Example Region",
                "carrier": "Example Carrier",
                "source": "PhoneLookup transform"
            })
            
            return [location]
            
        except Exception as e:
            status.set_text(f"Error during phone lookup: {str(e)}")
            return []
            
        finally:
            status.stop_loading(operation_id)

Custom Helpers

Helpers are specialized tools that provide additional investigation capabilities through a dedicated UI interface. To create a custom helper:

  1. Create a new file in the helpers folder (e.g., helpers/data_analyzer.py)
  2. Implement your helper class:
from PySide6.QtWidgets import (
    QWidget, QVBoxLayout, QHBoxLayout, QPushButton,
    QTextEdit, QLabel, QComboBox
)
from .base import BaseHelper
from qasync import asyncSlot

class DummyHelper(BaseHelper):
    """A dummy helper for testing"""
    
    name = "Dummy Helper" 
    description = "A dummy helper for testing"
    
    def setup_ui(self):
        """Initialize the helper's user interface"""
        # Create input text area
        self.input_label = QLabel("Input:")
        self.input_text = QTextEdit()
        self.input_text.setPlaceholderText("Enter text to p

Related Skills

View on GitHub
GitHub Stars420
CategoryDevelopment
Updated2d ago
Forks55

Languages

Python

Security Score

85/100

Audited on Mar 30, 2026

No findings