Skip to content
/ meows Public

A URL command multiplexer that transforms text shortcuts into parameterized URLs

License

Notifications You must be signed in to change notification settings

m3au/meows

Repository files navigation

title description detail_level tags revised
meows.space Documentation
Technical documentation for the meows.space project
System overview
overview
documentation
architecture
false

Welcome to the meows.space documentation. This knowledge base contains detailed documentation for the meows.space URL command multiplexer project.

meows.space logo

Table of Contents


Overview

meows.space is a URL command multiplexer that transforms text commands into parameterized URLs. The system implements a browser-based interface with a local-first architecture, enabling offline command management and online URL resolution.

Users define commands that expand to full URLs with optional parameters. For example, g cats expands to google.com/search?q=cats, and gh profile expands to github.com/profile.

The system features a graphical interface with a Windows 95-style icon grid and organization tools. The three-layer state management provides offline capabilities while maintaining cross-device synchronization. The architecture implements progressive loading and local-first operations for performance optimization.

Core Concept

meows.space transforms text inputs into navigable URLs through predefined templates. The system processes user commands and converts them to structured URLs using either static mappings or dynamic parameter interpolation.

The browser-based execution enables direct navigation to destinations. Command management functions offline, while URL resolution requires network connectivity.

Command System

The command system forms the core of meows.space, transforming user text inputs into parameterized URLs through a structured pipeline. It processes raw text commands, identifies command patterns, extracts parameters, and constructs destination URLs based on predefined templates. This system enables users to quickly navigate to web destinations using shorthand commands rather than typing full URLs.

Command Types

graph TD
    subgraph "Command Types"
        Static["Static Commands<br/><i>Direct URL mapping</i>"]
        Dynamic["Dynamic Commands<br/><i>Parameter interpolation</i>"]
    end

    subgraph "Examples"
        Static --- StaticEx["gh → github.com<br/>cal → calendar.google.com<br/>mail → gmail.com"]
        Dynamic --- DynamicEx["g {query} → google.com/search?q={query}<br/>gh {repo} → github.com/{repo}<br/>tr {from} {to} {text} → translate.google.com/?sl={from}&tl={to}&text={text}"]
    end
Loading

The system supports two fundamental command types:

Static Commands

Static commands provide direct URL mappings without parameters:

gm → gmail.com
cal → calendar.com
docs → docs.google.com

These commands navigate directly to the specified URL when invoked, serving as shortcuts for frequently accessed destinations.

Dynamic Commands

Dynamic commands incorporate parameters into URL templates:

# Search engines
g {query} → google.com/search?q={query}
yt {query} → youtube.com/results?search_query={query}
gh {query} → github.com/search?q={query}

# Direct navigation
gh/r {repo} → github.com/{repo}
npm {pkg} → npmjs.com/package/{pkg}
maps {loc} → google.com/maps/search/{loc}

# Multiple parameters
tr {from} {to} {text} → translate.google.com/?sl={from}&tl={to}&text={text}

These commands support multiple parameters with interpolation into the final URL.

Command Processing Pipeline

flowchart LR
    A[Raw Input] --> B[Parsing & Tokenization]
    B --> C[Command Lookup]
    C --> D[Template Hydration]
    D --> F[Browser Navigation]
Loading
Stage Description Example
Raw Input User-entered text command g cats
Parsing & Tokenization Breaks down input into command and parameters Command: g, Params: cats
Command Lookup Identifies the command and retrieves its template Template: google.com/search?q={query}
Template Hydration Populates the template with extracted parameters Result: google.com/search?q=cats
Browser Navigation Opens the generated URL in the browser Browser navigates to Google search for "cats"

Command Execution

When a user interacts with meows.space, the command execution process follows a natural flow from input to navigation:

