factory.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. // Copyright 2022 EMQ Technologies Co., Ltd.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package binder
  15. import "github.com/lf-edge/ekuiper/pkg/api"
  16. type SourceFactory interface {
  17. Source(name string) (api.Source, error)
  18. }
  19. type SinkFactory interface {
  20. Sink(name string) (api.Sink, error)
  21. }
  22. type FuncFactory interface {
  23. Function(name string) (api.Function, error)
  24. // HasFunctionSet Some functions are bundled together into a plugin which shares the same json file.
  25. // This function can return if the function set name exists.
  26. HasFunctionSet(funcName string) bool
  27. // ConvName Convert the name of the function usually to lowercase.
  28. // This is only be used when parsing the SQL statement.
  29. ConvName(funcName string) (string, bool)
  30. }
  31. type FactoryEntry struct {
  32. Name string
  33. Factory interface{}
  34. Weight int // bigger weight will be initialized first
  35. }
  36. type Entries []FactoryEntry
  37. func (e Entries) Len() int {
  38. return len(e)
  39. }
  40. func (e Entries) Less(i, j int) bool {
  41. return e[i].Weight > e[j].Weight
  42. }
  43. func (e Entries) Swap(i, j int) {
  44. e[i], e[j] = e[j], e[i]
  45. }