Skip to content

Latest commit

 

History

History
748 lines (536 loc) · 23.4 KB

README.md

File metadata and controls

748 lines (536 loc) · 23.4 KB

List of PSDify Cmdlets

PSDify includes the following cmdlets.

Detailed help is not provided, so please refer to the examples on this page for cmdlet usage.

Category Cmdlet Description
Authentication Connect-Dify Authenticate with Dify using password or email authentication, enabling operations with other PSDify cmdlets.
Authentication Disconnect-Dify Log out from Dify.
Application Management Get-DifyApp Retrieve app information.
Application Management Remove-DifyApp Delete apps.
Application Management Import-DifyApp Import apps from local DSL files.
Application Management Export-DifyApp Export apps to DSL files.
Application Management Get-DifyDSLContent Retrieve content from DSL file as string.
Application Management Set-DifyDSLContent Write content to DSL file.
Application Management Get-DifyAppAPIKey Retrieve app API keys.
Application Management New-DifyAppAPIKey Create app API keys.
Application Management Remove-DifyAppAPIKey Delete app API keys.
Knowledge Management Get-DifyKnowledge Retrieve knowledge information.
Knowledge Management New-DifyKnowledge Add new empty knowledge.
Knowledge Management Remove-DifyKnowledge Delete knowledge.
Knowledge Management Get-DifyDocument Retrieve document information in knowledge.
Knowledge Management Add-DifyDocument Upload documents to knowledge.
Member Management Get-DifyMember Retrieve workspace member information.
Member Management New-DifyMember Add (invite) a new member to the workspace.
Member Management Remove-DifyMember Remove members from the workspace.
Member Management Set-DifyMemberRole Change members' role in the workspace.
Model Management Get-DifyModel Retrieves workspace model information.
Model Management New-DifyModel Add new models to the workspace.
Model Management Get-DifySystemModel Retrieve system model information for the workspace.
Model Management Set-DifySystemModel Change the system model in the workspace.
Tag Management Get-DifyTag Retrieve tag information.
Tag Management Get-DifyAppTag Retrieve tag information for apps.
Tag Management Get-DifyKnowledgeTag Retrieve tag information for knowledge.
Information Retrieval Get-DifyVersion Retrieve Dify version information.
Information Retrieval Get-DifyProfile Retrieve authenticated account information.
Instance Initialization Wait-Dify Wait the Dify instance to be ready.
Instance Initialization Initialize-Dify Create an admin account (Community Edition only).
Miscellaneous Set-PSDifyConfiguration Disables SSL certificate verification for HTTPS connections.
Miscellaneous Add-DifyFile Upload files.
Miscellaneous Get-DifyDocumentIndexingStatus Retrieve document indexing status.
Miscellaneous Invoke-DifyRestMethod Invoke REST API methods.
Chat Operations Send-DifyChatMessage Send chat messages to the app.

✨ Authentication

Connect-Dify

Authenticate with Dify using password or email-based login, enabling operations with other PSDify cmdlets.

Note

Upon successful authentication, the following environment variables will be set:

$env:PSDIFY_CONSOLE_TOKEN = "..."
$env:PSDIFY_CONSOLE_REFRESH_TOKEN = "..."

If the environment variables are already set and the value (token) is valid, re-authentication will not be performed unless the -Force option is specified.

Email Authentication (For Cloud Edition)

SSO-authenticated accounts can also log in via email authentication using the associated email address.

# Email authentication (enter the code manually manually which will be sent to your email address after execution)
Connect-Dify -AuthMethod "Code" -Email "[email protected]"

Note

You can use environment variables to simplify cmdlet arguments.

$env:PSDIFY_URL = "https://cloud.dify.ai"
$env:PSDIFY_AUTH_METHOD = "Code"
$env:PSDIFY_EMAIL = "[email protected]"

Password Authentication (For Community Edition)

Note

If using a self-signed certificate for HTTPS in the Community Edition, disable certificate verification before invoking Connect-Dify.

# Disable certificate verification
Set-PSDifyConfiguration -IgnoreSSLVerification $true
# Password authentication (enter the password manually after execution)
Connect-Dify -Server "https://dify.example.com" -Email "[email protected]"

# Password authentication (use predefined password)
$DifyPassword = ConvertTo-SecureString -String "AwesomeDify123!" -AsPlainText -Force
Connect-Dify -Server "https://dify.example.com" -Email "[email protected]" -Password $DifyPassword

Note

You can use environment variables to simplify cmdlet arguments.

$env:PSDIFY_URL = "https://dify.example.com"
$env:PSDIFY_AUTH_METHOD = "Password"
$env:PSDIFY_EMAIL = "[email protected]"
$env:PSDIFY_PASSWORD = "AwesomeDify123!"
$env:PSDIFY_DISABLE_SSL_VERIFICATION = "true"  # For self-signed certificates

Disconnect-Dify

Log out from Dify.

# Logout (invalidate issued tokens)
Disconnect-Dify

# Force logout (remove local environment variables regardless of logout success)
Disconnect-Dify -Force

✨ Application Management

Get-DifyApp

Retrieve app information.

# Get all apps
Get-DifyApp

# Get apps by ID
Get-DifyApp -Id "..."

# Get apps by name (complete match)
Get-DifyApp -Name "..."

# Get apps by name (partial match)
Get-DifyApp -Search "..."

# Get apps by mode
## Modes: "chat", "workflow", "agent-chat", "channel", "all"
Get-DifyApp -Mode "chat"

# Get apps by tags (multiple tags can be specified)
Get-DifyApp -Tags "...", "..."

# Example: Combine filters
Get-DifyApp -Name "..." -Mode "chat"

Remove-DifyApp

Delete apps.

# Delete app (specify directly from Get-DifyApp)
Get-DifyApp -Name "..." | Remove-DifyApp

# Delete app (use result from Get-DifyApp)
$AppsToBeRemoved = Get-DifyApp -Name "..."
Remove-DifyApp -App $AppsToBeRemoved

Import-DifyApp

Import apps from local DSL files.

# Import apps (specify file paths, supports wildcards and multiple paths)
Import-DifyApp -Path "DSLs/*.yml"
Import-DifyApp -Path "DSLs/demo1.yml", "DSLs/demo2.yml"

# Import apps (specify directly from Get-Item or Get-ChildItem)
Get-Item -Path "DSLs/*.yml" | Import-DifyApp

# Import apps (use result from Get-ChildItem)
$DSLFiles = Get-ChildItem -Path "DSLs/*.yml"
Import-DifyApp -Item $DSLFiles

# Import an app (specify the content of the DSL file directly via pipe)
Get-DifyDSLContent -Path "DSLs/demo.yml" | Import-DifyApp -Content

Export-DifyApp

Export apps to DSL files. By default, files are saved in the DSLs directory.

# Export app (specify directly from Get-DifyApp)
Get-DifyApp | Export-DifyApp

# Export app (use result from Get-DifyApp)
$AppsToBeExported = Get-DifyApp
Export-DifyApp -App $AppsToBeExported

# Export app (change target directory)
Get-DifyApp | Export-DifyApp -Path "./path/to/your/directory"

# Export app (include secrets)
Get-DifyApp | Export-DifyApp -IncludeSecret

Get-DifyDSLContent / Set-DifyDSLContent

Retrieve content from DSL file as string and write content to DSL file. These are designed to handle DSL files consistently in UTF-8 without BOM.

This is useful when you want to rewrite part of an existing DSL file and save it as another file, or when you want to import it directly by piping it to Import-DifyApp -Content.

# Retrieve content from DSL file
$RawContent = Get-DifyDSLContent -Path "DSLs/old.yml"

# Rewrite the old knowledge ID in the DSL file to the new knowledge ID and save it as another DSL file
$RawContent -replace "8b960203-299d-4345-b953-3308663dd790", "574d9556-189a-4d35-b296-09231b859667" | Set-DifyDSLContent -Path "DSLs/new.yml"

