github-actions[bot] c9dcc93d4f Release: uppy@2.9.0 (#3598) 3 năm trước cách đây
..
bin 10bc79574e lerna link convert (#1730) 5 năm trước cách đây
infra bac107fc5f @uppy/companion: fix Dockerfile and deploy automation (#3355) 3 năm trước cách đây
output e82f828d19 companion: smaller heroku deployment (#2845) 4 năm trước cách đây
src 0033b9fd5e Companion server upload events (#3544) 3 năm trước cách đây
test 0033b9fd5e Companion server upload events (#3544) 3 năm trước cách đây
.gitignore 5cfb9fe7a5 fix unpslash author meta, sanitize metadata to strings and improve companion tests (#3478) 3 năm trước cách đây
.npmignore e65f2b0397 add `.npmignore` files to ignore .gitignore when packing (#3380) 3 năm trước cách đây
ARCHITECTURE.md 0d831b6f78 fix callback urls (#3458) 3 năm trước cách đây
CHANGELOG.md c9dcc93d4f Release: uppy@2.9.0 (#3598) 3 năm trước cách đây
KUBERNETES.md 56339fc3e5 Rewrite Companion providers to use streams to allow simultaneous upload/download without saving to disk (#3159) 3 năm trước cách đây
LICENSE 9a841f693a refactor: rename service-dog -> companion 6 năm trước cách đây
Makefile 9a841f693a refactor: rename service-dog -> companion 6 năm trước cách đây
README.md 4e4eddf4a5 finish master->main job (#3315) 3 năm trước cách đây
env_example 56339fc3e5 Rewrite Companion providers to use streams to allow simultaneous upload/download without saving to disk (#3159) 3 năm trước cách đây
heroku.yml fee5ad917f Fix Companion deploys (#3388) 3 năm trước cách đây
nodemon.json 9a841f693a refactor: rename service-dog -> companion 6 năm trước cách đây
package.json c9dcc93d4f Release: uppy@2.9.0 (#3598) 3 năm trước cách đây
tsconfig.json fc1c808ab9 companion: generate type declaration files (#2749) 4 năm trước cách đây

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 existing server, or it may also be run as a standalone server:

Plug to an 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)

Run as standalone server

Please make sure 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": "latest"
  }
}' > 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