PSRyver¶
This is a quick and dirty community module to interact with the Ryver API.
Pull requests and other contributions would be welcome!
Prerequisites¶
- PowerShell 3 or later
- Valid credentials or an incoming webhook URI from Ryver.
Getting Started¶
- Installation
- PowerShell 3 & 4
- Download the repository
- Unblock the zip
- Extract the PSRyver folder to a module path in
$Env:PSModulePath
- Example:
"$Env:USERPROFILE\Documents\WindowsPowerShell\Modules\"
- Example:
- PowerShell 5+
Install-Module -Name 'PSRyver' Import-Module -Name 'PSRyver'
- PowerShell 3 & 4
- List the commands in the module
Get-Command -Module 'PSRyver'
- Get help
# Output the full help content in PowerShell. Get-Help -Name 'Send-RyverMessage' -Full # Open the help content from the documentation site in a new tab on your default browser. Get-Help -Name 'Send-RyverMessage' -Online
Examples¶
Send a Simple Ryver Message¶
- This example shows a crudely crafted message without any attachments, using parameters from
Send-RyverMessage
to construct the message. NOTE: This assumes that an incoming webhook URI was setup at"https://${yourOrg}.ryver.com/"
- Send a message to @tlindsay42 in the channel configured for the webhook
$splat = @{ IncomingWebhookUri = 'Some incoming webhook URI from Ryver' Message = 'Hello @tlindsay42, join me in #devnull!' } Send-RyverMessage @splat
Search for a Ryver Message¶
-
Search for all chat messages containing the word PowerShell.
Find-RyverMessage -SearchText 'PowerShell'
-
Search for attachments that contain the name PowerShell.
Find-RyverAttachment -SearchText 'PowerShell'
Store and Retrieve Configs¶
- To save time and typing, you can save your credentials or incoming webhook URI to a config file (protected via DPAPI on Windows) and a module variable.
- This is used as the default for commands, and is loaded automatically when you import the PowerShell module if stored in the default location:
"~/.psryver.xml"
.
# Update the current config in memory. Set-PSRyverConfig -RestApiBaseUri "https://${yourOrg}.ryver.com/api/1/odata.svc" -Credential ( Get-Credential ) # Read the current config in memory. Get-PSRyverConfig # Save the current config to file. Export-PSRyverConfig # Read & decrypt the default config file (if authorized). Read-PSRyverConfig
Credentials¶
# Update the current config in memory. Set-PSRyverConfig -IncomingWebhookUri "https://${yourOrg}.ryver.com/application/webhook/${yourWebhookID}" # Read the current config in memory. Get-PSRyverConfig
Notes¶
This project was forked with from v0.1.0 of Warren Frame's awesome PSSlack project. Thanks Warren!
Currently evaluating .NET Core / Cross-platform functionality. The following will not work initially:
- Serialization of URIs via
Set-PSRyverConfig
. Set these values per-session if needed. [System.Drawing.Color]::SomeColor
shortcut. Use the provided$Script:PSRyverColorMap
hash to simplify this.- Example:
$Script:PSRyverColorMap.Red
- Example:
If you want to go beyond interacting with the Ryver API, you might consider using a bot.