QOR is a set of libraries written in Go that abstracts common features needed for business applications, CMSs, and E-commerce systems.
This is actually the third version of QOR: 1 and 2 were written in Ruby and used internally at The Plant. We decided to rewrite QOR in Go and open source it - which has happened as of June 2015.
QOR is still beta software - we will probably break an API or two before we release a stable 1.0 (scheduled for September 2015).
While nearing API freeze our other main focus is building up API documentation for each module and a tutorial that will eventually cover features from most of the modules.
QOR is not a "boxed turnkey solution". You need proper coding skills to use it. It's designed to make the lives of developers easier when building complex EC systems, not providing you one out of the box.
-
Admin - The heart of any QOR system, where you manage all your resources
-
Publish - Providing a staging environment for all content changes to be reviewed before being published to the live system
-
Transition - A configurable State Machine: define states, events (eg. pay order), and validation constraints for state transitions
-
Media Library - Asset Management with support for several cloud storage backends and publishing via a CDN
-
Worker (Batch processing) - A process scheduler
-
Exchange - Data exchange with other business applications using CSV or Excel data
-
Internationalization (i18n) - Managing and (inline) editing of translations
-
Localization (l10n) - Manage DB-backed models on per-locale basis, with support for defining/editing localizable attributes, and locale-based querying
-
Roles - Access Control
We are planning to update the godoc documentation for all modules after the API for the 1.0 release is frozen. Still outstanding are:
- Admin
- Publish
- Transition
- Media Library
- Worker
- Exchange
- Internationalization (i18n)
- Localization (l10n)
- Roles
The example application is a work in progress but already covers the following modules:
- Setup & Installation
- Define a first set of resources (qor/admin)
- Introduce Meta - Back Office display control for your resources
- Basic Media library usage
- Using Publish
- L10n & I18n
- [] Roles (very little)
- Worker
Requires Node.js and Gulp for building frontend files
npm install && npm install -g gulp
- Watch SCSS/JavaScript changes:
gulp
- Build Release files:
gulp release
- How to integrate with beego
adm := admin.New(&qor.Config{DB: &db.DB})
adm.AddResource(&db.User{}, &admin.Config{Menu: []string{"管理"}})
mux := http.NewServeMux()
adm.MountTo("/admin", mux)
beego.Handler("/admin/*", mux)
beego.Run()
- How to integrate with Gin
mux := http.NewServeMux()
admin.Admin.MountTo("/admin", mux)
r := gin.Default()
r.Any("/admin/*w", gin.WrapH(mux))
r.Run()