factory.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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. LookupSource(name string) (api.LookupSource, error)
  19. }
  20. type SinkFactory interface {
  21. Sink(name string) (api.Sink, error)
  22. }
  23. type FuncFactory interface {
  24. Function(name string) (api.Function, error)
  25. // HasFunctionSet Some functions are bundled together into a plugin which shares the same json file.
  26. // This function can return if the function set name exists.
  27. HasFunctionSet(funcName string) bool
  28. // ConvName Convert the name of the function usually to lowercase.
  29. // This is only be used when parsing the SQL statement.
  30. ConvName(funcName string) (string, bool)
  31. }
  32. type FactoryEntry struct {
  33. Name string
  34. Factory interface{}
  35. Weight int // bigger weight will be initialized first
  36. }
  37. type Entries []FactoryEntry
  38. func (e Entries) Len() int {
  39. return len(e)
  40. }
  41. func (e Entries) Less(i, j int) bool {
  42. return e[i].Weight > e[j].Weight
  43. }
  44. func (e Entries) Swap(i, j int) {
  45. e[i], e[j] = e[j], e[i]
  46. }