Skip to content

Latest commit

 

History

History
65 lines (49 loc) · 1.47 KB

plugins.md

File metadata and controls

65 lines (49 loc) · 1.47 KB

Plugins Development


A plugin needs to implement the corresponding four interfaces, such as:

// Plug-in is an important part of GoAdmin. Different plug-ins have different features.
type Plugin interface {

    // Get handlers
    GetHandler() context.HandlerMap
    
    // Initialize the plug-in
    InitPlugin(services service.List)
    
    // Get plugin name
    Name() string
    
    // Url prefix
	Prefix() string
}

Create a new plug-in must inheritplugin.Base. For example:

package example

import (
	c "github.com/GoAdminGroup/go-admin/modules/config"
	"github.com/GoAdminGroup/go-admin/modules/service"
	"github.com/GoAdminGroup/go-admin/plugins"
)

type Example struct {
	*plugins.Base
}

func NewExample() *Example {
	return &Example{
		Base: &plugins.Base{PlugName: "example", URLPrefix: "example"},
	}
}

func (e *Example) InitPlugin(srv service.List) {
	e.InitBase(srv)
	e.App = e.initRouter(c.Prefix(), srv)
}

func (e *Example) initRouter(prefix, srv service.List) {

	app := context.NewApp()
    route := app.Group(prefix)
    // Join the certification middleware
	route.GET("/show/me/something", auth.Middleware(db.GetConnection(srv)), func(ctx *context.Context){
        // Controller logic
    })
	return app
}

More: