Skip to content

Commit

Permalink
feat: add redundancy options
Browse files Browse the repository at this point in the history
  • Loading branch information
Cafe137 committed Feb 19, 2024
1 parent bf1c3ea commit e73862a
Showing 1 changed file with 60 additions and 1 deletion.
61 changes: 60 additions & 1 deletion src/command/upload.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Tag, Utils } from '@ethersphere/bee-js'
import { RedundancyLevel, Tag, Utils } from '@ethersphere/bee-js'

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (14.x)

Module '"@ethersphere/bee-js"' has no exported member 'RedundancyLevel'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (14.x)

Argument of type '{ tag: number | undefined; pin: boolean; encrypt: boolean; contentType: string | undefined; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'FileUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (14.x)

Argument of type '{ tag: number | undefined; deferred: boolean; encrypt: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'UploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (14.x)

Argument of type '{ indexDocument: string; errorDocument: string; tag: number | undefined; pin: boolean; encrypt: boolean; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'CollectionUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (14.x)

Argument of type '{ tag: number | undefined; pin: boolean; encrypt: boolean; contentType: string | undefined; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'FileUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (14.x)

Property 'getRedundancyStat' does not exist on type 'typeof import("/home/runner/work/swarm-cli/swarm-cli/node_modules/@ethersphere/bee-js/dist/types/utils/expose")'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (14.x)

Property 'approximateOverheadForRedundancyLevel' does not exist on type 'typeof import("/home/runner/work/swarm-cli/swarm-cli/node_modules/@ethersphere/bee-js/dist/types/utils/expose")'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (16.x)

Module '"@ethersphere/bee-js"' has no exported member 'RedundancyLevel'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (16.x)

Argument of type '{ tag: number | undefined; pin: boolean; encrypt: boolean; contentType: string | undefined; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'FileUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (16.x)

Argument of type '{ tag: number | undefined; deferred: boolean; encrypt: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'UploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (16.x)

Argument of type '{ indexDocument: string; errorDocument: string; tag: number | undefined; pin: boolean; encrypt: boolean; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'CollectionUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (16.x)

Argument of type '{ tag: number | undefined; pin: boolean; encrypt: boolean; contentType: string | undefined; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'FileUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (16.x)

Property 'getRedundancyStat' does not exist on type 'typeof import("/home/runner/work/swarm-cli/swarm-cli/node_modules/@ethersphere/bee-js/dist/types/utils/expose")'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (16.x)

Property 'approximateOverheadForRedundancyLevel' does not exist on type 'typeof import("/home/runner/work/swarm-cli/swarm-cli/node_modules/@ethersphere/bee-js/dist/types/utils/expose")'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (18.x)

Module '"@ethersphere/bee-js"' has no exported member 'RedundancyLevel'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (18.x)

Argument of type '{ tag: number | undefined; pin: boolean; encrypt: boolean; contentType: string | undefined; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'FileUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (18.x)

Argument of type '{ tag: number | undefined; deferred: boolean; encrypt: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'UploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (18.x)

Argument of type '{ indexDocument: string; errorDocument: string; tag: number | undefined; pin: boolean; encrypt: boolean; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'CollectionUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (18.x)

Argument of type '{ tag: number | undefined; pin: boolean; encrypt: boolean; contentType: string | undefined; deferred: boolean; redundancyLevel: any; }' is not assignable to parameter of type 'FileUploadOptions'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (18.x)

Property 'getRedundancyStat' does not exist on type 'typeof import("/home/runner/work/swarm-cli/swarm-cli/node_modules/@ethersphere/bee-js/dist/types/utils/expose")'.

Check failure on line 1 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / node-tests (18.x)

Property 'approximateOverheadForRedundancyLevel' does not exist on type 'typeof import("/home/runner/work/swarm-cli/swarm-cli/node_modules/@ethersphere/bee-js/dist/types/utils/expose")'.
import { Presets, SingleBar } from 'cli-progress'
import * as FS from 'fs'
import { Argument, LeafCommand, Option } from 'furious-commander'
Expand Down Expand Up @@ -104,6 +104,12 @@ export class Upload extends RootCommand implements LeafCommand {
})
public contentType!: string

