This Node.js® server posts videos and photos to the Museum's Facebook and Tumblr pages.
- dependencies
- setup 0. platform authentication
- configuration
- Running 0. Endpoints
- Limitations
- Troubleshooting
developed/tested/used with
- Node.js
- 6.10.0 (LTS)
- 5.9.1
- 4.3.1
- npm
- 3.10.10
- 3.7.3
- -nix OS
- Ubuntu 14.04
- OSX 10.11
- OSX 10.12.3
- Facebook app setup directions below
- Tumblr app setup directions below
- server for serving images and videos to the internet
- publicly-accessible server
- ngrok
This webservice requires a lot of setup. You need to authenticate against each network you want to post to, and set up a server to be able to serve media to the internet.
- Open Terminal
- Navigate to where you installed the MMI_Interactives code, and to the Sharing folder inside
cd /path/to/MMI_Interactives/Sharing
npm install
to download all Node.js dependencies- go through Platform Authentication
First we need to set up the ability to post media to Tumblr and Facebook. These instructions were current as of May 2016.
- Ensure your server has a publicly-accessible URL
- The token-fetching server binds to port 8012. Make sure requests are forwarded to the appropriate port before continuing.
- For the Museum server, this should already be configured. For testing and/or debugging, we suggest using usig ngrok
- If your computer or network configuration make this impractical, read through [using ngrok](../ Readme.md#using-ngrok)
- Setup a config.json file by copying and renaming the config.json.sample file
- Open this file (you will edit it in the Facebook and Tumblr steps below)
- Set up a Facebook App (below) and Tumblr App (below)
- Follow the instructions for the Token Fetching Service
- Now you are ready to Run
You will need a Facebook App to be able to post to Facebook.
- This requires you be signed in as an owner of the MMI Facebook Page
- You will also need a Facebook Page if you are debugging and/or testing.
Once you are signed in, you can set up the App.
- Click 'Create a new app' on the Facebook App page
- Setup the app, selecting a memorable 'Display Name' and entering your email in 'Contact Email'
- Once you're setup, click the "Settings" tab
0. First, click "+ Add Platform"
- Select "Website"
- In "App Domains" (under settings) and "Site URL" (under 'Website'), enter your public-facing URL 0. For production, it will most likely be http://www.movingimage.us/ 0. For developing using ngrok, it will be something like http://2z999999.ngrok.io 0.
- Click "Save Changes"
- You may add other users via the Roles tab 0. In order to authenticate with the Sharing script, they must have a Role (Administrator, Developer, or Tester)
- From the "Dashboard" page, show the App Secret (click show)
- Enter the Facebook App's ID and Secret into config.json
- Contunue Setting up
You will need a Tumblr app to be able to post to Tumblr. This requires you sign in as the Museum on Tumblr.
- Navigate to https://www.tumblr.com/oauth/apps
- Click "+ Register Application"
- On the Setup screen, fill in all required fields:
- Application Name: 'HensonPost' or similar (up to you)
- Application Description: "A Tumblr app that posts content from the Jim Henson Exhibition"
- Website URL: see 'Default callback URL' below; it should match this.
- Administrative contact email: your email
- Default callback URL: The URL you setup above 0. For production, it will most likely be http://www.movingimage.us/ 0. For developing using ngrok, it will be something like http://2z999999.ngrok.io 0.
- Click "Register" to finish
- Copy the Tumblr App's Key and Secret into config.json
- This is always accessible under your app at the Tumblr Apps page
- Contunue Setting up
configuration settings go in config.json. A sample is in config.json.sample with sensitive data removed.
- processInterval number of milliseconds between processing the queue of media to post
- maxAttempts the number of consecutive upload failures for any particular item before it is removed from the queue.
- media
- localpath the relative path from server.js to the directory where the media files are served from
- netpath the web address used to reach the media files
- e.g. for the Museum server, it may look like this (the slash is necessary):
"netpath":"http://www.movingimage.us/"
- facebook
- app details of the Facebook App being used for posting
- id the App ID
- secret the App Secret
- draft whether to post as a draft (to allow review before publicly posting)
- app details of the Facebook App being used for posting
- tumblr
- app details of the Tumblr App being used for posting
- key OAuth consumer key
- secret OAuth consumer secret
- draft whether to post as a draft (to allow review before publicly posting)
- app details of the Tumblr App being used for posting
For both media.localpath and media.netpath
the filename that is supplied to the sync webservice
is simply concatenated to the end.
Lets assume media.localpath is "../../media/"
and media.netpath is "http://www.movingimage.us/muppets/"
,
then the filename performance/video.mp4 will result in
../../media/performance/video.mp4
and http://www.movingimage.us/muppets/performance/video.mp4.
If your server configuration is such that simple concatenation
is not appropriate, extra development will be necessary.
This file should not be created or edited manually. Use the fetchToken app to create this file.
- page details for the page to post media to
- token long-live token for authenticating requests
- id the Facebook ID of the page
- album optional details for the album to post photos to
- id the Facebook ID of this album
- videoList optional details for the video list to post videos to
- id the Facebook Id of this video list
This file should not be created or edited manually. Use the fetchToken app to create this file.
- accessToken the Tumblr access token to use for authenticating requests
- accessSecret the associated token secret for authenticating requests
- blog the name of the blog to post to
start this server with npm start
.
It will start an HTTP server on port 8013.
In production this will probably be set up to start on boot using Upstart
or init.d in which case you will configure those services to execute
/PATH/TO/node /PATH/TO/REPO/Sharing/server.js ./config.json
where /PATH/TO/node can be determined by running which node
.
The Sharing server itself does not need to be accessible from the internet, but the media files you want to post will need to be because they are downloaded by Facebook and Tumblr.
If the computer you are working from cannot serve files to the internet, you can use ngrok and a static server to open a tunnel to the media directory (media.localpath in config.json).
As a static server (to which ngrok forwards connections), you can use anything. Suggestions include:
- Python's SimpleHTTPServer module
python -m SimpleHTTPServer 8012
- Node.js' http-server module
http-server . --enable-cors -p 8012
- after
npm install -g http-server
- after
- if you are testing the Sharing interface, CORS must be enabled to allow the images and videos to be viewable on the iPad.
- POST /video In order to upload Videos,
post the filename (relative to media.localpath in config.json)
of the video to
/video
like so:curl --data "filename=performance/myvideo.mov" http://localhost:8013/video
- POST /photo In order to upload Photos,
post the filename (relative to media.localpath in config.json)
of the photo to
/photo
like so:curl --data "filename=anythingmuppets/myphoto.png" http://localhost:8013/photo
- GET /state You can check the status of files like so:
curl http://localhost:8013/state?filename=anythingmuppets/myphoto.png
- This endpoint returns a JSON-formatted response:
{"filename":"FILENAME","type":"TYPE","state":"STATE"}
- FILENAME will match the queried filename
- TYPE will be either
photo
orvideo
- STATE will be either
unknown
,posting
,posted
, orfailed
- unknown means the file was never submitted for posting, or it has since been deleted from the server.
- failed means the file failed to post too many times. It can be re-submitted for posting.
- This endpoint returns a JSON-formatted response:
The Tumblr posting service currently uploads videos directly to Tumblr. We originally tried embedding the FB videos in Tumblr, but people could only see them if they were logged into FB. Tumblr has a number of posting limits:
- max 250 posts per day
- max 5 minutes of uploaded video per day
- max 100 MB uploaded video per day
- Make sure the media files are accessible from the internet.
- Make sure the media.localpath and media.netpath values are correct and resolve POST-ed filename values to the correct relative path and internet address.
- Make sure the Sync service is properly and periodically copying files from the touchpoint computers to the server.
- The Sharing server uses log4js
- The script will normally log to rolling files in the log/ directory
- to enable console logging add
{"type":"console"}
to the appenders array in log4js_conf.json - you can change the logging detail by changing the value of levels.[all] (and/or any other key in the levels object) in log4js_conf.json to
"INFO"
,"DEBUG"
,"TRACE"
, or"ALL"