Release Notes
v0.5.0
2023-04-12
DefraDB v0.5 is a major pre-production release. Until the stable version 1.0 is reached, the SemVer minor patch number will denote notable releases, which will give the project freedom to experiment and explore potentially breaking changes.
There many new features in this release, but most importantly, this is the first open source release for DefraDB. As such, this release focused on various quality of life changes and refactors, bug fixes, and overall cleanliness of the repo so it can effectively be used and tested in the public domain.
To get a full outline of the changes, we invite you to review the official changelog below. Some highlights are the first iteration of our schema update system, allowing developers to add new fields to schemas using our JSON Patch based DDL, a new DAG based delete system which will persist "soft-delete" ops into the CRDT Merkle DAG, and a early prototype for our collection level peer-to-peer synchronization.
This release does include a Breaking Change to existing v0.4.x databases. If you need help migrating an existing deployment, reach out at hello@source.network or join our Discord at https://discord.source.network/.
Features
- Add document delete mechanics (#1263)
- Ability to explain an executed request (#1188)
- Add SchemaPatch CLI command (#1250)
- Add support for one-one mutation from sec. side (#1247)
- Store only key in DAG instead of dockey path (#1245)
- Add collectionId field to commit field (#1235)
- Add field kind substitution for PatchSchema (#1223)
- Add dockey field for commit field (#1216)
- Allow new fields to be added locally to schema (#1139)
- Add
like
sub-string filter (#1091) - Add ability for P2P to wait for pushlog by peer (#1098)
- Add P2P collection topic subscription (#1086)
- Add support for schema version id in queries (#1067)
- Add schema version id to commit queries (#1061)
- Persist schema version at time of commit (#1055)
- Add ability to input simple explain type arg (#1039)
Fixes
- API address parameter validation (#1311)
- Improve error message for NonNull GQL types (#1333)
- Handle panics in the rpc server (#1330)
- Handle returned error in select.go (#1329)
- Resolve handful of CLI issues (#1318)
- Only check for events queue on subscription request (#1326)
- Remove client Create/UpdateCollection (#1309)
- CLI to display specific command usage help (#1314)
- Fix P2P collection CLI commands (#1295)
- Dont double up badger file path (#1299)
- Update immutable package (#1290)
- Fix panic on success of Add/RemoveP2PCollections (#1297)
- Fix deadlock on memory-datastore Close (#1273)
- Determine if query is introspection query (#1255)
- Allow newly added fields to sync via p2p (#1226)
- Expose
ExplainEnum
in the GQL schema (#1204) - Resolve aggregates' mapping with deep nested subtypes (#1175)
- Make sort stable and handle nil comparison (#1094)
- Change successful schema add status to 200 (#1106)
- Add delay in P2P test util execution (#1093)
- Ensure errors test don't hard expect folder name (#1072)
- Remove potential P2P deadlock (#1056)
- Rework the P2P integration tests (#989)
- Improve DAG sync with highly concurrent updates (#1031)
Documentation
- Update docs for the v0.5 release (#1320)
- Document client interfaces in client/db.go (#1305)
- Document client Description types (#1307)
- Improve security policy (#1240)
- Add security disclosure policy (#1194)
- Correct commits query example in readme (#1172)
Refactoring
- Improve p2p collection operations on peer (#1286)
- Migrate gql introspection tests to new framework (#1211)
- Reorganise client transaction related interfaces (#1180)
- Config-local viper, rootdir, and logger parsing (#1132)
- Migrate mutation-relation tests to new framework (#1109)
- Rework integration test framework (#1089)
- Generate gql types using col. desc (#1080)
- Extract config errors to dedicated file (#1107)
- Change terminology from query to request (#1054)
- Allow db keys to handle multiple schema versions (#1026)
- Extract query schema errors to dedicated file (#1037)
- Extract planner errors to dedicated file (#1034)
- Extract query parser errors to dedicated file (#1035)
Testing
- Remove test reference to DEFRA_ROOTDIR env var (#1328)
- Expand tests for Peer subscribe actions (#1287)
- Fix flaky TestCloseThroughContext test (#1265)
- Add gql introspection tests for patch schema (#1219)
- Explicitly state change detector split for test (#1228)
- Add test for successful one-one create mutation (#1215)
- Ensure that all databases are always closed on exit (#1187)
- Add P2P tests for Schema Update adding field (#1182)
- Migrate P2P/state tests to new framework (#1160)
- Remove sleep from subscription tests (#1156)
- Fetch documents on test execution start (#1163)
- Introduce basic testing for the
version
module (#1111) - Boost test coverage for collection_update (#1050)
- Wait between P2P update retry attempts (#1052)
- Exclude auto-generated protobuf files from codecov (#1048)
- Add P2P tests for relational docs (#1042)
Continuous integration
- Add workflow that builds DefraDB AMI upon tag push (#1304)
- Allow PR title to end with a capital letter (#1291)
- Changes for
dependabot
to be well-behaved (#1165) - Skip benchmarks for dependabot (#1144)
- Add workflow to ensure deps build properly (#1078)
- Runner and Builder Containerfiles (#951)
- Fix go-header linter rule to be any year (#1021)
Chore
- Add Islam as contributor (#1302)
- Update go-libp2p to 0.26.4 (#1257)
- Improve the test coverage of datastore (#1203)
- Add issue and discussion templates (#1193)
- Bump libp2p/go-libp2p-kad-dht from 0.21.0 to 0.21.1 (#1146)
- Enable dependabot (#1120)
- Update
opentelemetry
dependencies (#1114) - Update dependencies including go-ipfs (#1112)
- Bump to GoLang v1.19 (#818)
- Remove versionedScan node (#1049)
Bot
- Bump github.com/multiformats/go-multiaddr from 0.8.0 to 0.9.0 (#1277)
- Bump google.golang.org/grpc from 1.53.0 to 1.54.0 (#1233)
- Bump github.com/multiformats/go-multibase from 0.1.1 to 0.2.0 (#1230)
- Bump github.com/ipfs/go-libipfs from 0.6.2 to 0.7.0 (#1231)
- Bump github.com/ipfs/go-cid from 0.3.2 to 0.4.0 (#1200)
- Bump github.com/ipfs/go-ipfs-blockstore from 1.2.0 to 1.3.0 (#1199)
- Bump github.com/stretchr/testify from 1.8.1 to 1.8.2 (#1198)
- Bump github.com/ipfs/go-libipfs from 0.6.1 to 0.6.2 (#1201)
- Bump golang.org/x/crypto from 0.6.0 to 0.7.0 (#1197)
- Bump libp2p/go-libp2p-gostream from 0.5.0 to 0.6.0 (#1152)
- Bump github.com/ipfs/go-libipfs from 0.5.0 to 0.6.1 (#1166)
- Bump github.com/ugorji/go/codec from 1.2.9 to 1.2.11 (#1173)
- Bump github.com/libp2p/go-libp2p-pubsub from 0.9.0 to 0.9.3 (#1183)
v0.4.0
2023-12-23
DefraDB v0.4 is a major pre-production release. Until the stable version 1.0 is reached, the SemVer minor patch number will denote notable releases, which will give the project freedom to experiment and explore potentially breaking changes.
There are various new features in this release - some of which are breaking - and we invite you to review the official changelog below. Some highlights are persistence of replicators, DateTime scalars, TLS support, and GQL subscriptions.
This release does include a Breaking Change to existing v0.3.x databases. If you need help migrating an existing deployment, reach out at hello@source.network or join our Discord at https://discord.source.network/.
Features
- Add basic metric functionality (#971)
- Add thread safe transactional in-memory datastore (#947)
- Persist p2p replicators (#960)
- Add DateTime custom scalars (#931)
- Add GraphQL subscriptions (#934)
- Add support for tls (#885)
- Add group by support for commits (#887)
- Add depth support for commits (#889)
- Make dockey optional for allCommits queries (#847)
- Add WithStack to the errors package (#870)
- Add event system (#834)
Fixes
- Correct errors.WithStack behaviour (#984)
- Correctly handle nested one to one joins (#964)
- Do not assume parent record exists when joining (#963)
- Change time format for HTTP API log (#910)
- Error if group select contains non-group-by fields (#898)
- Add inspection of values for ENV flags (#900)
- Remove panics from document (#881)
- Add __typename support (#871)
- Handle subscriber close (#877)
- Publish update events post commit (#866)
Refactoring
- Make rootstore require Batching and TxnDatastore (#940)
- Conceptually clarify schema vs query-language (#924)
- Decouple db.db from gql (#912)
- Merkle clock heads cleanup (#918)
- Simplify dag fetcher (#913)
- Cleanup parsing logic (#909)
- Move planner outside the gql directory (#907)
- Refactor commit nodes (#892)
- Make latest commits syntax sugar (#890)
- Remove commit query (#841)
Testing
- Add event tests (#965)
- Add new setup for testing explain functionality (#949)
- Add txn relation-type delete and create tests (#875)
- Skip change detection for tests that assert panic (#883)
Continuous integration
- Bump all gh-action versions to support node16 (#990)
- Bump ssh-agent action to v0.7.0 (#978)
- Add error message format check (#901)
Chore
- Extract (events, merkle) errors to errors.go (#973)
- Extract (datastore, db) errors to errors.go (#969)
- Extract (connor, crdt, core) errors to errors.go (#968)
- Extract inline (http and client) errors to errors.go (#967)
- Update badger version (#966)
- Move Option and Enumerable to immutables (#939)
- Add configuration of external loggers (#942)
- Strip DSKey prefixes and simplify NewDataStoreKey (#944)
- Include version metadata in cross-building (#930)
- Update to v0.23.2 the libP2P package (#908)
- Remove
ipfslite
dependency (#739)
v0.3.1
2022-09-23
DefraDB v0.3.1 is a minor release, primarily focusing on additional/extended features and fixes of items added in the v0.3.0
release.
Features
- Add cid support for allCommits (#857)
- Add offset support to allCommits (#859)
- Add limit support to allCommits query (#856)
- Add order support to allCommits (#845)
- Display CLI usage on user error (#819)
- Add support for dockey filters in child joins (#806)
- Add sort support for numeric aggregates (#786)
- Allow filtering by nil (#789)
- Add aggregate offset support (#778)
- Remove filter depth limit (#777)
- Add support for and-or inline array aggregate filters (#779)
- Add limit support for aggregates (#771)
- Add support for inline arrays of nillable types (#759)
- Create errors package (#548)
- Add ability to display peer id (#719)
- Add a config option to set the vlog max file size (#743)
- Explain
topLevelNode
like aMultiNode
plan (#749) - Make
topLevelNode
explainable (#737)
Fixes
- Order subtype without selecting the join child (#810)
- Correctly handles nil one-one joins (#837)
- Reset scan node for each join (#828)
- Handle filter input field argument being nil (#787)
- Ensure CLI outputs JSON to stdout when directed to pipe (#804)
- Error if given the wrong side of a one-one relationship (#795)
- Add object marker to enable return of empty docs (#800)
- Resolve the extra
typeIndexJoin
s for_avg
aggregate (#774) - Remove _like filter operator (#797)
- Remove having gql types (#785)
- Error if child _group selected without parent groupBy (#781)
- Error nicely on missing field specifier (#782)
- Handle order input field argument being nil (#701)
- Change output to outputpath in config file template for logger (#716)
- Delete mutations not correct persisting all keys (#731)
Tooling
Documentation
- Clarify meaning of url param, update in-repo CLI docs (#814)
- Disclaimer of exposed to network and not encrypted (#793)
- Update logo to respect theme (#728)
Refactoring
- Replace all
interface{}
withany
alias (#805) - Use fastjson to parse mutation data string (#772)
- Rework limit node flow (#767)
- Make Option immutable (#769)
- Rework sum and count nodes to make use of generics (#757)
- Remove some possible panics from codebase (#732)
- Change logging calls to use feedback in CLI package (#714)
Testing
- Add tests for aggs with nil filters (#813)
- Add not equals filter tests (#798)
- Fix
cli/peerid_test
to not clash addresses (#766) - Add change detector summary to test readme (#754)
- Add tests for inline array grouping (#752)
Continuous integration
- Reduce test resource usage and test with file db (#791)
- Add makefile target to verify the local module cache (#775)
- Allow PR titles to end with a number (#745)
- Add a workflow to validate pull request titles (#734)
- Fix the linter version to
v1.47
(#726)
Chore
- Remove file system paths from resulting executable (#831)
- Add goimports linter for consistent imports ordering (#816)
- Improve UX by providing more information (#802)
- Change to defra errors and handle errors stacktrace (#794)
- Clean up
go.mod
with pruned module graphs (#756) - Update to v0.20.3 of libp2p (#740)
- Bump to GoLang
v1.18
(#721)
v0.3.0
2022-08-02
DefraDB v0.3 is a major pre-production release. Until the stable version 1.0 is reached, the SemVer minor patch number will denote notable releases, which will give the project freedom to experiment and explore potentially breaking changes.
There are several new features in this release, and we invite you to review the official changelog below. Some highlights are various new features for Grouping & Aggregation for the query system, like top-level aggregation and group filtering. Moreover, a brand new Query Explain system was added to introspect the execution plans created by DefraDB. Lastly we introduced a revamped CLI configuration system.
This release does include a Breaking Change to existing v0.2.x databases. If you need help migrating an existing deployment, reach out at hello@source.network or join our Discord at https://discord.source.network/.
Features
- Add named config overrides (#659)
- Expose color and caller log options, add validation (#652)
- Add ability to explain
groupNode
and it's attribute(s). (#641) - Add primary directive for schema definitions (@primary) (#650)
- Add support for aggregate filters on inline arrays (#622)
- Add explainable renderLimitNode & hardLimitNode attributes. (#614)
- Add support for top level aggregates (#594)
- Update
countNode
explanation to be consistent. (#600) - Add support for stdin as input in CLI (#608)
- Explain
cid
&field
attributes fordagScanNode
(#598) - Add ability to explain
dagScanNode
attribute(s). (#560) - Add the ability to send user feedback to the console even when logging to file. (#568)
- Add ability to explain
sortNode
attribute(s). (#558) - Add ability to explain
sumNode
attribute(s). (#559) - Introduce top-level config package (#389)
- Add ability to explain
updateNode
attributes. (#514) - Add
typeIndexJoin
explainable attributes. (#499) - Add support to explain
countNode
attributes. (#504) - Add CORS capability to HTTP API (#467)
- Add explaination of spans for
scanNode
. (#492) - Add ability to Explain the response plan. (#385)
- Add aggregate filter support for groups only (#426)
- Configurable caller option in logger (#416)
- Add Average aggregate support (#383)
- Allow summation of aggregates (#341)
- Add ability to check DefraDB CLI version. (#339)
Fixes
- Add a check to ensure limit is not 0 when evaluating query limit and offset (#706)
- Support multiple
--logger
flags (#704) - Return without an error if relation is finalized (#698)
- Logger not correctly applying named config (#696)
- Add content-type media type parsing (#678)
- Remove portSyncLock deadlock condition (#671)
- Silence cobra default errors and usage printing (#668)
- Add stdout validation when setting logging output path (#666)
- Consider
--logoutput
CLI flag properly (#645) - Handle errors and responses in CLI
client
commands (#579) - Rename aggregate gql types (#638)
- Error when attempting to insert value into relationship field (#632)
- Allow adding of new schema to database (#635)
- Correctly parse dockey in broadcast log event. (#631)
- Increase system's open files limit in integration tests (#627)
- Avoid populating
order.ordering
with empties. (#618) - Change to supporting of non-null inline arrays (#609)
- Assert fields exist in collection before saving to them (#604)
- CLI
init
command to reinitialize only config file (#603) - Add config and registry clearing to TestLogWritesMessagesToFeedbackLog (#596)
- Change
$eq
to_eq
in the failing test. (#576) - Resolve failing HTTP API tests via cleanup (#557)
- Ensure Makefile compatibility with macOS (#527)
- Separate out iotas in their own blocks. (#464)
- Use x/cases for titling instead of strings to handle deprecation (#457)
- Handle limit and offset in sub groups (#440)
- Issue preventing DB from restarting with no records (#437)
- log serving HTTP API before goroutine blocks (#358)
Testing
- Add integration testing for P2P. (#655)
- Fix formatting of tests with no extra brackets (#643)
- Add tests for
averageNode
explain. (#639) - Add schema integration tests (#628)
- Add tests for default properties (#611)
- Specify which collection to update in test framework (#601)
- Add tests for grouping by undefined value (#543)
- Add test for querying undefined field (#544)
- Expand commit query tests (#541)
- Add cid (time-travel) query tests (#539)
- Restructure and expand filter tests (#512)
- Basic unit testing of
node
package (#503) - Test filter in filter tests (#473)
- Add test for deletion of records in a relationship (#329)
- Benchmark transaction iteration (#289)
Refactoring
- Improve CLI error handling and fix small issues (#649)
- Add top-level
version
package (#583) - Remove extra log levels (#634)
- Change
sortNode
toorderNode
. (#591) - Rework update and delete node to remove secondary planner (#571)
- Trim imported connor package (#530)
- Internal doc restructure (#471)
- Copy-paste connor fork into repo (#567)
- Add safety to the tests, add ability to catch stderr logs and add output path validation (#552)
- Change handler functions implementation and response formatting (#498)
- Improve the HTTP API implementation (#382)
- Use new logger in net/api (#420)
- Rename NewCidV1_SHA2_256 to mixedCaps (#415)
- Remove utils package (#397)
- Rework planNode Next and Value(s) function (#374)
- Restructure aggregate query syntax (#373)
- Remove dead code from client package and document remaining (#356)
- Restructure datastore keys (#316)
- Add commits lost during github outage (#303)
- Move public members out of core and base packages (#295)
- Make db stuff internal/private (#291)
- Rework client.DB to ensure interface contains only public types (#277)
- Remove GetPrimaryIndexDocKey from collection interface (#279)
- Remove DataStoreKey from (public) dockey struct (#278)
- Renormalize to ensure consistent file line termination. (#226)
- Strongly typed key refactor (#17)
Documentation
- Use permanent link to BSL license document (#692)
- README update v0.3.0 (#646)
- Improve code documentation (#533)
- Add CONTRIBUTING.md (#531)
- Add package level docs for logging lib (#338)
Tooling
- Include all touched packages in code coverage (#673)
- Use
gotestsum
overgo test
(#619) - Update Github pull request template (#524)
- Fix the cross-build script (#460)
- Add test coverage html output (#466)
- Add linter rule for
goconst
. (#398) - Add github PR template. (#394)
- Disable auto-fixing linter issues by default (#429)
- Fix linting of empty
else
code blocks (#402) - Add the
gofmt
linter rule. (#405) - Cleanup linter config file (#400)
- Add linter rule for copyright headers (#360)
- Organize our config files and tooling. (#336)
- Limit line length to 100 characters (linter check) (#224)
- Ignore db/tests folder and the bench marks. (#280)
Continuous Integration
- Fix circleci cache permission errors. (#371)
- Ban extra elses (#366)
- Fix change-detection to not fail when new tests are added. (#333)
- Update golang-ci linter and explicit go-setup to use v1.17 (#331)
- Comment the benchmarking result comparison to the PR (#305)
- Add benchmark performance comparisons (#232)
- Add caching / storing of bench report on default branch (#290)
- Ensure full-benchmarks are ran on a PR-merge. (#282)
- Add ability to control benchmarks by PR labels. (#267)
Chore
- Update APL to refer to D2 Foundation (#711)
- Update gitignore to include
cmd
folders (#617) - Enable random execution order of tests (#554)
- Enable linters exportloopref, nolintlint, whitespace (#535)
- Add utility for generation of man pages (#493)
- Add Dockerfile (#517)
- Enable errorlint linter (#520)
- Binaries in
cmd
folder, examples inexamples
folder (#501) - Improve log outputs (#506)
- Move testing to top-level
tests
folder (#446) - Update dependencies (#450)
- Update go-ipfs-blockstore and ipfs-lite (#436)
- Update libp2p dependency to v0.19 (#424)
- Update ioutil package to io / os packages. (#376)
- git ignore vscode (#343)
- Updated README.md contributors section (#292)
- Update changelog v0.2.1 (#252)
v0.2.1
2022-03-04
Features
- Add ability to delete multiple documents using filter (#206)
- Add ability to delete multiple documents, using multiple ids (#196)
Fixes
- Concurrency control of Document using RWMutex (#213)
- Only log errors and above when benchmarking (#261)
- Handle proper type conversion on sort nodes (#228)
- Return empty array if no values found (#223)
- Close fetcher on error (#210)
- Installing binary using defradb name (#190)
Tooling
- Add short benchmark runner option (#263)
Documentation
- Add data format changes documentation folder (#89)
- Correcting typos (#143)
- Update generated CLI docs (#208)
- Updated readme with P2P section (#220)
- Update old or missing license headers (#205)
- Update git-chglog config and template (#195)
Refactoring
- Introduction of logging system (#67)
- Restructure db/txn/multistore structures (#199)
- Initialize database in constructor (#211)
- Purge all println and ban it (#253)
Testing
- Detect and force breaking filesystem changes to be documented (#89)
- Boost collection test coverage (#183)
Continuous integration
- Combine the Lint and Benchmark workflows so that the benchmark job depends on the lint job in one workflow (#209)
- Add rule to only run benchmark if other check are successful (#194)
- Increase linter timeout (#230)
Chore
v0.2.0
2022-02-07
DefraDB v0.2 is a major pre-production release. Until the stable version 1.0 is reached, the SemVer minor patch number will denote notable releases, which will give the project freedom to experiment and explore potentially breaking changes.
This release is jam-packed with new features and a small number of breaking changes. Read the full changelog for a detailed description. Most notable features include a new Peer-to-Peer (P2P) data synchronization system, an expanded query system to support GroupBy & Aggregate operations, and lastly TimeTraveling queries allowing to query previous states of a document.
Much more than just that has been added to ensure we're building reliable software expected of any database, such as expanded test & benchmark suites, automated bug detection, performance gains, and more.
This release does include a Breaking Change to existing v0.1 databases regarding the internal data model, which affects the "Content Identifiers" we use to generate DocKeys and VersionIDs. If you need help migrating an existing deployment, reach out at hello@source.network or join our Discord at https://discord.source.network.
Features
- Added Peer-to-Peer networking data synchronization (#177)
- TimeTraveling (History Traversing) query engine and doc fetcher (#59)
- Add Document Deletion with a Key (#150)
- Add support for sum aggregate (#121)
- Add support for lwwr scalar arrays (full replace on update) (#115)
- Add count aggregate support (#102)
- Add support for named relationships (#108)
- Add multi doc key lookup support (#76)
- Add basic group by functionality (#43)
- Update datastore packages to allow use of context (#48)
Bug fixes
- Only add join if aggregating child object collection (#188)
- Handle errors generated during input object thunks (#123)
- Remove new types from in-memory cache on generate error (#122)
- Support relationships where both fields have the same name (#109)
- Handle errors generated in fields thunk (#66)
- Ensure OperationDefinition case has at least one selection(#24)
- Close datastore iterator on scan close (#56) (resulted in a panic when using limit)
- Close superseded iterators before orphaning (#56) (fixes a panic in the join code)
- Move discard to after error check (#88) (did result in panic if transaction creation fails)
- Check for nil iterator before closing document fetcher (#108)
Tooling
- Added benchmark suite (#160)
Documentation
Testing
- Add transaction integration tests (#175)
- Allow running of tests using badger-file as well as IM options (#128)
- Add test datastore selection support (#88)
Refactoring
- Datatype modification protection (#138)
- Cleanup Linter Complaints and Setup Makefile (#63)
- Rework document rendering to avoid data duplication and mutation (#68)
- Remove dependency on concrete datastore implementations from db package (#51)
- Remove all
errors.Wrap
and update them withfmt.Errorf
. (#41) - Restructure integration tests to provide better visibility (#15)
- Remove schemaless code branches (#23)
Performance
Continous integration
- Use more accurate test coverage. (#134)
- Disable Codecov's Patch Check
- Make codcov less strict for now to unblock development (#125)
- Add codecov config file. (#118)
- Add workflow that runs a job on AWS EC2 instance. (#110)
- Add Code Test Coverage with CodeCov (#116)
- Integrate GitHub Action for golangci-lint Annotations (#106)
- Add Linter Check to CircleCi (#92)