# UploadOptions

Defined in: [packages/synapse-sdk/src/types.ts:447](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L447)

Options for uploading individual pieces to an existing storage context

Used by StorageContext.upload() for uploading data to a specific provider
and data set that has already been created/selected.

## Extends

- [`StoreOptions`](/reference/filoz/synapse-sdk/synapse/interfaces/storeoptions/).[`UploadCallbacks`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/)

## Properties

### onCopyComplete?

> `optional` **onCopyComplete?**: (`providerId`, `pieceCid`) => `void`

Defined in: [packages/synapse-sdk/src/types.ts:423](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L423)

Called when a secondary copy completes successfully

#### Parameters

| Parameter | Type |
| ------ | ------ |
| `providerId` | `bigint` |
| `pieceCid` | `PieceLink` |

#### Returns

`void`

#### Inherited from

[`UploadCallbacks`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/).[`onCopyComplete`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/#oncopycomplete)

***

### onCopyFailed?

> `optional` **onCopyFailed?**: (`providerId`, `pieceCid`, `error`) => `void`

Defined in: [packages/synapse-sdk/src/types.ts:425](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L425)

Called when a secondary copy fails

#### Parameters

| Parameter | Type |
| ------ | ------ |
| `providerId` | `bigint` |
| `pieceCid` | `PieceLink` |
| `error` | [`Error`](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Error) |

#### Returns

`void`

#### Inherited from

[`UploadCallbacks`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/).[`onCopyFailed`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/#oncopyfailed)

***

### onPiecesAdded?

> `optional` **onPiecesAdded?**: (`transaction`, `providerId`, `pieces`) => `void`

Defined in: [packages/synapse-sdk/src/types.ts:419](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L419)

Called when the addPieces transaction has been submitted for a provider

#### Parameters

| Parameter | Type |
| ------ | ------ |
| `transaction` | `` `0x${string}` `` |
| `providerId` | `bigint` |
| `pieces` | `object`[] |

#### Returns

`void`

#### Inherited from

[`UploadCallbacks`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/).[`onPiecesAdded`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/#onpiecesadded)

***

### onPiecesConfirmed?

> `optional` **onPiecesConfirmed?**: (`dataSetId`, `providerId`, `pieces`) => `void`

Defined in: [packages/synapse-sdk/src/types.ts:421](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L421)

Called when the addPieces transaction is confirmed on-chain for a provider

#### Parameters

| Parameter | Type |
| ------ | ------ |
| `dataSetId` | `bigint` |
| `providerId` | `bigint` |
| `pieces` | [`PieceRecord`](/reference/filoz/synapse-sdk/synapse/interfaces/piecerecord/)[] |

#### Returns

`void`

#### Inherited from

[`UploadCallbacks`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/).[`onPiecesConfirmed`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/#onpiecesconfirmed)

***

### onProgress?

> `optional` **onProgress?**: (`bytesUploaded`) => `void`

Defined in: [packages/synapse-sdk/src/types.ts:551](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L551)

Progress callback for upload bytes

#### Parameters

| Parameter | Type |
| ------ | ------ |
| `bytesUploaded` | `number` |

#### Returns

`void`

#### Inherited from

[`StoreOptions`](/reference/filoz/synapse-sdk/synapse/interfaces/storeoptions/).[`onProgress`](/reference/filoz/synapse-sdk/synapse/interfaces/storeoptions/#onprogress)

***

### onPullProgress?

> `optional` **onPullProgress?**: (`providerId`, `pieceCid`, `status`) => `void`

Defined in: [packages/synapse-sdk/src/types.ts:427](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L427)

Called with pull status updates during SP-to-SP transfer

#### Parameters

| Parameter | Type |
| ------ | ------ |
| `providerId` | `bigint` |
| `pieceCid` | `PieceLink` |
| `status` | [`PullStatus`](/reference/filoz/synapse-sdk/synapse/type-aliases/pullstatus/) |

#### Returns

`void`

#### Inherited from

[`UploadCallbacks`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/).[`onPullProgress`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/#onpullprogress)

***

### onStored?

> `optional` **onStored?**: (`providerId`, `pieceCid`) => `void`

Defined in: [packages/synapse-sdk/src/types.ts:417](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L417)

Called when piece data has been stored on a provider (before on-chain commit)

#### Parameters

| Parameter | Type |
| ------ | ------ |
| `providerId` | `bigint` |
| `pieceCid` | `PieceLink` |

#### Returns

`void`

#### Inherited from

[`UploadCallbacks`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/).[`onStored`](/reference/filoz/synapse-sdk/synapse/interfaces/uploadcallbacks/#onstored)

***

### pieceCid?

> `optional` **pieceCid?**: `PieceLink`

Defined in: [packages/synapse-sdk/src/types.ts:547](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L547)

Optional pre-calculated PieceCID to skip CommP calculation

#### Inherited from

[`StoreOptions`](/reference/filoz/synapse-sdk/synapse/interfaces/storeoptions/).[`pieceCid`](/reference/filoz/synapse-sdk/synapse/interfaces/storeoptions/#piececid)

***

### pieceMetadata?

> `optional` **pieceMetadata?**: [`MetadataObject`](/reference/filoz/synapse-sdk/synapse/type-aliases/metadataobject/)

Defined in: [packages/synapse-sdk/src/types.ts:449](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L449)

Custom metadata for this specific piece (key-value pairs)

***

### signal?

> `optional` **signal?**: [`AbortSignal`](https://developer.mozilla.org/docs/Web/API/AbortSignal)

Defined in: [packages/synapse-sdk/src/types.ts:549](https://github.com/FilOzone/synapse-sdk/blob/bd9e06ee9cf6823545e5c4af63ab47e38bbf43ef/packages/synapse-sdk/src/types.ts#L549)

Optional AbortSignal to cancel the store

#### Inherited from

[`StoreOptions`](/reference/filoz/synapse-sdk/synapse/interfaces/storeoptions/).[`signal`](/reference/filoz/synapse-sdk/synapse/interfaces/storeoptions/#signal)