index.js 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. const express = require('express')
  2. // the ../../../packages is just to use the local version
  3. // instead of the npm version—in a real app use `require('@uppy/companion')`
  4. const uppy = require('../../../packages/@uppy/companion')
  5. const bodyParser = require('body-parser')
  6. const session = require('express-session')
  7. const app = express()
  8. app.use(bodyParser.json())
  9. app.use(session({
  10. secret: 'some-secret',
  11. resave: true,
  12. saveUninitialized: true
  13. }))
  14. app.use((req, res, next) => {
  15. res.setHeader('Access-Control-Allow-Origin', req.headers.origin || '*')
  16. res.setHeader(
  17. 'Access-Control-Allow-Methods',
  18. 'GET, POST, OPTIONS, PUT, PATCH, DELETE'
  19. )
  20. res.setHeader(
  21. 'Access-Control-Allow-Headers',
  22. 'Authorization, Origin, Content-Type, Accept'
  23. )
  24. res.setHeader('Access-Control-Allow-Credentials', 'true')
  25. next()
  26. })
  27. // Routes
  28. app.get('/', (req, res) => {
  29. res.setHeader('Content-Type', 'text/plain')
  30. res.send('Welcome to my uppy companion service')
  31. })
  32. // initialize uppy
  33. const uppyOptions = {
  34. providerOptions: {
  35. google: {
  36. key: 'your google key',
  37. secret: 'your google secret'
  38. }
  39. },
  40. customProviders: {
  41. mycustomprovider: {
  42. config: {
  43. // your oauth handlers
  44. authorize_url: 'http://localhost:3020/oauth/authorize',
  45. access_url: 'http://localhost:3020/oauth/token',
  46. oauth: 2,
  47. key: '***',
  48. secret: '**',
  49. scope: ['read', 'write']
  50. },
  51. // you provider module
  52. module: require('./customprovider')
  53. }
  54. },
  55. server: {
  56. host: 'localhost:3020',
  57. protocol: 'http'
  58. },
  59. filePath: './output',
  60. secret: 'some-secret',
  61. debug: true
  62. }
  63. app.get('/oauth/authorize', (req, res) => {
  64. // skips the default oauth process.
  65. // ideally this endpoint should handle the actual oauth process
  66. res.redirect(`http://localhost:3020/mycustomprovider/callback?state=${req.query.state}&access_token=randombytes`)
  67. })
  68. app.use(uppy.app(uppyOptions))
  69. // handle 404
  70. app.use((req, res, next) => {
  71. return res.status(404).json({ message: 'Not Found' })
  72. })
  73. // handle server errors
  74. app.use((err, req, res, next) => {
  75. console.error('\x1b[31m', err.stack, '\x1b[0m')
  76. res.status(err.status || 500).json({ message: err.message, error: err })
  77. })
  78. uppy.socket(app.listen(3020), uppyOptions)
  79. console.log('Welcome to Uppy Companion!')
  80. console.log(`Listening on http://0.0.0.0:${3020}`)