@Option({
key: 'redundancy',
description: 'Redundancy of the upload (MEDIUM, STRONG, INSANE, PARANOID)',
})
public redundancy!: string

// CLASS FIELDS

public hash!: string
Expand Down Expand Up @@ -140,6 +146,7 @@ export class Upload extends RootCommand implements LeafCommand {
}

await this.maybeRunSizeChecks()
await this.maybePrintRedundancyStats()

const tag = this.sync ? await this.bee.createTag() : undefined

Expand Down Expand Up @@ -211,6 +218,7 @@ export class Upload extends RootCommand implements LeafCommand {
encrypt: this.encrypt,
contentType,
deferred: this.deferred,
redundancyLevel: this.determineRedundancyLevel(),
})
this.hash = reference

Expand All @@ -219,6 +227,8 @@ export class Upload extends RootCommand implements LeafCommand {
const { reference } = await this.bee.uploadData(this.stamp, this.stdinData, {
tag: tag?.uid,
deferred: this.deferred,
encrypt: this.encrypt,
redundancyLevel: this.determineRedundancyLevel(),
})
this.hash = reference

Expand All @@ -239,6 +249,7 @@ export class Upload extends RootCommand implements LeafCommand {
pin: this.pin,
encrypt: this.encrypt,
deferred: this.deferred,
redundancyLevel: this.determineRedundancyLevel(),
})
this.hash = reference

Expand All @@ -260,6 +271,7 @@ export class Upload extends RootCommand implements LeafCommand {
encrypt: this.encrypt,
contentType,
deferred: this.deferred,
redundancyLevel: this.determineRedundancyLevel(),
})
this.hash = reference

Expand Down Expand Up @@ -340,6 +352,35 @@ export class Upload extends RootCommand implements LeafCommand {
}
}

private async maybePrintRedundancyStats(): Promise<void> {
if (!this.redundancy || this.quiet) {
return
}

const currentSetting = Utils.getRedundancyStat(this.redundancy)
const originalSize = await this.getUploadSize()
const originalChunks = Math.ceil(originalSize.getBytes() / 4e3)
const sizeMultiplier = Utils.approximateOverheadForRedundancyLevel(
originalChunks,
currentSetting.value,
this.encrypt,
)
const newSize = new Storage(originalChunks * 4e3 * (1 + sizeMultiplier))
const extraSize = new Storage(newSize.getBytes() - originalSize.getBytes())

this.console.log(createKeyValue('Redundancy setting', currentSetting.label))
this.console.log(`This setting will provide ${Math.round(currentSetting.errorTolerance * 100)}% error tolerance.`)
this.console.log(`An additional ${extraSize.toString()} of data will be uploaded approximately.`)
this.console.log(`${originalSize.toString()}${newSize.toString()} (+${extraSize.toString()})`)
if (!this.yes && !this.quiet) {

Check failure on line 375 in src/command/upload.ts

View workflow job for this annotation

GitHub Actions / check (18.x)

Expected blank line before this statement
const confirmation = await this.console.confirm('Do you want to proceed?')

if (!confirmation) {
exit(0)
}
}
}

private async getUploadSize(): Promise<Storage> {
let size = -1

Expand Down Expand Up @@ -424,4 +465,22 @@ export class Upload extends RootCommand implements LeafCommand {

return defaultName
}

private determineRedundancyLevel(): RedundancyLevel | undefined {
if (!this.redundancy) {
return undefined
}
switch (this.redundancy.toUpperCase()) {
case 'MEDIUM':
return RedundancyLevel.MEDIUM
case 'STRONG':
return RedundancyLevel.STRONG
case 'INSANE':
return RedundancyLevel.INSANE
case 'PARANOID':
return RedundancyLevel.PARANOID
default:
throw new CommandLineError(`Invalid redundancy level: ${this.redundancy}`)
}
}
}

0 comments on commit e73862a

Please sign in to comment.