title | description | detail_level | tags | revised | |||
---|---|---|---|---|---|---|---|
meows.space Documentation |
Technical documentation for the meows.space project |
System overview |
|
false |
Welcome to the meows.space documentation. This knowledge base contains detailed documentation for the meows.space URL command multiplexer project.
Table of Contents
- Overview
- Core Concept
- Command System
- Command Organization and Catalog
- System Integration & Feedback
- System Architecture
- Glossary
- Artifacts
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.
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.
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.
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
The system supports two fundamental command types:
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 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.
flowchart LR
A[Raw Input] --> B[Parsing & Tokenization]
B --> C[Command Lookup]
C --> D[Template Hydration]
D --> F[Browser Navigation]
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" |
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])
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.
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.
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
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.
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.
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.
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.
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.
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.
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.
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.
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.
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.
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]
meows.space implements a layered architecture with clear separation of concerns:
- Client Layer: Handles user interaction, command processing, state management, and synchronization
- Storage Layer: Provides persistent local storage through IndexedDB and browser local storage
- Network Layer: Manages communication with server APIs and authentication services
- 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.
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
The state management system handles data persistence and retrieval across different storage layers. It maintains application state during runtime and across sessions.
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 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 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.
The data synchronization system manages bidirectional data flow between client and server databases.
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
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.
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
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.
The frontend architecture implements a single-page application with a focus on performance, offline capabilities, and responsive design.
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
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
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.
The application loads in a defined sequence:
-
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.
-
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.
-
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.
-
User Data (Variable Size) loads last for authenticated users, including personal commands, preferences, history, and folder structure.
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
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 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.
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
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.
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. |
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 |
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
}
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
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 |
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 |
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 |
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 |