summaryrefslogtreecommitdiffstats
path: root/plugin
diff options
context:
space:
mode:
authorChristopher Speller <crspeller@gmail.com>2018-07-31 07:44:44 -0700
committerGitHub <noreply@github.com>2018-07-31 07:44:44 -0700
commit82dfe9e61df90c9eb6c6540ca6d82b328661b652 (patch)
tree9507e82769c3be7783b746454e8939c010db50e8 /plugin
parent8766690c81fcefdbe0c9d85590de1eea07a908d7 (diff)
downloadchat-82dfe9e61df90c9eb6c6540ca6d82b328661b652.tar.gz
chat-82dfe9e61df90c9eb6c6540ca6d82b328661b652.tar.bz2
chat-82dfe9e61df90c9eb6c6540ca6d82b328661b652.zip
Adding support for code split plugins. (#9184)
Diffstat (limited to 'plugin')
-rw-r--r--plugin/environment.go20
1 files changed, 14 insertions, 6 deletions
diff --git a/plugin/environment.go b/plugin/environment.go
index 7d639bdd7..6f915fd80 100644
--- a/plugin/environment.go
+++ b/plugin/environment.go
@@ -6,11 +6,13 @@ package plugin
import (
"fmt"
"io/ioutil"
+ "os"
"path/filepath"
"sync"
"github.com/mattermost/mattermost-server/mlog"
"github.com/mattermost/mattermost-server/model"
+ "github.com/mattermost/mattermost-server/utils"
"github.com/pkg/errors"
)
@@ -172,15 +174,21 @@ func (env *Environment) Activate(id string) (reterr error) {
return fmt.Errorf("invalid webapp bundle path")
}
bundlePath = filepath.Join(env.pluginDir, id, bundlePath)
+ destinationPath := filepath.Join(env.webappPluginDir, id)
- webappBundle, err := ioutil.ReadFile(bundlePath)
- if err != nil {
- return errors.Wrapf(err, "unable to read webapp bundle: %v", id)
+ if err := os.RemoveAll(destinationPath); err != nil {
+ return errors.Wrapf(err, "unable to remove old webapp bundle directory: %v", destinationPath)
}
- err = ioutil.WriteFile(fmt.Sprintf("%s/%s_bundle.js", env.webappPluginDir, id), webappBundle, 0644)
- if err != nil {
- return errors.Wrapf(err, "unable to write webapp bundle: %v", id)
+ if err := utils.CopyDir(filepath.Dir(bundlePath), destinationPath); err != nil {
+ return errors.Wrapf(err, "unable to copy webapp bundle directory: %v", id)
+ }
+
+ if err := os.Rename(
+ filepath.Join(destinationPath, filepath.Base(bundlePath)),
+ filepath.Join(destinationPath, fmt.Sprintf("%s_bundle.js", id)),
+ ); err != nil {
+ return errors.Wrapf(err, "unable to rename webapp bundle: %v", id)
}
}