flowchart TD
    Start([User Input]) --> InputType{Input Type}

    InputType -->|Text Command| ParseText[Parse Text Command]
    InputType -->|Icon Click| IconClick[Process Icon Selection]

    ParseText --> CommandType{Command Type}
    IconClick --> HasParams{Has Parameters?}

    HasParams -->|Yes| GetParams[Get Parameters from Input]
    HasParams -->|No| DirectURL[Use Direct URL]

    CommandType -->|Static| StaticResolve[Resolve Static URL]
    CommandType -->|Dynamic| DynamicResolve[Extract Parameters]

    DynamicResolve --> TemplateHydration[Hydrate URL Template]
    GetParams --> TemplateHydration

    StaticResolve --> OpenURL[Open URL in Browser]
    DirectURL --> OpenURL
    TemplateHydration --> OpenURL

    OpenURL --> End([Return Focus])
Loading

The user begins by either typing a command or clicking an icon in the grid. For text input, the system parses the command and identifies whether it's static or dynamic. Static commands immediately resolve to their target URL, while dynamic commands extract parameters from the input and interpolate them into the URL template.

When a user clicks an icon, the system checks if there's text in the input field that should be used as a parameter. If parameters are needed, they're extracted from the input; otherwise, the system uses the direct URL associated with the command.

Once the final URL is constructed, the browser opens it in a new tab, and focus returns to meows.space for the next command. This streamlined process allows users to quickly navigate to their desired destinations with minimal effort.

Command Organization and Catalog

The system provides both global catalog and user inventory with a flexible organization system. Users can have multiple profiles, each with its own set of commands and labels.

Global Catalog

The global catalog serves as a distributed registry for command discovery and sharing. It contains commands created and shared by the community:

graph TD
    subgraph "Global Catalog Interface"
        SearchBar[Search Commands]
        FilterBar["Filter: All / Popular / Recent"]
        CategoryList[Category List]
        CommandGrid[Command Grid]
    end

    subgraph "Command Display"
        ServiceCard[Service Card]
        ImportButton[Import to Inventory]
        RatingStars[Rating Stars]
    end

    SearchBar --> CommandGrid
    FilterBar --> CommandGrid
    CategoryList --> CommandGrid
    CommandGrid --> ServiceCard
    ServiceCard --> ImportButton
    ServiceCard --> RatingStars
Loading

Inventory

Each user has a personal inventory where they can create, customize, and organize their own commands. The inventory uses a label-based indexing system:

[Search]
- Google {shortcut: "g"}
- YouTube {shortcut: "yt"}
- Wikipedia {shortcut: "wiki"}

[Development]
- MDN {url: "developer.mozilla.org"}
- DevDocs {url: "devdocs.io/{topic}"}
- GitHub {url: "github.com/{repo}"}
- npm {url: "npmjs.com/package/{pkg}"}

Each command is represented by an icon in the grid. These icons are either automatically fetched from the domain favicon or custom icons uploaded by the user. Below each icon is the command name, similar to desktop shortcuts in traditional operating systems.

The organization system uses a flat label structure where each command can have multiple labels. This design enables commands to appear in different contexts based on their categorization. For example, a GitHub search command might appear under both "Development" and "Search" labels.

Social Sharing

The system enables command sharing between users, enhancing collaboration and discovery:

  • Users can share individual commands or collections via direct links
  • Commands can be liked or favorited to build personal collections
  • Popular commands rise to the top of the global catalog
  • Users can import shared commands directly to their personal inventory
  • Command creators receive attribution when their commands are shared
  • Privacy settings allow users to control which commands are publicly visible

This social layer builds community around command creation while maintaining individual productivity as the core focus.

User Profiles

Users can create multiple profiles, each with its own:

  • Set of commands (each profile has its own distinct commands)
  • Active label (the currently selected label for filtering)
  • Set of labels shown under the input field
  • Default browser settings

Each profile functions as a separate workspace, allowing users to maintain different command sets for different contexts, such as work, personal, or specific projects. The same command cannot have different parameters across profiles - if a user needs a variation of a command, they must create a new command in that profile.

System Integration & Feedback

Authentication Integration

meows.space implements authentication through OAuth-based providers including GitHub, LinkedIn, and Facebook. This approach eliminates the need for direct username/password management while providing secure identity verification. Authentication is only required for command management functions, not for basic command execution, maintaining a low barrier to entry for new users.

