v2.0 binaries released

Greg Young  |  18 July 2013

Version 2.0 binaries are now available for download on our website.

The new version is fully compatible with all database files from old versions no data upgrade is required. With the addition of security you will likely get asked for a username/password, the default is admin:changeit.

Major Changes

  • Authentication over HTTP using basic authentication
  • Authentication over TCP for built-in user accounts
  • Management of internal accounts and ACLs
  • Changed configuration now supports environment variables and config files
  • Tcp client can now run over SSL
  • $stream-created events removed from streams
  • Stream metadata separated
  • Better AtomPub compliance
  • SSL + authentication for web console
  • Trusted intermediaries
  • Separated internal/external networks (HA only)
  • SSL for replication channels (HA only)
  • SSL for manager connections (HA only)
  • Ability to disable routing (HA only)

Summary

The largest single change in moving to 2.0 is the addition of security. Security allows for both locking down the Event Store and setting up Access Control Lists on streams. This can allow to control not just access to the stream but how people are allowed to access the stream.

In adding security to the system it also became necessary to support SSL on the various forms of connecting to the Event Store. As such the Client API (.NET) and the Atom interface in the Single Node version now both support SSL. In the HA clustered version SSL has been added to the replication channels and all other internal communications as well. The HA version has also had all internal vs external traffic segmented so it can be run with internal traffic on a different network than client traffic.

The AtomPub interface has also had quite a few small changes to better represent the atom protocol. There is no longer a special type that gets posted to the resource instead all of the information from that type is put into http headers such as ES_ExpectedVersion. The differences can be seen in how you write to a stream.

Projections can now be considered in a beta stage. We have a few more changes we want to get in before calling it officially released and we have a ton of documentation to write on it but the chances of the language changing are low.

The configuration system has also had a major overhaul. Command line options are great but when you start getting many of them it also nice to be able to use environment variables or config files. All options can now be set through any of the three mechanisms. This is particularly useful when dealing with the HA version as you can centralize management easily.

Version 2.0 will install and use the same database as all previous versions. When using 2.0 however you must upgrade your .NET client API to 2.0 as well its on nuget. This is largely due to the security changes. We do not foresee having any further client/server mismatches in the medium term (12 months) though it’s likely longer. Another change you will notice is that the $stream-created events no longer get created in your stream (when you create a stream there will be 0 events in it).

You may also notice we have quite a few more docs there will be many more coming!

The Future

We will also be changing a bit our release cycles. We expect to be seeing many minor releases to master and binaries dropped for them, likely around once per week. Periodically we will be releasing new “stable” drops that have gone through a full period of stress testing (beyond the continuous automated stress testing). As such more people will be able to test bleeding edge if they want in development or staging environments.

There will be many new features coming out the next few months including memory only usage, projections, and quite a few surprises!