# Rewrite the old knowledge ID in the DSL file to the new knowledge ID and import it as a new app
$RawContent -replace "8b960203-299d-4345-b953-3308663dd790", "574d9556-189a-4d35-b296-09231b859667" | Import-DifyApp -Content

Get-DifyAppAPIKey

Retrieve the API key of the app.

# Get API key (specify directly from Get-DifyApp)
Get-DifyApp -Name "..." | Get-DifyAppAPIKey

# Get API key (use result from Get-DifyApp)
$AppsToGetAPIKey = Get-DifyApp -Name "..."
Get-DifyAppAPIKey -App $AppsToGetAPIKey

New-DifyAppAPIKey

Create an API key for the app.

# Create an API key (specify directly from Get-DifyApp)
Get-DifyApp -Name "..." | New-DifyAppAPIKey

# Create an API key (use result from Get-DifyApp)
$AppsToCreateAPIKey = Get-DifyApp -Name "..."

Remove-DifyAppAPIKey

Delete the API key of the app.

# Delete the API key (specify directly from Get-DifyAppAPIKey)
Get-DifyApp -Name "..." | Get-DifyAppAPIKey | Remove-DifyAppAPIKey

# Delete the API key (use result from Get-DifyAppAPIKey)
$APIKeysToBeRemoved = Get-DifyApp -Name "..." | Get-DifyAppAPIKey
Remove-DifyAppAPIKey -APIKey $APIKeysToBeRemoved

✨ Knowledge Management

Get-DifyKnowledge

Retrieve knowledge information.

# Get all knowledge
Get-DifyKnowledge

# Get knowledge by ID
Get-DifyKnowledge -Id "..."

# Get knowledge by name (complete match)
Get-DifyKnowledge -Name "..."

# Get knowledge by name (partial match)
Get-DifyKnowledge -Search "..."

# Get knowledge by tags (multiple tags can be specified)
Get-DifyKnowledge -Tags "...", "..."

New-DifyKnowledge

Add new empty knowledge.

# Add new knowledge
New-DifyKnowledge -Name "My New Knowledge"

# Add new knowledge with description
New-DifyKnowledge -Name "My New Knowledge" -Description "This is a new knowledge."

Remove-DifyKnowledge

Delete knowledge.

# Delete knowledge (specify directly from Get-DifyKnowledge)
Get-DifyKnowledge -Name "..." | Remove-DifyKnowledge

# Delete knowledge (use result from Get-DifyKnowledge)
$KnowledgeToBeRemoved = Get-DifyKnowledge -Name "..."
Remove-DifyKnowledge -Knowledge $KnowledgeToBeRemoved

Get-DifyDocument

Retrieve document information in knowledge.

# Get all documents (specify directly from Get-DifyKnowledge)
Get-DifyKnowledge -Name "..." | Get-DifyDocument

# Get all documents (use result from Get-DifyKnowledge)
$Knowledge = Get-DifyKnowledge -Name "..."
Get-DifyDocument -Knowledge $Knowledge

# Get documents by ID
Get-DifyKnowledge -Name "..." | Get-DifyDocument -Id "..."

# Get documents by name (complete match)
Get-DifyKnowledge -Name "..." | Get-DifyDocument -Name "..."

# Get documents by name (partial match)
Get-DifyKnowledge -Name "..." | Get-DifyDocument -Search "..."

Add-DifyDocument

Upload documents to knowledge. By default, the settings for Automatic, High Quality with system model, and Vector Aearch are applied.

Currently, detailed configuration is not implemented.

# Prerequisite: Get the knowledge to upload the document
$Knowledge = Get-DifyKnowledge -Name "My New Knowledge"

# Upload documents (specify file paths, supports wildcards and multiple paths)
Add-DifyDocument -Knowledge $Knowledge -Path "Docs/*.md"

# Upload documents (specify from Get-Item or Get-ChildItem via pipe)
Get-Item -Path "Docs/*.md" | Add-DifyDocument -Knowledge $Knowledge

# Upload documents (specify chunk settings)
## Chunk settings: "automatic", "custom"
Add-DifyDocument -Knowledge $Knowledge -Path "Docs/*.md" -ChunkMode "custom"

# Upload documents (use any model)
$EmbeddingModel = Get-DifyModel -Provider "openai" -Name "text-embedding-3-small"
Add-DifyDocument -Knowledge $Knowledge -Path "Docs/*.md" -IndexMode "high_quality" -Model $EmbeddingModel

# Upload documents (use economy mode)
Add-DifyDocument -Knowledge $Knowledge -Path "Docs/*.md" -IndexMode "economy"

# Wait for indexing to complete
Add-DifyDocument -Knowledge $Knowledge -Path "Docs/*.md" -Wait

# Custom wait settings
Add-DifyDocument -Knowledge $Knowledge -Path "Docs/*.md" -Wait -Interval 10 -Timeout 600

Remove-DifyDocument

Delete documents.

# Delete documents (specify directly from Get-DifyDocument)
Get-DifyKnowledge -Name "..." | Get-DifyDocument | Remove-DifyDocument

# Delete documents (use result from Get-DifyDocument)
$DocumentsToBeRemoved = Get-DifyKnowledge -Name "..." | Get-DifyDocument
Remove-DifyDocument -Document $DocumentsToBeRemoved

✨ Member Management

Get-DifyMember

Retrieve workspace member information.

# Get all members
Get-DifyMember

# Get member by ID
Get-DifyMember -Id "..."

# Get member by name
Get-DifyMember -Name "..."

# Get member by email
Get-DifyMember -Email "..."

New-DifyMember

Add (invite) a new member to the workspace.

# Invite a new member
## Roles: "admin", "editor", "normal"
New-DifyMember -Email "[email protected]" -Role "normal" -Language "en-US"

Remove-DifyMember

Remove members from the workspace.

# Remove members (specify directly from Get-DifyMember)
Get-DifyMember -Name "..." | Remove-DifyMember

# Remove members (use result from Get-DifyMember)
$MembersToBeRemoved = Get-DifyMember -Name "..."
Remove-DifyMember -Member $MembersToBeRemoved

Set-DifyMemberRole

Change members' role in the workspace.

# Change role (specify directly from Get-DifyMember)
Get-DifyMember -Name "..." | Set-DifyMemberRole -Role "editor"

# Change role (use result from Get-DifyMember)
$MembersToBeChanged = Get-DifyMember -Name "..."
Set-DifyMemberRole -Member $MembersToBeChanged -Role "editor"

✨ Model Management

Get-DifyModel

Retrieve workspace model information.

# Get all models
Get-DifyModel

# Get models by provider
Get-DifyModel -Provider "..."

# Get models by type
## Types: "predefined", "customizable"
Get-DifyModel -From "..."

# Get models by name
Get-DifyModel -Name "..."

# Get models by model type
## Model types: "llm", "text-embedding", "speech2text", "moderation", "tts", "rerank"
Get-DifyModel -Type "..."

# Example: Combine filters
Get-DifyModel -Provider "..." -Type "llm"

New-DifyModel

Add new models to the workspace. The credentials required depend on the provider and the model. Check the actual HTTP requests using browser developer tools for precise details.

# Add predefined models (example for OpenAI)
New-DifyModel -Provider "openai" -From "predefined" `
  -Credential @{
    "openai_api_key" = "sk-proj-****************"
  }

# Add predefined models (example for Cohere)
New-DifyModel -Provider "cohere" -From "predefined" `
  -Credential @{
    "api_key" = "****************************************"
  }

# Add customizable models (example for OpenAI)
New-DifyModel -Provider "openai" -From "customizable" `
  -Type "llm" -Name "gpt-4o-mini" `
  -Credential @{
    "openai_api_key" = "sk-proj-****************"
  }