The authentication system integrates with the local-first architecture, storing authentication tokens in secure browser storage and refreshing them as needed. This enables offline access to authenticated features while maintaining security standards.

Local-First Architecture Integration

The local-first architecture forms the foundation of the system's integration approach. Command execution occurs primarily in the browser, with local storage handling command data persistence. This architecture enables offline functionality for core features while maintaining cross-device synchronization when connectivity is available.

Synchronization is implemented selectively, focusing on command management rather than execution. This approach minimizes network dependencies while ensuring data consistency across devices. The system operates independently of external services for core functionality, enhancing reliability and reducing potential points of failure.

Browser Integration

meows.space operates as a standalone web application without requiring browser extensions or plugins. This design decision simplifies deployment and reduces maintenance overhead while ensuring broad compatibility across browsers and platforms. The system maintains its own command history and state management, independent of browser history or bookmark systems.

The system can be extended through optional browser integrations, such as bookmark synchronization or browser extension features, which remain supplementary rather than core requirements. This approach maintains the system's independence while allowing for enhanced functionality for users who desire deeper browser integration.

External Services

The system generates URLs without requiring external API access or service credentials, maintaining independence from third-party services for core functionality. This design eliminates API limits, quotas, and credential management concerns that typically accompany external service dependencies.

For services that require authentication, such as private GitHub repositories, the system passes authentication through the browser's standard mechanisms rather than storing or managing service credentials directly. This approach maintains security while enabling access to authenticated services when needed.

User Feedback Mechanisms

In-app Feedback

The system implements a unified feedback mechanism accessible through the main navigation menu. Users can submit bug reports, feature suggestions, and general feedback through a single form interface that categorizes submissions for appropriate routing and response. This streamlined approach simplifies the feedback process while ensuring that user input reaches the appropriate teams.

The feedback system captures contextual information such as browser version and system configuration to assist in issue diagnosis, while maintaining user privacy by excluding personal data unless explicitly provided by the user.

Analytics Integration

meows.space implements Google Analytics to monitor system usage patterns and identify opportunities for improvement. The analytics implementation tracks feature usage, user flows, and interaction patterns without capturing personally identifiable information. This data informs development priorities and interface optimizations based on actual usage rather than assumptions.

The analytics system implements appropriate data retention policies and provides users with clear information about data collection practices. Users can opt out of analytics collection through the settings interface if desired.

Support Channels

The system provides a unified support channel through a dedicated email address that handles all types of inquiries. This approach simplifies the support process for users while ensuring that questions reach the appropriate team members for resolution. Support documentation complements direct assistance, providing self-service options for common questions and issues.

System Architecture

flowchart TB
    subgraph "Client Layer"
        UI[User Interface]
        CommandProcessor[Command Processor]
        StateManager[State Manager]
        SyncClient[Sync Client]

        UI --> CommandProcessor
        CommandProcessor --> StateManager
        StateManager --> SyncClient
    end

    subgraph "Storage Layer"
        IndexedDB[(IndexedDB)]
        LocalStorage[(Local Storage)]

        StateManager --> IndexedDB
        StateManager --> LocalStorage
    end

    subgraph "Network Layer"
        APIClient[API Client]
        AuthService[Auth Service]

        SyncClient --> APIClient
        APIClient --> AuthService
    end

    subgraph "Server Layer"
        APIServer[API Server]
        AuthServer[Auth Server]
        Database[(Database)]

        APIClient <--> APIServer
        AuthService <--> AuthServer
        APIServer --> Database
        AuthServer --> Database
    end

    User((User)) --> UI
    CommandProcessor --> |URL Navigation| Browser[Browser Navigation]
    Browser --> |Opens| Destination[Web Destination]
Loading

meows.space implements a layered architecture with clear separation of concerns:

  1. Client Layer: Handles user interaction, command processing, state management, and synchronization
  2. Storage Layer: Provides persistent local storage through IndexedDB and browser local storage
  3. Network Layer: Manages communication with server APIs and authentication services
  4. Server Layer: Hosts API endpoints, authentication services, and database storage

