You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
pingme/docs/services.md

16 KiB

Configuration

All the flags have crosponding enviornment variables assosiated with it. You can either provide the value with flags or export to a variable. You can view the crosponding variable to each with --help flag.

Flags take presedance over variables

Default value for message title is current time

Telegram

Telegram uses bot token to authenticate & send messages to defined channels. Multiple channel ids can be used separated by comma ','.

pingme  telegram  --token "0125:AAFHvnYf_ABC"  --msg "This is a new message ✈" --channel="-1001001001,-1002002001"
  • GitHub Action
on: [push]

jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2

      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          TELEGRAM_TOKEN: ${{ secrets.TELEGRAM_TOKEN }}
          TELEGRAM_CHANNELS: ${{ secrets.TELEGRAM_CHANNELS }}
          TELEGRAM_TITLE: 'Reference: ${{ github.ref }}'
          TELEGRAM_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams / pushover / discord / email
          service: telegram
  • Variables
Variables Default Value
TELEGRAM_MSG_TITLE ""
TELEGRAM_TOKEN ""
TELEGRAM_CHANNELS ""
TELEGRAM_MESSAGE ""
TELEGRAM_MSG_TITLE ""

RocketChat

RocketChat uses token & userID to authenticate and send messages to defined channels. Multiple channel ids can be used separated by comma ','.

pingme rocketchat \
  --channel "general,Pingme" \
  --msg ":wave: rocketchat from cli" \
  --userid "123" \
  --token "abcxyz" \
  --url 'localhost:3000' \
  --scheme "http"
  • Github Action
on:
  release:
    types: [published]
jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2
      
      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          ROCKETCHAT_USERID: ${{ secrets.ROCKETCHAT_USERID }}
          ROCKETCHAT_TOKEN: ${{ secrets.ROCKETCHAT_TOKEN }}
          ROCKETCHAT_SERVER_URL: ${{ secrets.ROCKETCHAT_SERVER_URL }}
          ROCKETCHAT_CHANNELS: ${{ secrets.ROCKETCHAT_CHANNELS }}
          ROCKETCHAT_URL_SCHEME: "https"
          ROCKETCHAT_TITLE: 'Reference: ${{ github.ref }}'
          ROCKETCHAT_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams / 
          # pushover / discord / email / mattermost
          service: rocketchat
  • Variables
Variables Default Value
ROCKETCHAT_USERID ""
ROCKETCHAT_TOKEN ""
ROCKETCHAT_SERVER_URL ""
ROCKETCHAT_URL_SCHEME "https"
RTOCKETCHAT_MESSAGE ""
ROCKETCHAT_TITLE ""
ROCKETCHAT_CHANNELS ""

Pushover

pingme pushover \
  --token '123' \
  --user '12345567' \
  --title 'some title' \
  --msg 'some message'
  • GitHub Action
on: [push]

jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2

      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          PUSHOVER_TOKEN: ${{ secrets.PUSHOVER_TOKEN }}
          PUSHOVER_USER: ${{ secrets.PUSHOVER_USER }}
          PUSHOVER_TITLE: 'Reference: ${{ github.ref }}'
          PUSHOVER_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams / 
          # pushover / discord / email
          service: pushover
  • Variables
Variables Default Value
PUSHOVER_TOKEN ""
PUSHOVER_USER ""
PUSHOVER_MESSAGE ""
PUSHOVER_TITLE ""

Mattermost

Mattermost uses token to authenticate and channel ids for targets. Destination server can be specified as 'example.com' by default the 'https' is used, you can change this with --scheme flag and set it to 'http'. Latest api version 4 is used for interacting with server, this can also be changes with --api flag. You can specify multiple channels by separating the value with ','.

pingme mattermost \
  --token '123' \
  --channel '12345,567' \
  --url 'localhost' \
  --scheme 'http' \
  --msg 'some message'
  • GitHub Action
on:
  release:
    types: [published]
jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2
      
      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          MATTERMOST_TOKEN: ${{ secrets.MATTERMOST_TOKEN }}
          MATTERMOST_SERVER_URL: ${{ secrets.MATTERMOST_SERVER_URL }}
          MATTERMOST_CHANNELS: ${{ secrets.MATTERMOST_CHANNELS }}
          MATTERMOST_CHANNELS: ${{ secrets.MATTERMOST_CHANNELS }}
          MATTERMOST_TITLE: 'Reference: ${{ github.ref }}'
          MATTERMOST_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams / 
          # pushover / discord / email / mattermost
          service: mattermost
  • Variables
Variables Default Value
MATTERMOST_API_URL "/api/v4/posts"
MATTERMOST_TOKEN ""
MATTERMOST_SERVER_URL ""
MATTERMOST_SCHEME "https"
MATTERMOST_MESSAGE ""
MATTERMOST_TITLE ""
MATTERMOST_CHANNELS ""

Slack

Slack uses token to authenticate and send messages to defined channels. Multiple channel ids can be used separated by comma ','.

pingme slack \
  --token '123' \
  --channel '1234567890' \
  --msg 'some message'
  • Github Action
on:
  release:
    types: [published]
jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2
      
      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          SLACK_TOKEN: ${{ secrets.SLACK_TOKEN }}
          SLACK_CHANNELS: ${{ secrets.SLACK_CHANNELS }}
          SLACK_MSG_TITLE: 'Reference: ${{ github.ref }}'
          SLACK_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams / 
          # pushover / discord / email
          service: slack
  • Variables
Variables Default Value
SLACK_TOKEN ""
SLACK_CHANNELS ""
SLACK_MESSAGE ""

Discord

Discord uses bot token to authenticate & send messages to defined channels. Multiple channel ids can be used separated by comma ','.

 pingme discord --token '123' --channel '1234567890' --msg 'some message'
  • GitHub Action
on:
  release:
    types: [published]
jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2
      
      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          DISCORD_CHANNELS: ${{ secrets.DISCORD_CHANNELS }}
          DISCORD_TOKEN: ${{ secrets.DISCORD_TOKEN }}
          DISCORD_TITLE: 'Reference: ${{ github.ref }}'
          DISCORD_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams / 
          # pushover / discord / email / mattermost
          service: discord
  • Variables
Variables Default Value
DISCORD_TOKEN ""
DISCORD_CHANNELS ""
DISCORD_MESSAGE ""
DISCORD_MSG_TITLE ""

Microsoft Teams

Teams uses webhooks to send messages, you can add multiple webhooks separated by comma ',' or you can add permissions for multiple channels to single webhook.

pingme teams --webhook 'https://example.webhook.office.com/xx' --msg 'some message'
  • GitHub Action
on: [push]

jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2

      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          TEAMS_WEBHOOK: ${{ secrets.TEAMS_WEBHOOK }}
          TEAMS_MSG_TITLE: 'Reference: ${{ github.ref }}'
          TEAMS_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams /
          # pushover / discord / email / mattermost
          service: teams
  • Variables
Variables Default Value
TEAMS_WEBHOOK ""
TEAMS_MESSAGE ""
TEAMS_MSG_TITLE ""

Pushbullet

  • SMS
pingme pushbullet \
  --sms true \
  --token "abcdefg" \
  -d "adnroid" \
  --msg "some message" \
  --number "00123456789"
  • Push notification
pingme pushbullet --token "abcdefg" -d "adnroid" --msg "some message"
  • GitHub Action
on: [push]

jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2

      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          PUSHBULLET_TOKEN: ${{ secrets.PUSHBULLET_TOKEN }}
          PUSHBULLET_DEVICE: ${{ secrets.PUSHBULLET_DEVICE }}
          PUSHBULLET_TITLE: 'Reference: ${{ github.ref }}'
          PUSHBULLET_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams /
          # pushover / discord / email
          service: pushbullet
  • Variables
Variables Default Value
PUSHBULLET_TOKEN ""
PUSHBULLET_DEVICE ""
PUSHBULLET_NUMBER ""
PUSHBULLET_MESSAGE ""
PUSHBULLET_SMS "false"
PUSHBULLET_TITLE ""

Twillio SMS

SMS can be sent via twillio to multiple numbers, you can add multiple receivers separated by a comma.

 pingme twillio \
   --token 'tokenabc' \
   --account 'sid123' \
   --sender '+140001442' \
   --receiver '+140001442' \
   --msg 'some message'
  • GitHub Action
on: [push]

jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2

      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          TWILLIO_TOKEN: ${{ secrets.TWILLIO_TOKEN }}
          TWILLIO_ACCOUNT_SID: ${{ secrets.TWILLIO_ACCOUNT_SID }}
          TWILLIO_SENDER: ${{ secrets.TWILLIO_SENDER }}
          TWILLIO_RECEIVER: ${{ secrets.TWILLIO_RECEIVER }}
          TWILLIO_TITLE: 'Reference: ${{ github.ref }}'
          TWILLIO_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        with:
          # Chose the messaging platform. 
          # slack / telegram / rocketchat / teams /
          # pushover / discord / email / mattermost / twillio
          service: twillio
  • Variables
Variables Default Value
TWILLIO_TOKEN ""
TWILLIO_ACCOUNT_SID ""
TWILLIO_SENDER ""
TWILLIO_RECEIVER ""
TWILLIO_TITLE ""
TWILLIO_MESSAGE ""

Mastodon

Mastodon uses application token to authorize and set status.

mastodon --url "mastodon.social" --msg "some message" --title "PingMe CLI" --token "123"
  • GitHub Action
on: [push]

jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2

      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          MASTODON_TOKEN: ${{ secrets.MASTODON_TOKEN }}
          MASTODON_SERVER: 'mastodon.social'
          MASTODON_TITLE: 'Reference: ${{ github.ref }}'
          MASTODON_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        
        with:
          service: mastodon
  • Variables
Variables Default Value
MASTODON_TOKEN ""
MASTODON_SERVER ""
MASTODON_TITLE ""
MASTODON_MESSAGE ""

Zulip

Mastodon uses application token to authorize and set status.

pingme zulip 
--email 'john.doe@email.com' \ 
 --api-key '12345567' \ 
 --to 'london' \
 --type 'stream' \
 --topic 'some topic' \
 --msg 'content of message'
  • GitHub Action
on: [push]

jobs:
  pingme-job:
    runs-on: ubuntu-latest
    name: PingMe
    steps:
      - name: Checkout
        uses: actions/checkout@v2

      - name: Ping me On
        uses: kha7iq/pingme-action@v1
        env:
          ZULIP_DOMAIN: ${{ secrets.ZULIP_DOMAIN }}
          ZULIP_BOT_EMAIL_ADDRESS: ${{ secrets.ZULIP_BOT_EMAIL_ADDRESS }}
          ZULIP_BOT_API_KEY: ${{ secrets.ZULIP_BOT_API_KEY }}
          ZULIP_MSG_TYPE: 'stream'
          ZULIP_STREAM_NAME: 'general'
          ZULIP_TOPIC: 'Reference: ${{ github.ref }}'
          ZULIP_MESSAGE: 'Event is triggered by ${{ github.event_name }}'
        
        with:
          service: zulip
  • Variables
Variables Default Value
ZULIP_DOMAIN ""
ZULIP_BOT_EMAIL_ADDRESS ""
ZULIP_BOT_API_KEY ""
ZULIP_MSG_TYPE ""
ZULIP_STREAM_NAME ""
ZULIP_TOPIC ""
ZULIP_MESSAGE ""

Email

Email uses username & password to authenticate for sending emails. SMTP hostname i.e smtp.gmail.com and port i.e (587) should be provided as well for the server. Multiple email ids can be used separated by comma ',' as receiver email address. All configuration options are also available via environment variables check configuration section.

pingme email \
  --rec "example@gmail.com,example@outlook.com" \
  --msg "This is an email from PingMe CLI" \
  --sub "Email from PingMe CLI" \
  --sender "sender@gmail.com" \
  --host "smtp.gmail.com" \
  --port "587" \
  --pass "secretPassword"
  • Variables
Variables Default Value
EMAIL_SENDER ""
EMAIL_PASSWORD ""
EMAIL_RECEIVER ""
EMAIL_IDENTITY ""
EMAIL_HOST "smtp.gmail.com"
EMAIL_PORT "587"
EMAIL_MESSAGE ""
EMAIL_SUBJECT ""