All Versions
39
Latest Version
2.2
Avg Release Cycle
28 days
Latest Release
1321 days ago

Changelog History
Page 1

  • v2.2 Changes

    April 23, 2021

    ๐Ÿ› Bug Fixes

    • โšก๏ธ update Discord invite link
    • readme typo and mascot placement (#693)
    • embedded/store: ensure done message is received
    • pkg/client: delete token file on logout only if the file exists

    ๐Ÿ”„ Changes

    • โž• Add benchmark to README (based on 0.9.x) (#706)
    • github workflow to run stress_tool (#714)
    • README SDK description and links (#717)
    • ๐Ÿ›  fix immugw support
    • โž• Add roadmap
    • โœ‚ remove grpc term from token expiration description
    • embedded/store: check latest indexed tx is not greater than latest committed one
    • embedded/store: use specified sync mode also for the incremental hash tree
    • embedded/store: defer lock releasing
    • โœ… pkg/client/clienttest: add VerifiedGetAt mock method
    • pkg/database: use newly exposed KeyReaderSpec

    ๐Ÿ”‹ Features

    • โž• add token expiration time flag
    • embedded/store: readAsBefore and reset reader
    • pkg/sql: readAsBefore operation
  • v1.4.1 Changes

    November 14, 2022

    ๐Ÿ”„ Changes

    • pkg/server: Add logs for activities related to users
  • v1.4.1-RC1 Changes

    November 16, 2022

    ๐Ÿ› Bug Fixes

    • ๐Ÿ”„ Change replication-related terms in codebase
    • ๐Ÿ”„ Change replication-related terms in tests
    • cmd: Rename replication flags to follow consistent convention
    • cmd/immudb: Better description of the --force-admin-password flag
    • cmd/immudb: Fix description of the force-admin-password flag
    • embedded/appendable: fsync parent directory
    • embedded/appendable: fsync parent folder in remote appedable
    • pkg: Rename replication-related fields in GRPC protocol
    • pkg/client: Delay server identity validation
    • pkg/client/cache: Add methods to validate server identity
    • pkg/client/cache: Validate server's identity
    • pkg/server: Remove includeDeactivated flag when querying for users
    • โœ… pkg/server/servertest: Add uuid to buffconn server
    • โœ… pkg/server/servertest: Fix resetting grpc connection
    • โœ… test/perf-test-suite: Avoid dumping immudb logo on perf test results file
    • ๐ŸŽ test/performance-test-suite: Ensure results are shown after proper is finished
    • verification: Additional Linear proof consistency check
    • verification: Recreate linear advance proofs for older servers

    ๐Ÿ”„ Changes

    • ci: migrate deprecating set-output commands
    • cmd/immudb: Allow resetting sysadmin password
    • ๐Ÿ“„ docs/security: Be less specific about package version in examples
    • ๐Ÿ“„ docs/security: Add resources for the linear-fake vulnerability
    • embedded/appendable: sync directories
    • embedded/store: Disable asynchronous AHT generation
    • embedded/store: Remove AHT Wait Hub
    • pkg/client: Document WithDisableIdentityCheck option
    • pkg/client/cache: Describe serverIdentity parameter
    • pkg/client/cache: Limit the hash part of the identity file name
    • pkg/client/state: Cleanup mutex handling in StateService
    • pkg/server: Warn if sysadmin user password was not reset
    • pkg/server: Better warning for unchanged admin password
    • ๐ŸŽ test/performance-test-suite: Add summary to json output

    ๐Ÿ”‹ Features

    • ci: fix message and input
    • ci: add runner name to mattermost message header
    • ci: simplify results extraction
    • ci: extract performance tests into separate workflow to be reused
    • ci: add scheduled daily test runs and send results to Mattermost
    • pkg/replication: Disable server's identity check in internal replication
  • v1.4.0 Changes

    October 12, 2022

    ๐Ÿ› Bug Fixes

    • ๐Ÿ— build: Do not publish official non-dev images on RC tags
    • pkg/client: replace keepAlive context from the original one to the background, avoiding parent expiration

    ๐Ÿ”„ Changes

    • ๐Ÿ”€ Rename sync-followers to sync-acks
    • cmd/immuclient: include precommit state when quering status
    • pkg/server: Better error message when validating replication options
  • v1.4.0-RC2 Changes

    October 10, 2022

    ๐Ÿ› Bug Fixes

    • ๐Ÿ— build: Use correct binary download links
    • embedded/store: edge-case calculation of precommitted tx
    • embedded/watchers: Fix invariant breakage in watchers
    • embedded/watchers: Fix invariant breakage in watchers
    • pkg/database: any follower can do progress due to its prefech buffer
    • pkg/replication: Do not crash on invalid tx metadata
    • pkg/replication: handle replication already closed case
    • pkg/replication: discard precommitted txs and continue from latest committed one
    • pkg/replication: solve issues when follower diverged from master
    • wmbedded/watchers: Correctly fix the original implementation

    ๐Ÿ”„ Changes

    • embedded/watchers: Simplify and document cancellation path
    • embedded/watchers: Simplify mutex locking code
    • embedded/watchers: single-point for init and cleanup
    • pkg/database: wait for tx when a non-existent or non-ready transaction is requested
    • pkg/database: add TODO comment on replication passive waiting
    • pkg/database: simplify follower's wait
    • pkg/replication: Add TX gap metrics
    • pkg/replication: Add basic replication metrics
    • pkg/replication: improve replication logging
  • v1.4.0-RC1 Changes

    October 04, 2022

    ๐Ÿ› Bug Fixes

    • ๐Ÿ‘‰ Makefile: add fips build flag to test/fips
    • ๐Ÿ‘‰ Makefile: remove interactive flag from dist/fips command
    • ci: fix regex pattern for fips binaries
    • cmd/immuadmin: set correct data-type for replication-sync-followers flag
    • embedded/store: fix size calculation of precommitted txs
    • embedded/store: Fix checking for closed store when syncing TXs
    • embedded/store: avoid attempts to commit in wrong order
    • embedded/store: expose durable precommitted state
    • embedded/store: include allowPrecommitted into tx reader construction
    • embedded/store: ensure tx is released upon error
    • embedded/store: aht up to precommited tx
    • github: Update github actions after migration of Dockerfile's
    • pkg/database: return master commit state if failing to read follower precommitted one
    • pkg/database: Fix mutex lock in ExportTx
    • pkg/database: set follower states holder when changing replication status
    • pkg/server: add logs when replicator does not start

    ๐Ÿ”„ Changes

    • โž• add dependabot config
    • โž• Add empty line between license header and package
    • ๐Ÿณ Dockerfile.fips: add fips build changes
    • cmd/immuadmin: add new replication flags
    • cmd/immuadmin: revert default replication-master-port
    • cmd/immuadmin: use default immudb port as default value for replication-master-port flag
    • cmd/immuclient: flag replication-sync-enabled to enable sync replication
    • cmd/immudb: deprecate replication-enabled towards replication-is-replica
    • ๐Ÿณ docker: Move main Dockerfile's to build folder
    • ๐Ÿณ docker: Simplify the main Dockerfile
    • embedded/store: resolve pre-committed using clogbuf
    • embedded/store: wip reduce allocations in exportTx
    • embedded/store: mutexless export-tx
    • embedded/store: enhanced tx discarding logic
    • embedded/store: wip load precommitted txs
    • embedded/store: method to dynamically switch to external allowance
    • embedded/store: wip wait for precommitted txs
    • embedded/store: explicit allowPrecommitted and restricted access to precommitted txs
    • embedded/store: minor code simplification
    • embedded/store: possibility to read tx header of precommitted txs
    • embedded/store: support for concurrent replicated precommits
    • embedded/store: tx parsing with sanity checks
    • embedded/store: handle commit case when there is nothing new to commit
    • embedded/store: tolerate partial data or inconsistencies when loading pre-committed txs
    • embedded/store: explanatory comments added
    • embedded/store: waits for durable precommitted txs
    • embedded/store: minor renaming and comment additions
    • embedded/store: add integrity checks when reading precommitted txs
    • pkg/api: currentState endpoint includes precommitted info
    • pkg/api: explicit sync replication setting
    • pkg/api/schema: reformat schema.proto file
    • pkg/database: minor typo in comment
    • pkg/database: sync exportTx
    • pkg/database: improve error comparison
    • pkg/database: follower commit progress without additional waits
    • pkg/database: handle special case related to sql initialization
    • pkg/database: disable automatic sql init on older databases
    • pkg/integration: add synchronous replication integration tests
    • pkg/replication: allowPreCommitted only with sync replication enabled
    • pkg/replication: speed up follower reconnection
    • pkg/replication: use session-based authentication
    • pkg/replication: handling a particular case in an optimized manner
    • pkg/replication: backward compatible replication
    • pkg/replication: check committedTxID from master
    • pkg/replication: wip optimize concurrency in replicators
    • pkg/replication: handle case when follower precommit state is up-to-date but commit state is lies behind
    • pkg/replication: sync replication using follower state
    • pkg/replication: configurable prefetchTxBufferSize and replicationCommitConcurrency
    • pkg/replication: improve error comparison
    • pkg/replication: graceful closing
    • pkg/replication: further progress in sync replication
    • pkg/replication: replicator with backward compatibility mode
    • pkg/replicator: wip precommitted tx discarding when follower diverged from master
    • pkg/server: explicit sync replication
    • pkg/server: handle admin user creation with sync replication enabled
    • pkg/server: support for systemdb with session-based auth
    • pkg/server: display all replication settings
    • pkg/server: include sync replication settings in options
    • pkg/server: use replication settings

    ๐Ÿ”‹ Features

    • cmd/immuadmin: flag to set the number of sync followers
    • cmd/immudb: flag to set the number of sync followers for systemdb and defaultdb
    • embedded/store: functionality to discard precommitted txs
    • embedded/store: core support for sync replication
    • pkg/api: api extensions to support sync replication
    • pkg/database: wip sync replication logic
    • pkg/replication: mode to allow tx discarding on followers
    • pkg/replication: wip replicator with support for sync replication
    • pkg/server: sync replication logic
    • pkg/server: Add ability to inject custom database management object
  • v1.3.2 Changes

    January 01, 0001
  • v1.3.2-RC1 Changes

    August 24, 2022

    ๐Ÿ› Bug Fixes

    • access tls value in global scope within ingress annotations
    • company name in webconsole and other files
    • ๐Ÿ— build: Fix go-acc and goveralls invocations
    • ๐Ÿ— build: update go version to 1.18 in Dockerfiles
    • ๐Ÿ— build/RELEASING.md: Add note about updating playground
    • embedded: use tmp folder for unit test cases
    • embedded/sql: Support single BEGIN statement.
    • embedded/store: Check precommitted state when replicating
    • embedded/store: Optionally preallocate Tx pools
    • embedded/store: Ensure ordering of transaction timestamps
    • embedded/store: Assign blTxID within locked tx state
    • embedded/store: ensure tx is released upon error
    • embedded/store: Improved check for replicated transaction
    • embedded/store: Return correct error on key length exceeded
    • embedded/store: Protect against simultaneous replicators
    • embedded/store: Reduce the amount of allocations for tx object
    • embedded/tools/stress_tool: Fix compilation after recent update to tx holder pool
    • getRandomTable: increase RNG range for table generation
    • github: Remove unnecessary /test/ path when uploading perf results to s3
    • github: Do not use yaml anchors in github workflows
    • pkg/client: Invalid client state after connection refused
    • โœ… pkg/client/clienttest: enforce mock client to interface
    • pkg/database: Fix calculation of proof for VerifiableTxByID
    • pkg/database: Correct revision for Scan requirests
    • server: Show info text with a logger
    • โœ… servertest: Allow accessing Server object before starting the server
    • stdlib/rows: add colums to row response
    • ๐ŸŽ test/performance: Cleanup test directory

    ๐Ÿ”„ Changes

    • ๐Ÿ“Œ pin google.golang.org/protobuf to v1.27.1 (currently used version for generated code).
    • Introduce separate TxHolder pools
    • โšก๏ธ update github.com/spf13/viper to v1.12.0.
    • ๐Ÿ‘‰ makefile formatting.
    • โšก๏ธ update build constraint to new & future-proof syntax.
    • format tools.go.
    • ๐Ÿ—„ deprecate ImmuClient.HealthCheck in favour of ServerInfo.
    • ๐Ÿ—„ reimplement ImmuClient.HealthCheck using rpc ServerInfo instead of (deprecated) Health.
    • ๐Ÿ”จ refactor TestServerInfo.
    • โšก๏ธ Update main go versin to 1.18
    • generate gRPC stubs.
    • ignore schema_grpc.pb.go in coveralls.
    • ๐Ÿ— use go.mod version of github.com/grpc-ecosystem/grpc-gateway when building codegen.
    • regenerate with correct version of protoc-gen-go.
    • ignore schema_grpc.pb.go in code coverage.
    • ๐Ÿ“Œ pin github.com/pseudomuto/protoc-gen-doc to 1.4.1 (currently used version for generated code).
    • ๐Ÿ‘‰ Makefile: Update webconsole to 1.0.16
    • ๐Ÿ— build: Update RELEASING.md doc
    • ๐Ÿ— build: Improve generation of build checksums
    • cmd/immuadmin: Add support for max-commit-concurrency option
    • cmd/immuadmin: Add support for read-tx-pool-size option
    • cmd/immudb: Add support for max-sessions command line option
    • database/sql: Delay txholder allocation on VerifiableSQLGet
    • embedded/ahtree: threshold-based sync
    • embedded/ahtree: use bigger default write buffer size
    • embedded/ahtree: improve error handling
    • embedded/ahtree: flushless append
    • embedded/ahtree: improve validations and error handling
    • embedded/ahtree: support newst appendable implementation
    • embedded/ahtree: improve error message consistency
    • embedded/ahtree: minor error message change
    • embedded/appendable: autosync when write buffer is full
    • embedded/appendable: autosync support in multi-appendable
    • embedded/appendable: flush when no more writes are done in appendable
    • embedded/appendable: improve explanatory comment inside sync method
    • embedded/appendable: improve singleapp validation and error handling
    • embedded/appendable: error tolerant seek
    • embedded/appendable: improve validations and error handling
    • embedded/appendable: inmem buffer offset
    • embedded/appendable: wip remoteapp validation
    • embedded/appendable: return io.EOF when offset is out of range
    • embedded/appendable: upgrade mocked and remote appendable based on new flushing assumptions
    • embedded/appendable: auto-sync options
    • embedded/appendable: multi-appendable shared write buffer
    • embedded/htree: improve error handling
    • embedded/sql: Remove unnecessary tx holder buffer from SQLTx
    • embedded/store: Better errors returned during replication error
    • embedded/store: aht options
    • embedded/store: Use dedicated error for replication conflicts
    • embedded/store: sync AHT before tx commit log
    • embedded/store: in-mem clog buffer written when synced
    • embedded/store: wrap internal already closed errors
    • embedded/store: handle appendable already close error
    • embedded/store: Optimize ReadTxHeader method
    • embedded/store: Do not write values if concurrency limit is reached
    • embedded/store: Add dedicated error for tx pool exhaustion
    • embedded/store: add TODO comment
    • embedded/store: parametrize write buffer size
    • embedded/store: wip retryable sync
    • embedded/store: flush-less precommit
    • embedded/store: multi-tx syncs
    • embedded/store: use smaller default buffer size
    • embedded/store: Add txDataReader to process transaction data
    • embedded/store: avoid sync waiting if there are no new transactions
    • embedded/store: improve error comparison with errors.Is(...)
    • embedded/store: wip error declaration
    • embedded/store: Add explicit ReadTxEntry method
    • embedded/store: Add explicit ReadTxHeader
    • embedded/store: Optimize ReadTxEntry method
    • embedded/store: Add txPoolOptions to setup pool parameters upon creation
    • embedded/store: set new default write buffer values
    • embedded/store/txpool: Allocate pool entries separately
    • embedded/store/txpool: Make txPoolOptions members private
    • embedded/tbtree: improve error handling
    • embedded/tbtree: use non-retryable sync
    • embedded/tbtree: define using generic errors towards errors.Is(...) usage
    • embedded/watchers: improve error handling
    • github: Update ACTIONS_SECRETS.md file
    • github: Allow selection of runner to run perf test
    • github: Run perf test suite on pull requests
    • github: Run performance test suite on push to master
    • github: Add simple documentation of PERF_TEST_xxx secrets
    • github: Install qemu using docker/setup-qemu-action
    • github: Allow using multiple runners for perf test suite
    • github: Upload perf results to AWS s3
    • pkg/api: Add tx pool size to GRPC and stored db options
    • pkg/api: milliseconds message type
    • pkg/api: expose aht settings
    • pkg/api: export syncFrequency database parameter
    • pkg/api: deprecate rpc Health in favour of ServerInfo.
    • pkg/database: Add tx pool size to db options
    • pkg/database: Remove txHolder from get operation
    • pkg/database: Do not allocate txholder for history scans
    • pkg/database: allocate tx buffer before doing verified writes
    • pkg/logger: Add memory logger
    • pkg/logger: add json logger
    • pkg/server: simplify ImmuServer.Health.
    • pkg/server: Add pprof option
    • ๐ŸŽ test/performance: Add basic flags to the benchmark process
    • ๐ŸŽ test/performance: Add separate Write KV/s test.
    • ๐ŸŽ test/performance: Split benchmark list and run code
    • ๐ŸŽ test/performance: Move test seed out of configuration
    • ๐ŸŽ test/performance: Move random generator and key tracker to common coode
    • ๐ŸŽ test/performance: Add CPU time / memory stats gathering
    • ๐ŸŽ test/performance: Allow customized name for the benchmark
    • ๐ŸŽ test/performance: Add basic IO stats
    • ๐ŸŽ test/performance: Improve live IO display
    • ๐ŸŽ test/performance: Better logging and output
    • ๐ŸŽ test/performance: Correctly close random data generator

    ๐Ÿ”‹ Features

    • โช revert usages of ServerInfo that would break backwards compatibility.
    • โž• add test for HealthCheck.
    • cmd/immuadmin: expose syncFrequency and WriteBufferSize db parameters
    • cmd/immuclient: add info command to immuclient.
    • pkg/api: expose write buffer parameter
    • pkg/api: improve documentation of ServerInfo.
    • pkg/api: remove ServerInfoResponse.status field.
    • pkg/api: add ServerInfo rpc to deprecate Health.
    • pkg/client: revert WaitForHealthCheck change to maintain backwards-compatibility.
    • pkg/client: implement ImmuClient.ServerInfo.
    • pkg/server: implement ImmuServer.ServerInfo.
  • v1.3.1 Changes

    June 30, 2022

    ๐Ÿ› Bug Fixes

    • embedded/store: filter evaluation after valRef resolution

    ๐Ÿ”„ Changes

    • embedded/store: offset handling at keyreader

    ๐Ÿ”‹ Features

    • embedded/sql: offset clause
    • embedded/store: offset in key scanning
    • pkg/api: offset attribute in scan and zscan endpoints
  • v1.3.1-RC1 Changes

    June 30, 2022

    ๐Ÿ› Bug Fixes

    • README: Update readme to show examples for 1.3.0 version
    • cmd/immuadmin: use StreamChunkSize as max chunk size during tx replication
    • cmd/immudb: include metrics endpoint related flags
    • โœ… embedded/remotestorage: Fix invalid comment
    • โœ… embedded/remotestorage/s3: Correctly url decode entry names
    • โœ… embedded/remotestorage/s3: Simplify the code for scan
    • โœ… embedded/remotestorage/s3: Avoid using HEAD requests
    • โœ… embedded/remotestorage/s3: Fix s3 object name validation
    • embedded/sql: Use defer to cleanup unclosed readers on error
    • embedded/sql: Fix snapshot leak on query initialization failure
    • embedded/sql: Properly close readers in joint row reader
    • embedded/sql: Fix reader leaks during initialization failures
    • embedded/sql: Fix snapshot leaks in union readers
    • embedded/sql: ensure timestamp is evaluated with microsecond precision
    • pkg/client: ensure connection is closed and session can be re-established
    • pkg/database: Do not panic if incorrect number of pk values is given to VerifiableSQLGet
    • pkg/server: Fix remote storage test after recent changes
    • pkg/server/sessions: Avoid deadlock when closing session manager
    • pkg/server/sessions: Session manager test fixes
    • pkg/server/sessions: Handle short buffer read when generating session id
    • pkg/server/sessions: Correctly start session guard
    • pkg/server/sessions: Use strong random source for session ID

    ๐Ÿ”„ Changes

    • โšก๏ธ Update dependencies
    • ๐Ÿ— build: Update RELEASING.md file
    • โœ… embedded/remotestorage: Improve error reporting
    • โœ… embedded/remotestorage: More detailed errors
    • โœ… embedded/remotestorage: Improve testing of remotestorage
    • โœ… embedded/remotestorage/s3: Improved s3 object name checks
    • embedded/sql: Do not return error from conditional and limit readers
    • embedded/sql: fixed-timed tx
    • github: Update push action
    • github: Run tests with minio service
    • github: On macOS run client only test on pull requests
    • github: Run coverage tests with minio enabled
    • github: Update minimal supported go version to 1.15
    • pkg/client: Better detection of tests that require external immudb
    • pkg/server: Add missing copyright headers
    • pkg/server/session: Move options normalization into options struct
    • pkg/server/sessions: Improve options handling
    • pkg/server/sessions: Add MaxSessions option
    • pkg/server/sessions: Simplify session handling code
    • โœ… remotestorage: Add prometheus metrics for remote storage kind
    • tools: Remove old stream tool