This architecture enables the local-first approach, where commands can be managed offline while still providing synchronization capabilities when online. The system prioritizes client-side processing for command execution, with server components primarily supporting data persistence and sharing functionality.

State Management

block-beta
    block:App State
        block:Runtime State
            columns 3
            Command Context
            Search State
            Navigation State
        end
        block:Persistent State
            columns 2
            IndexedDB
            Local Storage
        end
    end
Loading

The state management system handles data persistence and retrieval across different storage layers. It maintains application state during runtime and across sessions.

State Architecture

The state architecture consists of two primary components: runtime state in memory and persistent state in storage. Runtime state provides fast access to frequently used data, while persistent state ensures data durability across sessions.

Runtime State

Runtime state contains the active application context during a session:

  • Command context maintains the currently active command and its parameters. This includes the command being edited or executed, along with any extracted parameters.
  • UI state tracks the current interface configuration, including selected commands, active panels, search queries, and scroll positions.
  • Command history keeps a record of recently executed commands in an LRU cache, enabling quick access to frequently used commands without database queries.
  • Search index provides an in-memory structure for fast command lookup, using prefix-based searching and fuzzy matching algorithms.

Persistent State

Persistent state maintains durable data across browser sessions:

  • Command definitions store all user-defined commands, including their URLs, parameters, and metadata. This forms the core of the user's command library.
  • User profiles contain user information, including display name, email, and authentication details.
  • User preferences store interface settings, default behaviors, and personalization options that persist across sessions.
  • Command history maintains a complete record of executed commands with timestamps and execution contexts.
  • Organization structure stores the folder hierarchy, labels, and categorization system for commands.
  • Pending changes queue modifications made while offline, ensuring they're synchronized when connectivity is restored.

Data Synchronization

The data synchronization system manages bidirectional data flow between client and server databases.

Local-First Operations

sequenceDiagram
    participant U as User
    participant C as Client
    participant D as IndexedDB
    participant S as Server

    U->>C: Execute Command
    C->>D: Store History
    C->>S: Log Usage
    S-->>C: Sync State
Loading

The system handles two primary processes:

Command Management Synchronization uses a transaction-based approach. When users modify commands, the system first applies changes to the local IndexedDB, then queues them for server synchronization. Each change is timestamped and assigned a unique transaction ID. When online, the system transmits these changes to the server in batches. For concurrent edits from multiple devices, the system applies last-writer-wins conflict resolution, with special handling for structural conflicts like command deletion followed by modification.

Command Execution records command usage statistics. When a user executes a command, the system logs this event locally and, when online, transmits usage data to the server for analytics. The browser handles the actual URL navigation after command processing.

System Flow

sequenceDiagram
    participant User
    participant Browser
    participant IndexedDB
    participant API
    participant Database

    User->>Browser: Edit/Create Service
    Browser->>IndexedDB: Store Changes
    Browser-->>User: Update UI

    Browser->>API: Sync Changes
    API->>Database: Update Commands
    Database-->>API: Sync Complete
    API-->>Browser: Sync Confirmed

    User->>Browser: Execute Command
    Browser->>Browser: Navigate to URL
Loading

This diagram shows the data flow during command management and execution. Command edits are immediately stored in IndexedDB and reflected in the UI. When online, changes are synchronized with the server. For command execution, the browser constructs the URL and performs navigation directly.

Frontend Architecture

The frontend architecture implements a single-page application with a focus on performance, offline capabilities, and responsive design.

Technical Implementation

The frontend architecture is designed around these principles:

  • Component-based UI architecture
  • Strong type safety throughout the codebase
  • Scoped styling to prevent conflicts
  • Client-side storage for offline functionality
  • Service workers for offline capabilities and caching

Loading & Performance

graph LR
    subgraph "Progressive Loading"
        direction TB
        Shell["Shell<br/><i>10KB</i>"]
        Core["Core<br/><i>50KB</i>"]
        GlobalData["Global Data<br/><i>100KB</i>"]
        UserData["User Data<br/><i>Variable</i>"]
    end

    subgraph "Lazy-loaded Features"
        direction TB
        Settings["Settings<br/><i>15KB</i>"]
        Catalog["Catalog<br/><i>15KB</i>"]
        Search["Search<br/><i>10KB</i>"]
        Sync["Sync<br/><i>20KB</i>"]
    end

    Shell --> Core
    Core --> GlobalData
    GlobalData --> UserData

    UserData -.-> Settings
    UserData -.-> Catalog
    UserData -.-> Search
    UserData -.-> Sync
Loading

The application implements a sequential loading strategy to reduce initial load time. Through progressive loading and code splitting, the system loads critical functionality first while deferring non-essential features.

Progressive Loading Strategy

The application loads in a defined sequence:

  1. Shell (10KB) loads first, containing the HTML structure, critical CSS, and minimal JavaScript for command input. This initial payload loads in approximately 200ms on standard connections, providing immediate access to the command input field.

  2. Core (50KB) loads second, including the command parser, state management system, and primary UI components. This enables basic command execution while additional components continue loading.

  3. Global Data (100KB) loads third, containing the public command catalog, default templates, and system configuration. This data is cached and shared across users, allowing non-authenticated users to access public commands.

  4. User Data (Variable Size) loads last for authenticated users, including personal commands, preferences, history, and folder structure.

Performance Optimization Techniques

The application implements multiple optimization techniques:

Code Splitting divides the application into separate chunks that load on demand. Features like settings, command catalog, search functionality, and synchronization components load only when accessed, reducing initial load time.

Virtual Rendering for grids and lists renders only visible items, providing stable performance with large command sets. This uses windowed rendering that creates DOM elements only for items in the viewport.

Bundle Optimization includes tree-shaking to remove unused code, module deduplication to reduce redundancy, and critical CSS extraction. The delivery pipeline uses Brotli compression, cache control with ETags, and content-based versioning.

Data Prefetching loads data before user interaction, such as prefetching command details on hover or loading the next page of results before reaching the current page end.

Caching Strategy uses multiple storage mechanisms:

  • Browser cache for static assets
  • Client-side database for command data and user preferences
  • Memory cache for frequently accessed data
  • Service worker for offline functionality

Backend Architecture

API Implementation

The backend implements a REST API with endpoints for:

  • Command storage and retrieval
  • User authentication
  • Cross-device synchronization

API endpoints use standard HTTP methods and return JSON responses with appropriate status codes. Authentication uses session tokens with configurable expiration.

For detailed information about API endpoints, see the API Endpoints section.

Data Storage

Data is stored in two layers:

  • Client-side storage for local persistence
  • Server-side database for remote storage

The database schema mirrors the data models with tables for commands, users, and usage data. Indexes are implemented on frequently queried fields to optimize read performance.

Security Implementation

sequenceDiagram
    participant User
    participant Client
    participant API
    participant Auth
    participant Database

    User->>Client: Login Request
    Client->>API: Authentication Request
    API->>Auth: Validate Credentials
    Auth->>Database: Verify User
    Database-->>Auth: User Data
    Auth-->>API: Generate JWT Token
    API-->>Client: Set HTTP-only Cookie
    Client-->>User: Authentication Complete

    Note over Client,API: Subsequent Requests
    Client->>API: Request with Cookie
    API->>Auth: Validate Token
    Auth-->>API: Token Valid
    API->>Database: Authorized Request
    Database-->>API: Response Data
    API-->>Client: Protected Resource
Loading

Authentication uses session-based tokens stored in HTTP-only cookies with secure and SameSite attributes. User passwords are hashed using bcrypt with appropriate work factors. All API communications require HTTPS, with HSTS headers enforcing secure connections. The system implements rate limiting for authentication endpoints and uses CSRF tokens for state-changing operations.

For data at rest, the database implements field-level encryption for sensitive information. Access controls enforce user-specific data boundaries, preventing unauthorized access to other users' commands and settings.

Glossary

This glossary standardizes terminology used throughout the meows.space documentation to ensure consistency and clarity.

