-
Notifications
You must be signed in to change notification settings - Fork 49
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
MariaDB compatibility #70
base: main
Are you sure you want to change the base?
Conversation
Thanks for this PR. The existing syntax is MySQL 8.x which is explicitly called out in the requirements. In #62 I mentioned:
That said I'm willing to continue the conversation on this – either in the Slack channel or perhaps in #3 (or another GH discussion). |
To be clear: the reason for this stance is that we would be going backward with MySQL support.
|
So, thinking about this, perhaps we could implement a sort of "dialects" option or something. I haven't tested this code, but something akin to this: diff --git a/storage/mysql/mysql.go b/storage/mysql/mysql.go
index 166dfac..e26d17c 100644
--- a/storage/mysql/mysql.go
+++ b/storage/mysql/mysql.go
@@ -25,6 +25,8 @@ type MySQLStorage struct {
logger log.Logger
db *sql.DB
rm bool
+
+ newOnDupStx bool
}
type config struct {
@@ -82,7 +84,7 @@ func New(opts ...Option) (*MySQLStorage, error) {
if err = cfg.db.Ping(); err != nil {
return nil, err
}
- return &MySQLStorage{db: cfg.db, logger: cfg.logger, rm: cfg.rm}, nil
+ return &MySQLStorage{db: cfg.db, logger: cfg.logger, rm: cfg.rm, newOnDupStx: true}, nil
}
// nullEmptyString returns a NULL string if s is empty.
@@ -129,6 +131,20 @@ func (s *MySQLStorage) storeDeviceTokenUpdate(r *mdm.Request, msg *mdm.TokenUpda
return err
}
return err
}
+func (s *MySQLStorage) asNew() string {
+ if s.newOnDupStx {
+ return " AS new"
+ }
+ return ""
+}
+
+func (s *MySQLStorage) asNewCol(col string) string {
+ if s.newOnDupStx {
+ return "new." + col
+ }
+ return "VALUES(" + col + ")"
+}
+
func (s *MySQLStorage) storeUserTokenUpdate(r *mdm.Request, msg *mdm.TokenUpdate) error {
// there shouldn't be an Unlock Token on the user channel, but
// complain if there is to warn an admin
@@ -142,13 +158,13 @@ func (s *MySQLStorage) storeUserTokenUpdate(r *mdm.Request, msg *mdm.TokenUpdate
INSERT INTO users
(id, device_id, user_short_name, user_long_name, token_update, token_update_at)
VALUES
- (?, ?, ?, ?, ?, CURRENT_TIMESTAMP) AS new
+ (?, ?, ?, ?, ?, CURRENT_TIMESTAMP)`+s.asNew()+`
ON DUPLICATE KEY
UPDATE
device_id = new.device_id,
- user_short_name = new.user_short_name,
- user_long_name = new.user_long_name,
- token_update = new.token_update,
+ user_short_name = `+s.asNewCol("user_short_name")+`,
+ user_long_name = `+s.asNewCol("user_long_name")+`,
+ token_update = `+s.asNewCol("token_update")+`,
token_update_at = CURRENT_TIMESTAMP;`,
r.ID,
r.ParentID, Then of course hook up config and Options configurable in the backend options. Thoughts? |
@jessepeterson Can do! Happy to be assigned it. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See previous discussions. :)
Several Linux distributions have replaced MySQL in their repositories with MariaDB, a fork of MySQL. MariaDB does not support
INSERT ... AS
, so this PR rewrites the existing use ofINSERT ... AS
to a form that works in both MySQL and MariaDB.