Skip to main content

Introduction

Prompt Deck registers five Artisan commands for managing your prompts from the command line. All commands are available when running in the console.
CommandDescription
make:promptCreate a new prompt structure with versioned role files.
prompt:listList all available prompts and their versions.
prompt:activateActivate a specific version of a prompt.
prompt:diffShow differences between two prompt versions.
prompt:testTest a prompt with sample input and see the rendered result.

make:prompt

Create a new prompt structure for your AI agent.
make:prompt {name?} {--from=} {--desc=} {--u|user} {--role=*} {--i|interactive} {--f|force}

Arguments

ArgumentRequiredDescription
nameNoThe name of the prompt. Omit for interactive mode. Automatically normalised to kebab-case.

Options

OptionShorthandDescription
--from=Path to a custom stub file to use as the user prompt template.
--desc=A short description stored in metadata.json.
--user-uAlso create a user prompt file alongside the default system prompt.
--role=*Additional roles to scaffold. Repeatable (e.g. --role=assistant --role=developer).
--interactive-iInteractively choose which additional roles to create.
--force-fOverwrite an existing prompt’s latest version without confirmation.

Examples

# Minimal prompt (system only)
php artisan make:prompt order-summary

# With system + user files
php artisan make:prompt order-summary --user

# With system + multiple custom roles
php artisan make:prompt order-summary --role=assistant --role=developer

# With description
php artisan make:prompt order-summary --desc="Summarises customer orders"

# Fully interactive
php artisan make:prompt

# Force-overwrite in CI
php artisan make:prompt order-summary --force

# Custom user prompt template
php artisan make:prompt order-summary --user --from=stubs/my-template.md

Output

Version 1 of the [order-summary] prompt has been created successfully with the following roles: system, user.

Behaviour with existing prompts

When run against a prompt that already exists, the command presents a choice:
⚠ Prompt [order-summary] already exists at version 2.
What would you like to do?
  [version]    Create a new version (v3)
  [overwrite]  Overwrite version 2
  [cancel]     Cancel
With --force, the latest version is overwritten without prompting. See Creating Prompts for comprehensive documentation.

prompt:list

List all available prompts and their versions.
prompt:list {--all : Show all versions for each prompt}

Options

OptionDescription
--allShow all versions for each prompt, not just the active one.

Examples

List active versions only:
php artisan prompt:list
Output:
+---------------+----------------+--------+----------------------------+
| Prompt        | Active Version | Active | Description                |
+---------------+----------------+--------+----------------------------+
| order-summary | v2             | ✅     | Summarises customer orders |
| code-reviewer | v1             | ✅     | Reviews code quality       |
+---------------+----------------+--------+----------------------------+
List all versions:
php artisan prompt:list --all
Output:
+---------------+----------------+--------+----------------------------+
| Prompt        | Active Version | Active | Description                |
+---------------+----------------+--------+----------------------------+
| order-summary | v1             |        | Initial version            |
| order-summary | v2             | ✅     | Improved tone              |
| code-reviewer | v1             | ✅     | Reviews code quality       |
+---------------+----------------+--------+----------------------------+

Notes

  • If the prompts directory does not exist, a warning is displayed.
  • If no prompts are found, an informational message is shown.
  • Descriptions come from each version’s metadata.json.

prompt:activate

Activate a specific version of a prompt.
prompt:activate {name : The prompt name} {version : The version number to activate}

Arguments

ArgumentRequiredDescription
nameYesThe prompt name (e.g. order-summary).
versionYesThe version number to activate (e.g. 2).

Examples

php artisan prompt:activate order-summary 2
Output:
Version 2 of prompt [order-summary] activated.

How it works

  • With database tracking enabled: Updates the prompt_versions table — sets is_active = false on all versions for that prompt, then is_active = true on the specified version.
  • Without tracking: Writes the active_version key to the prompt’s root metadata.json file.

Error handling

If the prompt or version does not exist, an error message is displayed:
Version 5 for prompt [order-summary] does not exist.

prompt:diff

Show differences between two prompt versions using unified diff output.
prompt:diff {name : The prompt name} {--v1= : First version number} {--v2= : Second version number} {--type= : system, user, or all (default)}

Arguments

ArgumentRequiredDescription
nameYesThe prompt name (e.g. order-summary).

Options

OptionRequiredDescription
--v1=YesThe first version number to compare.
--v2=YesThe second version number to compare.
--type=NoWhich role files to compare: system, user, or all (default).

Examples

Compare all role files between v1 and v2:
php artisan prompt:diff order-summary --v1=1 --v2=2
Output:
--- System Prompt ---
@@ -1,5 +1,5 @@
 You are an AI assistant specialized in...

 Follow these guidelines:
-- Use {{ $tone }} tone
-+ Use a professional and {{ $tone }} tone
+- Be helpful and concise

--- User Prompt ---
@@ -1,3 +1,3 @@
...
Compare only system prompts:
php artisan prompt:diff order-summary --v1=1 --v2=2 --type=system
Compare only user prompts:
php artisan prompt:diff order-summary --v1=1 --v2=2 --type=user

Notes

  • Both --v1 and --v2 are required. The command fails with an error if either is missing.
  • If a role file exists in one version but not the other, the diff shows the full content as added or removed.
  • If a role file doesn’t exist in either version, it is silently skipped.
  • Uses sebastian/diff for unified diff output.

prompt:test

Test a prompt with sample input and see the rendered result.
prompt:test {name : The prompt name} {--ver= : Specific version (defaults to active)} {--input= : The input to test} {--variables= : JSON string of variables}

Arguments

ArgumentRequiredDescription
nameYesThe prompt name to test (e.g. order-summary).

Options

OptionDescription
--ver=Specific version to test. Defaults to the active version.
--input=Custom input text. Defaults to "Sample user input".
--variables=JSON string of variables for interpolation. Defaults to {}.

Examples

Test the active version with defaults:
php artisan prompt:test order-summary
Output:
Testing prompt [order-summary] version 2

Expected variables: tone, input

--- SYSTEM PROMPT ---
You are an AI assistant specialized in...

Follow these guidelines:
- Be helpful
- Use {{ $tone }} tone

--- USER PROMPT ---
Summarise the following order: Sample user input
Test a specific version with variables:
php artisan prompt:test order-summary --ver=1 --variables='{"tone":"friendly","input":"Order #1234"}'
Output:
Testing prompt [order-summary] version 1

Expected variables: tone, input

--- SYSTEM PROMPT ---
You are an AI assistant specialized in...

Follow these guidelines:
- Be helpful
- Use friendly tone

--- USER PROMPT ---
Summarise the following order: Order #1234
Test with custom input:
php artisan prompt:test order-summary --input="Order #5678 with 3 items"

Notes

  • The --variables option expects valid JSON. Invalid JSON produces an error: Invalid JSON for --variables.
  • Expected variables (from metadata.json) are displayed as a hint, if available.
  • Both the rendered system and user prompts are displayed.
  • Unmatched variables remain as placeholders in the output, making it easy to spot missing values.