/twitter-archive-explorer-server

Server-side for Archive Explorer project

Primary LanguageTypeScriptOtherNOASSERTION

archive-explorer-node

Serve requests for the Archive Explorer project.

This is the back-end side of the Archive Explorer project. See archive-explorer-web for the front-end website.

Website is available in archive-explorer.com !

Foreword

None of the pages served to clients are server-side rendered. This server provides static access to the bundled React website, and gives access to an API developed with the Express framework.

API exposes multiple REST endpoints and a WebSocket powered by Socket.io.

This server needs a open mongoDB server to store user credentials and tweets/twitter users cache, internally opered by mongoose.

The whole project is developed in TypeScript.

Worker threads are used to dispatch tweet delete requests, so make sure you have a Node version that support the worker_threads module !

Supported Node versions are Node 10.5+ with --experimental-worker flag, or Node 12+ without flags.

Getting started for development

Clone repository and install dependencies with NPM.

git clone https://github.com/alkihis/archive-explorer-node.git
cd archive-explorer-node
npm i

Setting up constants

Some constants are not built-in, to provide security.

Twitter constants

You must have a working Twitter application in order to run server. This could be long to obtain, but I just can't share my own credentials.

Duplicate the file settings.sample.json and name it settings.json.

Set up inside the newly created file your Twitter application token (consumer key), the application secret key (consumer_secret key), and the callback after Sign in with Twitter login flow (localhost:3000/finalize should be fine for development, change it for production).

Public and private keys

This server use JWT (JSON Web Tokens) as token system. This kind of credentials requires a couple of public/private keys in order to sign tokens.

Create a .ssh folder in the directory root. Go to this directory. Create a public and private key with a passphrase.

All the created files will not be gitted to your fork or repo.

# Creating dir
mkdir .ssh
cd .ssh

# Generating private key (do not forget to enter a passphrase when asked)
ssh-keygen -t rsa -b 4096 -m PEM -f key_new.pem

# Generating public key
openssl rsa -in key_new.pem -pubout -outform PEM -out key_new

# Register the passphrase in the file "passphrase"
echo "my_choosen_passphrase" > passphrase

Project is ready !

Compiling and running project

You need to first compile the project in order to start the index.js file with Node. Make sure TypeScript npm package is installed globally.

tsc

Now, make sure the mongoDB server is running, then start the server:

node build/index.js -l <logLevel> -p <emitPort> -m <mongoDBPort>

Default values are:

  • -l info
  • -p 3128
  • -m 3281

You can ask for help with --help.

Deploy

By default, server will emit to port 443 (HTTPS). You just need to specify --prod argument to build/index.js.

Certificates should be in directory mentionned in settings.json's https_key_directory. It assume you will use Let's Encrypt.