Skip to content

Instantly share code, notes, and snippets.

@muesli
Last active July 23, 2020 22:54
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save muesli/f3f3f7bc59628289c97b2dfb8ac0e414 to your computer and use it in GitHub Desktop.
Save muesli/f3f3f7bc59628289c97b2dfb8ac0e414 to your computer and use it in GitHub Desktop.
DevrantBee
/*
* Copyright (C) 2014-2017 Christian Muehlhaeuser
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published
* by the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Authors:
* Nicolas Martin <penguwingithub@gmail.com>
* Christian Muehlhaeuser <muesli@gmail.com>
*/
// Package devrantbee is a Bee that can post blogs & quotes on Devrant.
package devrantbee
import (
"github.com/jayeshsolanki93/devgorant"
"github.com/muesli/beehive/bees"
)
// DevrantBee is a Bee that can post blogs & quotes on Devrant.
type DevrantBee struct {
bees.Bee
client *devgorant.Client
evchan chan bees.Event
}
// Action triggers the action passed to it.
func (mod *DevrantBee) Action(action bees.Action) []bees.Placeholder {
outs := []bees.Placeholder{}
switch action.Name {
case "surprise":
rant, err := mod.client.Surprise()
if err != nil {
mod.LogErrorf("Failed to fetch surprise rant: %v", err)
}
mod.triggerEvent(rant)
case "weekly":
rants, err := mod.client.WeeklyRants()
if err != nil {
mod.LogErrorf("Failed to fetch weekly rants: %v", err)
}
for _, v := range rants {
mod.triggerEvent(v)
}
case "rant":
limit := 0
action.Options.Bind("limit", &limit)
rants, err := mod.client.Rants("", limit, 0)
if err != nil {
mod.LogErrorf("Failed to fetch rants: %v", err)
}
for i := range rants {
mod.triggerEvent(rants[i])
}
default:
panic("Unknown action triggered in " + mod.Name() + ": " + action.Name)
}
return outs
}
func (mod *DevrantBee) triggerEvent(rant devgorant.RantModel) {
ev := bees.Event{
Bee: mod.Name(),
Name: "rant",
Options: []bees.Placeholder{
{
Name: "ID",
Type: "int",
Value: rant.Id,
},
{
Name: "text",
Type: "string",
Value: rant.Text,
},
{
Name: "upvotes",
Type: "int",
Value: rant.Upvotes,
},
{
Name: "downvotes",
Type: "int",
Value: rant.Downvotes,
},
{
Name: "score",
Type: "int",
Value: rant.Score,
},
{
Name: "created_time",
Type: "int",
Value: rant.CreatedTime,
},
{
Name: "num_comments",
Type: "int",
Value: rant.NumComments,
},
{
Name: "user_id",
Type: "int",
Value: rant.UserId,
},
{
Name: "username",
Type: "string",
Value: rant.UserUsername,
},
{
Name: "user_score",
Type: "int",
Value: rant.UserScore,
},
},
}
mod.evchan <- ev
}
// Run executes the Bee's event loop.
func (mod *DevrantBee) Run(eventChan chan bees.Event) {
mod.evchan = eventChan
// Setting up the client, unfortunately we can't really log in as an user
mod.client = devgorant.New()
}
// ReloadOptions parses the config options and initializes the Bee.
func (mod *DevrantBee) ReloadOptions(options bees.BeeOptions) {
mod.SetOptions(options)
}
/*
* Copyright (C) 2014-2017 Christian Muehlhaeuser
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published
* by the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Authors:
* Nicolas Martin <penguwingithub@gmail.com>
* Christian Muehlhaeuser <muesli@gmail.com>
*/
package devrantbee
import (
"github.com/muesli/beehive/bees"
)
// DevrantBeeFactory is a factory for DevrantBees.
type DevrantBeeFactory struct {
bees.BeeFactory
}
// New returns a new Bee instance configured with the supplied options.
func (factory *DevrantBeeFactory) New(name, description string, options bees.BeeOptions) bees.BeeInterface {
bee := DevrantBee{
Bee: bees.NewBee(name, factory.ID(), description, options),
}
bee.ReloadOptions(options)
return &bee
}
// ID returns the ID of this Bee.
func (factory *DevrantBeeFactory) ID() string {
return "devrantbee"
}
// Name returns the name of this Bee.
func (factory *DevrantBeeFactory) Name() string {
return "Devrant"
}
// Description returns the description of this Bee.
func (factory *DevrantBeeFactory) Description() string {
return "Retrieves rants from Devrant"
}
// Image returns the filename of an image for this Bee.
func (factory *DevrantBeeFactory) Image() string {
return factory.ID() + ".png"
}
// LogoColor returns the preferred logo background color (used by the admin interface).
func (factory *DevrantBeeFactory) LogoColor() string {
return "#54556E"
}
// Events describes the available events provided by this Bee.
func (factory *DevrantBeeFactory) Events() []bees.EventDescriptor {
events := []bees.EventDescriptor{
{
Namespace: factory.Name(),
Name: "rant",
Description: "is triggered after rants were fetched",
Options: []bees.PlaceholderDescriptor{
{
Name: "ID",
Description: "ID of a rant",
Type: "int",
},
{
Name: "text",
Description: "Text of a rant",
Type: "string",
},
{
Name: "upvotes",
Description: "Sum of upvotes",
Type: "int",
},
{
Name: "downvotes",
Description: "Sum of downvotes",
Type: "int",
},
{
Name: "score",
Description: "Current score of a rant",
Type: "int",
},
{
Name: "created_time",
Description: "Creation time of a rant",
Type: "int",
},
{
Name: "num_comments",
Description: "Number of comments",
Type: "int",
},
{
Name: "user_id",
Description: "ID of the user who posted the rant",
Type: "int",
},
{
Name: "username",
Description: "Username of the ranter",
Type: "string",
},
{
Name: "user_score",
Description: "Total user score",
Type: "int",
},
},
},
}
return events
}
// Actions describes the available actions provided by this Bee.
func (factory *DevrantBeeFactory) Actions() []bees.ActionDescriptor {
actions := []bees.ActionDescriptor{
{
Namespace: factory.Name(),
Name: "surprise",
Description: "Fetches a surprise rant",
Options: []bees.PlaceholderDescriptor{},
},
{
Namespace: factory.Name(),
Name: "weekly",
Description: "Fetches the top weekly rants",
Options: []bees.PlaceholderDescriptor{},
},
{
Namespace: factory.Name(),
Name: "rant",
Description: "Fetches new rants",
Options: []bees.PlaceholderDescriptor{
{
Name: "limit",
Description: "How many rants to retrieve",
Type: "int",
Mandatory: true,
},
},
},
}
return actions
}
func init() {
f := DevrantBeeFactory{}
bees.RegisterFactory(&f)
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment