Antoine du Hamel 1eb317ba3a Release il y a 3 ans
..
bin 10bc79574e lerna link convert (#1730) il y a 5 ans
infra 0367074d92 companion: fixes docker version tagging. fixes #1579. il y a 4 ans
output e82f828d19 companion: smaller heroku deployment (#2845) il y a 4 ans
src b7559acd7c Make `@uppy/unsplash` production ready (#3196) il y a 3 ans
test 56a67de550 Close window on auth callback error and show error to user (#3143) il y a 3 ans
.dockerignore 8367cb643e Attempt at fixing docker build /cc @kiloreux il y a 6 ans
.gitignore 9a841f693a refactor: rename service-dog -> companion il y a 6 ans
ARCHITECTURE.md 7bf390abda add markdown linting using remark (#2181) il y a 5 ans
Dockerfile c88e27608c ci: fix companion deploys to docker and heroku il y a 4 ans
Dockerfile.test 771baab716 companion: install git so we can fetch tus-js-client fork (#1404) il y a 6 ans
KUBERNETES.md a03a1ed7d6 use tusd.tusdemo.net (#2691) il y a 4 ans
LICENSE 9a841f693a refactor: rename service-dog -> companion il y a 6 ans
Makefile 9a841f693a refactor: rename service-dog -> companion il y a 6 ans
Procfile e82f828d19 companion: smaller heroku deployment (#2845) il y a 4 ans
README.md c48064ba56 doc: lint JS code snippets (#2954) il y a 3 ans
docker-compose-dev.yml 9cd8c519b1 Update and fix docker-compose (#1076) il y a 6 ans
docker-compose-test.yml 9a841f693a refactor: rename service-dog -> companion il y a 6 ans
docker-compose.yml 9cd8c519b1 Update and fix docker-compose (#1076) il y a 6 ans
env.test.sh 970ac8df5b companion,box: Box provider implementation (#2549) il y a 4 ans
env_example 970ac8df5b companion,box: Box provider implementation (#2549) il y a 4 ans
nodemon.json 9a841f693a refactor: rename service-dog -> companion il y a 6 ans
package.json 1eb317ba3a Release il y a 3 ans
tsconfig.json fc1c808ab9 companion: generate type declaration files (#2749) il y a 4 ans

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@1.x (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

import express from 'express'
import bodyParser from 'body-parser'
import session from 'express-session'
import companion from '@uppy/companion'

const 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.

// ...
const 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