Skip to content

Latest commit

 

History

History
139 lines (101 loc) · 3.97 KB

README.md

File metadata and controls

139 lines (101 loc) · 3.97 KB

Adonis Backblaze Provider

CI/CD - GHPackages

Adonis BackBlaze Service Provider using backblaze-b2 under the hood.

Install

npm install --save @ks-labs/adonis-backblaze

Provider

Make sure to register the provider inside start/app.js file.

const providers = ['@ks-labs/adonis-backblaze/providers/B2Provider']

That's all! Now you can use the request transformer by importing it from the http context

// To get type definitions working on vscode
/** @type {typeof import('@ks-labs/adonis-backblaze/src/B2Service')} */
const B2Provider = use('AdonisB2')

class UserController {
  async index({ request, response, params }) {
    const b2ModelInstance = await B2Provider.uploadAndInsertB2File({
      bufferToUpload: Buffer.from('test'),
      originalName: 'FileName'
    })

    response.send(b2ModelInstance)
  }
}

Config

The config file is saved as config/b2-provider.js. Make sure to tweak it as per your needs.

Define B2File model as the example on:

'./templates/B2File.js'

The Database schema also is defined at:

'./templates/1607035890123_b_2_file_schema.js'

You can manipulate the backblaze entries references like this

/** @type {typeof import('../Models/B2File')} */
const B2File = use('App/Models/B2File')

Migrate from different token/bucket

yes, you can move entire files created from one bucket to another, this can be achieved by calling the following method

  • Allready Downloaded files will be skipped if match same SHA-1 from BackBlaze
// migrating from one appkey to another
const migration = await b2Singleton.migrateTokenAndDatabaseNames({
  // when true and all files moved with success old files versions will be deleted
  deleteOldFiles: true,
  // when true and all files moved with success the database entries will be updated with new reference
  updateDBModels: true,
  from: cfgWithSlashPrefix, // where come from
  to: cfgWithoutSlash // where will be moved to
})

// two configs follows the same schema
const configSchema = {
  blazeAppKey: process.env.B2_APP_KEY,
  blazeAppKeyID: process.env.B2_APP_KEY_ID,
  blazeAppKeyName: process.env.B2_APP_KEY_NAME,
  blazeAppKeyPrefix: process.env.B2_APP_KEY_PREFIX
}

// and will produce something like this
// during migration

[LOG] Total old files to migrate: 3
[LOG] Downloading 1 of 3 old files
[LOG] Downloading 2 of 3 old files
[LOG] Downloading 3 of 3 old files
[LOG] All files downloaded with success
[LOG] Changing to new token and uploading:
[LOG] Uploading remaining 3 of 3 files total
[LOG] Uploading remaining 2 of 3 files total
[LOG] Uploading remaining 1 of 3 files total
[LOG] All files migrated with success

Thanks

Special thanks to the creator(s) of AdonisJS for creating such a great framework.

Known Bugs

  • The entire file path being used as filename (caused by B2 API)

    Instead the backblaze use the file path folder to build the folder structure, it uses the path as the fully file name.

    The following upload code :

    const entityCreated = await B2Provider.uploadAndInsertB2File({
      bufferToUpload: Buffer.from('File Content'),
      fileName: 'test.txt',
      pathToFile: 'custom-folder/custom2',
      originalName: 'original.name.txt'
    })

    When generate a filename that sounds like this: /provider-files/custom-folder/test.txt But we need the filename, without the leading forward slash: provider-files/custom-folder/test.txt

    Its caused by :

    So... the app key allowed prefix specified are B2_APP_KEY_PREFIX=/provider-files The library parses the leading fowarded slash and all following path, as the filename instead being the folder name.

    Fix : Remove the leading backslash from B2_APP_KEY_PREFIX=/provider-files to B2_APP_KEY_PREFIX=provider-files

    And then when upload some file to backblaze the returned filename will be : 'my-bucket/custom-folder/test.txt'