Renée Kooi 054e40831a companion: a few dependency updates (#2333) 4 роки тому
..
bin 10bc79574e lerna link convert (#1730) 5 роки тому
infra e101256350 Fixes and upgrades (#2198) 5 роки тому
src 2ab00ab05d companion: enable protection when fetching file size + log info about blocked redirect (#2332) 4 роки тому
test 740ba1d5b3 companion: block redirects to urls with different protocol (#2322) 4 роки тому
.dockerignore 8367cb643e Attempt at fixing docker build /cc @kiloreux 6 роки тому
.eslintrc.json 62c48408ba companion: return 401 early if token is not set (#2118) 5 роки тому
.gitignore 9a841f693a refactor: rename service-dog -> companion 6 роки тому
ARCHITECTURE.md 7bf390abda add markdown linting using remark (#2181) 5 роки тому
Dockerfile 5b20573909 build: upgrade node to v10 on companion.uppy.io (#2329) 4 роки тому
Dockerfile.test 771baab716 companion: install git so we can fetch tus-js-client fork (#1404) 6 роки тому
KUBERNETES.md 7bf390abda add markdown linting using remark (#2181) 5 роки тому
LICENSE 9a841f693a refactor: rename service-dog -> companion 6 роки тому
Makefile 9a841f693a refactor: rename service-dog -> companion 6 роки тому
README.md b02bb2c517 Update README.md (#2206) 5 роки тому
docker-compose-dev.yml 9cd8c519b1 Update and fix docker-compose (#1076) 6 роки тому
docker-compose-test.yml 9a841f693a refactor: rename service-dog -> companion 6 роки тому
docker-compose.yml 9cd8c519b1 Update and fix docker-compose (#1076) 6 роки тому
env.test.sh 67af833fdb More uppy server -> companion renames (#1037) 6 роки тому
env_example c3ea4d384f companion,facebook: add support for facebook provider 5 роки тому
nodemon.json 9a841f693a refactor: rename service-dog -> companion 6 роки тому
package.json 054e40831a companion: a few dependency updates (#2333) 4 роки тому
tsconfig.json 9a841f693a refactor: rename service-dog -> companion 6 роки тому

README.md

Companion

Build Status

Companion is a server integration for Uppy file uploader.

It handles the server-to-server communication between your server and file storage providers such as Google Drive, Dropbox, Instagram, etc. Companion is not a target to upload files to. For this, use a https://tus.io server (if you want resumable) or your existing Apache/Nginx server (if you don't). See here for full documentation

Install

npm install @uppy/companion

If you don't have a Node.js project with a package.json you might want to install/run Companion globally like so: [sudo] npm install -g @uppy/companion@0.17.4 (best check the actual latest version, and use that, so (re)installs are reproducible, and upgrades intentional).

Usage

companion may either be used as pluggable express app, which you plug to your already existing server, or it may simply be run as a standalone server:

Plug to already existing server


var express = require('express')
var bodyParser = require('body-parser')
var session = require('express-session')
var companion = require('@uppy/companion')

var app = express()
app.use(bodyParser.json())
app.use(session({secret: 'some secrety secret'}))
...
// be sure to place this anywhere after app.use(bodyParser.json()) and app.use(session({...})
const options = {
  providerOptions: {
    google: {
      key: 'GOOGLE_KEY',
      secret: 'GOOGLE_SECRET'
    }
  },
  server: {
    host: 'localhost:3020',
    protocol: 'http',
  },
  filePath: '/path/to/folder/'
}

app.use(companion.app(options))

To enable companion socket for realtime feed to the client while upload is going on, you call the socket method like so.

...
var server = app.listen(PORT)

companion.socket(server, options)

Run as standalone server

Please ensure that the required env variables are set before runnning/using companion as a standalone server. See.

$ companion

If you cloned the repo from GitHub and want to run it as a standalone server, you may also run the following command from within its directory

npm start

Deploy to heroku

Companion can also be deployed to Heroku

mkdir uppy-companion && cd uppy-companion

git init

echo 'export COMPANION_PORT=$PORT' > .profile
echo 'node_modules' > .gitignore
echo '{
  "name": "uppy-companion",
  "version": "1.0.0",
  "scripts": {
    "start": "companion"
  },
  "dependencies": {
    "@uppy/companion": "^1.13.1"
  }
}' > package.json

npm i

git add . && git commit -am 'first commit'

heroku create

git push heroku master

Make sure you set the required environment variables.

See full documentation