From 79e9244dc9977c6ec6adc78631c0485efa9f60af Mon Sep 17 00:00:00 2001 From: Florian Orben Date: Fri, 13 Nov 2015 22:56:41 +0100 Subject: allow to toggle features in backend --- config/pre_release_features.json | 6 ---- store/sql_preference_store.go | 47 +++++++++++++++++++++++++++++ store/sql_store.go | 2 ++ store/store.go | 3 +- web/static/config/pre_release_features.json | 7 ++++- 5 files changed, 57 insertions(+), 8 deletions(-) delete mode 100644 config/pre_release_features.json mode change 120000 => 100644 web/static/config/pre_release_features.json diff --git a/config/pre_release_features.json b/config/pre_release_features.json deleted file mode 100644 index d1b27ecf9..000000000 --- a/config/pre_release_features.json +++ /dev/null @@ -1,6 +0,0 @@ -[ - { - "label": "#1389", - "description": "Show markdown preview option in message input box" - } -] \ No newline at end of file diff --git a/store/sql_preference_store.go b/store/sql_preference_store.go index 8454abcbd..63561a509 100644 --- a/store/sql_preference_store.go +++ b/store/sql_preference_store.go @@ -4,6 +4,7 @@ package store import ( + l4g "code.google.com/p/log4go" "github.com/go-gorp/gorp" "github.com/mattermost/platform/model" "github.com/mattermost/platform/utils" @@ -13,6 +14,10 @@ type SqlPreferenceStore struct { *SqlStore } +const ( + FEATURE_TOGGLE_PREFIX = "feature_enabled_" +) + func NewSqlPreferenceStore(sqlStore *SqlStore) PreferenceStore { s := &SqlPreferenceStore{sqlStore} @@ -36,6 +41,23 @@ func (s SqlPreferenceStore) CreateIndexesIfNotExists() { s.CreateIndexIfNotExists("idx_preferences_name", "Preferences", "Name") } +func (s SqlPreferenceStore) DeleteUnusedFeatures() { + l4g.Debug("Deleting any unused pre-release features") + + sql := `DELETE + FROM Preferences + WHERE + Category = :Category + AND Value = :Value + AND Name LIKE '` + FEATURE_TOGGLE_PREFIX + `%'` + + queryParams := map[string]string{ + "Category": "advanced_settings", + "Value": "false", + } + s.GetMaster().Exec(sql, queryParams) +} + func (s SqlPreferenceStore) Save(preferences *model.Preferences) StoreChannel { storeChannel := make(StoreChannel) @@ -257,3 +279,28 @@ func (s SqlPreferenceStore) PermanentDeleteByUser(userId string) StoreChannel { return storeChannel } + +func (s SqlPreferenceStore) FeatureToggle(feature, userId string) StoreChannel { + storeChannel := make(StoreChannel) + + go func() { + result := StoreResult{} + if value, err := s.GetReplica().SelectStr(`SELECT + value + FROM + Preferences + WHERE + UserId = :UserId + AND Category = :Category + AND Name = :Name`, map[string]interface{}{"UserId": userId, "Category": "advanced_settings", "Name": FEATURE_TOGGLE_PREFIX + feature}); err != nil { + result.Err = model.NewAppError("SqlPreferenceStore.featureToggle", "We encountered an error while finding a pre release feature preference", err.Error()) + } else { + result.Data = value == "true" + } + + storeChannel <- result + close(storeChannel) + }() + + return storeChannel +} diff --git a/store/sql_store.go b/store/sql_store.go index f348db10b..d17a3e8c3 100644 --- a/store/sql_store.go +++ b/store/sql_store.go @@ -148,6 +148,8 @@ func NewSqlStore() Store { sqlStore.webhook.(*SqlWebhookStore).CreateIndexesIfNotExists() sqlStore.preference.(*SqlPreferenceStore).CreateIndexesIfNotExists() + sqlStore.preference.(*SqlPreferenceStore).DeleteUnusedFeatures() + if model.IsPreviousVersion(schemaVersion) || isSchemaVersion07 || isSchemaVersion10 { sqlStore.system.Update(&model.System{Name: "Version", Value: model.CurrentVersion}) l4g.Warn("The database schema has been upgraded to version " + model.CurrentVersion) diff --git a/store/store.go b/store/store.go index 338ae186f..36d991a15 100644 --- a/store/store.go +++ b/store/store.go @@ -186,4 +186,5 @@ type PreferenceStore interface { GetCategory(userId string, category string) StoreChannel GetAll(userId string) StoreChannel PermanentDeleteByUser(userId string) StoreChannel -} + FeatureToggle(feature, userId string) StoreChannel +} \ No newline at end of file diff --git a/web/static/config/pre_release_features.json b/web/static/config/pre_release_features.json deleted file mode 120000 index fa410e1d1..000000000 --- a/web/static/config/pre_release_features.json +++ /dev/null @@ -1 +0,0 @@ -../../../config/pre_release_features.json \ No newline at end of file diff --git a/web/static/config/pre_release_features.json b/web/static/config/pre_release_features.json new file mode 100644 index 000000000..d1b27ecf9 --- /dev/null +++ b/web/static/config/pre_release_features.json @@ -0,0 +1,6 @@ +[ + { + "label": "#1389", + "description": "Show markdown preview option in message input box" + } +] \ No newline at end of file -- cgit v1.2.3-1-g7c22