# Add customizable models (example for Cohere)
New-DifyModel -Provider "cohere" -From "customizable" `
  -Type "llm" -Name "command-r-plus" `
  -Credential @{
    "mode"    = "chat"
    "api_key" = "****************************************"
  }

Remove-DifyModel

Delete models.

# Delete models (specify directly from Get-DifyModel)
Get-DifyModel -Name "..." | Remove-DifyModel

# Delete models (use result from Get-DifyModel)
$ModelsToBeRemoved = Get-DifyModel -Name "..."
Remove-DifyModel -Model $ModelsToBeRemoved

Get-DifySystemModel

Retrieve system model information for the workspace.

# Get system model
Get-DifySystemModel

# Get system model by type
## Types: "llm", "text-embedding", "rerank", "speech2text", "tts"
Get-DifySystemModel -Type "..."

Set-DifySystemModel

Change the system model in the workspace.

# Change system model
Set-DifySystemModel -Type "llm" -Provider "openai" -Name "gpt-4o-mini"

# Change system model (specify directly from Get-DifySystemModel)
Get-DifySystemModel -Type "llm" -Provider "openai" -Name "gpt-4o-mini" | Set-DifySystemModel

# Change system model (use result from Get-DifySystemModel)
$SystemModelToBeChanged = Get-DifySystemModel -Type "llm" -Provider "openai" -Name "gpt-4o-mini"
Set-DifySystemModel -Model $SystemModelToBeChanged

✨ Tag Management

Get-DifyTag

Retrieve tag information.

# Get tags by type
## Types: "app", "knowledge"
Get-DifyTag -Type "app"

# Get tags by ID
Get-DifyTag -Type "app" -Id "..."

# Get tags by name
Get-DifyTag -Type "app" -Name "..."

Get-DifyAppTag

Retrieve tag information for apps. This is equivalent to Get-DifyTag -Type "app".

# Get app tags
Get-DifyAppTag

# Get app tags by ID
Get-DifyAppTag -Id "..."

# Get app tags by name
Get-DifyAppTag -Name "..."

Get-DifyKnowledgeTag

Retrieve tag information for knowledge. This is equivalent to Get-DifyTag -Type "knowledge".

# Get knowledge tags
Get-DifyKnowledgeTag

# Get knowledge tags by ID
Get-DifyKnowledgeTag -Id "..."

# Get knowledge tags by name
Get-DifyKnowledgeTag -Name "..."

✨ Information Retrieval

Get-DifyVersion

Retrieve the version information for Dify.

# Get version information
Get-DifyVersion

Get-DifyProfile

Retrieve the authenticated account's profile information.

# Get account profile
Get-DifyProfile

✨ Instance Initialization

Wait-Dify

Wait for the Dify instance to be ready. It is useful to use after executing docker compose up -d.

# Wait for the Dify instance to be ready
Wait-Dify -Server "https://dify.example.com"

# Wait for the Dify instance to be ready (specify the interval and timeout)
Wait-Dify -Server "https://dify.example.com" -Interval 5 -Timeout 300

Initialize-Dify

Create an admin account (Community Edition only). After successful completion, it is equivalent to logging in with the admin account using Connect-Dify.

# Create an admin account (enter the password manually after execution)
Initialize-Dify -Server "https://dify.example.com" -Email "[email protected]"

# Create an admin account (use predefined password)
$DifyPassword = ConvertTo-SecureString -String "AwesomeDify123!" -AsPlainText -Force
Initialize-Dify -Server "https://dify.example.com" -Email "[email protected]" -Password $DifyPassword

# Create an admin account (if you've specify INIT_PASSWORD for Dify and use predefined init password)
$DifyInitPassword = ConvertTo-SecureString -String "AwesomeDifyInitPassword123!" -AsPlainText -Force
$DifyPassword = ConvertTo-SecureString -String "AwesomeDify123!" -AsPlainText -Force
Initialize-Dify -Server "https://dify.example.com" -Email "[email protected]" -InitPassword $DifyInitPassword -Password $DifyPassword

