services.go 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package app
  2. import (
  3. "context"
  4. "database/sql"
  5. "github.com/kujtimiihoxha/termai/internal/config"
  6. "github.com/kujtimiihoxha/termai/internal/db"
  7. "github.com/kujtimiihoxha/termai/internal/logging"
  8. "github.com/kujtimiihoxha/termai/internal/lsp"
  9. "github.com/kujtimiihoxha/termai/internal/lsp/watcher"
  10. "github.com/kujtimiihoxha/termai/internal/message"
  11. "github.com/kujtimiihoxha/termai/internal/permission"
  12. "github.com/kujtimiihoxha/termai/internal/session"
  13. )
  14. type App struct {
  15. Context context.Context
  16. Sessions session.Service
  17. Messages message.Service
  18. Permissions permission.Service
  19. LSPClients map[string]*lsp.Client
  20. Logger logging.Interface
  21. ceanups []func()
  22. }
  23. func New(ctx context.Context, conn *sql.DB) *App {
  24. cfg := config.Get()
  25. q := db.New(conn)
  26. log := logging.Get()
  27. log.SetLevel(cfg.Log.Level)
  28. sessions := session.NewService(ctx, q)
  29. messages := message.NewService(ctx, q)
  30. app := &App{
  31. Context: ctx,
  32. Sessions: sessions,
  33. Messages: messages,
  34. Permissions: permission.NewPermissionService(),
  35. Logger: log,
  36. LSPClients: make(map[string]*lsp.Client),
  37. }
  38. for name, client := range cfg.LSP {
  39. lspClient, err := lsp.NewClient(client.Command, client.Args...)
  40. app.ceanups = append(app.ceanups, func() {
  41. lspClient.Close()
  42. })
  43. workspaceWatcher := watcher.NewWorkspaceWatcher(lspClient)
  44. if err != nil {
  45. log.Error("Failed to create LSP client for", name, err)
  46. continue
  47. }
  48. _, err = lspClient.InitializeLSPClient(ctx, config.WorkingDirectory())
  49. if err != nil {
  50. log.Error("Initialize failed", "error", err)
  51. continue
  52. }
  53. go workspaceWatcher.WatchWorkspace(ctx, config.WorkingDirectory())
  54. app.LSPClients[name] = lspClient
  55. }
  56. return app
  57. }
  58. func (a *App) Close() {
  59. for _, cleanup := range a.ceanups {
  60. cleanup()
  61. }
  62. for _, client := range a.LSPClients {
  63. client.Close()
  64. }
  65. a.Logger.Info("App closed")
  66. }