All notable changes to this project will be documented in this file. This project adheres to Semantic Versioning.
- Consistent handling of client errors (MeteorError) which shouldn't be logged.
- Reduce wheel size from 204KB to 68KB by removing dddp.test package.
- Reduce sdist size from 10MB to 209KB by removing Meteor build from test suite.
- Improve test suite with coverage now 65% when tested via Travis CI.
- Dropped support for Python 3.3.
- Fix for #3 -- drop support for Django 1.7, add support for Django 1.9 - thanks @schinckel.
- Re-raise exceptions from DDP WebSocket handlers rather than swallowing them.
- Fix for #33 -- Add meteor_autoupdate_clientVersions publication.
- Dropped support for Django 1.7 (support expired on December 1 2015, see https://www.djangoproject.com/download/#supported-versions).
- Require setuptools>=18.5 at install time due to use of python_platform_implementation environment marker.
- Moved repository to https://github.com/django-ddp/django-ddp (new Github organisation).
- Started work on documentation refresh.
- Fail on start if any child threads can't start (eg: port in use).
- Rudimentary support for dynamic publications which may now refer to this.user.
- Correctly close DB connections during shutdown, useful for test suite.
- Add missing versions and dates to the change log, and note on Semantic Versioning.
- Emit django.core.signals.request_finished to close DB connection and yield to other greenlets between processing messages from WebSocket.
- Back to universal wheels, thanks to PEP-0496 environment markers.
- Expand test suite coverage to start a DDP server instance and perform a HTTP GET request, no WebSocket/DDP tests yet. Fails in Pyton 3 because of a bug in gevent-websocket (https://bitbucket.org/noppo/gevent-websocket/issues/54/python-3-support).
- Fix for #23 (Python 3 compatibility).
- Set application_name on PostgreSQL async connection.
- Send django.core.signals.request_finished when closing WebSocket.
- Don't require DJANGO_SETTINGS_MODULE to import API.
- Tox test suite updated to runs against Python 2.7/3.3/3.4/3.5 and Django 1.8/1.9.
- Build wheels from tox environment to ensure consistency.
- Remove debug argment from PostgresGreenlet class (unused).
- Don't assume Django projects include a wsgi.py.
- Python implementation specific builds using tox so that Python2 and Python3 can have different dependencies (eg: gevent>=1.1 for Pyton3).
- Added support for METEOR_SETTINGS environment variable.
- Depend on gevent>=1.1b6 if running anything other than CPython 2.7, otherwise allow gevent 1.0 (current stable).
- Preliminary (but broken) support for PyPy/Jython/IronPython though platform specific install_requires on psycopg2cffi instead of psycopg2 for all platforms except CPython 2/3.
- Python 3 fixes using six compatibility library (#16, #17).
- Fix minor issue where some subscription queries still used slow queries.
- Make the SQL for subscriptions much faster for PostgreSQL.
- Repeatable builds using ye olde make.
- Use tox test runner - no tests yet (#11).
- Add concrete requirement files for test suite (#11).
- Started documentation using Sphinx (#10).
- Python 3 style exception handling.
- New setting: DDP_API_ENDPOINT_DECORATORS.
This setting takes a list of dotted import paths to decorators which are applied to API endpoints. For example, enable New Relic instrumentation by adding the line below to your Django settings.py:
DDP_API_ENDPOINT_DECORATORS = ['newrelic.agent.background_task']
Fixed #7 -- Warn if using DB engines other than psycopg2 - thanks @Matvey-Kuk.
Improvements to error/exception handling.
Warn if many TX chunks are queued in case WebSocket has stalled.
Bugfix thread locals setup when opening WebSocket.
Add missing import for print function (Python 2).
Work towards #16 -- Use psycopg2cffi compatibility if psycopg2 not installed.
- Renamed Logs collection and publication to dddp.logs to be consistent with naming conventions used elsewhere.
- Pass all attributes from logging.LogRecord via dddp.logs collection.
- Use select_related() and resultant cached relational fields to speed up Colleciton.serialize() by significantly reducing round-trips to the database.
- Fix bug in get_meteor_ids() which caused many extra database hits.
- Correctly handle serving app content from the root path of a domain.
- Account security tokens are now calculated for each minute allowing for finer grained token expiry.
- Fix bug in error handling where invalid arguments were being passed to logging.error().
- Change setting names (and implied meanings):
- DDP_PASSWORD_RESET_DAYS_VALID becomes DDP_PASSWORD_RESET_MINUTES_VALID.
- DDP_LOGIN_RESUME_DAYS_VALID becomes DDP_LOGIN_RESUME_MINUTES_VALID.
- Include created field in logs collection.
- Stop depending on Referrer HTTP header which is optional.
- Honour --verbosity in dddp command, now showing API endpoints in more verbose modes.
- Updated dddp.test to Meteor 1.2 and also showing example of URL config to serve Meteor files from Python.
- Abstract DDPLauncher out from dddp.main.serve to permit use from other contexts.
- Allow Ctrl-C (Break) handling at any time.
- Only run async DB connection when PostgresGreenlet is running.
- Remove unused import os.path from setup.
- Include name and levelno attributes in DDP emitted log records.
- Don't attempt to monkey patch more than once.
- Include exception info in logger.error logging call.
- Update project classifiers to show specific versions of supported dependencies (fixes #6).
- Use sane default options for python setup.py bdist_wheel.
- Fixed README link to meteor - thanks @LegoStormtroopr.
- Set blank=True on AleaIdField, allowing adding items without inventing IDs yourself.
- Add AleaIdMixin which provides aid = AleaIdField(unique=True) to models.
- Use AleaIdField(unique=True) wherever possible when translating between Meteor style identifiers and Django primary keys, reducing round trips to the database and hence drastically improving performance when such fields are available.
- Get path to star.json from view config (defined in your urls.py) instead of from settings.
- Dropped dddp.server.views, use dddp.views instead.
- Support more than 8KB of change data by splitting large payloads into multiple chunks.
- Add Logs publication that can be configured to emit logs via DDP through the use of the dddp.logging.DDPHandler log handler.
- Add option to dddp daemon to provide a BackdoorServer (telnet) for interactive debugging (REPL) at runtime.
- Bugfix dddp.accounts forgot_password feature.
- Stop processing request middleware upon connection - see https://github.com/commoncode/django-ddp/commit/e7b38b89db5c4e252ac37566f626b5e9e1651a29 for rationale. Access to this.request.user is gone.
- Add this.user handling to dddp.accounts.
- Fix ordering of user added vs login ready in dddp.accounts authentication methods.
- Add dddp.models.get_object_ids helper function.
- Add ObjectMappingMixini abstract model mixin providing GenericRelation back to ObjectMapping model.
- Bugfix /app.model/schema helper method on collections to work with more model field types.
- Fix bug in post login/logout subscription handling.
- Fix bug in Accounts.forgotPassword implementation.
- Match return values for Accounts.changePassword and Accounts.changePassword methods in dddp.accounts submodule.
- Fix method signature for Accouts.changePassword.
- Updated Accounts hashing to prevent cross-purposing auth tokens.
- Correct method signature to match Meteor Accounts.resetPassword in dddp.accounts submodule.
- Include array of permissions on User publication.
- Use mimetypes module to correctly guess mime types for Meteor files being served.
- Include ROOT_URL_PATH_PREFIX in ROOT_URL when serving Meteor build files.
- Use HTTPS for DDP URL if settings.SECURE_SSL_REDIRECT is set.
- Added support for django.contrib.postres.fields.ArrayField serialization.
- Added Django 1.8 compatibility. The current implementation has a hackish (but functional) implementation to use PostgreSQL's array_agg function. Pull requests are welcome.
- Retained compatibility with Django 1.7, though we still depend on the dbarray package for this even though not strictly required with Django 1.8. Once again, pull requests are welcome.
- Add missing dependency on pybars3 used to render boilerplate HTML template when serving Meteor application files.
- Add dddp.server Django app to serve Meteor application files.
- Show input params after traceback if exception occurs in API methods.
- Small pylint cleanups.
- Refactor serialization to improve performance through reduced number of database queries, especially on sub/unsub.
- Fix login/logout user subscription, now emitting user added/ removed upon login/logout respectively.
- Use OrderedDict for geventwebsocket.Resource spec to support geventwebsockets 0.9.4 and above.
- Send removed messages when client unsubscribes from publications.
- Add support for SSL options and --settings=SETTINGS args in dddp tool.
- Add optional and label attributes to ManyToManyField simple schema.
- Check order of added/changed when emitting WebSocket frames rather than when queuing messages.
- Move test projects into path that can be imported post install.
- Refactor pub/sub functionality to fix support for removed messages.
- Bugfix issue where DDP connection thread stops sending messages after changing item that has subscribers for other connections but not self.
- Fix createUser method to login new user after creation.
- Dump stack trace to console on error for easier debugging DDP apps.
- Fix handing of F expressions in object change handler.
- Send nosub in response to invalid subscription request.
- Per connection tracking of sent objects so changed/added sent appropriately.
- Add dddp.accounts module which provides password based auth mapping to django.contrib.auth module.
- Fix ordering of change messages and result message in method calls.
- Drop relations to sessions.Session as WebSocket requests don't have HTTP cookie support -- you must `migrate` your database after upgrading.
- Refactor core to support custom serialization per collection, and correctly dispatch change messages per collection.
- Allow specifying specific collection for publication queries rather than assuming the auto-named default collections.
- Improve schema introspection to include options for fields with choices.
- Cleanup transaction handling to apply once at the entry point for DDP API calls.
- Make live updates honour user_rel restrictions, also allow superusers to see everything.
- Support serializing objects that are saved with F expressions by reading field values for F expressions from database explicitly before serializing.
- Allow fresh connections from browsers that have not established a session in the database yet, also allow subscriptions from unauthenticated sessions (but don't show any data for collections that have user_rel items defined). This change includes a schema change, remember to run migrations after updating.
- New DB field: Connection.server_addr -- you must `migrate` your database after upgrading.
- Cleanup connections on shutdown (and purge associated subscriptions).
- Make dddp management command a subclass of the runserver command so that staticfiles work as expected.
- Fix non-threadsafe failure in serializer - now using thread local serializer instance.
- Fix unsubscribe from publications.
- Fix /schema method call.
- Fix foreign key references in change messages to correctly reference related object rather than source object.
- Fix unicode rendering bug in DDP admin for ObjectMapping model.
- Add dddp console script to start DDP service in more robust manner than using the dddp Django mangement command.
- Don't include null/None reply from method calls in message.
- Force creation of Alea/Meteor ID even if nobody seems to care -- they do care if they're using the ID with latency compensated views.
- Support collections to models having non-integer primary key fields.
- Fix latency compensated Alea/Meteor ID generation to match Meteor semantics of using a namespace to generate seeded Alea PRNGs.
- Change validation so that we now pass the DDP test suite <http://ddptest.meteor.com/>.
- Add lots of useful info to the README.
- Add dddp.models.get_meteor_id and dddp.models.get_object_id methods.
- Add Connection, Subscription and SubscriptionColleciton models, instances of which are managed during life cycle of connections and subscriptions.
- Fixed incorrect use of django.core.serializers where different threads used same the serializer instance.
- Add Collection.user_rel class attribute allowing user-specific filtering of objects at the collection level.
- Add dddp.test test project with example meteor-todos/django-ddp project.
- Change dddp management command default port from 3000 to 8000.
- Validate django.conf.settings.DATABASES configuration on start.
- React to django.db.models.signals.m2m_changed model changes for ManyToManyField.
- Add dependency on django-dbarray.
- Add missing dependencies on gevent, gevent-websocket, meteor-ejson and psycogreen.
- Meteor compatible latency compensation using Alea PRNG.
- Add dddp.THREAD_LOCAL with factories.
- Register django signals handlers via AppConfig.ready() handler.
- Add dddp management command.
- Add dddp.models.AleaIdField and dddp.models.ObjectMapping model.
- Major internal refactoring.
- Working proof-of-concept.