Term Definition
Command A text shortcut that expands to a full URL, optionally with parameters. The core unit of functionality in meows.space.
Service A web destination that can be accessed via commands. Represented visually as an icon in the ServiceGrid.
Command vs Service Commands are text inputs (e.g., "g cats") that users type, while Services are the URL templates (e.g., "google.com/search?q={query}") that define how commands are processed into navigable URLs. Commands reference Services, and the combination produces the final URL navigation.
Parameter A variable portion of a command that gets interpolated into the final URL.
Template The URL pattern associated with a command, containing placeholders for parameters.
Label A categorization label applied to commands for organization and filtering.
Global Catalog A shared, community-maintained collection of commands available to all users. Contains verified, popular commands that can be imported to a user's inventory.
Inventory A user's private collection of commands, customized to their specific needs and preferences. Commands in the inventory can be created, edited, and organized by the user.
Profile A user's workspace containing their commands, preferences, and settings.
Static Command A command that maps directly to a URL without parameters.
Dynamic Command A command that incorporates parameters into a URL template.
ServiceGrid The Windows 95-style icon grid component that displays commands as interactive tiles. Supports drag-and-drop organization and visual categorization.
Command Execution The process of transforming a text command into a URL and navigating to it.
Command Management The process of creating, editing, and organizing commands.

Artifacts

Flow charts

Flow Description Key Steps
Command Execution Traces the journey from user input to URL navigation, showing how commands are parsed, parameters extracted, and URLs generated. Input parsing → Command lookup → Parameter extraction → URL generation → Browser navigation
Command Management Documents the creation, editing, and organization of commands, including validation, storage, and synchronization processes. Command creation → Validation → Storage → Synchronization → Organization
User Interaction Patterns Illustrates common user workflows across different pages, highlighting interaction patterns and navigation flows. Search → Execute → Organize → Customize → Share
Profile Management Details the user profile management processes including preferences, settings, and profile data management. Profile creation → Customization → Settings management → Data synchronization
Authentication Login Documents the login and logout processes, including standard and OAuth authentication flows with security considerations. Credential submission → Validation → Token generation → Session management → Logout
Authentication Logoff Details the process of terminating all active sessions across all devices simultaneously for security purposes. Access security settings → Verification → Session termination → Security notification
Registration Describes the user registration process including account creation, email verification, and initial profile setup. Account creation → Email verification → Profile setup → Dashboard access
Account Deletion Details the account deletion process including verification, data removal, grace period, and privacy considerations. Deletion request → Verification → Data marking → Grace period → Permanent deletion

Data Models

The following class diagram provides a high-level overview of the data model relationships in meows.space. This is a simplified representation; complete and detailed models can be found in their respective model files. The diagram illustrates the relationships between commands, services, labels, users, and their associated entities.

classDiagram
    Command "1" -- "0..*" Parameter: contains
    Command "0..*" -- "0..*" Label: categorized by
    Command "0..*" -- "1" Service: represents
    User "1" -- "1" UserProfile: has
    User "1" -- "0..*" Catalog: owns
    UserProfile "1" -- "0..*" Command: owns
    UserProfile "1" -- "1" UserPreferences: configures
    Catalog "1" -- "0..*" Command: contains
    GlobalCatalog "1" -- "0..*" Command: contains

    class Command {
        +String id
        +String key
        +String url
        +String type
        +Parameter[] params
        +Object metadata
    }

    class Service {
        +String id
        +String name
        +String icon
        +String description
        +Number popularity
    }

    class Label {
        +String id
        +String name
        +String color
        +Command[] commands
    }

    class UserProfile {
        +String id
        +String displayName
        +String email
        +UserPreferences preferences
    }

    class UserPreferences {
        +String theme
        +String defaultBrowser
        +Number commandsPerPage
    }

    class Parameter {
        +String name
        +String type
        +Boolean required
        +String defaultValue
    }

    class User {
        +String id
        +String email
        +String authProvider
        +Date createdAt
        +Boolean isVerified
        +Date lastLogin
    }

    class Catalog {
        +String id
        +String name
        +String ownerId
        +Command[] commands
        +Label[] labels
        +Date createdAt
        +Date updatedAt
    }

    class GlobalCatalog {
        +Command[] commands
        +Number totalCommands
        +Number popularityThreshold
        +Date lastUpdated
    }
