All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- Authorizing a key for a single bucket ensures that this bucket is cached
Bucket.lsoperation supports wildcard matching strings- Documentation for AbstractUploadSource and its children
InvalidJsonResponsewhen the received error is not a proper JSON document- Raising
PotentialS3EndpointPassedAsRealmwhen a specific misconfiguration is suspected - Add
large_file_sha1support
- Removed information about replication being in closed beta
- Additional tests for listing files/versions
- Ensured that changelog validation only happens on pull requests
- Upgraded GitHub actions checkout to v3, python-setup to v4
- GitHub actions are using new GITHUB_OUTPUT instead of deprecated set-output
1.18.0 - 2022-09-20
- Logging performance summary of parallel download threads
- Add
max_download_streams_per_fileparameter to B2Api class and underlying structures - Add
is_file_lock_enabledparameter toBucket.update()and related methods
- Replace
ReplicationScanResult.source_has_sse_c_enabledwithsource_encryption_mode - Fix
B2Api.get_key()andRawSimulator.delete_key() - Fix calling
CopySizeTooBigexception
- Fix nox's deprecated
session.install()calls - Re-enable changelog validation in CI
- StatsCollector contains context managers for gathering performance statistics
1.17.3 - 2022-07-15
- Fix
FileVersion._get_upload_headerswhen encryption key isNone
- Fix download integration tests on non-production environments
- Add
B2_DEBUG_HTTPenv variable to enable network-level test debugging - Disable changelog validation temporarily
1.17.2 - 2022-06-24
- Fix a race in progress reporter
- Fix import of replication
1.17.1 - 2022-06-23 [YANKED]
- Fix importing scan module
1.17.0 - 2022-06-23 [YANKED]
As in version 1.16.0, the replication API may still be unstable, however no backward-incompatible changes are planned at this point.
- Add
included_sourcesmodule for keeping track of included modified third-party libraries - Add
include_existing_filesparameter toReplicationSetupHelper
- Downloading compressed files with
Content-Encodingheader set no longer causes them to be decompressed on the fly - it's an option - Change the per part retry limit from 5 to 20 for data transfer operations. Please note that the retry system is not considered to be a part of the public interface and is subject to be adjusted
- Do not wait more than 64 seconds between retry attempts (unless server asks for it)
- On longer failures wait an additional (random, up to 1s) amount of time to prevent client synchronization
- Flatten
ReplicationConfigurationinterface - Reorder actions of
ReplicationSetupHelperto avoid zombie rules
- Fix: downloading compressed files and decompressing them on the fly now does not cause a TruncatedOutput error
- Fix
AccountInfo.is_master_key() - Fix docstring of
SqliteAccountInfo - Fix lifecycle rule type in the docs
- Add 3.11.0-beta.1 to CI
- Change Sphinx major version from 5 to 6
- Extract folder/bucket scanning into a new
scanmodule - Enable pip cache in CI
1.16.0 - 2022-04-27
This release contains a preview of replication support. It allows for basic usage of B2 replication feature (currently in closed beta).
As the interface of the sdk (and the server api) may change, the replication support shall be considered PRIVATE interface and should be used with caution. Please consult the documentation on how to safely use the private api interface.
Expect substantial amount of work on sdk interface:
- The interface of
ReplicationConfigurationWILL change - The interface of
FileVersion.replication_statusMIGHT change - The interface of
FileVersionDownloadMIGHT change
- Add basic replication support to
BucketandFileVersion - Add
is_master_key()method toAbstractAccountInfo - Add
readBucketReplicationsandwriteBucketReplicationstoALL_CAPABILITIES - Add log tracing of
interpret_b2_error - Add
ReplicationSetupHelper
- Fix license test on Windows
- Fix cryptic errors when running integration tests with a non-full key
1.15.0 - 2022-04-12
- Don't run coverage in pypy in CI
- Introduce a common thread worker pool for all downloads
- Increase http timeout to 20min (for copy using 5GB parts)
- Remove inheritance from object (leftover from python2)
- Run unit tests on all CPUs
- Add pypy-3.8 to test matrix
- Add support for unverified checksum upload mode
- Add dedicated exception for unverified email
- Add a parameter to customize
sync_policy_manager - Add parameters to set the min/max part size for large file upload/copy methods
- Add CopySourceTooBig exception
- Add an option to set a custom file version class to
FileVersionFactory - Add an option for B2Api to turn off hash checking for downloaded files
- Add an option for B2Api to set write buffer size for
DownloadedFile.save_tomethod - Add support for multiple profile files for SqliteAccountInfo
- Fix copying objects larger than 1TB
- Fix uploading objects larger than 1TB
- Fix downloading files with unverified checksum
- Fix decoding in filename and file info of
DownloadVersion - Fix an off-by-one bug and other bugs in the Simulator copy functionality
- Drop support for Python 3.5 and Python 3.6
1.14.1 - 2022-02-23
- Fix setting permissions for local sqlite database (thanks to Jan Schejbal for responsible disclosure!)
1.14.0 - 2021-12-23
- Relax constraint on arrow to allow for versions >= 1.0.2
1.13.0 - 2021-10-24
- Add support for Python 3.10
- Update a list with all capabilities
- Fix pypy selector in CI
1.12.0 - 2021-08-06
- The
importlib-metadatarequirement is less strictly bound now (just >=3.3.0 for python > 3.5). B2Apiupdate_file_legal_holdandupdate_file_retention_settingnow return the set values
BucketIdNotFoundthrown based on B2 cloud response_clonemethod toFileVersionandDownloadVersiondelete,update_legal_hold,update_retentionanddownloadmethods added toFileVersion
- FileSimulator returns special file info headers properly
- One unused import.
1.11.0 - 2021-06-24
- apiver
v2interface released.from b2sdk.v2 import ...is now the recommended import, butfrom b2sdk.v1 import ...works as before
1.10.0 - 2021-06-23
get_fresh_statemethod added toFileVersionandBucket
download_file_*methods refactored to allow for inspecting DownloadVersion before downloading the whole fileB2Api.get_file_inforeturns aFileVersionobject in v2B2RawApirenamed toB2RawHTTPApiB2HTTPtests are now commonB2HttpApiConfigclass introduced to provide parameters likeuser_agent_appendtoB2Apiwithout using internal classes in v2Bucket.updatereturns aBucketobject in v2Bucket.lsargumentshow_versionsrenamed tolatest_onlyin v2B2Apiapplication key methods refactored to operate with dataclasses instead of dicts in v2B2Api.list_keysis a generator lazily fetching all keys in v2account_idandbucket_idadded to FileVersion
- Fix EncryptionSetting.from_response_headers
- Fix FileVersion.size and FileVersion.mod_time_millis type ambiguity
- Old buckets (from past tests) are cleaned up before running integration tests in a single thread
- Remove deprecated
SyncReportmethods
1.9.0 - 2021-06-07
ScanPoliciesManageris able to filter b2 files by upload timestamp
Synchronizer.make_file_sync_actionsandSynchronizer.make_folder_sync_actionswere made private in v2 interface- Refactored
sync.file.*Fileandsync.file.*FileVersiontosync.path.*SyncPathin v2 - Refactored
FileVersionInfotoFileVersionin v2 ScanPoliciesManagerexclusion interface changed in v2B2Apiunittests for v0, v1 and v2 are now commonB2Api.cancel_large_filereturns aFileIdAndNameobject instead of aFileVersionobject in v2FileVersionhas a mandatoryapiparameter in v2B2Folderholds a handle to B2ApiBucketunit tests for v1 and v2 are now common
- Fix call to incorrect internal api in
B2Api.get_download_url_for_file_name
1.8.0 - 2021-05-21
- Add
get_bucket_name_or_none_from_bucket_idtoAccountInfoandCache - Add possibility to change realm during integration tests
- Add support for "file locks": file retention, legal hold and default bucket retention
- Cleanup sync errors related to directories
- Use proper error handling in
ScanPoliciesManager - Application key restriction message reverted to previous form
- Added missing apiver wrappers for FileVersionInfo
- Fix crash when Content-Range header is missing
- Pin dependency versions appropriately
b2sdk.v1.syncrefactored to reflectb2sdk.syncstructure- Make
B2Api.get_bucket_by_idreturn populated bucket objects in v2 - Add proper support of
recommended_part_sizeandabsolute_minimum_part_sizeinAccountInfo - Refactored
minimum_part_sizetorecommended_part_size(the value used stays the same) - Encryption settings, types and providers are now part of the public API
- Remove
Bucket.copy_fileandBucket.start_large_file - Remove
FileVersionInfo.format_ls_entryandFileVersionInfo.format_folder_ls_entry
1.7.0 - 2021-04-22
- Add
__slots__and__eq__toFileVersionInfofor memory usage optimization and ease of testing - Add support for SSE-C server-side encryption mode
- Add support for
XDG_CONFIG_HOMEfor determining the location ofSqliteAccountInfodb file
BasicSyncEncryptionSettingsProvidersupports different settings sets for reading and writing- Refactored AccountInfo tests to a single file using pytest
- Fix clearing cache during
authorize_account - Fix
ChainedStream(needed inBucket.create_fileetc.) - Make tqdm-based progress reporters less jumpy and easier to read
- Fix emerger examples in docs
1.6.0 - 2021-04-08
- Fetch S3-compatible API URL from
authorize_account
- Exclude packages inside the test package when installing
- Fix for server response change regarding SSE
1.5.0 - 2021-03-25
- Add
dependabot.yml - Add support for SSE-B2 server-side encryption mode
- Add upper version limit for the requirements
- Pin
setuptools-scm<6.0as>=6.0doesn't support Python 3.5
1.4.0 - 2021-03-03
- Add an ability to provide
bucket_idfilter parameter forlist_buckets - Add
is_same_keymethod toAccountInfo - Add upper version limit for arrow dependency, because of a breaking change
- Fix docs autogen
1.3.0 - 2021-01-13
- Add custom exception for
403 transaction_cap_exceeded - Add
get_file_info_by_idandget_file_info_by_nametoBucket FileNotPresentandNonExistentBucketnow subclass new exceptionsFileOrBucketNotFoundandResourceNotFound
- Fix missing import in the synchronization example
- Use
setuptools-scmfor versioning - Clean up CI steps
1.2.0 - 2020-11-03
- Add support for Python 3.9
- Support for bucket to bucket sync
- Add a possibility to append a string to the User-Agent in
B2Http
- Change default fetch count for
lsto 10000
- Drop Python 2 and Python 3.4 support 🎉
- Remove
--prefixfromls(it didn't really work, usefolderNameargument)
- Allow to set an empty bucket info during the update
- Fix docs generation in CI
1.1.4 - 2020-07-15
- Allow specifying custom realm in B2Session.authorize_account
1.1.2 - 2020-07-06
- Fix upload part for file range on Python 2.7
1.1.0 - 2020-06-24
- Add
list_file_versionsmethod to buckets. - Add server-side copy support for large files
- Add ability to synthesize objects from local and remote sources
- Add AuthInfoCache, InMemoryCache and AbstractCache to public interface
- Add ability to filter in ScanPoliciesManager based on modification time
- Add ScanPoliciesManager and SyncReport to public interface
- Add md5 checksum to FileVersionInfo
- Add more keys to dicts returned by as_dict() methods
- Make sync treat hidden files as deleted
- Ignore urllib3 "connection pool is full" warning
- Remove arrow warnings caused by arrow-py/arrow#612
- Fix handling of modification time of files
1.0.2 - 2019-10-15
- Remove upper version limit for arrow dependency
1.0.0 - 2019-10-03
- Minor bug fix.
1.0.0-rc1 - 2019-07-09
- Deprecate some transitional method names to v0 in preparation for v1.0.0.
0.1.10 - 2019-07-09
- Remove a parameter (which did nothing, really) from
b2sdk.v1.Bucket.copy_filesignature
0.1.8 - 2019-06-28
- Add support for b2_copy_file
- Add support for
prefixparameter on ls-like calls
0.1.6 - 2019-04-24
- Rename account ID for authentication to application key ID. Account ID is still backwards compatible, only the terminology has changed.
- Fix transferer crashing on empty file download attempt
0.1.4 - 2019-04-04
Initial official release of SDK as a separate package (until now it was a part of B2 CLI)