PHP Classes

File: docs/commands.md

Recommend this page to a friend!
  Packages of Victor John Ukam   Prompt Deck   docs/commands.md   Download  
File: docs/commands.md
Role: Auxiliary data
Content type: text/markdown
Description: Auxiliary data
Class: Prompt Deck
Organize versioned artificial intelligence promts
Author: By
Last change:
Date: 2 months ago
Size: 9,222 bytes
 

Contents

Class file image Download

Artisan Commands

<a name="introduction"></a>

Introduction

Prompt Deck registers five Artisan commands for managing your prompts from the command line. All commands are available when running in the console.

| Command | Description | |---|---| | make:prompt | Create a new prompt structure with versioned role files. | | prompt:list | List all available prompts and their versions. | | prompt:activate | Activate a specific version of a prompt. | | prompt:diff | Show differences between two prompt versions. | | prompt:test | Test a prompt with sample input and see the rendered result. |

<a name="make-prompt"></a>

make:prompt

Create a new prompt structure for your AI agent.

make:prompt {name?} {--from=} {--desc=} {--u|user} {--role=*} {--i|interactive} {--f|force}

Arguments

| Argument | Required | Description | |----------|----------|-------------| | name | No | The name of the prompt. Omit for interactive mode. Automatically normalised to kebab-case. |

Options

| Option | Shorthand | Description | |---|---|---| | --from= | | Path to a custom stub file to use as the user prompt template. | | --desc= | | A short description stored in metadata.json. | | --user | -u | Also create a user prompt file alongside the default system prompt. | | --role=* | | Additional roles to scaffold. Repeatable (e.g. --role=assistant --role=developer). | | --interactive | -i | Interactively choose which additional roles to create. | | --force | -f | Overwrite 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.

<a name="prompt-list"></a>

prompt:list

List all available prompts and their versions.

prompt:list {--all : Show all versions for each prompt}

Options

| Option | Description | |---|---| | --all | Show 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`.

<a name="prompt-activate"></a>

prompt:activate

Activate a specific version of a prompt.

prompt:activate {name : The prompt name} {version : The version number to activate}

Arguments

| Argument | Required | Description | |----------|----------|-------------| | name | Yes | The prompt name (e.g. order-summary). | | version | Yes | The 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.

<a name="prompt-diff"></a>

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

| Argument | Required | Description | |----------|----------|-------------| | name | Yes | The prompt name (e.g. order-summary). |

Options

| Option | Required | Description | |---|---|---| | --v1= | Yes | The first version number to compare. | | --v2= | Yes | The second version number to compare. | | --type= | No | Which 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.

<a name="prompt-test"></a>

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

| Argument | Required | Description | |----------|----------|-------------| | name | Yes | The prompt name to test (e.g. order-summary). |

Options

| Option | Description | |---|---| | --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.