mirror of
https://github.com/wailsapp/wails.git
synced 2026-03-14 14:45:49 +01:00
51 lines
1.2 KiB
Go
51 lines
1.2 KiB
Go
package fileserver
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
|
|
"github.com/wailsapp/wails/v3/pkg/application"
|
|
)
|
|
|
|
// ---------------- Service Setup ----------------
|
|
// This is the main Service struct. It can be named anything you like.
|
|
|
|
type Config struct {
|
|
RootPath string
|
|
}
|
|
|
|
type Service struct {
|
|
config *Config
|
|
fs http.Handler
|
|
}
|
|
|
|
func New(config *Config) *Service {
|
|
return &Service{
|
|
config: config,
|
|
fs: http.FileServer(http.Dir(config.RootPath)),
|
|
}
|
|
}
|
|
|
|
// OnShutdown is called when the app is shutting down
|
|
// You can use this to clean up any resources you have allocated
|
|
func (s *Service) OnShutdown() error {
|
|
return nil
|
|
}
|
|
|
|
// Name returns the name of the plugin.
|
|
// You should use the go module format e.g. github.com/myuser/myplugin
|
|
func (s *Service) Name() string {
|
|
return "github.com/wailsapp/wails/v3/services/fileserver"
|
|
}
|
|
|
|
// OnStartup is called when the app is starting up. You can use this to
|
|
// initialise any resources you need.
|
|
func (s *Service) OnStartup(ctx context.Context, options application.ServiceOptions) error {
|
|
// Any initialization code here
|
|
return nil
|
|
}
|
|
|
|
func (s *Service) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
|
// Create a new file server rooted at the given path
|
|
s.fs.ServeHTTP(w, r)
|
|
}
|