/* * Copyright 2020 The Dragonfly Authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package plugins import ( "d7y.io/dragonfly/v2/cdnsystem/config" logger "d7y.io/dragonfly/v2/pkg/dflog" "fmt" ) var mgr = NewManager() // SetManager sets a Manager implementation instead of the default one. func SetManager(m Manager) { mgr = m } // Initialize builds all plugins defined in config file. func Initialize(cfg *config.Config) error { for pt, value := range cfg.Plugins { for _, v := range value { if !v.Enable { logger.Infof("plugin[%s][%s] is disabled", pt, v.Name) continue } builder := mgr.GetBuilder(pt, v.Name) if builder == nil { return fmt.Errorf("cannot find builder to create plugin[%s][%s]", pt, v.Name) } p, err := builder(v.Config) if err != nil { return fmt.Errorf("failed to build plugin[%s][%s]: %v", pt, v.Name, err) } mgr.AddPlugin(p) logger.Infof("add plugin[%s][%s]", pt, v.Name) } } return nil } // RegisterPlugin register a plugin builder that will be called to create a new // plugin instant when cdn starts. func RegisterPlugin(pt config.PluginType, name string, builder Builder) { mgr.AddBuilder(pt, name, builder) } // GetPlugin returns a plugin instant with the giving plugin type and name. func GetPlugin(pt config.PluginType, name string) Plugin { return mgr.GetPlugin(pt, name) }