Skip to content

Commit

Permalink
Merge branch 'master' into post-customization
Browse files Browse the repository at this point in the history
  • Loading branch information
William B Ernest authored Feb 18, 2021
2 parents 094da16 + 3e08ee5 commit d97566c
Show file tree
Hide file tree
Showing 4 changed files with 36 additions and 18 deletions.
8 changes: 5 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ This plugin allows a user to subscribe a channel to an RSS (Version 2 only) or a
- Version < 0.1.0 requires Mattermost 5.6

## Getting Started
Upload tar.gz to Mattermost using the plugin screen.
Upload `tar.gz` to Mattermost using the plugin screen.
Assign a user under the settings for posting.

To allow for the plugin to override user user name and icon on posts you must enable the feature in your Mattermost system settings:
Expand All @@ -17,8 +17,10 @@ To allow for the plugin to override user user name and icon on posts you must en
To use the plugin, navigate to the channel you want subscribed and use the following commands:
```
/feed help // to see the help menu
/feed subscribe <url> // to subscribe the channel to an rss feed
/feed unsubscribe <url> // to unsubscribe the channel from an rss feed
/feed subscribe <url> // to subscribe the channel to an RSS feed
/feed sub <url> // to subscribe the channel to an RSS feed
/feed unsubscribe <url> // to unsubscribe the channel from an RSS feed
/feed unsub <url> // to unsubscribe the channel from an RSS feed
/feed list // to list the feeds the channel is subscribed to
```

Expand Down
6 changes: 4 additions & 2 deletions plugin.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"id": "rssfeed",
"name": "RSSFeed",
"description": "This plugin serves as an rss subscription service for Mattermost.",
"description": "This plugin serves as an RSS subscription service for Mattermost.",
"version": "0.2.0",
"server": {
"executables": {
Expand All @@ -16,7 +16,7 @@
"settings": [
{
"key": "Heartbeat",
"display_name": "Time window between rss feed checks (minutes).",
"display_name": "Time window between RSS feed checks (minutes).",
"type": "text",
"help_text": "This is used to set a timer for the system to know when to go check to see if there is any new data in the subscribed rss feeds. Defaults to 15 minutes."
},
Expand Down Expand Up @@ -72,6 +72,8 @@
"type": "bool",
"help_text": "(Optional) Specify, whether the title of an Atom feed should be posted",
"default": true
"help_text": "(Optional) Use this field to hide the description in RSS post (Useful if link already returns a valid link back to post)."

}
]
}
Expand Down
14 changes: 7 additions & 7 deletions server/command.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,19 +10,19 @@ import (
)

// COMMAND_HELP is the text you see when you type /feed help
const COMMAND_HELP = `* |/feed subscribe url| - Connect your Mattermost channel to an rss feed
* |/feed list| - Lists the rss feeds you have subscribed to
* |/feed unsubscribe url| - Unsubscribes the Mattermost channel from the rss feed`
const COMMAND_HELP = `* |/feed subscribe url| or |/feed sub url| - Connect your Mattermost channel to an RSS feed
* |/feed list| - Lists the RSS feeds you have subscribed to
* |/feed unsubscribe url| or |/feed unsub url| - Unsubscribes the Mattermost channel from the RSS feed`

// + `* |/feed initiate| - initiates the rss feed subscription poller`
// + `* |/feed initiate| - initiates the RSS feed subscription poller`

func getCommand() *model.Command {
return &model.Command{
Trigger: "feed",
DisplayName: "RSSFeed",
Description: "Allows user to subscribe to an rss feed.",
AutoComplete: true,
AutoCompleteDesc: "Available commands: list, subscribe, unsubscribe, help",
AutoCompleteDesc: "Available commands: list, subscribe, sub, unsubscribe, unsub, help",
AutoCompleteHint: "[command]",
}
}
Expand Down Expand Up @@ -69,7 +69,7 @@ func (p *RSSFeedPlugin) ExecuteCommand(c *plugin.Context, args *model.CommandArg
}
}
return getCommandResponse(model.COMMAND_RESPONSE_TYPE_EPHEMERAL, txt), nil
case "subscribe":
case "subscribe", "sub":

if len(parameters) == 0 {
return getCommandResponse(model.COMMAND_RESPONSE_TYPE_EPHEMERAL, "Please specify a url."), nil
Expand All @@ -84,7 +84,7 @@ func (p *RSSFeedPlugin) ExecuteCommand(c *plugin.Context, args *model.CommandArg
}

return getCommandResponse(model.COMMAND_RESPONSE_TYPE_EPHEMERAL, fmt.Sprintf("Successfully subscribed to %s.", url)), nil
case "unsubscribe":
case "unsubscribe", "unsub":
if len(parameters) == 0 {
return getCommandResponse(model.COMMAND_RESPONSE_TYPE_EPHEMERAL, "Please specify a url."), nil
} else if len(parameters) > 1 {
Expand Down
26 changes: 20 additions & 6 deletions server/plugin.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,18 +2,20 @@ package main

import (
"errors"
"github.com/lunny/html2md"
"github.com/mattermost/mattermost-server/model"
"github.com/mattermost/mattermost-server/plugin"
"github.com/wbernest/atom-parser"
"github.com/wbernest/rss-v2-parser"
"fmt"
"io/ioutil"
"net/http"
"strconv"
"strings"
"sync"
"time"

"golang.org/x/tools/blog/atom"
"github.com/lunny/html2md"
"github.com/mattermost/mattermost-server/model"
"github.com/mattermost/mattermost-server/plugin"
atomparser "github.com/wbernest/atom-parser"
rssv2parser "github.com/wbernest/rss-v2-parser"
)

//const RSSFEED_ICON_URL = "./plugins/rssfeed/assets/rss.png"
Expand Down Expand Up @@ -118,7 +120,7 @@ func (p *RSSFeedPlugin) processSubscription(subscription *Subscription) error {
return errors.New("invalid atom feed format - " + err.Error())
}
} else {
return errors.New("invalid feed format")
return fmt.Errorf("invalid feed format for subscription: %s", subscription.URL)
}

return nil
Expand All @@ -141,6 +143,12 @@ func (p *RSSFeedPlugin) processRSSV2Subscription(subscription *Subscription) err

items := rssv2parser.CompareItemsBetweenOldAndNew(oldRssFeed, newRssFeed)

// if this is a new subscription only post the latest
// and not spam the channel
if len(oldRssFeed.Channel.ItemList) == 0 {
items = items[:1]
}

for _, item := range items {
post := ""

Expand Down Expand Up @@ -191,6 +199,12 @@ func (p *RSSFeedPlugin) processAtomSubscription(subscription *Subscription) erro

items := atomparser.CompareItemsBetweenOldAndNew(oldFeed, newFeed)

// if this is a new subscription only post the latest
// and not spam the channel
if len(oldFeed.Entry) == 0 {
items = items[:1]
}

for _, item := range items {
post := ""

Expand Down

0 comments on commit d97566c

Please sign in to comment.