Skip to content

Commit

Permalink
Fix minor inconsistencies in settings.
Browse files Browse the repository at this point in the history
- Add missing `app.root_url` key in migration.
- Register `/settings` handler in the backend.
- Add dummy dots in secret fields on the UI for visibility.
  • Loading branch information
knadh committed Aug 7, 2020
1 parent 16e47dd commit 7ed0755
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 6 deletions.
28 changes: 24 additions & 4 deletions frontend/src/views/Settings.vue
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,8 @@
<b-input v-model="form['upload.s3.aws_access_key_id']"
name="upload.s3.aws_access_key_id" :maxlength="200" />
</b-field>
<b-field label="AWS access secret" label-position="on-border" expanded>
<b-field label="AWS access secret" label-position="on-border" expanded
message="Enter a value to change.">
<b-input v-model="form['upload.s3.aws_secret_access_key']"
name="upload.s3.aws_secret_access_key" type="password"
:maxlength="200" />
Expand Down Expand Up @@ -281,7 +282,7 @@
name="username" placeholder="mysmtp" :maxlength="200" />
</b-field>
<b-field label="Password" label-position="on-border" expanded
message="Enter a value to change. Otherwise, leave empty.">
message="Enter a value to change.">
<b-input v-model="item.password"
:disabled="item.auth_protocol === 'none'"
name="password" type="password" placeholder="Enter to change"
Expand Down Expand Up @@ -389,6 +390,8 @@ import { mapState } from 'vuex';
import store from '../store';
import { models } from '../constants';
const dummyPassword = ' '.repeat(8);
export default Vue.extend({
data() {
return {
Expand Down Expand Up @@ -419,19 +422,28 @@ export default Vue.extend({
},
onSubmit() {
const form = { ...this.form };
const form = JSON.parse(JSON.stringify(this.form));
// De-serialize custom e-mail headers.
for (let i = 0; i < form.smtp.length; i += 1) {
// If it's the dummy UI password placeholder, ignore it.
if (form.smtp[i].password === dummyPassword) {
form.smtp[i].password = '';
}
if (form.smtp[i].strEmailHeaders && form.smtp[i].strEmailHeaders !== '[]') {
form.smtp[i].email_headers = JSON.parse(form.smtp[i].strEmailHeaders);
} else {
form.smtp[i].email_headers = [];
}
}
if (form['upload.s3.aws_secret_access_key'] === dummyPassword) {
form['upload.s3.aws_secret_access_key'] = '';
}
this.isLoading = true;
this.$api.updateSettings(this.form).then((data) => {
this.$api.updateSettings(form).then((data) => {
if (data.needsRestart) {
// Update the 'needsRestart' flag on the global serverConfig state
// as there are running campaigns and the app couldn't auto-restart.
Expand Down Expand Up @@ -462,6 +474,14 @@ export default Vue.extend({
// Serialize the `email_headers` array map to display on the form.
for (let i = 0; i < d.smtp.length; i += 1) {
d.smtp[i].strEmailHeaders = JSON.stringify(d.smtp[i].email_headers, null, 4);
// The backend doesn't send passwords, so add a dummy so that it
// the password looks filled on the UI.
d.smtp[i].password = dummyPassword;
}
if (d['upload.provider'] === 's3') {
d['upload.s3.aws_secret_access_key'] = dummyPassword;
}
this.form = d;
Expand Down
1 change: 1 addition & 0 deletions handlers.go
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,7 @@ func registerHTTPHandlers(e *echo.Echo) {
e.GET("/campaigns/media", handleIndexPage)
e.GET("/campaigns/templates", handleIndexPage)
e.GET("/campaigns/:campignID", handleIndexPage)
e.GET("/settings", handleIndexPage)
}

// handleIndex is the root handler that renders the Javascript frontend.
Expand Down
1 change: 1 addition & 0 deletions internal/migrations/v0.7.0.go
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@ func V0_7_0(db *sqlx.DB, fs stuffbin.FileSystem, ko *koanf.Koanf) error {
-- Insert default settings if the table is empty.
INSERT INTO settings (key, value) SELECT k, v::JSONB FROM (VALUES
('app.root_url', '"http://localhost:9000"'),
('app.favicon_url', '""'),
('app.from_email', '"listmonk <[email protected]>"'),
('app.logo_url', '"http://localhost:9000/public/static/logo.png"'),
Expand Down
2 changes: 1 addition & 1 deletion queries.sql
Original file line number Diff line number Diff line change
Expand Up @@ -733,5 +733,5 @@ SELECT JSON_OBJECT_AGG(key, value) AS settings

-- name: update-settings
UPDATE settings AS s SET value = c.value
-- For each key in the incoming JSON map, update the row with the key and it's value.
-- For each key in the incoming JSON map, update the row with the key and its value.
FROM(SELECT * FROM JSONB_EACH($1)) AS c(key, value) WHERE s.key = c.key;
2 changes: 1 addition & 1 deletion settings.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ func handleUpdateSettings(c echo.Context) error {
}
if !has {
return echo.NewHTTPError(http.StatusBadRequest,
"At least one SMTP block should be enabled")
"Minimum one SMTP block should be enabled.")
}

// S3 password?
Expand Down

0 comments on commit 7ed0755

Please sign in to comment.