Defiant has a complicated mission. We are trying to assemble many unique projects into a common framework. We are starting from scratch and bootstrapping it as we go. That means that things that should be here aren't yet, and things that are indispensable we haven't even gotten around to stubbing out yet!
This document is a mini-roadmap so that you can jump in and know where we need help in development. We will also try to include implementation notes so that you can see the direction we are striving for (although, like any complicated project, the details will probably change as we progress).
The things in this list are not in any particular order, although some may not be possible until other items on the list are somewhat functional. If you see something that you want to work on, however, there is nothing stopping you from working on anything that interests you!
- The Router properly identifies the applicable handlers for the given URL, including wildcard matching. Multiple handlers may match the requested URL. Handlers may or may not choose to reply to a route. The Router supports use of handler access functions to determine whether or not the handler should be given access to the request. 403 generated for access denied.
- The Form API correctly handles validation and cryptographic signing, as discussed here, as well as file uploads.
- The Session API gives the user an encrypted cookie, and recovers the user session from disk if not already in memory. The cookie encryption is randomly generated and unique for each installation. Session expiration works. A volatile Session also exists (non-disk based), and is used for small things (e.g., message delivery across page loads), but that are not important enough to save in the session file on disk.
- The Settings API is under way, with the user able to change the directories used to store Settings Data objects. The user can also change the Storage class for declared data objects.
- The Theme system works, so that child themes will have proper fallback to the parent definitions when necessary. Bootstrap is the basic (default) theme.
- Various utility functions exist.
- An Example plugin shows the basic usage for most features.
- There is some test coverage (mostly the utility functions).
- For the moment, a sqlite3 database is used, but will soon be replaced with a generic database abstraction.
- A Rudimentary ORM is in place. It has a concept of Tables, Entities, and Attributes. Entities are assembled by adding Attributes (e.g., text fields, numbers, etc.). Attributes can have sub-attributes for many levels. The Entity table is not revisioned (it should only keep static identity data). All data about an Entity that can change should be put into an Attribute. All Attributes support revisions. All Attributes can have a many-to-one relationship with the Entity; it is up to the code to control the number of Attributes allowed in a single revision.
- The "Message" functionality has been implemented, so that Error, Warning, Informational, etc. messages can be shown to the user. Messages are added to the Themed page output. Messages are stored in an in-memory-only, volatile session variable, so as to persist across page loads.
- A default admin account is created when the server is started (if the account doesn't already exist).
- User login, logout, & password change works, with account persistence through Sessions.
- Serving files from directories is now supported. This allows for mapping of arbitrary paths to specific directories, which is necessary for HTML inclusion of Plugin-provided HTML, CSS, & JavaScript.
- The context variable now has JavaScript and CSS Registries, so that plugins can add JS & CSS to a page load. Better, though, is using the Library plugin to utilize 3rd party plugins (jQuery and jQueryUI are included by default).
- JQuery is included by default by the base theme.
- Layouts are minimally functional and can be partially edited in-browser, including drag-and-drop widget placement.
- There is a Library API for managing 3rd party JS inclusions. Includes JQuery, JQuery UI, Bootstrap, and Materialize.
- The File API is shaping up, and progress is being made on the FileManager class, which allows for multiple types of file stores to manage uploaded files.
- The Query API is finally taking shape!!! Honestly, it will probably be perceived as the heart of what makes Defiant a distinctive and amazing option. Once it's finished, that is.
Database Abstraction class using node-sql.Done.
Default to sqlite3.Done.- In the future, the 1st run of Defiant will create an in-memory sqlite3 database.
- The user will then choose the actual database setup (file location if sqlite3, or db connection info).
- Defiant will save the setup into a bootstrap variable, and migrate the database.
- Support database schema versioning and upgrading.
User loginDone.
The admin user (if not found in the database), should be generated automatically and the password output viaDone.console.log()
.
RouterDone.
Router items should support validation.Done.Logic needs to be decided on for multiple router items responding to a request (later items may need to modify the structure created by previous items!).Done. Fall-through behavior supported.Support for serving static files.Done.Plugins must be able to provide their own resource files (javascript, images, css, etc.)- These files should be servable securely from the plugin directory by explicit listing of files.
- HTTP
- Consider doing away with the Connect module altogether, since HTTP serves the same purpose.
WidgetsDone.
Widgets are analogous to Drupal blocks. They may be forms, lists, menus, or any other information that needs to appear on a page, but that may not be the main content of that page.Done.
LayoutDone.
A Layout engine should wrap theDone.content
of "themed" pages. Layouts should be defined flexibly, and provide drag-and-drop addition of widgets.
ThemeDone.
A default Bootstrap theme would be nice.Done.
Messaging SystemDone.
We need a way for Plugins to communicate messages to the user.Done.The "Message box" will probably be a Widget so that it can be moved around the page as needed.Done.
JS/CSS InclusionDone.
At any time during the router handling, other plugins should be able to add JS and CSS files as needed.Done.- Support JS and CSS minification (if possible).
Perhaps a type of library support, too (e.g., D3, when needed).Done.
- Menu system
Plugins need a way to declare that some routes are intended to be menu items.Done. There are 4 default menus, which appear in the Layout as a Widget.- Types of menus are:
- Static (always appear regardless of current page)
- Contextual (only appear when their path can be generated from the URL of the current page)
Links should not appear if the user does not have access to that page.Done.- Now working on custom ordering, indenting, & other behavioral settings.
The Navigation Menu Widget needs to replace the current, static header.Done.
- Internationalization
- Stub out support for translation based on context.
- Figure out where to go from here...
- File API
When files are uploaded, they should be tracked by the system. They may be transferred to other file systems.Partially working. Will store files locally. Need to add additional storage types:- FTP
- S3 (and related)
- Logging/Data Store
- There are 3 types of data in the system:
- Database (relational data)
File-based settings (Settings plugin)Working- Logs (data that should be stored, but not necessarily indexed)
- Possibly emulate logrotate behavior
- Possibly track log files with the File API (would make it easy to backup logs to offsite storage, for example!)
- Sockets
- Now we're talking... this is what Node.js is good for!
- Needs same authentication mechanism as HTTP.
- Some example/demo plugin would be nice... perhaps the beginnings of a Slack clone or WebRTC client?
- Other Plugin discovery
- It would be nice if Defiant could discover other Defiant-compatible modules (plugins) that have been installed either locally or globally.
- This would make UI-based management of the engine very nice!
- UI-based Query builder. (Inspired by Drupal Views)
Initial, proof-of-concept is done. QueryApi exists and can perform nested queries and display results.More work on formatting plugins is required, though, and is in progress. All of this must be fleshed out before working on the GUI.- A powerful feature available in Drupal, but that could be made much nicer in a Node.js-based implementation.
- Lots of ideas, but this on is a biggie, and is further down the road.
- WYSIWYG
- Supporting a WYSIWYG editor
- In-place editing would be nice.
- Perhaps supporting input formats such as Markdown as well as HTML.
- Multi-engine communication.
- An important step on the roadmap.
- Multiple engines could communicate with one another to pass along file-based settings changes (presumably databases will be synchronizing themselves?).
- CMS
- This is not the main goal of Defiant, but it is a practical use case, as CMS features may be useful to many types of other plugins.
The ORM and QueryApi is a HUGE step in this direction.
- E-Commerce
- It's a long-term goal, but it would be important as many people are looking for this type of service these days.
Form APILargely working!
- Need to support ajax/partial form replacement. This is complicated because of the cryptographic signing currently used in the FormApi.
- World Domination.
- Because.