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.
Features
- Convert to Java (domain, config, storage-aws and filesystem) @kemitix (#446)
- Create and use a cache of hashes for local files @kemitix (#249)
Maintenance
- Add release drafter configuration @kemitix (#462)
- Bump aws-java-sdk-s3 from 1.11.805 to 1.11.806 @dependabot-preview (#457)
- Bump aws-java-sdk-s3 from 1.11.804 to 1.11.805 @dependabot-preview (#454)
- Bump aws-java-sdk-s3 from 1.11.803 to 1.11.804 @dependabot-preview (#452)
- Bump aws-java-sdk-s3 from 1.11.802 to 1.11.803 @dependabot-preview (#449)
- Bump aws-java-sdk-s3 from 1.11.801 to 1.11.802 @dependabot-preview (#447)
- Bump scala-library from 2.13.0 to 2.13.2 @dependabot-preview (#439)
- Bump aws-java-sdk-s3 from 1.11.800 to 1.11.801 @dependabot-preview (#442)
- Bump zio-streams_2.13 from 1.0.0-RC16 to 1.0.0-RC20 @dependabot-preview (#440)
- Bump tiles-maven-plugin from 2.16 to 2.17 @dependabot-preview (#441)
- Bump aws-java-sdk-s3 from 1.11.792 to 1.11.800 @dependabot-preview (#436)
- Bump jackson-dataformat-cbor from 2.10.4 to 2.11.0 @dependabot-preview (#432)
- Java rewrite - step 1 - build with Maven @kemitix (#431)
- Update jackson-dataformat-cbor to 2.10.4 @scala-steward (#389)
- Update jackson-databind to 2.10.4 @scala-steward (#388)
- Update sbt-scoverage to 1.6.1 @scala-steward (#272)
- Update sbt-ci-release to 1.5.3 @scala-steward (#379)
- Update sbt-bloop to 1.4.1 @scala-steward (#402)
- Update sbt-wartremover, wartremover to 2.4.9 @scala-steward (#417)
- Update sbt to 1.3.12 @scala-steward (#418)
- Update aws-java-sdk-s3 to 1.11.797 @kemitix (#425)
- Run Github Actions on pull requests @kemitix (#424)
- Update aws-java-sdk-s3 to 1.11.661 @scala-steward (#250)
- Update zio, zio-streams to 1.0.0-RC16 @scala-steward (#251)
- Update zio, zio-streams to 1.0.0-RC15 @scala-steward (#241)
- Update sbt-bloop to 1.3.5 @scala-steward (#247)
- Update sbt to 1.3.3 @scala-steward (#238)
This is the last v0.x
feature release. The next feature release will be v1.x
.
- Can’t publish new releases to sonatype (#219)
- Accept
parallel
in config files (#230)
- Reduce Progress widget from 3 lines to 2 (#221)
- Perform delete operations in parallel (#223)
- Update
sbt-bloop
to1.3.3
(#224) - Update
zio
,zio-streams
to1.0.0-RC14
(#226) - Update
sbt-bloop
to1.3.4
(#228) - Rollback
sbt-ci-release
to1.3.2
(#231)
- Progress UI should be updated when upload fails (#218)
- Update
aws-java-sdk-s3
to1.11.641
(#217)
- Support multiple parallel uploads (#188)
- Update
jackson-dataformat-cbor
to2.10.0
(#216) - Update
jackson-databind
to2.10.0
(#214) - Update
sbt-ci-release
to1.4.31
(#211)
- Not wrapping exceptions thrown in waitForUploadResult (#162)
- Update
jackson-dataformat-cbor
to2.9.10
(#208) - Update
jackson-databind
to2.9.10
(#206) - Update
sbt
to1.3.2
(#207) - Update
zio, zio-streams
to 1.0.0-RC13~ (#209) - Update
aws-java-sdk-s3
to1.11.635
(#203) - Update
sbt
to1.3.1
(#204) - Update
sbt-wartremover
to2.4.3
(#202) - Update
sbt-ci-release
to1.3.2
(#200)
- Log copy and delete operations (#119)
- Log errors with red label (#119)
- Ensure file handles are always closed (#122)
- [build] Install WartRemover plugin (#150)
- [build] Add GitHub Action
- [build] Add sbt-jacoco plugin for code coverage (#184)
- [internal] Replace cats-effect with zio (#117)(#148)(#149)(#178)
- [internal] Replace Monocle with local SimpleLens implementation (#121)
- [internal] Don’t use String as key in Map for hashes (#124)
- [internal] Convert Storage to full ZIO effect module (#133)
- [internal] Convert Config to full ZIO effect module (#134)
- [internal] Create FileSystem ZIO effect module (#135)
- [internal] Merge config package object with Config object (#138)
- [internal] Merge FS object into FileSystem object (#139)
- [internal] Assorted refactoring (#129)(#128)(#137)(#141)(#142)(#143)
- [internal] case classes shouldn’t be OO objects (#147)
- [internal] Restructure using EIP-ZIO channels (#183)
- [progressbar] Reset progress bar for each file (#145)
- Handle building large changesets better (#163)
- Update
aws-java-sdk-s3
from1.11.587
to1.11.610
(#118)(#144)(#158) - Update
jackson-databind
from2.9.9.1
to2.9.9.3
(#132)(#152) - Update
scalamock
from4.3.0
to4.4.0
(#165) - Upgrade to Scala 2.13.0 (#176)
- Update
sbt
from1.2.8
to1.3.0
(#180) - Update
sbt-ci-release
from1.2.6
to1.3.1
(#186)
- Apply
scalafmt
(#108) - Uses Lenses (#113)
- Creates incorrect MD5 hash for some files (#103)
- NullPointerException creating scaladoc (#115)
- Only settings in
.thorp.conf
for explicit sources are used (#111)
- Not reading
.thorp.conf
file (#110)(#111)
- Add a version command-line option (#99)
- Add a batch mode (#85)
- Display total size and progress for entire run (#94)
- Sync more than one source directory into a single bucket/prefix (#25)
- Upgrade
jackson-databind
from2.9.9
to2.9.9.1
(#101) - Upgrade
aws-java-sdk-s3
from1.11.580
to1.11.587
(#104) - Upgrade
sbt-assembly
from0.14.9
to0.14.10
(#105)
- Release to sonatype using correct profile name (#102)
- Abstraction layer encapsulating S3 as Storage (#76)
- Display simple error message when bucket is invalid (#81)
- Shutdown storage service once completed (#88)
- Release snapshots to sonatype from TravisCI (#92)
- Embed launch script in fat-jar (#98)
- Use correct hash locally for comparing multi-part uploaded files (#82)
- Handle large list of action in a stack-safe manner (#93)
- Upgrade
scalamock
from4.2.0
to4.3.0
(#84) - Upgrade
aws-java-sdk-s3
from1.11.573
to1.11.580
(#86)
- Add
thorp-lib
module (#66) - Enable running outside of sbt (#55)
-d
,--debug
flag for log messages (#60)- Read config from
.thorp.conf
in source directory (#71) - Read config from
$HOME/.config/thorp.conf
and/etc/thorp.conf
(#73) - Add
--no-global
and--no-user
options (#50) - Display any upload errors in summary report (#50)
- Rename project as ‘thorp’ (#75)
- Suppress Transfer event messages (#64)
- Better error message when source not found (#51)
- Reduced logging (#59)
- Prevent AWS SDK from recalculating MD5 hash (#50)
- Error when calculating md5 hash for large files (#56)
-v
verbosity flag (#63)
- Upgrade
aws-java-sdk-s3
from1.11.569
to1.11.570
(#57)
- Multi-part uploads
--include
to select files for synchronisation- Upload progress bar
--filter
renamed to-exclude
- Fetch md5 hashes for all remote objects, not just the first 1000
- Handle when a file goes away between scanning and uploading
- Removed
reactive-aws-s3-{core,cats}
and the AWS SDK v2 that it depended upon in favour of the AWS SDK v1 - Upgrade
aws-java-sdk-s3
from1.11.560
to1.11.569
- Upgrade
cats-effect
from1.2.0
to1.3.1
- Upgade
scalatest
from3.0.7
to3.0.8
- Filter to exclude files
- Display count of the number of files uploaded
- Improved performance by fetching all MD5 hashes from S3 in single request at startup
- Initial Release
- Synchronise files with an S3 bucket, using an MD5 hash to identify when the file has changed and needs to be uploaded