Loading

For API error handling, the system implements a standardized error response format:

classDiagram
    class ErrorResponse {
        +String code
        +String message
        +Object details
        +Number status
    }

    class API {
        +handleRequest()
        +validateInput()
        +formatResponse()
    }

    ErrorResponse -- API: returned by
Loading
Model Description Key Properties
Command Defines the structure of command objects, including static and dynamic variants. Commands connect user input to URL templates and manage parameter extraction. id, key, url, type, params, metadata
Service Represents service metadata including icons, descriptions, and usage statistics. Services provide the visual representation of commands in the UI. id, name, icon, description, popularity
Label Implements the label-based organization system, allowing commands to be categorized and filtered. Labels can be applied to multiple commands and commands can have multiple labels. id, name, color, commands
User Stores core user account information including authentication details, email verification status, and account creation metadata. id, email, authProvider, isVerified
User Profile Manages user profile information, display preferences, and interface settings. Connected to the core User model. id, displayName, email, preferences
User Preferences Stores user-specific settings including theme preferences, default behaviors, and interface configurations. theme, defaultBrowser, commandsPerPage
Inventory Represents a user's personal collection of commands, organized with labels and metadata. id, name, ownerId, commands, labels
Global Catalog Implements the shared, community-maintained collection of commands available to all users. Contains popularity metrics and curation data. commands, totalCommands, lastUpdated
Error Response Defines the standardized format for API error responses across the system. code, message, details, status

Pages

Page Route Description Key Features
Main Search / Primary interface for command execution, featuring a prominent search bar and quick access to frequently used commands. Command input, history, suggestions, quick execution
Inventory /personal User's workspace for managing personal commands, with organization tools and customization options. Command grid, label filtering, drag-and-drop organization
Settings     /personal/settings Configuration interface for user preferences, appearance settings, and default behaviors. Theme selection, display options, default settings
Create Service     /personal/service/create Form interface for creating new service definitions with parameter configuration and validation. Template builder, parameter editor, preview functionality
Edit Service     /personal/service/edit/[id] Editing interface for existing services, allowing modification of templates and parameters. Template editing, parameter configuration, usage statistics
User Profile     /personal/profile User profile management interface for updating personal information and preferences. Profile editing, avatar management, account settings
Global Catalog /catalog Discovery interface for community-shared commands, with filtering, sorting, and import capabilities. Command discovery, popularity sorting, import functionality
Service Details     /catalog/service/[id] Detailed view of a specific service or command, showing metadata, usage information, and related commands. Command details, usage statistics, related commands
Login /auth/login Authentication interface for existing users, with multiple login options and security features. Email/password login, OAuth providers, security measures
Register /auth/register Registration interface for new users, with account creation and verification processes. Account creation, email verification, initial setup
Help /help User guidance with visual demonstrations and explanations of key features and workflows. GIF demonstrations, feature explanations, usage tips
About /about Information about the project, team, technology stack, and contact details with links to resources and documentation. Project information, team details, contact information
Feedback /feedback Interface for users to submit feedback, report issues, and suggest improvements. Feedback form, issue reporting, feature requests
Privacy Policy /privacy Legal information about data handling practices, user rights, and compliance measures. Data collection, user rights, security measures
Cookie Policy /cookie-policy Information about how cookies are used, managed, and controlled within the application. Cookie usage, management options, third-party cookies
Data Protection /data-protection Detailed information about data protection measures, user data rights, and compliance with regulations. Data security, GDPR compliance, data access rights
Terms of Use /terms Legal terms governing the use of the service, user responsibilities, and limitations. Usage terms, user obligations, liability limitations

Components