Note

You can use environment variables to simplify cmdlet arguments.

$env:PSDIFY_URL = "https://dify.example.com"
$env:PSDIFY_AUTH_METHOD = "Password"
$env:PSDIFY_EMAIL = "[email protected]"
$env:PSDIFY_PASSWORD = "AwesomeDify123!"
$env:PSDIFY_DISABLE_SSL_VERIFICATION = "true"  # For self-signed certificates
$env:PSDIFY_INIT_PASSWORD = "AwesomeDifyInitPassword123!"  # If INIT_PASSWORD is set in Dify

✨ Miscellaneous

Set-PSDifyConfiguration

Enable or disable SSL certificate verification for HTTPS connections.

# Disable certificate verification
Set-PSDifyConfiguration -IgnoreSSLVerification $true

# Enable certificate verification
Set-PSDifyConfiguration -IgnoreSSLVerification $false

Add-DifyFile

Upload files.

# Upload files (specify file paths, supports wildcards and multiple paths)
Add-DifyFile -Path "Files/*"

# Upload files (specify from Get-Item or Get-ChildItem via pipe)
Get-Item -Path "Files/*" | Add-DifyFile

# Upload files (specify source information)
Get-Item -Path "Files/*" | Add-DifyFile -Source "..."

Get-DifyDocumentIndexingStatus

Retrieve document indexing status.

# Get indexing status (specify directly from Add-DifyDocument)
Add-DifyDocument -Knowledge $Knowledge -Path "Docs/*.md" | Get-DifyDocumentIndexingStatus

# Get indexing status (specify from Add-DifyDocument result)
$DocumentToCheckIndexingStatus = Add-DifyDocument -Knowledge $Knowledge -Path "Docs/*.md"
Get-DifyDocumentIndexingStatus -Document $DocumentToCheckIndexingStatus

# Get indexing status (specify knowledge and batch ID)
Get-DifyDocumentIndexingStatus -Knowledge $Knowledge -Batch "..."

# Get indexing status (wait for completion)
Get-DifyDocumentIndexingStatus -Knowledge $Knowledge -Batch "..." -Wait

# Get indexing status (change waiting time)
Get-DifyDocumentIndexingStatus -Knowledge $Knowledge -Batch "..." -Wait -Interval 10 -Timeout 600

Invoke-DifyRestMethod

Invokes REST API methods.

# Invoke REST API (GET)
$Query = @{
    "page"  = 1
    "limit" = 100
}
Invoke-DifyRestMethod -Method "GET" -Uri "https://dify.example.com/console/api/apps" -Query $Query -Token $env:PSDIFY_CONSOLE_TOKEN

# Invoke REST API (POST)
$Body =  @{
    "model_settings" = @(
        @{
            "model_type" = "llm"
            "provider"   = "openai"
            "model"      = "gpt-4o-mini"
        }
    )
} | ConvertTo-Json
Invoke-DifyRestMethod -Method "POST" -Uri "https://dify.example.com/console/api/workspaces/current/default-model" -Body $Body -Token $env:PSDIFY_CONSOLE_TOKEN

# Invoke REST API (using a session)
$DifySession = New-Object Microsoft.PowerShell.Commands.WebRequestSession
Invoke-DifyRestMethod -Method "GET" -Uri "https://dify.example.com/console/api/setup" -Session $DifySession

✨ Chat Operations

Send-DifyChatMessage

Send chat messages to the app. The following environment variables are required for operation.

  • $env:PSDIFY_APP_URL
  • $env:PSDIFY_APP_TOKEN

The content sent and the response are saved in the Logs folder.

# Set environment variables
$env:PSDIFY_APP_URL = "https://dify.example.com"
$env:PSDIFY_APP_TOKEN = "app-****************"

# Send chat messages
Send-DifyChatMessage -Message "Hello, Dify!"

# Send chat messages (start a new session)
Send-DifyChatMessage -Message "Hello, Dify!" -NewSession