2019-10-23 12:30:52 -04:00
|
|
|
import Component from "@ember/component";
|
2023-10-10 14:38:59 -04:00
|
|
|
import { action, set } from "@ember/object";
|
2019-10-31 13:37:24 -04:00
|
|
|
import { isEmpty } from "@ember/utils";
|
2023-10-10 14:38:59 -04:00
|
|
|
import { classNameBindings } from "@ember-decorators/component";
|
2023-10-18 06:07:09 -04:00
|
|
|
import I18n from "discourse-i18n";
|
2018-10-15 01:03:53 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
@classNameBindings(":value-list", ":secret-value-list")
|
|
|
|
export default class SecretValueList extends Component {
|
|
|
|
inputDelimiter = null;
|
|
|
|
collection = null;
|
|
|
|
values = null;
|
2018-10-15 01:03:53 -04:00
|
|
|
|
2024-06-04 14:16:05 -04:00
|
|
|
didReceiveAttrs() {
|
|
|
|
super.didReceiveAttrs(...arguments);
|
2018-10-15 01:03:53 -04:00
|
|
|
|
|
|
|
this.set(
|
|
|
|
"collection",
|
2024-06-04 14:16:05 -04:00
|
|
|
this._splitValues(this.values, this.inputDelimiter || "\n")
|
2018-10-15 01:03:53 -04:00
|
|
|
);
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
@action
|
|
|
|
changeKey(index, event) {
|
|
|
|
const newValue = event.target.value;
|
2022-07-08 07:00:33 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
if (this._checkInvalidInput(newValue)) {
|
|
|
|
return;
|
|
|
|
}
|
2022-07-08 07:00:33 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
this._replaceValue(index, newValue, "key");
|
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
@action
|
|
|
|
changeSecret(index, event) {
|
|
|
|
const newValue = event.target.value;
|
2022-07-08 07:00:33 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
if (this._checkInvalidInput(newValue)) {
|
|
|
|
return;
|
|
|
|
}
|
2022-07-08 07:00:33 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
this._replaceValue(index, newValue, "secret");
|
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
@action
|
|
|
|
addValue() {
|
|
|
|
if (this._checkInvalidInput([this.newKey, this.newSecret])) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
this._addValue(this.newKey, this.newSecret);
|
|
|
|
this.setProperties({ newKey: "", newSecret: "" });
|
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
2023-02-23 10:32:53 -05:00
|
|
|
@action
|
|
|
|
removeValue(value) {
|
|
|
|
this._removeValue(value);
|
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
2018-11-04 15:18:58 -05:00
|
|
|
_checkInvalidInput(inputs) {
|
|
|
|
for (let input of inputs) {
|
2019-10-31 13:37:24 -04:00
|
|
|
if (isEmpty(input) || input.includes("|")) {
|
2024-08-15 12:38:47 -04:00
|
|
|
this.setValidationMessage(
|
2018-11-04 15:18:58 -05:00
|
|
|
I18n.t("admin.site_settings.secret_list.invalid_input")
|
|
|
|
);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2024-08-15 12:38:47 -04:00
|
|
|
this.setValidationMessage(null);
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|
2018-11-04 15:18:58 -05:00
|
|
|
|
2018-10-15 01:03:53 -04:00
|
|
|
_addValue(value, secret) {
|
2021-11-09 18:31:41 -05:00
|
|
|
this.collection.addObject({ key: value, secret });
|
2018-10-15 01:03:53 -04:00
|
|
|
this._saveValues();
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
|
|
|
_removeValue(value) {
|
2019-05-27 04:15:39 -04:00
|
|
|
const collection = this.collection;
|
2018-10-15 01:03:53 -04:00
|
|
|
collection.removeObject(value);
|
|
|
|
this._saveValues();
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
|
|
|
_replaceValue(index, newValue, keyName) {
|
2019-05-27 04:15:39 -04:00
|
|
|
let item = this.collection[index];
|
2019-11-05 13:43:49 -05:00
|
|
|
set(item, keyName, newValue);
|
2018-10-15 01:03:53 -04:00
|
|
|
|
|
|
|
this._saveValues();
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
|
|
|
_saveValues() {
|
|
|
|
this.set(
|
|
|
|
"values",
|
2019-05-27 04:15:39 -04:00
|
|
|
this.collection
|
2018-10-15 01:03:53 -04:00
|
|
|
.map(function (elem) {
|
|
|
|
return `${elem.key}|${elem.secret}`;
|
|
|
|
})
|
|
|
|
.join("\n")
|
|
|
|
);
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|
2018-10-15 01:03:53 -04:00
|
|
|
|
|
|
|
_splitValues(values, delimiter) {
|
|
|
|
if (values && values.length) {
|
|
|
|
const keys = ["key", "secret"];
|
2021-01-27 06:39:20 -05:00
|
|
|
let res = [];
|
2018-10-15 01:03:53 -04:00
|
|
|
values.split(delimiter).forEach(function (str) {
|
2021-01-27 06:39:20 -05:00
|
|
|
let object = {};
|
2018-10-15 01:03:53 -04:00
|
|
|
str.split("|").forEach(function (a, i) {
|
|
|
|
object[keys[i]] = a;
|
|
|
|
});
|
|
|
|
res.push(object);
|
|
|
|
});
|
|
|
|
|
|
|
|
return res;
|
|
|
|
} else {
|
|
|
|
return [];
|
|
|
|
}
|
2023-02-23 10:32:53 -05:00
|
|
|
}
|
|
|
|
}
|