Component Description Usage
AuthForms Form components for user authentication including login, registration, password reset, and account verification. Login, Register pages
CatalogView Container component for displaying and managing catalogs. Handles catalog navigation, filtering, and command display. Inventory, Global Catalog
Footer Secondary navigation with legal links, support resources, and copyright information. Provides access to terms, privacy policy, and help. All pages
Header Primary navigation interface with logo, navigation menu, search bar, and user menu. Fixed at the top of all pages. All pages
IconSelector Component for selecting and customizing service icons from various sources including URL, upload, and preset options. Service creation and editing
ImportButton Button for importing commands from the global catalog to a user's inventory. Includes confirmation and success states. Global Catalog
InventoryView Container component for displaying and managing user's inventory with filtering, sorting, and organization tools. Inventory page
LabelBar Label-based filtering system allowing users to organize and filter commands by categories. Implements multi-select filtering with AND logic. Inventory, Global Catalog
ParameterEditor Form interface for defining and configuring command parameters with validation rules and default values. Service creation and editing
ProfileEditor Component for editing user profile information including display name, avatar, and account settings. User Profile, Settings pages
SearchBar Primary command input with autocomplete and history. Processes user text input and triggers command execution. Main Search, Inventory, Global Catalog
ServiceBuilder Form interface for creating and editing service definitions. Includes parameter configuration, validation, and preview functionality. Inventory, Service Details
ServiceCard Card component displaying command information, including icon, name, description, and usage statistics. Inventory, Global Catalog
ServiceGrid Windows 95-style icon grid displaying commands as interactive tiles. Supports drag-and-drop organization and visual categorization. Main Search, Inventory, Global Catalog
ServiceIcon Visual representation of a command with favicon and label. Displays the command's icon and name in the ServiceGrid. ServiceGrid, Inventory, Global Catalog
ThemeSelector Component for selecting and applying interface themes with preview functionality and system theme detection. Settings page
URLPreview Component for previewing constructed URLs with parameters, showing how the final URL will appear when executed. Service creation and editing
URLTemplateEditor Editor for creating and modifying URL templates with parameter placeholders and syntax highlighting. Service creation and editing
UserMenu Dropdown menu for user-related actions including profile access, settings, and logout functionality. Header component

API Endpoints

Endpoint Method Description Cached Auth Required
/api/auth/login POST User login No No
/api/auth/logout POST User logout No Yes
/api/auth/logoff POST User log-off from all devices No Yes
/api/auth/register POST New user registration No No
/api/auth/session GET Get current session No Yes
/api/auth/refresh POST Refresh access token No Yes
/api/services GET List all services Yes (5m) No
/api/services/:id GET Get service details No No
/api/services POST Create new service No Yes
/api/services/:id PUT Update service No Yes
/api/services/:id DELETE Delete service No Yes
/api/services/search GET Search services No No
/api/labels GET List all labels Yes (5m) No
/api/labels POST Create new label No Yes
/api/labels/:id PUT Update label No Yes
/api/labels/:id DELETE Delete label No Yes
/api/labels/trending GET Get trending labels No No
/api/inventory GET Get user's inventory No Yes
/api/inventory/commands GET Get inventory commands No Yes
/api/inventory/commands POST Add command to inventory No Yes
/api/inventory/commands/:id PUT Update inventory command No Yes
/api/inventory/commands/:id DELETE Remove command from inventory No Yes
/api/inventory/share/:id POST Share command No Yes
/api/catalogs/global GET Get global catalog Yes (1h) No
/api/user/preferences GET Get user preferences No Yes
/api/user/preferences PUT Update preferences No Yes
/api/user/history GET Get search history No Yes
/api/user/history DELETE Clear history No Yes
/api/user/favorites GET Get favorite services No Yes
/api/user/favorites/:id POST Add to favorites No Yes
/api/user/favorites/:id DELETE Remove from favorites No Yes
/api/providers GET List search providers Yes (1h) No
/api/providers/:id/search GET Execute provider search No No
/api/providers/default GET Get default provider No Yes
/api/providers/default PUT Set default provider No Yes
/api/analytics/event POST Log user event No No
/api/analytics/trending GET Get trending services Yes (1h) No
/api/analytics/popular GET Get popular services No No
/api/analytics/metrics GET Get usage metrics No Yes

About

A URL command multiplexer that transforms text shortcuts into parameterized URLs

Topics

Resources

License

Stars

Watchers

Forks