+.. contents::
+ :depth: 3
+ :local:
+
+[2.1.0] - 1/8/2020
+------------------
+
+::
+
+ * Represents a resillent version of 2.0.0 that uses Redis for persistence
+ * Now relies on SDL and dbaas; SDL is the python interface library to dbaas
+ * Adds a 503 http code to nearly all http methods, as A1 now depends on an upstream system
+ * Integration tests have a copy of a dbaas helm chart, however the goal is to simplify that deployment per https://jira.o-ran-sc.org/browse/RIC-45
+ * Unit tests have a mockup of SDL, however again the goal is to simplify as SDL grows per https://jira.o-ran-sc.org/browse/RIC-44
+
+
+
+[2.0.0] - 12/9/2019
+-------------------
+
+::
+
+ * Implements new logic around when instances are deleted. See flowcharts in docs/. Basically timeouts now trigger to actually delete instances from a1s database, and these timeouts are configurable.
+ * Eliminates the barrier to deleting an instance when no xapp evdr replied (via timeouts)
+ * Add two new ENV variables that control timeouts
+ * Make unit tests more modular so new workflows can be tested easily
+ * Fixes the API for ../status to return a richer structure. This is an (albeit tiny) API change.
+ * Clean up unused items in the integration tests helm chart
+ * Removed "RMR_RCV_RETRY_INTERVAL" leftovers since this isn't used anymore
+ * Uses the standard RIC logging library
+ * Switch the backend routing scheme to using subscription id with constant message types, per request.
+ * Given the above, policy type ids can be any valid 32bit greater than 0
+ * Decouple the API between northbound and A1 from A1 with xapps. This is now two seperate OpenAPI files
+ * Update example for AC Xapp
+ * Updgrade rmr and rmr-python to utilize new features; lots of cleanups because of that
+ * Implements a POLICY QUERY feature where A1 listens for queries for a policy type. A1 then responds via multiple RTS messages every policy instance of that policy type (and expects an ACK back from xapps as usual). This feature can be used for xapp recovery etc.
+
+[1.0.4]
+-------
+
+::
+
+ * Only external change here is to healthcheck the rmr thread as part of a1s healthcheck. k8s will now respin a1 if that is failing.
+ * Refactors (simplifies) how we wait for rmr initialization; it is now called as part of __init__
+ * Refactors (simplifies) how the thread is actually launched; it is now internal to the object and also a part of __init__
+ * Cleans up unit testing; a1rmr now exposes a replace_rcv_func; useful for unit testing, harmless if not called otherwise
+ * Upgrades to rmr-python 1.0.0 for simpler message allocation
+
+[1.0.3] - 10/22/2019
+--------------------