agi.go 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. package main
  2. import (
  3. "net/http"
  4. agi "imuslab.com/arozos/mod/agi"
  5. prout "imuslab.com/arozos/mod/prouter"
  6. "imuslab.com/arozos/mod/utils"
  7. )
  8. var (
  9. AGIGateway *agi.Gateway
  10. )
  11. func AGIInit() {
  12. //Create new AGI Gateway object
  13. gw, err := agi.NewGateway(agi.AgiSysInfo{
  14. BuildVersion: build_version,
  15. InternalVersion: internal_version,
  16. LoadedModule: moduleHandler.GetModuleNameList(),
  17. ReservedTables: []string{"auth", "permisson", "register", "desktop"},
  18. ModuleRegisterParser: moduleHandler.RegisterModuleFromAGI,
  19. ModuleListProvider: moduleHandler.GetModuleListJSONForUser,
  20. PackageManager: packageManager,
  21. Logger: systemWideLogger,
  22. UserHandler: userHandler,
  23. StartupRoot: "./web",
  24. ActivateScope: []string{"./web", "./subservice"},
  25. FileSystemRender: thumbRenderHandler,
  26. ShareManager: shareManager,
  27. NightlyManager: nightlyManager,
  28. TempFolderPath: *tmp_directory,
  29. })
  30. if err != nil {
  31. systemWideLogger.PrintAndLog("AGI", "AGI Gateway Initialization Failed", err)
  32. }
  33. //Register user request handler endpoint
  34. http.HandleFunc("/system/ajgi/interface", func(w http.ResponseWriter, r *http.Request) {
  35. //Require login check
  36. authAgent.HandleCheckAuth(w, r, func(w http.ResponseWriter, r *http.Request) {
  37. //API Call from actual human users
  38. thisuser, _ := gw.Option.UserHandler.GetUserInfoFromRequest(w, r)
  39. gw.InterfaceHandler(w, r, thisuser)
  40. })
  41. })
  42. //Register external API request handler endpoint
  43. http.HandleFunc("/api/ajgi/interface", func(w http.ResponseWriter, r *http.Request) {
  44. //Check if token exists
  45. token, err := utils.PostPara(r, "token")
  46. if err != nil {
  47. w.WriteHeader(http.StatusUnauthorized)
  48. w.Write([]byte("401 - Unauthorized (token is empty)"))
  49. return
  50. }
  51. //Validate Token
  52. if authAgent.TokenValid(token) {
  53. //Valid
  54. thisUsername, err := gw.Option.UserHandler.GetAuthAgent().GetTokenOwner(token)
  55. if err != nil {
  56. systemWideLogger.PrintAndLog("AGI", "Unable to validate token owner", err)
  57. w.WriteHeader(http.StatusInternalServerError)
  58. w.Write([]byte("500 - Internal Server Error"))
  59. return
  60. }
  61. thisuser, _ := gw.Option.UserHandler.GetUserInfoFromUsername(thisUsername)
  62. gw.APIHandler(w, r, thisuser)
  63. } else {
  64. w.WriteHeader(http.StatusUnauthorized)
  65. w.Write([]byte("401 - Unauthorized (Invalid / expired token)"))
  66. return
  67. }
  68. })
  69. http.HandleFunc("/api/ajgi/exec", gw.HandleAgiExecutionRequestWithToken)
  70. // external AGI related function
  71. externalAGIRouter := prout.NewModuleRouter(prout.RouterOption{
  72. ModuleName: "ARZ Serverless",
  73. AdminOnly: false,
  74. UserHandler: userHandler,
  75. DeniedHandler: func(w http.ResponseWriter, r *http.Request) {
  76. errorHandlePermissionDenied(w, r)
  77. },
  78. })
  79. externalAGIRouter.HandleFunc("/api/ajgi/listExt", gw.ListExternalEndpoint)
  80. externalAGIRouter.HandleFunc("/api/ajgi/addExt", gw.AddExternalEndPoint)
  81. externalAGIRouter.HandleFunc("/api/ajgi/rmExt", gw.RemoveExternalEndPoint)
  82. externalAGIRouter.HandleFunc("/api/ajgi/stats", gw.GetEndpointStats)
  83. AGIGateway = gw
  84. }