Skip to content

simov/slack-incoming-facebook

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

slack-incoming-facebook

Slack Incoming WebHook for Facebook

Install

npm install -g slack-incoming-facebook

CLI

slack-incoming-facebook \
  --config /path/to/config.json \
  --db /path/to/db.json \
  --env environment

config.json

{
  "development": {
    "facebook": {
      "id": "[Organization Screen Name]",
      "token": "[OAuth Access Token]",
      "types": ["post types to include (optional)"]
    },
    "slack": { "see below" }
  }
}

The username, icon_url and channel keys are optional and take effect only if the hook is a Custom Integration. These 3 keys have no effect for bundled OAuth Apps.

Single hook:

"slack": {
  "hook": "[Hook URL]",
  "username": "[App Name]",
  "icon_url": "[App Avatar]",
  "channel": "[Target #channel or @user]"
}

Multiple hooks with a common username, icon_url and channel configuration:

"slack": {
  "hook": [
    "[Hook URL 1]",
    "[Hook URL 2]"
  ],
  "username": "[App Name]",
  "icon_url": "[App Avatar]",
  "channel": "[Target #channel or @user]"
}

Multiple hooks with separate username, icon_url and channel configuration:

"slack": [
  {
    "hook": "[Hook URL 1]",
    "username": "[App Name]",
    "icon_url": "[App Avatar]",
    "channel": "[Target #channel or @user]"
  },
  {
    "hook": [
      "[Hook URL 2]",
      "[Hook URL 3]"
    ],
    "username": "[App Name]",
    "icon_url": "[App Avatar]",
    "channel": "[Target #channel or @user]"
  }
]

db.json

{
  "development": {
    "timestamp": 0
  },
  "production": {
    "timestamp": 0
  }
}

Crontab

# Run on every 15 min:
*/15 * * * * node slack-incoming-facebook [params] >> slack-incoming-facebook.log

API

var hook = require('slack-incoming-facebook')

hook({
  config: require('config.json'),
  db: require('db.json'),
  dpath: '/absolute/path/to/db.json',
  env: 'development'
})
.then((responses) => {
  responses.forEach(([res, body]) => {
    console.log(new Date().toString(), res.statusCode, body)
  })
})
.catch((err) => console.error(new Date().toString(), err))

About

Slack Incoming WebHook for Facebook

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published