qor

package module
v0.0.0-...-2ef9421 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 30, 2015 License: MIT Imports: 3 Imported by: 0

README

QOR

English Chat Room:

中文聊天室:

Build Status

What is QOR?

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.

What QOR is not

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.

The modules

  • 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

API Documentation

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

Example Application

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

Frontend Development

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

Q&A

  1. 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()

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Config

type Config struct {
	DB *gorm.DB
}

type Context

type Context struct {
	Request     *http.Request
	Writer      http.ResponseWriter
	ResourceID  string
	Config      *Config
	Roles       []string
	DB          *gorm.DB
	CurrentUser CurrentUser
	Errors
}

func (*Context) GetDB

func (context *Context) GetDB() *gorm.DB

func (*Context) SetDB

func (context *Context) SetDB(db *gorm.DB)

type CurrentUser

type CurrentUser interface {
	DisplayName() string
}

type Errors

type Errors struct {
	// contains filtered or unexported fields
}

func (*Errors) AddError

func (errs *Errors) AddError(errors ...error)

func (Errors) Error

func (errs Errors) Error() string

func (Errors) GetErrors

func (errs Errors) GetErrors() []error

func (Errors) HasError

func (errs Errors) HasError() bool

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL