Skip to content
This repository has been archived by the owner on Oct 18, 2022. It is now read-only.

Latest commit

 

History

History
111 lines (85 loc) · 4.29 KB

README.md

File metadata and controls

111 lines (85 loc) · 4.29 KB

Panoptès fetches content from different detectors of potential disinformation and sends formatted messages to a server Mattermost

Panoptès récupère le contenu de différents détecteurs de désinformation potentielle et envoie des messages formatés à un serveur Mattermost.


Development

This API is built with Node. You will need to install it to run this API.

Installation

Clone the repository and install dependencies:

git clone https://github.com/ambanum/panoptes.git
cd panoptes
npm install

Configuration

First of all you have to configure mattermost integrations'url in the config/default.json file:

{
    "mattermost": {
        "incomingWebhookUrl": "http://localhost:8065/hooks/dijcdr5s1tfajy8yorqwii4rny",
        "actions": {
            "urls": {
                "sendToAnalysis": "http://host.docker.internal:3000/sendToAnalysis",
                "mediaScale": "http://host.docker.internal:3000/media-scale"
            }
        }
    },
    
}
  • mattermost.incomingWebhookUrl: URL of the incoming webhook created to receive requests. An incoming webhook must be created on your Mattermost server. See Mattermost Incoming Webhooks documentation for more information.

  • mattermost.actions.urls.sendToAnalysis: URL of the action to send message to Analysis channel.

  • mattermost.actions.urls.mediaScale: URL of the action to call media-scale.

  • mattermost.actions.urls.mediaScaleResponseUrl: URL of the incoming webhook from media-scale.

Then you have to add some sources. There are two kinds of sources supported for now, RSS feeds from Buzzsumo and JSON files from AlgoTransparency.org.

{
    "mattermost": {
        
    },
    "sources": {
        "rss": {
            "lemonde": {
                "feedUrl": "https://app.buzzsumo.com/rss/alerts/ODJHGFTUxa2p87jhgqsdjfh%3D",
                "message": {
                    "author": "Le monde",
                    "authorIconUrl": "https://pbs.twimg.com/profile_images/817042499134980096/LTpqSDMM.jpg",
                    "color": "#88BB3E"
                }
            },
        },
        "algoTransparency": {
            "baseUrl": "https://algotransparency.org/data/france/",
            "maxItems": 5,
            "message": {
                "author": "Youtube France",
                "authorIconUrl": "https://cdn4.iconfinder.com/data/icons/social-messaging-ui-color-shapes-2-free/128/social-youtube-circle-512.png",
                "color": "#c4302b"
            }
        }
    }
}

For RSS source:

  • feedUrl: RSS feed URL.

For AlgoTransparency source:

  • baseUrl: URL of the folder containing JSON daily files from AlgoTransparency
  • maxItems: Max number of videos to display every day

For both:

Usage

Run the code:

node index.js
  • RSS Feeds will be fetched every minute and only new content will be sent to Mattermost.
  • AlgoTransparency will be fetched daily and only the top maxItems most recommended videos will be sent to Mattermost.

Deployment

Clone the repository on your server, install dependencies, configure the code for your production environement and run the server. We suggest to use a production process manager for Node.js like pm2 or Forever.

For information on how we deploy this app, you can take a look at the role panoptes in our disinfo.quaidorsay.fr-ops repository


License

The code for this software is distributed under the European Union Public Licence (EUPL) v1.2. Contact the author if you have any specific need or question regarding licensing.