serverless.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. package plugin_manager
  2. import (
  3. "fmt"
  4. "time"
  5. "github.com/langgenius/dify-plugin-daemon/internal/core/plugin_manager/basic_runtime"
  6. "github.com/langgenius/dify-plugin-daemon/internal/core/plugin_manager/serverless_runtime"
  7. "github.com/langgenius/dify-plugin-daemon/internal/db"
  8. "github.com/langgenius/dify-plugin-daemon/internal/types/models"
  9. "github.com/langgenius/dify-plugin-daemon/internal/utils/cache"
  10. "github.com/langgenius/dify-plugin-daemon/internal/utils/cache/helper"
  11. "github.com/langgenius/dify-plugin-daemon/pkg/entities/plugin_entities"
  12. )
  13. const (
  14. PLUGIN_SERVERLESS_CACHE_KEY = "serverless:runtime:%s"
  15. )
  16. func (p *PluginManager) getServerlessRuntimeCacheKey(
  17. identity plugin_entities.PluginUniqueIdentifier,
  18. ) string {
  19. return fmt.Sprintf(PLUGIN_SERVERLESS_CACHE_KEY, identity.String())
  20. }
  21. func (p *PluginManager) getServerlessPluginRuntime(
  22. identity plugin_entities.PluginUniqueIdentifier,
  23. ) (plugin_entities.PluginLifetime, error) {
  24. model, err := p.getServerlessPluginRuntimeModel(identity)
  25. if err != nil {
  26. return nil, err
  27. }
  28. // FIXME: get declaration
  29. declaration, err := helper.CombinedGetPluginDeclaration(identity, plugin_entities.PLUGIN_RUNTIME_TYPE_SERVERLESS)
  30. // init runtime entity
  31. runtimeEntity := plugin_entities.PluginRuntime{
  32. Config: *declaration,
  33. }
  34. runtimeEntity.InitState()
  35. // convert to plugin runtime
  36. pluginRuntime := serverless_runtime.AWSPluginRuntime{
  37. BasicChecksum: basic_runtime.BasicChecksum{
  38. MediaTransport: basic_runtime.NewMediaTransport(p.mediaBucket),
  39. InnerChecksum: model.Checksum,
  40. },
  41. PluginRuntime: runtimeEntity,
  42. LambdaURL: model.FunctionURL,
  43. LambdaName: model.FunctionName,
  44. }
  45. if err := pluginRuntime.InitEnvironment(); err != nil {
  46. return nil, err
  47. }
  48. return &pluginRuntime, nil
  49. }
  50. func (p *PluginManager) getServerlessPluginRuntimeModel(
  51. identity plugin_entities.PluginUniqueIdentifier,
  52. ) (*models.ServerlessRuntime, error) {
  53. // check if plugin is a serverless runtime
  54. runtime, err := cache.Get[models.ServerlessRuntime](
  55. p.getServerlessRuntimeCacheKey(identity),
  56. )
  57. if err != nil && err != cache.ErrNotFound {
  58. return nil, fmt.Errorf("unexpected error occurred during fetch serverless runtime cache: %v", err)
  59. }
  60. if err == cache.ErrNotFound {
  61. runtimeModel, err := db.GetOne[models.ServerlessRuntime](
  62. db.Equal("plugin_unique_identifier", identity.String()),
  63. )
  64. if err == db.ErrDatabaseNotFound {
  65. return nil, fmt.Errorf("plugin serverless runtime not found: %s", identity.String())
  66. }
  67. if err != nil {
  68. return nil, fmt.Errorf("failed to load serverless runtime from db: %v", err)
  69. }
  70. cache.Store(p.getServerlessRuntimeCacheKey(identity), runtimeModel, time.Minute*30)
  71. runtime = &runtimeModel
  72. } else if err != nil {
  73. return nil, fmt.Errorf("failed to load serverless runtime from cache: %v", err)
  74. }
  75. return runtime, nil
  76. }